188 lines
5.8 KiB
Makefile
188 lines
5.8 KiB
Makefile
#/***********************license start***************
|
|
# Copyright (c) 2003-2007 Cavium Inc. (support@cavium.com). All rights
|
|
# reserved.
|
|
#
|
|
#
|
|
# Redistribution and use in source and binary forms, with or without
|
|
# modification, are permitted provided that the following conditions are
|
|
# met:
|
|
#
|
|
# * Redistributions of source code must retain the above copyright
|
|
# notice, this list of conditions and the following disclaimer.
|
|
#
|
|
# * Redistributions in binary form must reproduce the above
|
|
# copyright notice, this list of conditions and the following
|
|
# disclaimer in the documentation and/or other materials provided
|
|
# with the distribution.
|
|
#
|
|
# * Neither the name of Cavium Inc. nor the names of
|
|
# its contributors may be used to endorse or promote products
|
|
# derived from this software without specific prior written
|
|
# permission.
|
|
#
|
|
# TO THE MAXIMUM EXTENT PERMITTED BY LAW, THE SOFTWARE IS PROVIDED "AS IS"
|
|
# AND WITH ALL FAULTS AND CAVIUM NETWORKS MAKES NO PROMISES, REPRESENTATIONS
|
|
# OR WARRANTIES, EITHER EXPRESS, IMPLIED, STATUTORY, OR OTHERWISE, WITH
|
|
# RESPECT TO THE SOFTWARE, INCLUDING ITS CONDITION, ITS CONFORMITY TO ANY
|
|
# REPRESENTATION OR DESCRIPTION, OR THE EXISTENCE OF ANY LATENT OR PATENT
|
|
# DEFECTS, AND CAVIUM SPECIFICALLY DISCLAIMS ALL IMPLIED (IF ANY) WARRANTIES
|
|
# OF TITLE, MERCHANTABILITY, NONINFRINGEMENT, FITNESS FOR A PARTICULAR
|
|
# PURPOSE, LACK OF VIRUSES, ACCURACY OR COMPLETENESS, QUIET ENJOYMENT, QUIET
|
|
# POSSESSION OR CORRESPONDENCE TO DESCRIPTION. THE ENTIRE RISK ARISING OUT
|
|
# OF USE OR PERFORMANCE OF THE SOFTWARE LIES WITH YOU.
|
|
#
|
|
#
|
|
# For any questions regarding licensing please contact marketing@cavium.com
|
|
#
|
|
# ***********************license end**************************************/
|
|
|
|
#
|
|
# component Makefile fragment
|
|
#
|
|
|
|
# standard component Makefile header
|
|
sp := $(sp).x
|
|
dirstack_$(sp) := $(d)
|
|
d := $(dir)
|
|
|
|
# component specification
|
|
|
|
LIBRARY := $(OBJ_DIR)/libcvmx.a
|
|
|
|
OBJS_$(d) := \
|
|
$(OBJ_DIR)/cvmx-app-hotplug.o \
|
|
$(OBJ_DIR)/cvmx-bootmem.o \
|
|
$(OBJ_DIR)/cvmx-clock.o \
|
|
$(OBJ_DIR)/cvmx-cmd-queue.o \
|
|
$(OBJ_DIR)/cvmx-cn3010-evb-hs5.o \
|
|
$(OBJ_DIR)/cvmx-core.o \
|
|
$(OBJ_DIR)/cvmx-coremask.o \
|
|
$(OBJ_DIR)/cvmx-csr-db.o \
|
|
$(OBJ_DIR)/cvmx-csr-db-support.o \
|
|
$(OBJ_DIR)/cvmx-crypto.o \
|
|
$(OBJ_DIR)/cvmx-dfa.o \
|
|
$(OBJ_DIR)/cvmx-dma-engine.o \
|
|
$(OBJ_DIR)/cvmx-ebt3000.o \
|
|
$(OBJ_DIR)/cvmx-error.o \
|
|
$(OBJ_DIR)/cvmx-error-custom.o \
|
|
$(OBJ_DIR)/cvmx-error-init-cn30xx.o \
|
|
$(OBJ_DIR)/cvmx-error-init-cn31xx.o \
|
|
$(OBJ_DIR)/cvmx-error-init-cn38xx.o \
|
|
$(OBJ_DIR)/cvmx-error-init-cn38xxp2.o \
|
|
$(OBJ_DIR)/cvmx-error-init-cn50xx.o \
|
|
$(OBJ_DIR)/cvmx-error-init-cn52xx.o \
|
|
$(OBJ_DIR)/cvmx-error-init-cn52xxp1.o \
|
|
$(OBJ_DIR)/cvmx-error-init-cn56xx.o \
|
|
$(OBJ_DIR)/cvmx-error-init-cn56xxp1.o \
|
|
$(OBJ_DIR)/cvmx-error-init-cn58xx.o \
|
|
$(OBJ_DIR)/cvmx-error-init-cn58xxp1.o \
|
|
$(OBJ_DIR)/cvmx-error-init-cn61xx.o \
|
|
$(OBJ_DIR)/cvmx-error-init-cn63xx.o \
|
|
$(OBJ_DIR)/cvmx-error-init-cn63xxp1.o \
|
|
$(OBJ_DIR)/cvmx-error-init-cn66xx.o \
|
|
$(OBJ_DIR)/cvmx-error-init-cn68xx.o \
|
|
$(OBJ_DIR)/cvmx-error-init-cn68xxp1.o \
|
|
$(OBJ_DIR)/cvmx-error-init-cnf71xx.o \
|
|
$(OBJ_DIR)/cvmx-flash.o \
|
|
$(OBJ_DIR)/cvmx-fpa.o \
|
|
$(OBJ_DIR)/cvmx-helper-board.o \
|
|
$(OBJ_DIR)/cvmx-helper-errata.o \
|
|
$(OBJ_DIR)/cvmx-helper-cfg.o \
|
|
$(OBJ_DIR)/cvmx-helper-fpa.o \
|
|
$(OBJ_DIR)/cvmx-helper-ilk.o \
|
|
$(OBJ_DIR)/cvmx-helper-loop.o \
|
|
$(OBJ_DIR)/cvmx-helper-npi.o \
|
|
$(OBJ_DIR)/cvmx-helper-rgmii.o \
|
|
$(OBJ_DIR)/cvmx-helper-sgmii.o \
|
|
$(OBJ_DIR)/cvmx-helper-spi.o \
|
|
$(OBJ_DIR)/cvmx-helper-srio.o \
|
|
$(OBJ_DIR)/cvmx-helper-util.o \
|
|
$(OBJ_DIR)/cvmx-helper-xaui.o \
|
|
$(OBJ_DIR)/cvmx-helper-jtag.o \
|
|
$(OBJ_DIR)/cvmx-helper.o \
|
|
$(OBJ_DIR)/cvmx-hfa.o \
|
|
$(OBJ_DIR)/cvmx-ilk.o \
|
|
$(OBJ_DIR)/cvmx-ipd.o \
|
|
$(OBJ_DIR)/cvmx-ixf18201.o \
|
|
$(OBJ_DIR)/cvmx-l2c.o \
|
|
$(OBJ_DIR)/cvmx-llm.o \
|
|
$(OBJ_DIR)/cvmx-log-arc.o \
|
|
$(OBJ_DIR)/cvmx-log.o \
|
|
$(OBJ_DIR)/cvmx-mgmt-port.o \
|
|
$(OBJ_DIR)/cvmx-nand.o \
|
|
$(OBJ_DIR)/cvmx-pcie.o \
|
|
$(OBJ_DIR)/cvmx-pko.o \
|
|
$(OBJ_DIR)/cvmx-pow.o \
|
|
$(OBJ_DIR)/cvmx-power-throttle.o \
|
|
$(OBJ_DIR)/cvmx-profiler.o \
|
|
$(OBJ_DIR)/cvmx-qlm.o \
|
|
$(OBJ_DIR)/cvmx-qlm-tables.o \
|
|
$(OBJ_DIR)/cvmx-raid.o \
|
|
$(OBJ_DIR)/cvmx-shmem.o \
|
|
$(OBJ_DIR)/cvmx-spi.o \
|
|
$(OBJ_DIR)/cvmx-spi4000.o \
|
|
$(OBJ_DIR)/cvmx-srio.o \
|
|
$(OBJ_DIR)/cvmx-sysinfo.o \
|
|
$(OBJ_DIR)/cvmx-thunder.o \
|
|
$(OBJ_DIR)/cvmx-tim.o \
|
|
$(OBJ_DIR)/cvmx-tlb.o \
|
|
$(OBJ_DIR)/cvmx-tra.o \
|
|
$(OBJ_DIR)/cvmx-twsi.o \
|
|
$(OBJ_DIR)/cvmx-usb.o \
|
|
$(OBJ_DIR)/cvmx-usbd.o \
|
|
$(OBJ_DIR)/cvmx-warn.o \
|
|
$(OBJ_DIR)/cvmx-zip.o \
|
|
$(OBJ_DIR)/cvmx-zone.o \
|
|
$(OBJ_DIR)/octeon-feature.o \
|
|
$(OBJ_DIR)/octeon-model.o \
|
|
$(OBJ_DIR)/octeon-pci-console.o
|
|
ifeq (linux,$(findstring linux,$(OCTEON_TARGET)))
|
|
OBJS_$(d) += \
|
|
$(OBJ_DIR)/cvmx-app-init-linux.o
|
|
else
|
|
OBJS_$(d) += \
|
|
$(OBJ_DIR)/cvmx-debug.o \
|
|
$(OBJ_DIR)/cvmx-debug-handler.o \
|
|
$(OBJ_DIR)/cvmx-debug-remote.o \
|
|
$(OBJ_DIR)/cvmx-debug-uart.o \
|
|
$(OBJ_DIR)/cvmx-interrupt.o \
|
|
$(OBJ_DIR)/cvmx-interrupt-handler.o \
|
|
$(OBJ_DIR)/cvmx-app-init.o \
|
|
$(OBJ_DIR)/cvmx-malloc.o \
|
|
$(OBJ_DIR)/cvmx-uart.o
|
|
endif
|
|
|
|
$(OBJS_$(d)): CFLAGS_LOCAL := -I$(d) -O2 -g -W -Wall -Wno-unused-parameter -Wundef -G0
|
|
|
|
# standard component Makefile rules
|
|
|
|
DEPS_$(d) := $(OBJS_$(d):.o=.d)
|
|
|
|
LIBS_LIST := $(LIBS_LIST) $(LIBRARY)
|
|
|
|
CLEAN_LIST := $(CLEAN_LIST) $(OBJS_$(d)) $(DEPS_$(d)) $(LIBRARY)
|
|
|
|
-include $(DEPS_$(d))
|
|
|
|
$(LIBRARY): $(OBJS_$(d))
|
|
$(AR) -cr $@ $^
|
|
|
|
$(OBJ_DIR)/%.o: $(d)/%.c
|
|
$(COMPILE)
|
|
|
|
$(OBJ_DIR)/%.o: $(d)/%.S
|
|
$(ASSEMBLE)
|
|
|
|
$(OBJ_DIR)/cvmx-app-init-linux.o: $(d)/cvmx-app-init-linux.c
|
|
$(CC) $(CFLAGS_GLOBAL) $(CFLAGS_LOCAL) -MD -c -Umain -o $@ $<
|
|
|
|
CFLAGS_SPECIAL := -I$(d) -I$(d)/cvmx-malloc -O2 -g -DUSE_CVM_THREADS=1 -D_REENTRANT
|
|
|
|
$(OBJ_DIR)/cvmx-malloc.o: $(d)/cvmx-malloc/malloc.c
|
|
$(CC) $(CFLAGS_GLOBAL) $(CFLAGS_SPECIAL) -MD -c -o $@ $<
|
|
|
|
# standard component Makefile footer
|
|
|
|
d := $(dirstack_$(sp))
|
|
sp := $(basename $(sp))
|