Print this page
10593 illumos build should not use kernel modules as link-editor input
Split |
Close |
Expand all |
Collapse all |
--- old/usr/src/uts/sun4u/cheetahplus/Makefile
+++ new/usr/src/uts/sun4u/cheetahplus/Makefile
1 1 #
2 2 # CDDL HEADER START
3 3 #
4 4 # The contents of this file are subject to the terms of the
5 5 # Common Development and Distribution License (the "License").
6 6 # You may not use this file except in compliance with the License.
7 7 #
8 8 # You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
9 9 # or http://www.opensolaris.org/os/licensing.
10 10 # See the License for the specific language governing permissions
11 11 # and limitations under the License.
12 12 #
13 13 # When distributing Covered Code, include this CDDL HEADER in each
14 14 # file and include the License file at usr/src/OPENSOLARIS.LICENSE.
15 15 # If applicable, add the following below this CDDL HEADER, with the
16 16 # fields enclosed by brackets "[]" replaced with your own identifying
17 17 # information: Portions Copyright [yyyy] [name of copyright owner]
18 18 #
19 19 # CDDL HEADER END
20 20 #
21 21
22 22 #
23 23 # Copyright 2009 Sun Microsystems, Inc. All rights reserved.
24 24 # Use is subject to license terms.
25 25 #
26 26
27 27 #
28 28 # This makefile drives the production of the sun4u UltraSPARC driver
29 29 # module.
30 30 #
31 31 # sun4u implementation architecture dependent
32 32 #
33 33
34 34 #
35 35 # Path to the base of the uts directory tree (usually /usr/src/uts).
36 36 #
37 37 UTSBASE = ../..
38 38
39 39 #
40 40 # Define the module and object file sets.
41 41 #
42 42 MODULE = SUNW,UltraSPARC-III+
43 43 OBJECTS = $(CHEETAHPLUS_OBJS:%=$(OBJS_DIR)/%)
44 44 LINTS = $(CHEETAHPLUS_OBJS:%.o=$(LINTS_DIR)/%.ln)
45 45 ROOTMODULE = $(ROOT_PSM_CPU_DIR)/$(MODULE)
46 46 SOFTLINKS = SUNW,UltraSPARC-IV SUNW,UltraSPARC-IV+
47 47 ROOTSOFTLINKS = $(SOFTLINKS:%=$(ROOT_PSM_CPU_DIR)/%)
48 48
49 49 CPU_DIR = .
50 50 HERE = ../cheetahplus
51 51
52 52 #
53 53 # Include common rules.
54 54 #
55 55 include $(UTSBASE)/sun4u/Makefile.sun4u
56 56
57 57 #
58 58 # Override defaults
59 59 #
60 60 CLEANFILES += $(CPULIB) $(SYM_MOD)
61 61
62 62 #
63 63 # Define targets
64 64 #
65 65 ALL_TARGET = $(SYM_MOD)
66 66 LINT_TARGET = $(MODULE).lint
67 67 INSTALL_TARGET = def $(BINARY) $(ROOTMODULE) $(ROOTSOFTLINKS)
68 68
69 69 #
70 70 # lint pass one enforcement
71 71 #
72 72 CFLAGS += $(CCVERBOSE) -DCHEETAH -DCHEETAH_PLUS -DCPU_IMP_L1_CACHE_PARITY \
73 73 -DCPU_IMP_ECACHE_ASSOC -DCPU_IMP_DUAL_PAGESIZE -DCPU_IMP_AFSR_EXT
74 74 ASFLAGS += -DCHEETAH -DCHEETAH_PLUS -DCPU_IMP_L1_CACHE_PARITY \
75 75 -DCPU_IMP_ECACHE_ASSOC -DCPU_IMP_DUAL_PAGESIZE -DCPU_IMP_AFSR_EXT
76 76
77 77 #
78 78 # cpu-module-specific flags
79 79 #
80 80 CPPFLAGS += -DCPU_MODULE -DCHEETAH -DCHEETAH_PLUS -DCPU_IMP_L1_CACHE_PARITY \
81 81 -DCPU_IMP_ECACHE_ASSOC -DCPU_IMP_DUAL_PAGESIZE -DCPU_IMP_AFSR_EXT
82 82 AS_CPPFLAGS += -DCPU_MODULE -DCHEETAH -DCHEETAH_PLUS -DCPU_IMP_L1_CACHE_PARITY \
83 83 -DCPU_IMP_ECACHE_ASSOC -DCPU_IMP_DUAL_PAGESIZE -DCPU_IMP_AFSR_EXT
84 84
85 85 #
86 86 # Default build targets.
87 87 #
88 88 .KEEP_STATE:
89 89
90 90 def: $(DEF_DEPS)
91 91
92 92 all: $(ALL_DEPS)
93 93
94 94 clean: $(CLEAN_DEPS)
95 95
↓ open down ↓ |
95 lines elided |
↑ open up ↑ |
96 96 clobber: $(CLOBBER_DEPS)
97 97
98 98 lint: $(LINT_DEPS)
99 99
100 100 modlintlib: $(MODLINTLIB_DEPS)
101 101
102 102 clean.lint: $(CLEAN_LINT_DEPS)
103 103
104 104 install: $(INSTALL_DEPS)
105 105
106 -$(CPULIB): $(BINARY)
107 - $(BUILD.SO) $(BINARY)
106 +$(CPULIB): $(OBJECTS)
107 + $(BUILD.SO) $(OBJECTS)
108 108
109 109 $(SYM_MOD): $(UNIX_O) $(CPULIB)
110 110 @echo "resolving symbols against unix.o"
111 111 @(cd $(UNIX_DIR); pwd; \
112 112 CPU_DIR=$(HERE) SYM_MOD=$(HERE)/$(SYM_MOD) $(MAKE) symcheck)
113 113
114 114 $(ROOTSOFTLINKS): $(ROOTMODULE)
115 115 $(RM) $@; $(SYMLINK) $(MODULE) $@
116 116
117 117 # Include common targets.
118 118 #
119 119 include $(UTSBASE)/sun4u/Makefile.targ
120 120
121 121 #
122 122 # For now, disable these lint checks; maintainers should endeavor
123 123 # to investigate and remove these for maximum lint coverage.
124 124 # Please do not carry these forward to new Makefiles.
125 125 #
126 126 LINTTAGS += -erroff=E_SUSPICIOUS_COMPARISON
127 127 LINTTAGS += -erroff=E_BAD_PTR_CAST_ALIGN
128 128 LINTTAGS += -erroff=E_STATIC_UNUSED
129 129 LINTTAGS += -erroff=E_PTRDIFF_OVERFLOW
130 130 LINTTAGS += -erroff=E_ASSIGN_NARROW_CONV
131 131
132 132 CERRWARN += -_gcc=-Wno-parentheses
133 133 CERRWARN += -_gcc=-Wno-uninitialized
134 134 CERRWARN += -_gcc=-Wno-unused-variable
135 135 CERRWARN += -_gcc=-Wno-type-limits
136 136 CERRWARN += -_gcc=-Wno-clobbered
↓ open down ↓ |
19 lines elided |
↑ open up ↑ |
XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX