Modified IBL to re-init PLL in DDR controller, added UART
[keystone-rtos/ibl.git] / src / hw / c64x / make / makefile
1 #*
2 #*
3 #* Copyright (C) 2010 Texas Instruments Incorporated - http://www.ti.com/ 
4 #* 
5 #* 
6 #*  Redistribution and use in source and binary forms, with or without 
7 #*  modification, are permitted provided that the following conditions 
8 #*  are met:
9 #*
10 #*    Redistributions of source code must retain the above copyright 
11 #*    notice, this list of conditions and the following disclaimer.
12 #*
13 #*    Redistributions in binary form must reproduce the above copyright
14 #*    notice, this list of conditions and the following disclaimer in the 
15 #*    documentation and/or other materials provided with the   
16 #*    distribution.
17 #*
18 #*    Neither the name of Texas Instruments Incorporated nor the names of
19 #*    its contributors may be used to endorse or promote products derived
20 #*    from this software without specific prior written permission.
21 #*
22 #*  THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 
23 #*  "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT 
24 #*  LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
25 #*  A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT 
26 #*  OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, 
27 #*  SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT 
28 #*  LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
29 #*  DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
30 #*  THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 
31 #*  (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE 
32 #*  OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
33 #*
36 #**************************************************************************
37 #* FILE NAME: makefile
38 #*
39 #* DESCRIPTION: Makes the low level drivers for the hardware modules
40 #*
41 #**************************************************************************
43 ifndef IBL_ROOT
44         export IBL_ROOT=../../..
45 endif
47 ECODIR= $(IBL_ROOT)/hw
49 # If no target specified, set CSRC to all files (used for clean)
50 ifeq ($(TARGET),c6472)
51  CSRC= t64.c cpmacdrv.c pll.c psc.c emif31.c mdio.c gpio.c nandgpio.c i2c.c 
52 else
53  ifeq ($(TARGET),c6474)
54   CSRC= t64.c cpmacdrv.c pll.c psc.c emif31.c mdio.c gpio.c nandgpio.c i2c.c sgmii.c
55  else
56   ifeq ($(TARGET),c6474l)
57    CSRC= t64.c cpmacdrv.c pll.c psc.c emif31.c mdio.c gpio.c nandgpio.c i2c.c sgmii.c
58   else
59    ifeq ($(TARGET),c6457)
60     CSRC= t64.c cpmacdrv.c pll.c psc.c emif31.c mdio.c gpio.c nandgpio.c i2c.c sgmiicur.c
61    else
62     ifeq ($(TARGET),c6455)
63      CSRC= t64.c cpmacdrv.c pll.c emif31.c mdio.c gpio.c nandgpio.c i2c.c
64         else
65          ifeq ($(TARGET),c66x)
66           CSRC= t64.c pll.c cfgpll.c cfgpll2.c mdio.c i2c.c psc.c cpsw.c qm.c cpdma.c pa.c sgmii.c serdes.c gmacsl.c emif4.c gpio.c
67           CSRC+= nandemif25.c nandgpio.c spi.c nandspi.c noremif25.c norspi.c emif25.c spiutil.c evmc66x_uart.c
68      else
69       CSRC= t64.c cpmacdrv.c pll.c psc.c emif31.c mdio.c gpio.c nandgpio.c i2c.c sgmii.c cfgpll.c cfgpll2.c
70           CSRC+= qm.c cpdma.c pa.c serdes.c gmacsl.c emif4.c nandemif25.c spi.c nandspi.c noremif25.c norspi.c emif25.c spiutil.c
71      endif
72     endif
73    endif
74   endif
75  endif
76 endif
79 .PHONY: hw
82 include $(IBL_ROOT)/make/$(ARCH)/makeeco.mk
85 C6X_C_DIR=   $(IBL_ROOT)
86 C6X_C_DIR+= ;$(IBL_ROOT)/arch/$(ARCH)
87 C6X_C_DIR+= ;$(ECODIR)
88 C6X_C_DIR+= ;$(STDINC)
89 C6X_C_DIR+= ;$(IBL_ROOT)/cfg/$(TARGET)
90 C6X_C_DIR+= ;$(IBL_ROOT)/hw/timer
91 C6X_C_DIR+= ;$(IBL_ROOT)/hw/macs/cpmac
92 C6X_C_DIR+= ;$(IBL_ROOT)/hw/macs
93 C6X_C_DIR+= ;$(IBL_ROOT)/hw/macs/cpmacsl
94 C6X_C_DIR+= ;$(IBL_ROOT)/driver/eth
95 C6X_C_DIR+= ;$(IBL_ROOT)/device
96 C6X_C_DIR+= ;$(IBL_ROOT)/device/$(TARGET)
97 C6X_C_DIR+= ;$(IBL_ROOT)/hw/plls
98 C6X_C_DIR+= ;$(IBL_ROOT)/hw/pscs
99 C6X_C_DIR+= ;$(IBL_ROOT)/hw/mdio
100 C6X_C_DIR+= ;$(IBL_ROOT)/hw/gpio
101 C6X_C_DIR+= ;$(IBL_ROOT)/hw/nands
102 C6X_C_DIR+= ;$(IBL_ROOT)/hw/nands/gpio
103 C6X_C_DIR+= ;$(IBL_ROOT)/hw/nands/emif25
104 C6X_C_DIR+= ;$(IBL_ROOT)/hw/nands/spi
105 C6X_C_DIR+= ;$(IBL_ROOT)/hw/i2c
106 C6X_C_DIR+= ;$(IBL_ROOT)/hw/sgmii
107 C6X_C_DIR+= ;$(IBL_ROOT)/hw/cpsw
108 C6X_C_DIR+= ;$(IBL_ROOT)/hw/cpdma
109 C6X_C_DIR+= ;$(IBL_ROOT)/hw/pa
110 C6X_C_DIR+= ;$(IBL_ROOT)/hw/spi
111 C6X_C_DIR+= ;$(IBL_ROOT)/hw/nors
112 C6X_C_DIR+= ;$(IBL_ROOT)/hw/emif25
113 C6X_C_DIR+= ;$(IBL_ROOT)/ecc
114 export C6X_C_DIR
117 vpath % $(ECODIR)/timer/timer64
119 ifeq ($(TARGET),c6472)
120  vpath % $(ECODIR)/macs/cpmac
121  vpath % $(ECODIR)/plls/pllxx1p8
122  vpath % $(ECODIR)/pscs/psc2
123  vpath % $(ECODIR)/ddrs/emif31
124  vpath % $(ECODIR)/mdio
125  vpath % $(ECODIR)/gpio
126  vpath % $(ECODIR)/nands/gpio
127  vpath % $(ECODIR)/i2c
128 endif
130 ifeq ($(TARGET),c6474)
131  vpath % $(ECODIR)/macs/cpmac
132  vpath % $(ECODIR)/plls/pllxx1p8
133  vpath % $(ECODIR)/pscs/psc2
134  vpath % $(ECODIR)/ddrs/emif31
135  vpath % $(ECODIR)/mdio
136  vpath % $(ECODIR)/gpio
137  vpath % $(ECODIR)/nands/gpio
138  vpath % $(ECODIR)/i2c
139  vpath % $(ECODIR)/sgmii
140 endif
142 ifeq ($(TARGET),c6474l)
143  vpath % $(ECODIR)/macs/cpmac
144  vpath % $(ECODIR)/plls/pllxx1p8
145  vpath % $(ECODIR)/pscs/psc2
146  vpath % $(ECODIR)/ddrs/emif31
147  vpath % $(ECODIR)/mdio
148  vpath % $(ECODIR)/gpio
149  vpath % $(ECODIR)/nands/gpio
150  vpath % $(ECODIR)/i2c
151  vpath % $(ECODIR)/sgmii
152 endif
154 ifeq ($(TARGET),c6457)
155  vpath % $(ECODIR)/macs/cpmac
156  vpath % $(ECODIR)/plls/pllcur
157  vpath % $(ECODIR)/pscs/psccur
158  vpath % $(ECODIR)/ddrs/emif31
159  vpath % $(ECODIR)/mdio
160  vpath % $(ECODIR)/gpio
161  vpath % $(ECODIR)/nands/gpio
162  vpath % $(ECODIR)/i2c
163  vpath % $(ECODIR)/sgmii
164 endif
166 ifeq ($(TARGET),c6455)
167  vpath % $(ECODIR)/macs/cpmac
168  vpath % $(ECODIR)/plls/pllxx1p8
169  vpath % $(ECODIR)/ddrs/emif31
170  vpath % $(ECODIR)/mdio
171  vpath % $(ECODIR)/gpio
172  vpath % $(ECODIR)/nands/gpio
173  vpath % $(ECODIR)/i2c
174 endif
176 ifeq ($(TARGET),c66x)
177  vpath % $(ECODIR)/plls/pll014phi
178  vpath % $(ECODIR)/mdio
179  vpath % $(ECODIR)/i2c
180  vpath % $(ECODIR)/pscs/psc2
181  vpath % $(ECODIR)/cpsw
182  vpath % $(ECODIR)/qm
183  vpath % $(ECODIR)/cpdma
184  vpath % $(ECODIR)/pa
185  vpath % $(ECODIR)/sgmii
186  vpath % $(ECODIR)/serdes
187  vpath % $(ECODIR)/gpio
188  vpath % $(ECODIR)/macs/cpmacsl
189  vpath % $(ECODIR)/ddrs/emif4
190  vpath % $(ECODIR)/nands/emif25
191  vpath % $(ECODIR)/nands/gpio
192  vpath % $(ECODIR)/nands/spi
193  vpath % $(ECODIR)/spi
194  vpath % $(ECODIR)/nors/emif25
195  vpath % $(ECODIR)/nors/spi
196  vpath % $(ECODIR)/emif25
197  vpath % $(ECODIR)/uart/c66x_uart
198 endif
201 hw: gen_cdefdep makefile $(OBJS)
203 $(OBJS): cdefdep
206 gen_cdefdep:
207         @echo Checking command line dependencies
208         @echo $(TARGET) $(ARCH) $(CDEFS) $(DEBUG) > cdefdep.tmp
209         @sh -c 'if diff -q cdefdep.tmp cdefdep ; then echo same ; else $(CP) cdefdep.tmp cdefdep ; fi '
211 cleant:
212         make -f makestg2 clean2 ARCH=c64x