mirror of
				https://github.com/smaeul/u-boot.git
				synced 2025-10-25 01:58:13 +01:00 
			
		
		
		
	Use the base address of the 'F' segment as a pointer to the global data structure. By adding the linear address (i.e. the 'D' segment address) as the first word of the global data structure, the address of the global data relative to the 'D' segment can be found simply, for example, by: fs movl 0, %eax This makes the gd 'pointer' writable prior to relocation (by reloading the Global Desctriptor Table) which brings x86 into line with all other arches NOTE: Writing to the gd 'pointer' is expensive (but we only do it twice) but using it to access global data members (read and write) is still fairly cheap -- Changes for v2: - Rebased against changes made to patch #3 - Removed extra indent - Tweaked commit message
		
			
				
	
	
		
			92 lines
		
	
	
		
			3.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			92 lines
		
	
	
		
			3.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  * (C) Copyright 2002-2010
 | |
|  * Wolfgang Denk, DENX Software Engineering, wd@denx.de.
 | |
|  *
 | |
|  * See file CREDITS for list of people who contributed to this
 | |
|  * project.
 | |
|  *
 | |
|  * 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.
 | |
|  *
 | |
|  * This program is distributed in the hope that it will be useful,
 | |
|  * but WITHOUT ANY WARRANTY; without even the implied warranty of
 | |
|  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | |
|  * GNU General Public License for more details.
 | |
|  *
 | |
|  * You should have received a copy of the GNU General Public License
 | |
|  * along with this program; if not, write to the Free Software
 | |
|  * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
 | |
|  * MA 02111-1307 USA
 | |
|  */
 | |
| 
 | |
| #ifndef	__ASM_GBL_DATA_H
 | |
| #define __ASM_GBL_DATA_H
 | |
| /*
 | |
|  * The following data structure is placed in some memory wich is
 | |
|  * available very early after boot (like DPRAM on MPC8xx/MPC82xx, or
 | |
|  * some locked parts of the data cache) to allow for a minimum set of
 | |
|  * global variables during system initialization (until we have set
 | |
|  * up the memory controller so that we can use RAM).
 | |
|  *
 | |
|  * Keep it *SMALL* and remember to set GENERATED_GBL_DATA_SIZE > sizeof(gd_t)
 | |
|  */
 | |
| 
 | |
| #ifndef __ASSEMBLY__
 | |
| 
 | |
| typedef	struct global_data {
 | |
| 	/* NOTE: gd_addr MUST be first member of struct global_data! */
 | |
| 	unsigned long	gd_addr;	/* Location of Global Data */
 | |
| 	bd_t		*bd;
 | |
| 	unsigned long	flags;
 | |
| 	unsigned long	baudrate;
 | |
| 	unsigned long	have_console;	/* serial_init() was called */
 | |
| #ifdef CONFIG_PRE_CONSOLE_BUFFER
 | |
| 	unsigned long	precon_buf_idx;	/* Pre-Console buffer index */
 | |
| #endif
 | |
| 	unsigned long	reloc_off;	/* Relocation Offset */
 | |
| 	unsigned long	load_off;	/* Load Offset */
 | |
| 	unsigned long	env_addr;	/* Address  of Environment struct */
 | |
| 	unsigned long	env_valid;	/* Checksum of Environment valid? */
 | |
| 	unsigned long	cpu_clk;	/* CPU clock in Hz!		*/
 | |
| 	unsigned long	bus_clk;
 | |
| 	unsigned long	relocaddr;	/* Start address of U-Boot in RAM */
 | |
| 	unsigned long	start_addr_sp;	/* start_addr_stackpointer */
 | |
| 	unsigned long	gdt_addr;	/* Location of GDT */
 | |
| 	unsigned long	new_gd_addr;	/* New location of Global Data */
 | |
| 	phys_size_t	ram_size;	/* RAM size */
 | |
| 	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)
 | |
| {
 | |
| 	gd_t *gd_ptr;
 | |
| 
 | |
| 	asm volatile("fs movl 0, %0\n" : "=r" (gd_ptr));
 | |
| 
 | |
| 	return gd_ptr;
 | |
| }
 | |
| 
 | |
| #define gd	get_fs_gd_ptr()
 | |
| 
 | |
| #endif
 | |
| 
 | |
| /*
 | |
|  * Global Data Flags
 | |
|  */
 | |
| #define	GD_FLG_RELOC		0x00001	/* Code was relocated to RAM		*/
 | |
| #define	GD_FLG_DEVINIT		0x00002	/* Devices have been initialized	*/
 | |
| #define	GD_FLG_SILENT		0x00004	/* Silent mode				*/
 | |
| #define	GD_FLG_POSTFAIL		0x00008	/* Critical POST test failed		*/
 | |
| #define	GD_FLG_POSTSTOP		0x00010	/* POST seqeunce aborted		*/
 | |
| #define	GD_FLG_LOGINIT		0x00020	/* Log Buffer has been initialized	*/
 | |
| #define GD_FLG_DISABLE_CONSOLE	0x00040	/* Disable console (in & out)		*/
 | |
| #define GD_FLG_ENV_READY	0x00080	/* Environment imported into hash table	*/
 | |
| 
 | |
| #define DECLARE_GLOBAL_DATA_PTR
 | |
| 
 | |
| #endif /* __ASM_GBL_DATA_H */
 |