Blame view

Documentation/laptops/sony-laptop.txt 5.64 KB
ab5bd2069   Mattia Dongili   sony-laptop: Upda...
1
2
3
4
  Sony Notebook Control Driver (SNC) Readme
  -----------------------------------------
  	Copyright (C) 2004- 2005 Stelian Pop <stelian@popies.net>
  	Copyright (C) 2007 Mattia Dongili <malattia@linux.it>
3d2b8a9f2   malattia@linux.it   sony-laptop: upda...
5
6
7
8
  This mini-driver drives the SNC and SPIC device present in the ACPI BIOS of the
  Sony Vaio laptops. This driver mixes both devices functions under the same
  (hopefully consistent) interface. This also means that the sonypi driver is
  obsoleted by sony-laptop now.
ab5bd2069   Mattia Dongili   sony-laptop: Upda...
9

3d2b8a9f2   malattia@linux.it   sony-laptop: upda...
10
11
12
13
  Fn keys (hotkeys):
  ------------------
  Some models report hotkeys through the SNC or SPIC devices, such events are
  reported both through the ACPI subsystem as acpi events and through the INPUT
1696d9dc5   Thomas Renninger   ACPI: Remove the ...
14
15
16
17
  subsystem. See the logs of /proc/bus/input/devices to find out what those
  events are and which input devices are created by the driver.
  Additionally, loading the driver with the debug option will report all events
  in the kernel log.
ab5bd2069   Mattia Dongili   sony-laptop: Upda...
18

747a562f3   John Hughes   to fix scancodes ...
19
20
21
22
  The "scancodes" passed to the input system (that can be remapped with udev)
  are indexes to the table "sony_laptop_input_keycode_map" in the sony-laptop.c
  module.  For example the "FN/E" key combination (EJECTCD on some models)
  generates the scancode 20 (0x14).
ab5bd2069   Mattia Dongili   sony-laptop: Upda...
23
24
25
26
27
28
  Backlight control:
  ------------------
  If your laptop model supports it, you will find sysfs files in the
  /sys/class/backlight/sony/
  directory. You will be able to query and set the current screen
  brightness:
19f594600   Matt LaPlante   trivial: Miscella...
29
  	brightness		get/set screen brightness (an integer
ab5bd2069   Mattia Dongili   sony-laptop: Upda...
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
  				between 0 and 7)
  	actual_brightness	reading from this file will query the HW
  				to get real brightness value
  	max_brightness		the maximum brightness value
  
  
  Platform specific:
  ------------------
  Loading the sony-laptop module will create a
  /sys/devices/platform/sony-laptop/
  directory populated with some files.
  
  You then read/write integer values from/to those files by using
  standard UNIX tools.
  
  The files are:
  	brightness_default	screen brightness which will be set
  				when the laptop will be rebooted
  	cdpower			power on/off the internal CD drive
  	audiopower		power on/off the internal sound card
  	lanpower		power on/off the internal ethernet card
  				(only in debug mode)
3d2b8a9f2   malattia@linux.it   sony-laptop: upda...
52
53
  	bluetoothpower		power on/off the internal bluetooth device
  	fanspeed		get/set the fan speed
ab5bd2069   Mattia Dongili   sony-laptop: Upda...
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
  
  Note that some files may be missing if they are not supported
  by your particular laptop model.
  
  Example usage:
  	# echo "1" > /sys/devices/platform/sony-laptop/brightness_default
  sets the lowest screen brightness for the next and later reboots,
  	# echo "8" > /sys/devices/platform/sony-laptop/brightness_default
  sets the highest screen brightness for the next and later reboots,
  	# cat /sys/devices/platform/sony-laptop/brightness_default
  retrieves the value.
  
  	# echo "0" > /sys/devices/platform/sony-laptop/audiopower
  powers off the sound card,
  	# echo "1" > /sys/devices/platform/sony-laptop/audiopower
  powers on the sound card.
