| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 1 | USB Legacy support | 
 | 2 | ~~~~~~~~~~~~~~~~~~ | 
 | 3 |  | 
 | 4 | Vojtech Pavlik <vojtech@suse.cz>, January 2004 | 
 | 5 |  | 
 | 6 |  | 
 | 7 | Also known as "USB Keyboard" or "USB Mouse support" in the BIOS Setup is a | 
 | 8 | feature that allows one to use the USB mouse and keyboard as if they were | 
 | 9 | their classic PS/2 counterparts.  This means one can use an USB keyboard to | 
 | 10 | type in LILO for example. | 
 | 11 |  | 
 | 12 | It has several drawbacks, though: | 
 | 13 |  | 
 | 14 | 1) On some machines, the emulated PS/2 mouse takes over even when no USB | 
 | 15 |    mouse is present and a real PS/2 mouse is present.  In that case the extra | 
 | 16 |    features (wheel, extra buttons, touchpad mode) of the real PS/2 mouse may | 
 | 17 |    not be available. | 
 | 18 |  | 
 | 19 | 2) If CONFIG_HIGHMEM64G is enabled, the PS/2 mouse emulation can cause | 
 | 20 |    system crashes, because the SMM BIOS is not expecting to be in PAE mode. | 
 | 21 |    The Intel E7505 is a typical machine where this happens. | 
 | 22 |  | 
 | 23 | 3) If AMD64 64-bit mode is enabled, again system crashes often happen, | 
 | 24 |    because the SMM BIOS isn't expecting the CPU to be in 64-bit mode.  The | 
 | 25 |    BIOS manufacturers only test with Windows, and Windows doesn't do 64-bit | 
 | 26 |    yet. | 
 | 27 |  | 
 | 28 | Solutions: | 
 | 29 |  | 
 | 30 | Problem 1) can be solved by loading the USB drivers prior to loading the | 
 | 31 | PS/2 mouse driver. Since the PS/2 mouse driver is in 2.6 compiled into | 
 | 32 | the kernel unconditionally, this means the USB drivers need to be | 
 | 33 | compiled-in, too. | 
 | 34 |  | 
 | 35 | Problem 2) can currently only be solved by either disabling HIGHMEM64G | 
 | 36 | in the kernel config or USB Legacy support in the BIOS. A BIOS update | 
 | 37 | could help, but so far no such update exists. | 
 | 38 |  | 
 | 39 | Problem 3) is usually fixed by a BIOS update. Check the board | 
 | 40 | manufacturers web site. If an update is not available, disable USB | 
 | 41 | Legacy support in the BIOS. If this alone doesn't help, try also adding | 
 | 42 | idle=poll on the kernel command line. The BIOS may be entering the SMM | 
 | 43 | on the HLT instruction as well. | 
 | 44 |  |