* [RFC PATCH 00/12] ARM: Decompressor multiplatform support
@ 2012-07-15 2:44 Domenico Andreoli
2012-07-17 14:31 ` Arnd Bergmann
0 siblings, 1 reply; 4+ messages in thread
From: Domenico Andreoli @ 2012-07-15 2:44 UTC (permalink / raw)
To: linux-arm-kernel
Hi all,
here is a new edition of my work in the decompressor area.
My intent is to get rid of uncompress.h and prepare the decompressor
to dynamically select the various machine specific decompressor init
steps, included the selection of the appropriate console driver.
Currently the mainline kernel defines these steps statically and indeed
has some trouble to boot on different boards with the same binary.
What this patch does is allowing the four functions (arch_decomp_setup,
arch_error, putc and flush) currently used to define such static steps
to be packed in quantity and to be selected/executed by the decompressor
accordingly to the machid or DT passed by the boot loader.
I forgot to say that all this code and data is relocated from the kernel
image to the decompressor during the build. So some pointer arithmetic
is required on the decompressor side. This unfortunately brings in also
some limitations in the code/data to be relocated.
The patchset is of course far from being ready for anything but
development and testing. I really looked into only three SoCs but I
know that aside from a kind of graphic adapter somewhere all the other
are a variation of these three players.
I'm able to test it on a out-of-tree bcm4760 board and a Samsung
S5P6450. I also build tested a dozen of other random samsung and ti/omap
defconfigs, sometimes nailing down problems. I've also my qq2440 ;)
The patchset also applies on top of Arnd's multiplatform tree and the
resulting binary boots on the bcm4760 board. In that configuration I
get the most fat relocation of code and data, with an amazing number
of four drivers and don't known how many console tags. I had also some
fun efficiently packing all that stuff :)
That said, thank you for the comments :)
cheers,
Domenico
^ permalink raw reply [flat|nested] 4+ messages in thread
* [RFC PATCH 00/12] ARM: Decompressor multiplatform support
2012-07-15 2:44 Domenico Andreoli
@ 2012-07-17 14:31 ` Arnd Bergmann
2012-07-17 14:54 ` Domenico Andreoli
0 siblings, 1 reply; 4+ messages in thread
From: Arnd Bergmann @ 2012-07-17 14:31 UTC (permalink / raw)
To: linux-arm-kernel
On Sunday 15 July 2012, Domenico Andreoli wrote:
> My intent is to get rid of uncompress.h and prepare the decompressor
> to dynamically select the various machine specific decompressor init
> steps, included the selection of the appropriate console driver.
>
> Currently the mainline kernel defines these steps statically and indeed
> has some trouble to boot on different boards with the same binary.
>
> What this patch does is allowing the four functions (arch_decomp_setup,
> arch_error, putc and flush) currently used to define such static steps
> to be packed in quantity and to be selected/executed by the decompressor
> accordingly to the machid or DT passed by the boot loader.
I definitely like the implementation, it looks very nicely done with the
driver specific code being right inside of the actual device drivers.
I think the main question we have to answer is whether we want to go
this far for the decompressor output. IIRC the last time this was
debated, the argument was made (I don't remember if it was by Russell
or someone else) that the decompressor code is designed to be as simple
as possible and we should add too much complexity in it that would make
it harder to debug when the only purpose of that code is to debug the
decompressor code itself.
I find it hard to judge what the benefit of your implementation is
compared to the risk of introducing bugs.
The other part I don't understand is how it relates to the
early_print() infrastructure that has some of the same requirements.
Arnd
^ permalink raw reply [flat|nested] 4+ messages in thread
* [RFC PATCH 00/12] ARM: Decompressor multiplatform support
2012-07-17 14:31 ` Arnd Bergmann
@ 2012-07-17 14:54 ` Domenico Andreoli
0 siblings, 0 replies; 4+ messages in thread
From: Domenico Andreoli @ 2012-07-17 14:54 UTC (permalink / raw)
To: linux-arm-kernel
On Tue, Jul 17, 2012 at 02:31:15PM +0000, Arnd Bergmann wrote:
> On Sunday 15 July 2012, Domenico Andreoli wrote:
> > My intent is to get rid of uncompress.h and prepare the decompressor
> > to dynamically select the various machine specific decompressor init
> > steps, included the selection of the appropriate console driver.
> >
> > Currently the mainline kernel defines these steps statically and indeed
> > has some trouble to boot on different boards with the same binary.
> >
> > What this patch does is allowing the four functions (arch_decomp_setup,
> > arch_error, putc and flush) currently used to define such static steps
> > to be packed in quantity and to be selected/executed by the decompressor
> > accordingly to the machid or DT passed by the boot loader.
>
> I definitely like the implementation, it looks very nicely done with the
> driver specific code being right inside of the actual device drivers.
yep, thanks.
> I think the main question we have to answer is whether we want to go
> this far for the decompressor output. IIRC the last time this was
> debated, the argument was made (I don't remember if it was by Russell
> or someone else) that the decompressor code is designed to be as simple
> as possible and we should add too much complexity in it that would make
> it harder to debug when the only purpose of that code is to debug the
> decompressor code itself.
I also made this question [0] but probably the message was too long and
nobody bothered to read it fully :)
The question applies almost unchanged for the arch_decomp_setup()/arch_error()
calls. Those could be worthy to preserve and probably less easy to dismiss
than the console ;)
> I find it hard to judge what the benefit of your implementation is
> compared to the risk of introducing bugs.
Indeed. I can also add that without a sound extraction of console data
from DT, where arm is heading, the thing looks even less appealing.
But I needed to publish it :)
> The other part I don't understand is how it relates to the
> early_print() infrastructure that has some of the same requirements.
If there is, it's not intentional.
cheers,
Domenico
[0] http://www.spinics.net/lists/arm-kernel/msg177843.html
^ permalink raw reply [flat|nested] 4+ messages in thread
* [RFC PATCH 00/12] ARM: Decompressor multiplatform support
@ 2012-07-19 3:48 shawn
0 siblings, 0 replies; 4+ messages in thread
From: shawn @ 2012-07-19 3:48 UTC (permalink / raw)
To: linux-arm-kernel
does this fix the problems in 3.5 with string.h ?
https://lkml.org/lkml/2012/5/30/465
--
-Shawn Landden
^ permalink raw reply [flat|nested] 4+ messages in thread
end of thread, other threads:[~2012-07-19 3:48 UTC | newest]
Thread overview: 4+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2012-07-19 3:48 [RFC PATCH 00/12] ARM: Decompressor multiplatform support shawn
-- strict thread matches above, loose matches on Subject: below --
2012-07-15 2:44 Domenico Andreoli
2012-07-17 14:31 ` Arnd Bergmann
2012-07-17 14:54 ` Domenico Andreoli
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).