Você não pode selecionar mais de 25 tópicos Os tópicos devem começar com uma letra ou um número, podem incluir traços ('-') e podem ter até 35 caracteres.

Config 5.2KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151
  1. # -*- makefile -*-
  2. ##############################################################################
  3. ##############################################################################
  4. #
  5. # IMPORTANT!
  6. #
  7. # The use of this file to set options that affect only single object
  8. # files is deprecated, because changing anything in this file results
  9. # in a complete rebuild, which is slow. All options are gradually
  10. # being migrated to config.h, which does not suffer from this problem.
  11. #
  12. # Only options that affect the entire build (e.g. overriding the $(CC)
  13. # Makefile variable) should be placed in here.
  14. #
  15. ##############################################################################
  16. ##############################################################################
  17. # Config for i386 Etherboot
  18. #
  19. # Do not delete the tag OptionDescription and /OptionDescription
  20. # It is used to automatically generate the documentation.
  21. #
  22. # @OptionDescrition@
  23. #
  24. # BIOS interface options:
  25. #
  26. # -DPCBIOS
  27. # Compile in support for the normal pcbios
  28. # -DLINUXBIOS
  29. # Compile in support for LinuxBIOS
  30. # -DBBS_BUT_NOT_PNP_COMPLIANT
  31. # Some BIOSes claim to be PNP but they don't conform
  32. # to the BBS spec which specifies that ES:DI must
  33. # point to the string $PnP on entry. This option
  34. # works around those. This option must be added to
  35. # LCONFIG.
  36. # -DNO_DELAYED_INT
  37. # Take control as soon as BIOS detects the ROM.
  38. # Normally hooks onto INT18H or INT19H. Use only if you
  39. # have a very non-conformant BIOS as it bypasses
  40. # BIOS initialisation of devices. This only works for
  41. # legacy ROMs, i.e. PCI_PNP_HEADER not defined.
  42. # This option was formerly called NOINT19H.
  43. # -DBOOT_INT18H
  44. # Etherboot normally hooks onto INT19H for legacy ROMs.
  45. # You can choose to hook onto INT18H (BASIC interpreter
  46. # entry point) instead. This entry point is used when
  47. # all boot devices have been exhausted. This option must
  48. # be added to LCONFIG.
  49. # -DCONFIG_PCI_DIRECT
  50. # Define this for PCI BIOSes that do not implement
  51. # BIOS32 or not correctly. Normally not needed.
  52. # Only works for BIOSes of a certain era.
  53. # -DCONFIG_TSC_CURRTICKS
  54. # Uses the processor time stamp counter instead of reading
  55. # the BIOS time counter. This allows Etherboot to work
  56. # even without a BIOS. This only works on late model
  57. # 486s and above.
  58. # -DCONFIG_NO_TIMER2
  59. # Some systems do not have timer2 implemented.
  60. # If you have a RTC this will allow you to roughly calibrate
  61. # it using outb instructions.
  62. # -DIBM_L40
  63. # This option uses the 0x92 method of controlling
  64. # A20 instead of the traditional method of using the
  65. # keyboard controller. An explanation of A20 is here:
  66. # http://www.win.tue.nl/~aeb/linux/kbd/A20.html
  67. # This occurs on MCA, EISA and some embedded boards,
  68. # and sometimes with the Fast Gate A20 option on some
  69. # BIOSes.
  70. # Enable this only if you are sure of what you are doing.
  71. #
  72. # Extended cpu options
  73. # -DCONFIG_X86_64
  74. # Compile in support for booting x86_64 64bit binaries.
  75. #
  76. # PXE loader options:
  77. #
  78. # -DPXELOADER_KEEP_ALL
  79. # Prevent PXE loader (prefix) from unloading the
  80. # PXE stack. You will want to use this if, for
  81. # example, you are booting via PXE-on-floppy.
  82. # You may want to use it under certain
  83. # circumstances when using the Etherboot UNDI
  84. # driver; these are complex and best practice is
  85. # not yet established.
  86. #
  87. # Obscure options you probably don't need to touch:
  88. #
  89. # -DIGNORE_E820_MAP
  90. # Ignore the memory map returned by the E820 BIOS
  91. # call. May be necessary on some buggy BIOSes.
  92. # -DT503_AUI
  93. # Use AUI by default on 3c503 cards.
  94. # -DFLATTEN_REAL_MODE
  95. # Use 4GB segment limits when calling out to or
  96. # returning to real-mode code. This is necessary to
  97. # work around some buggy code (e.g. OpenBSD's pxeboot)
  98. # that uses flat real-mode without being sufficiently
  99. # paranoid about the volatility of its segment limits.
  100. #
  101. # @/OptionDescription@
  102. # BIOS select don't change unless you know what you are doing
  103. CFLAGS+= -DPCBIOS
  104. # Compile in k8/hammer support
  105. # CFLAGS+= -DCONFIG_X86_64
  106. # Options to make a version of Etherboot that will work under linuxBIOS.
  107. # CFLAGS+= -DLINUXBIOS -DCONFIG_TSC_CURRTICKS -DCONSOLE_SERIAL -DCOMCONSOLE=0x3f8 -DCOMPRESERVE -DCONFIG_PCI_DIRECT -DELF_IMAGE
  108. # These options affect the loader that is prepended to the Etherboot image
  109. # LCONFIG+= -DBBS_BUT_NOT_PNP_COMPLIANT
  110. # LCONFIG+= -DBOOT_INT18H
  111. # Produce code that will work with OpenBSD's pxeboot
  112. # CFLAGS+= -DFLATTEN_REAL_MODE
  113. CFLAGS+= -fstrength-reduce -fomit-frame-pointer -march=i386
  114. # Squeeze the code in as little space as possible.
  115. # gcc3 needs a different syntax to gcc2 if you want to avoid spurious warnings.
  116. GCC_VERSION = $(subst ., ,$(shell $(CC) -dumpversion))
  117. GCC_MAJORVERSION = $(firstword $(GCC_VERSION))
  118. ifeq ($(GCC_MAJORVERSION),2)
  119. CFLAGS+= -malign-jumps=1 -malign-loops=1 -malign-functions=1
  120. else
  121. CFLAGS+= -falign-jumps=1 -falign-loops=1 -falign-functions=1
  122. endif
  123. GCC_MINORVERSION = $(word 2, $(GCC_VERSION))
  124. ifneq ($(GCC_MINORVERSION),4)
  125. CFLAGS+= -march=i386
  126. endif
  127. LDFLAGS+= -N
  128. ifeq "$(shell uname -s)" "FreeBSD"
  129. CFLAGS+= -DIMAGE_FREEBSD -DELF_IMAGE -DAOUT_IMAGE
  130. endif
  131. # An alternate location for isolinux.bin can be set here
  132. # ISOLINUX_BIN=/path/to/isolinux.bin
  133. # These seem to have some relevance to compiling on x86_64
  134. # EXTRA_CFLAGS=-m32
  135. # EXTRA_ASFLAGS=--32
  136. # EXTRA_LDFLAGS=-m elf_i386