From: Michal Simek <michal.simek@petalogix.com>
To: microblaze-uclinux@itee.uq.edu.au
Cc: John Linn <John.Linn@xilinx.com>,
David DeBonis <david.debonis@xilinx.com>,
Linux Kernel list <linux-kernel@vger.kernel.org>
Subject: Re: [microblaze-uclinux] Rethinking MicroBlaze commandline precedence
Date: Mon, 10 Aug 2009 11:25:35 +0200 [thread overview]
Message-ID: <4A7FE78F.4040504@petalogix.com> (raw)
In-Reply-To: <1d3f23370908100156q46b9869av5ecdcc8879617be9@mail.gmail.com>
Hi John,
John Williams wrote:
> Hi Michal,
>
> On Mon, Aug 10, 2009 at 5:29 PM, Michal Simek<michal.simek@petalogix.com> wrote:
>
>> John Williams wrote:
>
>>> Currently, MicroBlaze commandline handling in order of lowest to
>>> highest priority, looks like this:
>>>
>>> 1. pointer in r5 from bootloader
>>> 2. CONFIG_CMDLINE=...
>>> 3. "chosen" section in DTS/DT
>>> 4. CONFIG_CMDLINE=... && CONFIG_CMDLINE_FORCE
>>>
>>> I'm wondering if a cmdline in r5 should override the DTS. My thinking
>>> is based on two observations:
>>>
>>> (a) not everyone will use a bootloader like u-boot that can manipulate
>>> DTBs easily before kernel boot
>>> (b) a custom cmdline string in r5 allows the latest possible binding
>>> (runtime), where as the DTB is typically created at compile time.
>>>
>>> So, how about this order instead:
>>>
>>> 1. CONFIG_CMDLINE=...
>>> 2. "chosen" section in DTS/DT
>>> 3. pointer in r5 from bootloader
>>> 4. CONFIG_CMDLINE=... and CONFIG_CMDLINE_FORCE
>>>
>>> Then, apart from CMDLINE_FORCE, the precedence goes from earliest
>>> binding (kernel build) to latest (runtime via bootloader/r5).
>>>
>>> Thoughts?
>> I see there one big problem which can easily arise. Kernel expect that r5 points to
>> NULL string and DTS/DTB and CMDLINE will contain correct string. Kernel just copy it and use
>> it. There will be undefined behavior for more cases than for current handling. It will be
>> less error prune.
>
> This expectation currently exists anyway, giving precendence to DTS
> cmdline is only less error-prone on the assumption that it's more
> common.
>
> What about a move to an ARM-style ATAGs arrangement, where r5 points
> not to an ASCIIZ string but instead to some sort of loosely structured
> object, with tag codes to signify the commandline etc.
>
> That way, we can error check r5 - if it doesn't have the right tags
> then we don't use the (probably bogus) cmdline string?
Not sure if is help - but seems to me more complicated than we need.
>
>> Ad observation a)
>>
>> My expectation is that users will use s.....I.... format (I don't like that name - What about
>> renaming it?) with dtb - they setup commandline at once and they don't change it.
>
>
> Ah what's wrong with simpleImage? It's simple to boot, and make-fu
> makes it simple to build! :)
It is more complicated than origin file. Your suggestion for simple build/boot is fine. :-)
>
>> Ad observation b) - for final product they will use only one command line. For testing you can setup
>> kernel to use only r5.
>
> How? Do we add CONFIG_CMDLINE_IGNORE_DTB?
>
> Or just remove the commandline section from DTS "chosen" part?
yes.
>
>> I understand that you are trying to pass to kernel for example MTD map which could be possible but
>> IMHO better to do this in script which one with sed erase/comment/setup command line in DTS before
>> compilation.
>
> It's still a very early binding, and I think there are plenty of
> reasons to want to override it at boot time. If there weren't, why do
> u-boot and PPC simpleBoot add the capability to tweak at boot time,
> the cmdline passed via the DTB?
I understand that make sense to change it - especially for development.
It should be possible to do it in u-boot. Not sure if is work to extend command line but maybe yes.
Worth to ask on u-boot mailing list.
>
> Setting MAC addresses for example - you don't want to compile a new
> DTS for every board you ship, just to provide unique values. You just
> want to be able to tweak the cmdline in the config flash or whatever.
You should be able to change it in u-boot. The size of mac addr is the same. Shorten is possible too.
Cheers,
Michal
>
> Cheers,
>
> John
--
Michal Simek, Ing. (M.Eng)
PetaLogix - Linux Solutions for a Reconfigurable World
w: www.petalogix.com p: +61-7-30090663,+42-0-721842854 f: +61-7-30090663
next prev parent reply other threads:[~2009-08-10 9:25 UTC|newest]
Thread overview: 8+ messages / expand[flat|nested] mbox.gz Atom feed top
2009-08-10 6:28 Rethinking MicroBlaze commandline precedence John Williams
2009-08-10 7:29 ` [microblaze-uclinux] " Michal Simek
2009-08-10 8:56 ` John Williams
2009-08-10 9:25 ` Michal Simek [this message]
2009-08-10 16:42 ` Stephen Neuendorffer
2009-08-11 7:06 ` Michal Simek
2009-08-11 16:18 ` Stephen Neuendorffer
2009-08-11 16:59 ` Michal Simek
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=4A7FE78F.4040504@petalogix.com \
--to=michal.simek@petalogix.com \
--cc=John.Linn@xilinx.com \
--cc=david.debonis@xilinx.com \
--cc=linux-kernel@vger.kernel.org \
--cc=microblaze-uclinux@itee.uq.edu.au \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.