bsd.cpu.mk revision 126938
1# $FreeBSD: head/share/mk/bsd.cpu.mk 126938 2004-03-14 01:29:05Z trhodes $ 2 3# Set default CPU compile flags and baseline CPUTYPE for each arch. The 4# compile flags must support the minimum CPU type for each architecture but 5# may tune support for more advanced processors. 6 7.if !defined(CPUTYPE) || empty(CPUTYPE) 8. if ${MACHINE_ARCH} == "i386" 9_CPUCFLAGS = 10MACHINE_CPU = i486 11. elif ${MACHINE_ARCH} == "alpha" 12_CPUCFLAGS = -mcpu=ev4 -mtune=ev5 13MACHINE_CPU = ev4 14. elif ${MACHINE_ARCH} == "amd64" 15MACHINE_CPU = amd64 sse2 sse 16. elif ${MACHINE_ARCH} == "ia64" 17_CPUCFLAGS = 18MACHINE_CPU = itanium 19. elif ${MACHINE_ARCH} == "sparc64" 20_CPUCFLAGS = 21. endif 22.else 23 24# Handle aliases (not documented in make.conf to avoid user confusion 25# between e.g. i586 and pentium) 26 27. if ${MACHINE_ARCH} == "i386" 28. if ${CPUTYPE} == "pentiumpro" 29CPUTYPE = i686 30. elif ${CPUTYPE} == "pentium" 31CPUTYPE = i586 32. elif ${CPUTYPE} == "k7" 33CPUTYPE = athlon 34. endif 35. endif 36 37# Logic to set up correct gcc optimization flag. This must be included 38# after /etc/make.conf so it can react to the local value of CPUTYPE 39# defined therein. Consult: 40# http://gcc.gnu.org/onlinedocs/gcc/i386-and-x86-64-Options.html 41# http://gcc.gnu.org/onlinedocs/gcc/DEC-Alpha-Options.html 42# http://gcc.gnu.org/onlinedocs/gcc/SPARC-Options.html 43# http://gcc.gnu.org/onlinedocs/gcc/RS-6000-and-PowerPC-Options.html 44 45. if ${MACHINE_ARCH} == "i386" 46. if ${CPUTYPE} == "athlon-mp" || ${CPUTYPE} == "athlon-xp" || \ 47 ${CPUTYPE} == "athlon-4" 48_ICC_CPUCFLAGS = -tpp6 -xiMK 49_CPUCFLAGS = -march=${CPUTYPE} 50. elif ${CPUTYPE} == "athlon-tbird" || ${CPUTYPE} == "athlon" 51_CPUCFLAGS = -march=${CPUTYPE} 52_ICC_CPUCFLAGS = -tpp6 -xiM 53. elif ${CPUTYPE} == "k6-3" || ${CPUTYPE} == "k6-2" || ${CPUTYPE} == "k6" 54_CPUCFLAGS = -march=${CPUTYPE} 55_ICC_CPUCFLAGS = -tpp6 -xi 56. elif ${CPUTYPE} == "k5" 57_ICC_CPUCFLAGS = -tpp5 58_CPUCFLAGS = -march=pentium 59. elif ${CPUTYPE} == "p4" 60_ICC_CPUCFLAGS = -tpp7 -xiMKW 61_CPUCFLAGS = -march=pentium4 62. elif ${CPUTYPE} == "p3" 63_ICC_CPUCFLAGS = -tpp6 -xiMK 64_CPUCFLAGS = -march=pentium3 65. elif ${CPUTYPE} == "p2" 66_ICC_CPUCFLAGS = -tpp6 -xiM 67_CPUCFLAGS = -march=pentium2 68. elif ${CPUTYPE} == "i686" 69_ICC_CPUCFLAGS = -tpp6 -xiM 70_CPUCFLAGS = -march=pentiumpro 71. elif ${CPUTYPE} == "i586/mmx" 72_ICC_CPUCFLAGS = -tpp5 -xM 73_CPUCFLAGS = -march=pentium-mmx 74. elif ${CPUTYPE} == "i586" 75_ICC_CPUCFLAGS = -tpp5 76_CPUCFLAGS = -march=pentium 77. elif ${CPUTYPE} == "i486" 78_ICC_CPUCFLAGS = 79_CPUCFLAGS = -march=i486 80. endif 81. elif ${MACHINE_ARCH} == "alpha" 82. if ${CPUTYPE} == "ev67" 83_CPUCFLAGS = -mcpu=ev67 84. elif ${CPUTYPE} == "ev6" 85_CPUCFLAGS = -mcpu=ev6 86. elif ${CPUTYPE} == "pca56" 87_CPUCFLAGS = -mcpu=pca56 88. elif ${CPUTYPE} == "ev56" 89_CPUCFLAGS = -mcpu=ev56 90. elif ${CPUTYPE} == "ev5" 91_CPUCFLAGS = -mcpu=ev5 92. elif ${CPUTYPE} == "ev45" 93_CPUCFLAGS = -mcpu=ev45 94. elif ${CPUTYPE} == "ev4" 95_CPUCFLAGS = -mcpu=ev4 96. endif 97. endif 98 99# Set up the list of CPU features based on the CPU type. This is an 100# unordered list to make it easy for client makefiles to test for the 101# presence of a CPU feature. 102 103. if ${MACHINE_ARCH} == "i386" 104. if ${CPUTYPE} == "athlon-mp" || ${CPUTYPE} == "athlon-xp" || \ 105 ${CPUTYPE} == "athlon-4" 106MACHINE_CPU = athlon-xp k7 3dnow sse mmx k6 k5 i586 i486 i386 107. elif ${CPUTYPE} == "athlon" || ${CPUTYPE} == "athlon-tbird" 108MACHINE_CPU = athlon k7 3dnow mmx k6 k5 i586 i486 i386 109. elif ${CPUTYPE} == "k6-3" || ${CPUTYPE} == "k6-2" 110MACHINE_CPU = 3dnow mmx k6 k5 i586 i486 i386 111. elif ${CPUTYPE} == "k6" 112MACHINE_CPU = mmx k6 k5 i586 i486 i386 113. elif ${CPUTYPE} == "k5" 114MACHINE_CPU = k5 i586 i486 i386 115. elif ${CPUTYPE} == "p4" 116MACHINE_CPU = sse2 sse i686 mmx i586 i486 i386 117. elif ${CPUTYPE} == "p3" 118MACHINE_CPU = sse i686 mmx i586 i486 i386 119. elif ${CPUTYPE} == "p2" 120MACHINE_CPU = i686 mmx i586 i486 i386 121. elif ${CPUTYPE} == "i686" 122MACHINE_CPU = i686 i586 i486 i386 123. elif ${CPUTYPE} == "i586/mmx" 124MACHINE_CPU = mmx i586 i486 i386 125. elif ${CPUTYPE} == "i586" 126MACHINE_CPU = i586 i486 i386 127. elif ${CPUTYPE} == "i486" 128MACHINE_CPU = i486 i386 129. elif ${CPUTYPE} == "i386" 130MACHINE_CPU = i386 131. endif 132. elif ${MACHINE_ARCH} == "alpha" 133. if ${CPUTYPE} == "ev6" 134MACHINE_CPU = ev6 ev56 pca56 ev5 ev45 ev4 135. elif ${CPUTYPE} == "pca56" 136MACHINE_CPU = pca56 ev56 ev5 ev45 ev4 137. elif ${CPUTYPE} == "ev56" 138MACHINE_CPU = ev56 ev5 ev45 ev4 139. elif ${CPUTYPE} == "ev5" 140MACHINE_CPU = ev5 ev45 ev4 141. elif ${CPUTYPE} == "ev45" 142MACHINE_CPU = ev45 ev4 143. elif ${CPUTYPE} == "ev4" 144MACHINE_CPU = ev4 145. endif 146. elif ${MACHINE_ARCH} == "amd64" 147MACHINE_CPU = amd64 sse2 sse 148. elif ${MACHINE_ARCH} == "ia64" 149. if ${CPUTYPE} == "itanium" 150MACHINE_CPU = itanium 151. endif 152. endif 153.endif 154 155.if ${MACHINE_ARCH} == "alpha" 156_CPUCFLAGS += -mieee 157.endif 158 159# NB: COPTFLAGS is handled in /usr/src/sys/conf/kern.pre.mk 160 161.if !defined(NO_CPU_CFLAGS) 162. if ${CC} == "icc" 163CFLAGS += ${_ICC_CPUCFLAGS} 164. else 165CFLAGS += ${_CPUCFLAGS} 166. endif 167.endif 168