[SLOF] [PATCH slof v2] client: Load initramdisk location

Alexey Kardashevskiy aik at ozlabs.ru
Wed Nov 20 12:26:44 AEDT 2019



On 13/11/2019 17:29, Alexey Kardashevskiy wrote:
> For ages both vmlinux and zImage accepted the initramdisk location
> in r3/r4 [1] [2]. If r3==r4==0, vmlinux looks at the device tree for
> /chosen/linux,initrd-{start|end} but zImage does not so the QEMU user
> can only pass vmlinux via -kernel if -initrd is passed as well.
> 
> This initializes r3/r4 to point to the initramdisk location when present.
> 
> [1] https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/tree/arch/powerpc/kernel/prom_init.c?h=v5.3#n3230
> [2] https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/tree/arch/powerpc/boot/of.c?h=v5.3#n89
> 
> Signed-off-by: Alexey Kardashevskiy <aik at ozlabs.ru>

Pushed out.


> ---
> Changes:
> v2:
> * improved readability
> ---
>  slof/fs/client.fs | 8 ++++++++
>  1 file changed, 8 insertions(+)
> 
> diff --git a/slof/fs/client.fs b/slof/fs/client.fs
> index 8a7f6ac4326d..db7a1925792c 100644
> --- a/slof/fs/client.fs
> +++ b/slof/fs/client.fs
> @@ -45,6 +45,14 @@ VARIABLE  client-callback \ Address of client's callback function
>    >r  ciregs >r7 !  ciregs >r6 !  client-entry-point @ ciregs >r5 !
>    \ Initialise client-stack-pointer
>    cistack ciregs >r1 !
> +
> +  s" linux,initrd-end" get-chosen IF decode-int nip nip ELSE 0 THEN
> +  s" linux,initrd-start" get-chosen IF decode-int nip nip ELSE 0 THEN
> +		    ( end start )
> +  tuck -	    ( start len )
> +  ciregs >r4 !
> +  ciregs >r3 !
> +
>    \ jump-client maps to call_client in slof/entry.S
>    \ When jump-client returns, R3 holds the address of a NUL-terminated string
>    \ that holds the client interface word the client wants to call, R4 holds
> 

-- 
Alexey


More information about the SLOF mailing list