You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
98 lines
3.4 KiB
Markdown
98 lines
3.4 KiB
Markdown
*Migrated from https://github.com/Lekensteyn/acpi-stuff*
|
|
|
|
About
|
|
-----
|
|
|
|
bbswitch is a kernel module which automatically detects the required ACPI calls
|
|
for two kinds of Optimus laptops. It has been verified to work with "real"
|
|
Optimus and "legacy" Optimus laptops (at least, that is how I call them). The
|
|
machines on which these tests has performed are:
|
|
|
|
- Clevo B7130 - GT 425M ("real" Optimus, Lekensteyns laptop)
|
|
- Dell Vostro 3500 - GT 310M ("legacy" Optimus, Samsagax' laptop)
|
|
|
|
(note: there is no need to add more supported laptops here as the universal
|
|
calls should work for every laptop model supporting either Optimus calls)
|
|
|
|
It's preferred over manually hacking with the acpi_call module because it can
|
|
detect the correct handle preceding _DSM and has some built-in safeguards:
|
|
|
|
- You're not allowed to disable a card if a driver (nouveau, nvidia) is loaded.
|
|
- Before suspend, the card is automatically enabled. When resuming, it's
|
|
disabled again if that was the case before suspending. Hibernation should
|
|
work, but it not tested.
|
|
|
|
Build
|
|
-----
|
|
|
|
Build the module (kernel headers are required):
|
|
|
|
make
|
|
Then load it (requires root privileges, i.e. `sudo`):
|
|
|
|
make load
|
|
If your card is supported, there should be no error. Otherwise, you get a "No
|
|
such device" (ENODEV) error. Check your kernel log (dmesg) for more
|
|
information.
|
|
|
|
DKMS support
|
|
------------
|
|
|
|
Change `#MODULE_VERSION#` to the current version of bbswitch. Copy the
|
|
Makefile, C source and dkms.conf file to `/usr/src/bbswitch-VERSION/` (replace
|
|
VERSION with the current version of bbswitch which has been inserted for
|
|
`#MODULE_VERSION#`.
|
|
|
|
Usage
|
|
-----
|
|
|
|
bbswitch has three commands to check the card status and switching
|
|
(`#` means "run with root privileges, i.e. run it prefixed with `sudo `):
|
|
|
|
### Get the status:
|
|
|
|
# cat /proc/acpi/bbswitch
|
|
0000:01:00.0 ON
|
|
|
|
### Turn the card off, respectively on:
|
|
|
|
# tee /proc/acpi/bbswitch <<<OFF
|
|
# tee /proc/acpi/bbswitch <<<ON
|
|
If the card stays on when trying to disable it, you've probably forgotten to
|
|
unload the driver,
|
|
|
|
$ dmesg |tail -1
|
|
bbswitch: device 0000:01:00.0 is in use by driver 'nouveau', refusing OFF
|
|
|
|
Do **not** attempt to load a driver while the card is off or the card won't be
|
|
usable until the PCI configuration space has been recovered (for example, after
|
|
writing the contents manually or rebooting).
|
|
|
|
Reporting bugs
|
|
--------------
|
|
|
|
This module has been integrated in Bumblebee "Tumbleweed". Please report any
|
|
issues on this module in the issue tracker and provide the following details:
|
|
|
|
- The output of `dmesg | grep -C 10 bbswitch:`
|
|
- The kernel version `uname -a`
|
|
- Your distribution and version (if applicable)
|
|
- The version of your Xorg and the driver
|
|
- Submit your machine information on https://bugs.launchpad.net/bugs/752542;
|
|
the instructions are listed in the bug description. Summary: install the
|
|
packages containing `dmidecode`, `acpidump` and `iasl` and then run:
|
|
|
|
wget http://lekensteyn.nl/files/get-acpi-info.sh
|
|
sh get-acpi-info.sh
|
|
- Information about the ACPI handles associated with PCI devices. Since this is
|
|
a kernel module, you'll need kernel headers, gcc and automake. Commands:
|
|
|
|
git clone git://github.com/Lekensteyn/acpi-stuff.git --depth 1
|
|
cd acpi-stuff/acpi_dump_info
|
|
make
|
|
sudo make load
|
|
cat /proc/acpi/dump_info
|
|
|
|
Upload the generated tarball on the above Launchpad URL and provide a link to
|
|
the comment containing your report.
|