54286fd0d   Mattia Dongili   sony-laptop: docu...
70
71
72
73
74
75
76
77
  
  RFkill control:
  ---------------
  More recent Vaio models expose a consistent set of ACPI methods to
  control radio frequency emitting devices. If you are a lucky owner of
  such a laptop you will find the necessary rfkill devices under
  /sys/class/rfkill. Check those starting with sony-* in
  	# grep . /sys/class/rfkill/*/{state,name}
ab5bd2069   Mattia Dongili   sony-laptop: Upda...
78
79
80
81
82
83
84
85
86
87
88
  Development:
  ------------
  
  If you want to help with the development of this driver (and
  you are not afraid of any side effects doing strange things with
  your ACPI BIOS could have on your laptop), load the driver and
  pass the option 'debug=1'.
  
  REPEAT: DON'T DO THIS IF YOU DON'T LIKE RISKY BUSINESS.
  
  In your kernel logs you will find the list of all ACPI methods
54286fd0d   Mattia Dongili   sony-laptop: docu...
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
  the SNC device has on your laptop.
  
  * For new models you will see a long list of meaningless method names,
  reading the DSDT table source should reveal that:
  (1) the SNC device uses an internal capability lookup table
  (2) SN00 is used to find values in the lookup table
  (3) SN06 and SN07 are used to call into the real methods based on
      offsets you can obtain iterating the table using SN00
  (4) SN02 used to enable events.
  Some values in the capability lookup table are more or less known, see
  the code for all sony_call_snc_handle calls, others are more obscure.
  
  * For old models you can see the GCDP/GCDP methods used to pwer on/off
  the CD drive, but there are others and they are usually different from
  model to model.
ab5bd2069   Mattia Dongili   sony-laptop: Upda...
104
105
106
107
108
109
110
  
  I HAVE NO IDEA WHAT THOSE METHODS DO.
  
  The sony-laptop driver creates, for some of those methods (the most
  current ones found on several Vaio models), an entry under
  /sys/devices/platform/sony-laptop, just like the 'cdpower' one.
  You can create other entries corresponding to your own laptop methods by
3d2b8a9f2   malattia@linux.it   sony-laptop: upda...
111
  further editing the source (see the 'sony_nc_values' table, and add a new
ab5bd2069   Mattia Dongili   sony-laptop: Upda...
112
  entry to this table with your get/set method names using the
3d2b8a9f2   malattia@linux.it   sony-laptop: upda...
113
  SNC_HANDLE_NAMES macro).
ab5bd2069   Mattia Dongili   sony-laptop: Upda...
114
115
116
117
118
119
120
  
  Your mission, should you accept it, is to try finding out what
  those entries are for, by reading/writing random values from/to those
  files and find out what is the impact on your laptop.
  
  Should you find anything interesting, please report it back to me,
  I will not disavow all knowledge of your actions :)
3d2b8a9f2   malattia@linux.it   sony-laptop: upda...
121
122
  See also http://www.linux.it/~malattia/wiki/index.php/Sony_drivers for other
  useful info.
ab5bd2069   Mattia Dongili   sony-laptop: Upda...
123
124
125
126
127
128
129
130
131
132
  Bugs/Limitations:
  -----------------
  
  * This driver is not based on official documentation from Sony
    (because there is none), so there is no guarantee this driver
    will work at all, or do the right thing. Although this hasn't
    happened to me, this driver could do very bad things to your
    laptop, including permanent damage.
  
  * The sony-laptop and sonypi drivers do not interact at all. In the
54286fd0d   Mattia Dongili   sony-laptop: docu...
133
    future, sonypi will be removed and replaced by sony-laptop.
ab5bd2069   Mattia Dongili   sony-laptop: Upda...
134
135
  
  * spicctrl, which is the userspace tool used to communicate with the
54286fd0d   Mattia Dongili   sony-laptop: docu...
136
137
    sonypi driver (through /dev/sonypi) is deprecated as well since all
    its features are now available under the sysfs tree via sony-laptop.