Modification for removing makedep.exe requirement
[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 nandwrgpio.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 nandwrgpio.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 nandwrgpio.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 nandwrgpio.c sgmii.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 nandwrgpio.c
64     else
65      CSRC= t64.c cpmacdrv.c pll.c psc.c emif31.c mdio.c gpio.c nandgpio.c i2c.c nandwrgpio.c sgmii.c
66     endif
67    endif
68   endif
69  endif
70 endif
72 CDEFS += -DIBL_I2C_CFG_EEPROM_BUS_ADDR=$(I2C_PARAM_BUS_ADDR)
74 .PHONY: hw
77 include $(IBL_ROOT)/make/$(ARCH)/makeeco.mk
80 C6X_C_DIR=   $(IBL_ROOT)
81 C6X_C_DIR+= ;$(IBL_ROOT)/arch/$(ARCH)
82 C6X_C_DIR+= ;$(ECODIR)
83 C6X_C_DIR+= ;$(STDINC)
84 C6X_C_DIR+= ;$(IBL_ROOT)/cfg/$(TARGET)
85 C6X_C_DIR+= ;$(IBL_ROOT)/hw/timer
86 C6X_C_DIR+= ;$(IBL_ROOT)/hw/macs/cpmac
87 C6X_C_DIR+= ;$(IBL_ROOT)/driver/eth
88 C6X_C_DIR+= ;$(IBL_ROOT)/device
89 C6X_C_DIR+= ;$(IBL_ROOT)/device/$(TARGET)
90 C6X_C_DIR+= ;$(IBL_ROOT)/hw/plls
91 C6X_C_DIR+= ;$(IBL_ROOT)/hw/pscs
92 C6X_C_DIR+= ;$(IBL_ROOT)/hw/mdio
93 C6X_C_DIR+= ;$(IBL_ROOT)/hw/gpio
94 C6X_C_DIR+= ;$(IBL_ROOT)/hw/nands
95 C6X_C_DIR+= ;$(IBL_ROOT)/hw/nands/gpio
96 C6X_C_DIR+= ;$(IBL_ROOT)/hw/i2c
97 C6X_C_DIR+= ;$(IBL_ROOT)/hw/sgmii
98 C6X_C_DIR+= ;$(IBL_ROOT)/ecc
99 export C6X_C_DIR
102 vpath % $(ECODIR)/timer/timer64
104 ifeq ($(TARGET),c6472)
105  vpath % $(ECODIR)/macs/cpmac
106  vpath % $(ECODIR)/plls/pllxx1p8
107  vpath % $(ECODIR)/pscs/psc2
108  vpath % $(ECODIR)/ddrs/emif31
109  vpath % $(ECODIR)/mdio
110  vpath % $(ECODIR)/gpio
111  vpath % $(ECODIR)/nands/gpio
112  vpath % $(ECODIR)/i2c
113 endif
115 ifeq ($(TARGET),c6474)
116  vpath % $(ECODIR)/macs/cpmac
117  vpath % $(ECODIR)/plls/pllxx1p8
118  vpath % $(ECODIR)/pscs/psc2
119  vpath % $(ECODIR)/ddrs/emif31
120  vpath % $(ECODIR)/mdio
121  vpath % $(ECODIR)/gpio
122  vpath % $(ECODIR)/nands/gpio
123  vpath % $(ECODIR)/i2c
124  vpath % $(ECODIR)/sgmii
125 endif
127 ifeq ($(TARGET),c6474l)
128  vpath % $(ECODIR)/macs/cpmac
129  vpath % $(ECODIR)/plls/pllxx1p8
130  vpath % $(ECODIR)/pscs/psc2
131  vpath % $(ECODIR)/ddrs/emif31
132  vpath % $(ECODIR)/mdio
133  vpath % $(ECODIR)/gpio
134  vpath % $(ECODIR)/nands/gpio
135  vpath % $(ECODIR)/i2c
136  vpath % $(ECODIR)/sgmii
137 endif
139 ifeq ($(TARGET),c6457)
140  vpath % $(ECODIR)/macs/cpmac
141  vpath % $(ECODIR)/plls/pllxx1p8
142  vpath % $(ECODIR)/pscs/psc2
143  vpath % $(ECODIR)/ddrs/emif31
144  vpath % $(ECODIR)/mdio
145  vpath % $(ECODIR)/gpio
146  vpath % $(ECODIR)/nands/gpio
147  vpath % $(ECODIR)/i2c
148  vpath % $(ECODIR)/sgmii
149 endif
151 ifeq ($(TARGET),c6455)
152  vpath % $(ECODIR)/macs/cpmac
153  vpath % $(ECODIR)/plls/pllxx1p8
154  vpath % $(ECODIR)/ddrs/emif31
155  vpath % $(ECODIR)/mdio
156  vpath % $(ECODIR)/gpio
157  vpath % $(ECODIR)/nands/gpio
158  vpath % $(ECODIR)/i2c
159 endif
162 hw: gen_cdefdep makefile $(OBJS)
164 $(OBJS): cdefdep
167 gen_cdefdep:
168         @echo Checking command line dependencies
169         @echo $(ENDIAN) $(TARGET) $(ARCH) $(CDEFS) $(DEBUG) > cdefdep.tmp
170         @sh -c 'if diff -q cdefdep.tmp cdefdep ; then echo same ; else $(CP) cdefdep.tmp cdefdep ; fi '
172 clean:
173         make -f makestg2 clean2 ARCH=c64x