Commit e5a2072b authored by David Gibson's avatar David Gibson Committed by Paul Mackerras

[POWERPC] New reg.h for the zImage

This patch adds a reg.h to the zImage code, with common definitions
for accessing system registers.  For now, this includes functions for
retrieving the PVR and the stack pointer.  This patch then uses the
new reg.h to let start() display the running stack address without
having to explicitly pass the stack as a parameter from the asm code.
Signed-off-by: default avatarDavid Gibson <david@gibson.dropbear.id.au>
Signed-off-by: default avatarPaul Mackerras <paulus@samba.org>
parent fae59c39
...@@ -88,5 +88,4 @@ _zimage_start_lib: ...@@ -88,5 +88,4 @@ _zimage_start_lib:
bl platform_init bl platform_init
/* Call start */ /* Call start */
mr r3,r1
b start b start
...@@ -17,6 +17,7 @@ ...@@ -17,6 +17,7 @@
#include "ops.h" #include "ops.h"
#include "gunzip_util.h" #include "gunzip_util.h"
#include "flatdevtree.h" #include "flatdevtree.h"
#include "reg.h"
extern char _start[]; extern char _start[];
extern char __bss_start[]; extern char __bss_start[];
...@@ -247,7 +248,7 @@ struct dt_ops dt_ops; ...@@ -247,7 +248,7 @@ struct dt_ops dt_ops;
struct console_ops console_ops; struct console_ops console_ops;
struct loader_info loader_info; struct loader_info loader_info;
void start(void *sp) void start(void)
{ {
struct addr_range vmlinux, initrd; struct addr_range vmlinux, initrd;
kernel_entry_t kentry; kernel_entry_t kentry;
...@@ -260,7 +261,7 @@ void start(void *sp) ...@@ -260,7 +261,7 @@ void start(void *sp)
platform_ops.fixups(); platform_ops.fixups();
printf("\n\rzImage starting: loaded at 0x%p (sp: 0x%p)\n\r", printf("\n\rzImage starting: loaded at 0x%p (sp: 0x%p)\n\r",
_start, sp); _start, get_sp());
vmlinux = prep_kernel(); vmlinux = prep_kernel();
initrd = prep_initrd(vmlinux, loader_info.initrd_addr, initrd = prep_initrd(vmlinux, loader_info.initrd_addr,
......
...@@ -73,7 +73,7 @@ struct loader_info { ...@@ -73,7 +73,7 @@ struct loader_info {
}; };
extern struct loader_info loader_info; extern struct loader_info loader_info;
void start(void *sp); void start(void);
int ft_init(void *dt_blob, unsigned int max_size, unsigned int max_find_device); int ft_init(void *dt_blob, unsigned int max_size, unsigned int max_find_device);
int serial_console_init(void); int serial_console_init(void);
int ns16550_console_init(void *devp, struct serial_console_data *scdp); int ns16550_console_init(void *devp, struct serial_console_data *scdp);
......
#ifndef _PPC_BOOT_REG_H
#define _PPC_BOOT_REG_H
/*
* Copyright 2007 Davud Gibson, IBM Corporation.
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License
* as published by the Free Software Foundation; either version
* 2 of the License, or (at your option) any later version.
*/
static inline u32 mfpvr(void)
{
u32 pvr;
asm volatile ("mfpvr %0" : "=r"(pvr));
return pvr;
}
register void *__stack_pointer asm("r1");
#define get_sp() (__stack_pointer)
#endif /* _PPC_BOOT_REG_H */
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment