diff options
| author | Graeme Russ <graeme.russ@gmail.com> | 2012-11-27 15:38:35 +0000 | 
|---|---|---|
| committer | Simon Glass <sjg@chromium.org> | 2012-11-28 11:40:03 -0800 | 
| commit | e4fb6116495eafbeee5ea8ff7ea245eb5e96d012 (patch) | |
| tree | 3ef9c795b051ff68d0761f3afe4be192b1ea8460 | |
| parent | d41b3cc16fd97da23900f79e8fefdeedeebde8f6 (diff) | |
| download | olio-uboot-2014.01-e4fb6116495eafbeee5ea8ff7ea245eb5e96d012.tar.xz olio-uboot-2014.01-e4fb6116495eafbeee5ea8ff7ea245eb5e96d012.zip | |
x86: Forward declare gd_t
So it can be used as a type in struct global_data and remove an ugly typecast
Signed-off-by: Graeme Russ <graeme.russ@gmail.com>
Signed-off-by: Simon Glass <sjg@chromium.org>
Acked-by: Marek Vasut <marex@denx.de>
| -rw-r--r-- | arch/x86/cpu/cpu.c | 2 | ||||
| -rw-r--r-- | arch/x86/include/asm/global_data.h | 8 | ||||
| -rw-r--r-- | arch/x86/lib/init_helpers.c | 2 | 
3 files changed, 7 insertions, 5 deletions
| diff --git a/arch/x86/cpu/cpu.c b/arch/x86/cpu/cpu.c index e9bb0d770..67de6bcb3 100644 --- a/arch/x86/cpu/cpu.c +++ b/arch/x86/cpu/cpu.c @@ -92,7 +92,7 @@ static void load_gdt(const u64 *boot_gdt, u16 num_entries)  void init_gd(gd_t *id, u64 *gdt_addr)  { -	id->gd_addr = (ulong)id; +	id->gd_addr = id;  	setup_gdt(id, gdt_addr);  } diff --git a/arch/x86/include/asm/global_data.h b/arch/x86/include/asm/global_data.h index bce999f41..13a3ce8fb 100644 --- a/arch/x86/include/asm/global_data.h +++ b/arch/x86/include/asm/global_data.h @@ -33,9 +33,11 @@  #ifndef __ASSEMBLY__ -typedef	struct global_data { +typedef struct global_data gd_t; + +struct global_data {  	/* NOTE: gd_addr MUST be first member of struct global_data! */ -	unsigned long	gd_addr;	/* Location of Global Data */ +	gd_t *gd_addr;	/* Location of Global Data */  	bd_t		*bd;  	unsigned long	flags;  	unsigned int	baudrate; @@ -57,7 +59,7 @@ typedef	struct global_data {  	unsigned long	reset_status;	/* reset status register at boot */  	void		**jt;		/* jump table */  	char		env_buf[32];	/* buffer for getenv() before reloc. */ -} gd_t; +};  static inline gd_t *get_fs_gd_ptr(void)  { diff --git a/arch/x86/lib/init_helpers.c b/arch/x86/lib/init_helpers.c index 9ec34ff99..2f718d7c4 100644 --- a/arch/x86/lib/init_helpers.c +++ b/arch/x86/lib/init_helpers.c @@ -126,7 +126,7 @@ int copy_gd_to_ram_f_r(void)  	 * in-RAM copy of Global Data (calculate_relocation_address()  	 * has already calculated the in-RAM location of the GDT)  	 */ -	ram_gd->gd_addr = (ulong)ram_gd; +	ram_gd->gd_addr = ram_gd;  	init_gd(ram_gd, (u64 *)gd->gdt_addr);  	return 0; |