wdenk | 5b1d713 | 2002-11-03 00:07:02 +0000 | [diff] [blame] | 1 | /* |
| 2 | * (C) Copyright 2000 - 2002 |
| 3 | * Wolfgang Denk, DENX Software Engineering, wd@denx.de. |
| 4 | * |
Wolfgang Denk | d79de1d | 2013-07-08 09:37:19 +0200 | [diff] [blame] | 5 | * SPDX-License-Identifier: GPL-2.0+ |
Wolfgang Denk | f3f4518 | 2005-11-25 16:38:03 +0100 | [diff] [blame] | 6 | ******************************************************************** |
| 7 | * NOTE: This header file defines an interface to U-Boot. Including |
| 8 | * this (unmodified) header file in another file is considered normal |
| 9 | * use of U-Boot, and does *not* fall under the heading of "derived |
| 10 | * work". |
| 11 | ******************************************************************** |
wdenk | 5b1d713 | 2002-11-03 00:07:02 +0000 | [diff] [blame] | 12 | */ |
| 13 | |
| 14 | #ifndef __U_BOOT_H__ |
| 15 | #define __U_BOOT_H__ |
| 16 | |
| 17 | /* |
| 18 | * Board information passed to Linux kernel from U-Boot |
| 19 | * |
| 20 | * include/asm-ppc/u-boot.h |
| 21 | */ |
| 22 | |
Simon Glass | fa6945f | 2013-03-11 06:50:01 +0000 | [diff] [blame] | 23 | #ifdef CONFIG_SYS_GENERIC_BOARD |
| 24 | /* Use the generic board which requires a unified bd_info */ |
| 25 | #include <asm-generic/u-boot.h> |
| 26 | #else |
| 27 | |
wdenk | 5b1d713 | 2002-11-03 00:07:02 +0000 | [diff] [blame] | 28 | #ifndef __ASSEMBLY__ |
wdenk | 5b1d713 | 2002-11-03 00:07:02 +0000 | [diff] [blame] | 29 | |
| 30 | typedef struct bd_info { |
| 31 | unsigned long bi_memstart; /* start of DRAM memory */ |
Becky Bruce | a36601e | 2008-06-09 20:37:16 -0500 | [diff] [blame] | 32 | phys_size_t bi_memsize; /* size of DRAM memory in bytes */ |
wdenk | 5b1d713 | 2002-11-03 00:07:02 +0000 | [diff] [blame] | 33 | unsigned long bi_flashstart; /* start of FLASH memory */ |
| 34 | unsigned long bi_flashsize; /* size of FLASH memory */ |
| 35 | unsigned long bi_flashoffset; /* reserved area for startup monitor */ |
| 36 | unsigned long bi_sramstart; /* start of SRAM memory */ |
| 37 | unsigned long bi_sramsize; /* size of SRAM memory */ |
Masahiro Yamada | 5a2bf98 | 2014-03-05 17:40:10 +0900 | [diff] [blame] | 38 | #if defined(CONFIG_5xx) || defined(CONFIG_8xx) || defined(CONFIG_MPC8260) \ |
Jon Loeliger | 5c8aa97 | 2006-04-26 17:58:56 -0500 | [diff] [blame] | 39 | || defined(CONFIG_E500) || defined(CONFIG_MPC86xx) |
wdenk | 5b1d713 | 2002-11-03 00:07:02 +0000 | [diff] [blame] | 40 | unsigned long bi_immr_base; /* base of IMMR register */ |
| 41 | #endif |
wdenk | be9c1cb | 2004-02-24 02:00:03 +0000 | [diff] [blame] | 42 | #if defined(CONFIG_MPC5xxx) |
wdenk | 21136db | 2003-07-16 21:53:01 +0000 | [diff] [blame] | 43 | unsigned long bi_mbar_base; /* base of internal registers */ |
| 44 | #endif |
Peter Tyser | 62e7398 | 2009-05-22 17:23:24 -0500 | [diff] [blame] | 45 | #if defined(CONFIG_MPC83xx) |
Eran Liberty | 9095d4a | 2005-07-28 10:08:46 -0500 | [diff] [blame] | 46 | unsigned long bi_immrbar; |
| 47 | #endif |
Peter Tyser | 3a1362d | 2010-10-14 23:33:24 -0500 | [diff] [blame] | 48 | unsigned long bi_bootflags; /* boot / reboot flag (Unused) */ |
Anatolij Gustschin | 11f70bd | 2012-09-02 09:09:00 +0000 | [diff] [blame] | 49 | unsigned long bi_ip_addr; /* IP Address */ |
Mike Frysinger | 2625048 | 2009-02-11 20:07:19 -0500 | [diff] [blame] | 50 | unsigned char bi_enetaddr[6]; /* OLD: see README.enetaddr */ |
wdenk | 5b1d713 | 2002-11-03 00:07:02 +0000 | [diff] [blame] | 51 | unsigned short bi_ethspeed; /* Ethernet speed in Mbps */ |
| 52 | unsigned long bi_intfreq; /* Internal Freq, in MHz */ |
| 53 | unsigned long bi_busfreq; /* Bus Freq, in MHz */ |
Jon Loeliger | f5ad378 | 2005-07-23 10:37:35 -0500 | [diff] [blame] | 54 | #if defined(CONFIG_CPM2) |
wdenk | 5b1d713 | 2002-11-03 00:07:02 +0000 | [diff] [blame] | 55 | unsigned long bi_cpmfreq; /* CPM_CLK Freq, in MHz */ |
| 56 | unsigned long bi_brgfreq; /* BRG_CLK Freq, in MHz */ |
| 57 | unsigned long bi_sccfreq; /* SCC_CLK Freq, in MHz */ |
| 58 | unsigned long bi_vco; /* VCO Out from PLL, in MHz */ |
| 59 | #endif |
Grzegorz Bernacki | af554d8 | 2008-01-08 17:16:15 +0100 | [diff] [blame] | 60 | #if defined(CONFIG_MPC512X) |
| 61 | unsigned long bi_ipsfreq; /* IPS Bus Freq, in MHz */ |
| 62 | #endif /* CONFIG_MPC512X */ |
wdenk | be9c1cb | 2004-02-24 02:00:03 +0000 | [diff] [blame] | 63 | #if defined(CONFIG_MPC5xxx) |
wdenk | 21136db | 2003-07-16 21:53:01 +0000 | [diff] [blame] | 64 | unsigned long bi_ipbfreq; /* IPB Bus Freq, in MHz */ |
| 65 | unsigned long bi_pcifreq; /* PCI Bus Freq, in MHz */ |
| 66 | #endif |
wdenk | 232fe0b | 2003-09-02 22:48:03 +0000 | [diff] [blame] | 67 | #if defined(CONFIG_405) || \ |
| 68 | defined(CONFIG_405GP) || \ |
wdenk | 232fe0b | 2003-09-02 22:48:03 +0000 | [diff] [blame] | 69 | defined(CONFIG_405EP) || \ |
Stefan Roese | 17ffbc8 | 2007-03-21 13:38:59 +0100 | [diff] [blame] | 70 | defined(CONFIG_405EZ) || \ |
Stefan Roese | 153b3e2 | 2007-10-05 17:10:59 +0200 | [diff] [blame] | 71 | defined(CONFIG_405EX) || \ |
wdenk | 232fe0b | 2003-09-02 22:48:03 +0000 | [diff] [blame] | 72 | defined(CONFIG_440) |
wdenk | 5b1d713 | 2002-11-03 00:07:02 +0000 | [diff] [blame] | 73 | unsigned char bi_s_version[4]; /* Version of this structure */ |
Wolfgang Denk | 0ee7077 | 2005-09-23 11:05:55 +0200 | [diff] [blame] | 74 | unsigned char bi_r_version[32]; /* Version of the ROM (AMCC) */ |
wdenk | 5b1d713 | 2002-11-03 00:07:02 +0000 | [diff] [blame] | 75 | unsigned int bi_procfreq; /* CPU (Internal) Freq, in Hz */ |
| 76 | unsigned int bi_plb_busfreq; /* PLB Bus speed, in Hz */ |
| 77 | unsigned int bi_pci_busfreq; /* PCI Bus speed, in Hz */ |
| 78 | unsigned char bi_pci_enetaddr[6]; /* PCI Ethernet MAC address */ |
| 79 | #endif |
| 80 | #if defined(CONFIG_HYMOD) |
| 81 | hymod_conf_t bi_hymod_conf; /* hymod configuration information */ |
| 82 | #endif |
wdenk | 0aeb853 | 2004-10-10 21:21:55 +0000 | [diff] [blame] | 83 | |
wdenk | 54070ab | 2004-12-31 09:32:47 +0000 | [diff] [blame] | 84 | #ifdef CONFIG_HAS_ETH1 |
Mike Frysinger | 2625048 | 2009-02-11 20:07:19 -0500 | [diff] [blame] | 85 | unsigned char bi_enet1addr[6]; /* OLD: see README.enetaddr */ |
wdenk | 5b1d713 | 2002-11-03 00:07:02 +0000 | [diff] [blame] | 86 | #endif |
wdenk | 54070ab | 2004-12-31 09:32:47 +0000 | [diff] [blame] | 87 | #ifdef CONFIG_HAS_ETH2 |
Mike Frysinger | 2625048 | 2009-02-11 20:07:19 -0500 | [diff] [blame] | 88 | unsigned char bi_enet2addr[6]; /* OLD: see README.enetaddr */ |
wdenk | 5b1d713 | 2002-11-03 00:07:02 +0000 | [diff] [blame] | 89 | #endif |
wdenk | 54070ab | 2004-12-31 09:32:47 +0000 | [diff] [blame] | 90 | #ifdef CONFIG_HAS_ETH3 |
Mike Frysinger | 2625048 | 2009-02-11 20:07:19 -0500 | [diff] [blame] | 91 | unsigned char bi_enet3addr[6]; /* OLD: see README.enetaddr */ |
wdenk | 544e973 | 2004-02-06 23:19:44 +0000 | [diff] [blame] | 92 | #endif |
richardretanubun | e5167f1 | 2008-09-29 18:28:23 -0400 | [diff] [blame] | 93 | #ifdef CONFIG_HAS_ETH4 |
Mike Frysinger | 2625048 | 2009-02-11 20:07:19 -0500 | [diff] [blame] | 94 | unsigned char bi_enet4addr[6]; /* OLD: see README.enetaddr */ |
richardretanubun | e5167f1 | 2008-09-29 18:28:23 -0400 | [diff] [blame] | 95 | #endif |
| 96 | #ifdef CONFIG_HAS_ETH5 |
Mike Frysinger | 2625048 | 2009-02-11 20:07:19 -0500 | [diff] [blame] | 97 | unsigned char bi_enet5addr[6]; /* OLD: see README.enetaddr */ |
richardretanubun | e5167f1 | 2008-09-29 18:28:23 -0400 | [diff] [blame] | 98 | #endif |
wdenk | 0aeb853 | 2004-10-10 21:21:55 +0000 | [diff] [blame] | 99 | |
Stefan Roese | 17ffbc8 | 2007-03-21 13:38:59 +0100 | [diff] [blame] | 100 | #if defined(CONFIG_405GP) || defined(CONFIG_405EP) || \ |
| 101 | defined(CONFIG_405EZ) || defined(CONFIG_440GX) || \ |
Stefan Roese | 42fbddd | 2006-09-07 11:51:23 +0200 | [diff] [blame] | 102 | defined(CONFIG_440EP) || defined(CONFIG_440GR) || \ |
Stefan Roese | 50c0533 | 2008-03-11 15:07:10 +0100 | [diff] [blame] | 103 | defined(CONFIG_440EPX) || defined(CONFIG_440GRX) || \ |
| 104 | defined(CONFIG_460EX) || defined(CONFIG_460GT) |
wdenk | c6abb7e | 2003-11-17 21:14:37 +0000 | [diff] [blame] | 105 | unsigned int bi_opbfreq; /* OPB clock in Hz */ |
| 106 | int bi_iic_fast[2]; /* Use fast i2c mode */ |
| 107 | #endif |
Stefan Roese | 0c7ffc0 | 2005-08-16 18:18:00 +0200 | [diff] [blame] | 108 | #if defined(CONFIG_4xx) |
Stefan Roese | 50c0533 | 2008-03-11 15:07:10 +0100 | [diff] [blame] | 109 | #if defined(CONFIG_440GX) || \ |
| 110 | defined(CONFIG_460EX) || defined(CONFIG_460GT) |
Wolfgang Denk | a1be476 | 2008-05-20 16:00:29 +0200 | [diff] [blame] | 111 | int bi_phynum[4]; /* Determines phy mapping */ |
| 112 | int bi_phymode[4]; /* Determines phy mode */ |
Weirich, Bernhard | ca1b5db | 2011-09-08 18:27:38 +0200 | [diff] [blame] | 113 | #elif defined(CONFIG_405EP) || defined(CONFIG_405EX) || defined(CONFIG_440) |
Wolfgang Denk | a1be476 | 2008-05-20 16:00:29 +0200 | [diff] [blame] | 114 | int bi_phynum[2]; /* Determines phy mapping */ |
| 115 | int bi_phymode[2]; /* Determines phy mode */ |
Stefan Roese | 0c7ffc0 | 2005-08-16 18:18:00 +0200 | [diff] [blame] | 116 | #else |
Wolfgang Denk | a1be476 | 2008-05-20 16:00:29 +0200 | [diff] [blame] | 117 | int bi_phynum[1]; /* Determines phy mapping */ |
| 118 | int bi_phymode[1]; /* Determines phy mode */ |
wdenk | 56ed43e | 2004-02-22 23:46:08 +0000 | [diff] [blame] | 119 | #endif |
Stefan Roese | 0c7ffc0 | 2005-08-16 18:18:00 +0200 | [diff] [blame] | 120 | #endif /* defined(CONFIG_4xx) */ |
wdenk | 5b1d713 | 2002-11-03 00:07:02 +0000 | [diff] [blame] | 121 | } bd_t; |
| 122 | |
| 123 | #endif /* __ASSEMBLY__ */ |
Mike Frysinger | 5da0bed | 2011-10-03 14:50:33 +0000 | [diff] [blame] | 124 | |
Simon Glass | fa6945f | 2013-03-11 06:50:01 +0000 | [diff] [blame] | 125 | #endif /* !CONFIG_SYS_GENERIC_BOARD */ |
| 126 | |
Mike Frysinger | 5da0bed | 2011-10-03 14:50:33 +0000 | [diff] [blame] | 127 | /* For image.h:image_check_target_arch() */ |
| 128 | #define IH_ARCH_DEFAULT IH_ARCH_PPC |
| 129 | |
wdenk | 5b1d713 | 2002-11-03 00:07:02 +0000 | [diff] [blame] | 130 | #endif /* __U_BOOT_H__ */ |