Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 1 | AMD64 specific boot options |
| 2 | |
| 3 | There are many others (usually documented in driver documentation), but |
| 4 | only the AMD64 specific ones are listed here. |
| 5 | |
| 6 | Machine check |
| 7 | |
Andi Kleen | 8780e8e | 2009-05-27 21:56:56 +0200 | [diff] [blame] | 8 | Please see Documentation/x86/x86_64/machinecheck for sysfs runtime tunables. |
| 9 | |
Hidetoshi Seto | 62fdac5 | 2009-06-11 16:06:07 +0900 | [diff] [blame] | 10 | mce=off |
| 11 | Disable machine check |
| 12 | mce=no_cmci |
| 13 | Disable CMCI(Corrected Machine Check Interrupt) that |
| 14 | Intel processor supports. Usually this disablement is |
| 15 | not recommended, but it might be handy if your hardware |
| 16 | is misbehaving. |
| 17 | Note that you'll get more problems without CMCI than with |
| 18 | due to the shared banks, i.e. you might get duplicated |
| 19 | error logs. |
| 20 | mce=dont_log_ce |
| 21 | Don't make logs for corrected errors. All events reported |
| 22 | as corrected are silently cleared by OS. |
| 23 | This option will be useful if you have no interest in any |
| 24 | of corrected errors. |
| 25 | mce=ignore_ce |
| 26 | Disable features for corrected errors, e.g. polling timer |
| 27 | and CMCI. All events reported as corrected are not cleared |
| 28 | by OS and remained in its error banks. |
| 29 | Usually this disablement is not recommended, however if |
| 30 | there is an agent checking/clearing corrected errors |
| 31 | (e.g. BIOS or hardware monitoring applications), conflicting |
| 32 | with OS's error handling, and you cannot deactivate the agent, |
| 33 | then this option will be a help. |
| 34 | mce=bootlog |
| 35 | Enable logging of machine checks left over from booting. |
| 36 | Disabled by default on AMD because some BIOS leave bogus ones. |
| 37 | If your BIOS doesn't do that it's a good idea to enable though |
| 38 | to make sure you log even machine check events that result |
| 39 | in a reboot. On Intel systems it is enabled by default. |
Andi Kleen | e583538 | 2005-11-05 17:25:54 +0100 | [diff] [blame] | 40 | mce=nobootlog |
| 41 | Disable boot machine check logging. |
Andi Kleen | 3c07979 | 2009-05-27 21:56:55 +0200 | [diff] [blame] | 42 | mce=tolerancelevel[,monarchtimeout] (number,number) |
| 43 | tolerance levels: |
Tim Hockin | bd78432 | 2007-07-21 17:10:37 +0200 | [diff] [blame] | 44 | 0: always panic on uncorrected errors, log corrected errors |
| 45 | 1: panic or SIGBUS on uncorrected errors, log corrected errors |
| 46 | 2: SIGBUS or log uncorrected errors, log corrected errors |
| 47 | 3: never panic or SIGBUS, log all errors (for testing only) |
| 48 | Default is 1 |
Andi Kleen | 8c566ef | 2005-09-12 18:49:24 +0200 | [diff] [blame] | 49 | Can be also set using sysfs which is preferable. |
Andi Kleen | 3c07979 | 2009-05-27 21:56:55 +0200 | [diff] [blame] | 50 | monarchtimeout: |
| 51 | Sets the time in us to wait for other CPUs on machine checks. 0 |
| 52 | to disable. |
Naveen N. Rao | 450cc20 | 2012-09-27 10:08:00 -0700 | [diff] [blame] | 53 | mce=bios_cmci_threshold |
| 54 | Don't overwrite the bios-set CMCI threshold. This boot option |
| 55 | prevents Linux from overwriting the CMCI threshold set by the |
| 56 | bios. Without this option, Linux always sets the CMCI |
| 57 | threshold to 1. Enabling this may make memory predictive failure |
| 58 | analysis less effective if the bios sets thresholds for memory |
| 59 | errors since we will not see details for all errors. |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 60 | |
| 61 | nomce (for compatibility with i386): same as mce=off |
| 62 | |
| 63 | Everything else is in sysfs now. |
| 64 | |
| 65 | APICs |
| 66 | |
| 67 | apic Use IO-APIC. Default |
| 68 | |
| 69 | noapic Don't use the IO-APIC. |
| 70 | |
| 71 | disableapic Don't use the local APIC |
| 72 | |
| 73 | nolapic Don't use the local APIC (alias for i386 compatibility) |
| 74 | |
Uwe Hermann | 71cced6 | 2008-10-20 09:32:21 -0700 | [diff] [blame] | 75 | pirq=... See Documentation/x86/i386/IO-APIC.txt |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 76 | |
| 77 | noapictimer Don't set up the APIC timer |
| 78 | |
Andi Kleen | 14d98ca | 2005-05-20 14:27:59 -0700 | [diff] [blame] | 79 | no_timer_check Don't check the IO-APIC timer. This can work around |
| 80 | problems with incorrect timer initialization on some boards. |
| 81 | |
Andi Kleen | 73dea47 | 2006-02-03 21:50:50 +0100 | [diff] [blame] | 82 | apicmaintimer Run time keeping from the local APIC timer instead |
| 83 | of using the PIT/HPET interrupt for this. This is useful |
| 84 | when the PIT/HPET interrupts are unreliable. |
| 85 | |
| 86 | noapicmaintimer Don't do time keeping using the APIC timer. |
| 87 | Useful when this option was auto selected, but doesn't work. |
| 88 | |
Andi Kleen | 0c3749c | 2006-02-03 21:51:41 +0100 | [diff] [blame] | 89 | apicpmtimer |
| 90 | Do APIC timer calibration using the pmtimer. Implies |
| 91 | apicmaintimer. Useful when your PIT timer is totally |
| 92 | broken. |
| 93 | |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 94 | Early Console |
| 95 | |
| 96 | syntax: earlyprintk=vga |
| 97 | earlyprintk=serial[,ttySn[,baudrate]] |
| 98 | |
| 99 | The early console is useful when the kernel crashes before the |
| 100 | normal console is initialized. It is not enabled by |
| 101 | default because it has some cosmetic problems. |
| 102 | Append ,keep to not disable it when the real console takes over. |
| 103 | Only vga or serial at a time, not both. |
| 104 | Currently only ttyS0 and ttyS1 are supported. |
| 105 | Interaction with the standard serial driver is not very good. |
| 106 | The VGA output is eventually overwritten by the real console. |
| 107 | |
| 108 | Timing |
| 109 | |
| 110 | notsc |
| 111 | Don't use the CPU time stamp counter to read the wall time. |
| 112 | This can be used to work around timing problems on multiprocessor systems |
Andi Kleen | ef4d7cb | 2005-07-28 21:15:34 -0700 | [diff] [blame] | 113 | with not properly synchronized CPUs. |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 114 | |
| 115 | report_lost_ticks |
| 116 | Report when timer interrupts are lost because some code turned off |
| 117 | interrupts for too long. |
| 118 | |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 119 | nohpet |
| 120 | Don't use the HPET timer. |
| 121 | |
| 122 | Idle loop |
| 123 | |
| 124 | idle=poll |
| 125 | Don't do power saving in the idle loop using HLT, but poll for rescheduling |
| 126 | event. This will make the CPUs eat a lot more power, but may be useful |
| 127 | to get slightly better performance in multiprocessor benchmarks. It also |
| 128 | makes some profiling using performance counters more accurate. |
Andi Kleen | ef4d7cb | 2005-07-28 21:15:34 -0700 | [diff] [blame] | 129 | Please note that on systems with MONITOR/MWAIT support (like Intel EM64T |
| 130 | CPUs) this option has no performance advantage over the normal idle loop. |
| 131 | It may also interact badly with hyperthreading. |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 132 | |
| 133 | Rebooting |
| 134 | |
Huang, Ying | 9ad65e4 | 2008-01-30 13:31:19 +0100 | [diff] [blame] | 135 | reboot=b[ios] | t[riple] | k[bd] | a[cpi] | e[fi] [, [w]arm | [c]old] |
Matt LaPlante | d6bc8ac | 2006-10-03 22:54:15 +0200 | [diff] [blame] | 136 | bios Use the CPU reboot vector for warm reset |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 137 | warm Don't set the cold reboot flag |
| 138 | cold Set the cold reboot flag |
| 139 | triple Force a triple fault (init) |
| 140 | kbd Use the keyboard controller. cold reset (default) |
Aaron Durbin | fa20efd | 2008-01-30 13:31:17 +0100 | [diff] [blame] | 141 | acpi Use the ACPI RESET_REG in the FADT. If ACPI is not configured or the |
| 142 | ACPI reset does not work, the reboot path attempts the reset using |
| 143 | the keyboard controller. |
Huang, Ying | 9ad65e4 | 2008-01-30 13:31:19 +0100 | [diff] [blame] | 144 | efi Use efi reset_system runtime service. If EFI is not configured or the |
| 145 | EFI reset does not work, the reboot path attempts the reset using |
| 146 | the keyboard controller. |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 147 | |
| 148 | Using warm reset will be much faster especially on big memory |
| 149 | systems because the BIOS will not go through the memory check. |
| 150 | Disadvantage is that not all hardware will be completely reinitialized |
| 151 | on reboot so there may be boot problems on some systems. |
| 152 | |
| 153 | reboot=force |
| 154 | |
| 155 | Don't stop other CPUs on reboot. This can make reboot more reliable |
| 156 | in some cases. |
| 157 | |
| 158 | Non Executable Mappings |
| 159 | |
| 160 | noexec=on|off |
| 161 | |
| 162 | on Enable(default) |
| 163 | off Disable |
| 164 | |
| 165 | SMP |
| 166 | |
Andi Kleen | 420f8f6 | 2005-11-05 17:25:54 +0100 | [diff] [blame] | 167 | additional_cpus=NUM Allow NUM more CPUs for hotplug |
Uwe Hermann | 71cced6 | 2008-10-20 09:32:21 -0700 | [diff] [blame] | 168 | (defaults are specified by the BIOS, see Documentation/x86/x86_64/cpu-hotplug-spec) |
Andi Kleen | 420f8f6 | 2005-11-05 17:25:54 +0100 | [diff] [blame] | 169 | |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 170 | NUMA |
| 171 | |
| 172 | numa=off Only set up a single NUMA node spanning all memory. |
| 173 | |
| 174 | numa=noacpi Don't parse the SRAT table for NUMA setup |
| 175 | |
David Rientjes | 8df5bb34 | 2010-02-15 13:43:30 -0800 | [diff] [blame] | 176 | numa=fake=<size>[MG] |
| 177 | If given as a memory unit, fills all system RAM with nodes of |
| 178 | size interleaved over physical nodes. |
| 179 | |
David Rientjes | ca2107c | 2010-02-15 13:43:33 -0800 | [diff] [blame] | 180 | numa=fake=<N> |
| 181 | If given as an integer, fills all system RAM with N fake nodes |
| 182 | interleaved over physical nodes. |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 183 | |
| 184 | ACPI |
| 185 | |
| 186 | acpi=off Don't enable ACPI |
| 187 | acpi=ht Use ACPI boot table parsing, but don't enable ACPI |
| 188 | interpreter |
| 189 | acpi=force Force ACPI on (currently not needed) |
| 190 | |
| 191 | acpi=strict Disable out of spec ACPI workarounds. |
| 192 | |
| 193 | acpi_sci={edge,level,high,low} Set up ACPI SCI interrupt. |
| 194 | |
| 195 | acpi=noirq Don't route interrupts |
| 196 | |
| 197 | PCI |
| 198 | |
Lucas De Marchi | a6c3270 | 2011-03-17 16:24:15 -0300 | [diff] [blame] | 199 | pci=off Don't use PCI |
| 200 | pci=conf1 Use conf1 access. |
| 201 | pci=conf2 Use conf2 access. |
| 202 | pci=rom Assign ROMs. |
| 203 | pci=assign-busses Assign busses |
| 204 | pci=irqmask=MASK Set PCI interrupt mask to MASK |
| 205 | pci=lastbus=NUMBER Scan up to NUMBER busses, no matter what the mptable says. |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 206 | pci=noacpi Don't use ACPI to set up PCI interrupt routing. |
| 207 | |
Karsten Weiss | 5558870 | 2007-02-13 13:26:21 +0100 | [diff] [blame] | 208 | IOMMU (input/output memory management unit) |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 209 | |
Karsten Weiss | 5558870 | 2007-02-13 13:26:21 +0100 | [diff] [blame] | 210 | Currently four x86-64 PCI-DMA mapping implementations exist: |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 211 | |
Karsten Weiss | 5558870 | 2007-02-13 13:26:21 +0100 | [diff] [blame] | 212 | 1. <arch/x86_64/kernel/pci-nommu.c>: use no hardware/software IOMMU at all |
| 213 | (e.g. because you have < 3 GB memory). |
| 214 | Kernel boot message: "PCI-DMA: Disabling IOMMU" |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 215 | |
Joerg Roedel | fffcda1 | 2011-05-10 17:22:06 +0200 | [diff] [blame] | 216 | 2. <arch/x86/kernel/amd_gart_64.c>: AMD GART based hardware IOMMU. |
Karsten Weiss | 5558870 | 2007-02-13 13:26:21 +0100 | [diff] [blame] | 217 | Kernel boot message: "PCI-DMA: using GART IOMMU" |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 218 | |
Karsten Weiss | 5558870 | 2007-02-13 13:26:21 +0100 | [diff] [blame] | 219 | 3. <arch/x86_64/kernel/pci-swiotlb.c> : Software IOMMU implementation. Used |
| 220 | e.g. if there is no hardware IOMMU in the system and it is need because |
| 221 | you have >3GB memory or told the kernel to us it (iommu=soft)) |
| 222 | Kernel boot message: "PCI-DMA: Using software bounce buffering |
| 223 | for IO (SWIOTLB)" |
| 224 | |
| 225 | 4. <arch/x86_64/pci-calgary.c> : IBM Calgary hardware IOMMU. Used in IBM |
| 226 | pSeries and xSeries servers. This hardware IOMMU supports DMA address |
| 227 | mapping with memory protection, etc. |
| 228 | Kernel boot message: "PCI-DMA: Using Calgary IOMMU" |
| 229 | |
| 230 | iommu=[<size>][,noagp][,off][,force][,noforce][,leak[=<nr_of_leak_pages>] |
| 231 | [,memaper[=<order>]][,merge][,forcesac][,fullflush][,nomerge] |
| 232 | [,noaperture][,calgary] |
| 233 | |
| 234 | General iommu options: |
| 235 | off Don't initialize and use any kind of IOMMU. |
| 236 | noforce Don't force hardware IOMMU usage when it is not needed. |
| 237 | (default). |
| 238 | force Force the use of the hardware IOMMU even when it is |
| 239 | not actually needed (e.g. because < 3 GB memory). |
| 240 | soft Use software bounce buffering (SWIOTLB) (default for |
| 241 | Intel machines). This can be used to prevent the usage |
| 242 | of an available hardware IOMMU. |
| 243 | |
| 244 | iommu options only relevant to the AMD GART hardware IOMMU: |
| 245 | <size> Set the size of the remapping area in bytes. |
| 246 | allowed Overwrite iommu off workarounds for specific chipsets. |
| 247 | fullflush Flush IOMMU on each allocation (default). |
| 248 | nofullflush Don't use IOMMU fullflush. |
| 249 | leak Turn on simple iommu leak tracing (only when |
| 250 | CONFIG_IOMMU_LEAK is on). Default number of leak pages |
| 251 | is 20. |
| 252 | memaper[=<order>] Allocate an own aperture over RAM with size 32MB<<order. |
| 253 | (default: order=1, i.e. 64MB) |
Randy Dunlap | 57d3077 | 2007-02-13 13:26:23 +0100 | [diff] [blame] | 254 | merge Do scatter-gather (SG) merging. Implies "force" |
Karsten Weiss | 5558870 | 2007-02-13 13:26:21 +0100 | [diff] [blame] | 255 | (experimental). |
Randy Dunlap | 57d3077 | 2007-02-13 13:26:23 +0100 | [diff] [blame] | 256 | nomerge Don't do scatter-gather (SG) merging. |
Karsten Weiss | 5558870 | 2007-02-13 13:26:21 +0100 | [diff] [blame] | 257 | noaperture Ask the IOMMU not to touch the aperture for AGP. |
| 258 | forcesac Force single-address cycle (SAC) mode for masks <40bits |
| 259 | (experimental). |
| 260 | noagp Don't initialize the AGP driver and use full aperture. |
| 261 | allowdac Allow double-address cycle (DAC) mode, i.e. DMA >4GB. |
| 262 | DAC is used with 32-bit PCI to push a 64-bit address in |
| 263 | two cycles. When off all DMA over >4GB is forced through |
| 264 | an IOMMU or software bounce buffering. |
| 265 | nodac Forbid DAC mode, i.e. DMA >4GB. |
| 266 | panic Always panic when IOMMU overflows. |
| 267 | calgary Use the Calgary IOMMU if it is available |
| 268 | |
| 269 | iommu options only relevant to the software bounce buffering (SWIOTLB) IOMMU |
| 270 | implementation: |
| 271 | swiotlb=<pages>[,force] |
| 272 | <pages> Prereserve that many 128K pages for the software IO |
| 273 | bounce buffering. |
| 274 | force Force all IO through the software TLB. |
| 275 | |
| 276 | Settings for the IBM Calgary hardware IOMMU currently found in IBM |
| 277 | pSeries and xSeries machines: |
| 278 | |
| 279 | calgary=[64k,128k,256k,512k,1M,2M,4M,8M] |
| 280 | calgary=[translate_empty_slots] |
| 281 | calgary=[disable=<PCI bus number>] |
| 282 | panic Always panic when IOMMU overflows |
Jon Mason | e465058 | 2006-06-26 13:58:14 +0200 | [diff] [blame] | 283 | |
| 284 | 64k,...,8M - Set the size of each PCI slot's translation table |
| 285 | when using the Calgary IOMMU. This is the size of the translation |
| 286 | table itself in main memory. The smallest table, 64k, covers an IO |
| 287 | space of 32MB; the largest, 8MB table, can cover an IO space of |
| 288 | 4GB. Normally the kernel will make the right choice by itself. |
| 289 | |
| 290 | translate_empty_slots - Enable translation even on slots that have |
| 291 | no devices attached to them, in case a device will be hotplugged |
| 292 | in the future. |
| 293 | |
| 294 | disable=<PCI bus number> - Disable translation on a given PHB. For |
| 295 | example, the built-in graphics adapter resides on the first bridge |
| 296 | (PCI bus number 0); if translation (isolation) is enabled on this |
| 297 | bridge, X servers that access the hardware directly from user |
| 298 | space might stop working. Use this option if you have devices that |
| 299 | are accessed from userspace directly on some PCI host bridge. |
| 300 | |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 301 | Debugging |
| 302 | |
Randy Dunlap | 57d3077 | 2007-02-13 13:26:23 +0100 | [diff] [blame] | 303 | kstack=N Print N words from the kernel stack in oops dumps. |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 304 | |
Randy Dunlap | 57d3077 | 2007-02-13 13:26:23 +0100 | [diff] [blame] | 305 | pagefaulttrace Dump all page faults. Only useful for extreme debugging |
Andi Kleen | 9e43e1b | 2005-11-05 17:25:54 +0100 | [diff] [blame] | 306 | and will create a lot of output. |
| 307 | |
Andi Kleen | b783fd9 | 2006-07-28 14:44:54 +0200 | [diff] [blame] | 308 | call_trace=[old|both|newfallback|new] |
| 309 | old: use old inexact backtracer |
| 310 | new: use new exact dwarf2 unwinder |
| 311 | both: print entries from both |
| 312 | newfallback: use new unwinder but fall back to old if it gets |
| 313 | stuck (default) |
| 314 | |
Randy Dunlap | 57d3077 | 2007-02-13 13:26:23 +0100 | [diff] [blame] | 315 | Miscellaneous |
Ingo Molnar | 00d1c5e | 2008-04-17 17:40:45 +0200 | [diff] [blame] | 316 | |
| 317 | nogbpages |
| 318 | Do not use GB pages for kernel direct mappings. |
| 319 | gbpages |
| 320 | Use GB pages for kernel direct mappings. |