blob: ad4bc2dbea435057d4eaa861ef7c4310e42a0a07 [file] [log] [blame]
Mauro Carvalho Chehab8b4a5032019-06-08 23:27:16 -03001=============================
Linus Torvalds1da177e2005-04-16 15:20:36 -07002S/390 driver model interfaces
Mauro Carvalho Chehab8b4a5032019-06-08 23:27:16 -03003=============================
Linus Torvalds1da177e2005-04-16 15:20:36 -07004
51. CCW devices
6--------------
7
8All devices which can be addressed by means of ccws are called 'CCW devices' -
9even if they aren't actually driven by ccws.
10
Mauro Carvalho Chehab8b4a5032019-06-08 23:27:16 -030011All ccw devices are accessed via a subchannel, this is reflected in the
12structures under devices/::
Linus Torvalds1da177e2005-04-16 15:20:36 -070013
Mauro Carvalho Chehab8b4a5032019-06-08 23:27:16 -030014 devices/
Cornelia Huck373c4912005-11-07 00:59:03 -080015 - system/
Linus Torvalds1da177e2005-04-16 15:20:36 -070016 - css0/
Mauro Carvalho Chehab8b4a5032019-06-08 23:27:16 -030017 - 0.0.0000/0.0.0815/
Linus Torvalds1da177e2005-04-16 15:20:36 -070018 - 0.0.0001/0.0.4711/
19 - 0.0.0002/
Cornelia Huckdc060102006-03-24 03:15:13 -080020 - 0.1.0000/0.1.1234/
Linus Torvalds1da177e2005-04-16 15:20:36 -070021 ...
Cornelia Huck7f090142006-12-08 15:56:02 +010022 - defunct/
Linus Torvalds1da177e2005-04-16 15:20:36 -070023
Cornelia Huckdc060102006-03-24 03:15:13 -080024In this example, device 0815 is accessed via subchannel 0 in subchannel set 0,
25device 4711 via subchannel 1 in subchannel set 0, and subchannel 2 is a non-I/O
26subchannel. Device 1234 is accessed via subchannel 0 in subchannel set 1.
Linus Torvalds1da177e2005-04-16 15:20:36 -070027
Cornelia Huck7f090142006-12-08 15:56:02 +010028The subchannel named 'defunct' does not represent any real subchannel on the
Matt LaPlanted9195882008-07-25 19:45:33 -070029system; it is a pseudo subchannel where disconnected ccw devices are moved to
Cornelia Huck7f090142006-12-08 15:56:02 +010030if they are displaced by another ccw device becoming operational on their
31former subchannel. The ccw devices will be moved again to a proper subchannel
32if they become operational again on that subchannel.
33
Linus Torvalds1da177e2005-04-16 15:20:36 -070034You should address a ccw device via its bus id (e.g. 0.0.4711); the device can
35be found under bus/ccw/devices/.
36
37All ccw devices export some data via sysfs.
38
Mauro Carvalho Chehab8b4a5032019-06-08 23:27:16 -030039cutype:
40 The control unit type / model.
Linus Torvalds1da177e2005-04-16 15:20:36 -070041
Mauro Carvalho Chehab8b4a5032019-06-08 23:27:16 -030042devtype:
43 The device type / model, if applicable.
Linus Torvalds1da177e2005-04-16 15:20:36 -070044
Mauro Carvalho Chehab8b4a5032019-06-08 23:27:16 -030045availability:
46 Can be 'good' or 'boxed'; 'no path' or 'no device' for
Linus Torvalds1da177e2005-04-16 15:20:36 -070047 disconnected devices.
48
Mauro Carvalho Chehab8b4a5032019-06-08 23:27:16 -030049online:
50 An interface to set the device online and offline.
Linus Torvalds1da177e2005-04-16 15:20:36 -070051 In the special case of the device being disconnected (see the
Cornelia Huck373c4912005-11-07 00:59:03 -080052 notify function under 1.2), piping 0 to online will forcibly delete
Linus Torvalds1da177e2005-04-16 15:20:36 -070053 the device.
54
55The device drivers can add entries to export per-device data and interfaces.
56
57There is also some data exported on a per-subchannel basis (see under
58bus/css/devices/):
59
Mauro Carvalho Chehab8b4a5032019-06-08 23:27:16 -030060chpids:
61 Via which chpids the device is connected.
Linus Torvalds1da177e2005-04-16 15:20:36 -070062
Mauro Carvalho Chehab8b4a5032019-06-08 23:27:16 -030063pimpampom:
64 The path installed, path available and path operational masks.
Linus Torvalds1da177e2005-04-16 15:20:36 -070065
66There also might be additional data, for example for block devices.
67
68
691.1 Bringing up a ccw device
70----------------------------
71
72This is done in several steps.
73
74a. Each driver can provide one or more parameter interfaces where parameters can
75 be specified. These interfaces are also in the driver's responsibility.
76b. After a. has been performed, if necessary, the device is finally brought up
77 via the 'online' interface.
78
79
801.2 Writing a driver for ccw devices
81------------------------------------
82
83The basic struct ccw_device and struct ccw_driver data structures can be found
Mauro Carvalho Chehab8b4a5032019-06-08 23:27:16 -030084under include/asm/ccwdev.h::
Linus Torvalds1da177e2005-04-16 15:20:36 -070085
Mauro Carvalho Chehab8b4a5032019-06-08 23:27:16 -030086 struct ccw_device {
87 spinlock_t *ccwlock;
88 struct ccw_device_private *private;
89 struct ccw_device_id id;
Linus Torvalds1da177e2005-04-16 15:20:36 -070090
Mauro Carvalho Chehab8b4a5032019-06-08 23:27:16 -030091 struct ccw_driver *drv;
92 struct device dev;
Linus Torvalds1da177e2005-04-16 15:20:36 -070093 int online;
94
95 void (*handler) (struct ccw_device *dev, unsigned long intparm,
Mauro Carvalho Chehab8b4a5032019-06-08 23:27:16 -030096 struct irb *irb);
97 };
Linus Torvalds1da177e2005-04-16 15:20:36 -070098
Mauro Carvalho Chehab8b4a5032019-06-08 23:27:16 -030099 struct ccw_driver {
100 struct module *owner;
101 struct ccw_device_id *ids;
102 int (*probe) (struct ccw_device *);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700103 int (*remove) (struct ccw_device *);
104 int (*set_online) (struct ccw_device *);
105 int (*set_offline) (struct ccw_device *);
106 int (*notify) (struct ccw_device *, int);
107 struct device_driver driver;
108 char *name;
Mauro Carvalho Chehab8b4a5032019-06-08 23:27:16 -0300109 };
Linus Torvalds1da177e2005-04-16 15:20:36 -0700110
111The 'private' field contains data needed for internal i/o operation only, and
112is not available to the device driver.
113
114Each driver should declare in a MODULE_DEVICE_TABLE into which CU types/models
115and/or device types/models it is interested. This information can later be found
Mauro Carvalho Chehab8b4a5032019-06-08 23:27:16 -0300116in the struct ccw_device_id fields::
Linus Torvalds1da177e2005-04-16 15:20:36 -0700117
Mauro Carvalho Chehab8b4a5032019-06-08 23:27:16 -0300118 struct ccw_device_id {
119 __u16 match_flags;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700120
Mauro Carvalho Chehab8b4a5032019-06-08 23:27:16 -0300121 __u16 cu_type;
122 __u16 dev_type;
123 __u8 cu_model;
124 __u8 dev_model;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700125
126 unsigned long driver_info;
Mauro Carvalho Chehab8b4a5032019-06-08 23:27:16 -0300127 };
Linus Torvalds1da177e2005-04-16 15:20:36 -0700128
129The functions in ccw_driver should be used in the following way:
Mauro Carvalho Chehab8b4a5032019-06-08 23:27:16 -0300130
131probe:
132 This function is called by the device layer for each device the driver
Linus Torvalds1da177e2005-04-16 15:20:36 -0700133 is interested in. The driver should only allocate private structures
134 to put in dev->driver_data and create attributes (if needed). Also,
135 the interrupt handler (see below) should be set here.
136
Mauro Carvalho Chehab8b4a5032019-06-08 23:27:16 -0300137::
Linus Torvalds1da177e2005-04-16 15:20:36 -0700138
Mauro Carvalho Chehab8b4a5032019-06-08 23:27:16 -0300139 int (*probe) (struct ccw_device *cdev);
140
141Parameters:
142 cdev
143 - the device to be probed.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700144
145
Mauro Carvalho Chehab8b4a5032019-06-08 23:27:16 -0300146remove:
147 This function is called by the device layer upon removal of the driver,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700148 the device or the module. The driver should perform cleanups here.
149
Mauro Carvalho Chehab8b4a5032019-06-08 23:27:16 -0300150::
Linus Torvalds1da177e2005-04-16 15:20:36 -0700151
Mauro Carvalho Chehab8b4a5032019-06-08 23:27:16 -0300152 int (*remove) (struct ccw_device *cdev);
153
154Parameters:
155 cdev
156 - the device to be removed.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700157
158
Mauro Carvalho Chehab8b4a5032019-06-08 23:27:16 -0300159set_online:
160 This function is called by the common I/O layer when the device is
Linus Torvalds1da177e2005-04-16 15:20:36 -0700161 activated via the 'online' attribute. The driver should finally
162 setup and activate the device here.
163
Mauro Carvalho Chehab8b4a5032019-06-08 23:27:16 -0300164::
Linus Torvalds1da177e2005-04-16 15:20:36 -0700165
Mauro Carvalho Chehab8b4a5032019-06-08 23:27:16 -0300166 int (*set_online) (struct ccw_device *);
167
168Parameters:
169 cdev
170 - the device to be activated. The common layer has
Linus Torvalds1da177e2005-04-16 15:20:36 -0700171 verified that the device is not already online.
172
173
174set_offline: This function is called by the common I/O layer when the device is
175 de-activated via the 'online' attribute. The driver should shut
176 down the device, but not de-allocate its private data.
177
Mauro Carvalho Chehab8b4a5032019-06-08 23:27:16 -0300178::
Linus Torvalds1da177e2005-04-16 15:20:36 -0700179
Mauro Carvalho Chehab8b4a5032019-06-08 23:27:16 -0300180 int (*set_offline) (struct ccw_device *);
181
182Parameters:
183 cdev
184 - the device to be deactivated. The common layer has
Linus Torvalds1da177e2005-04-16 15:20:36 -0700185 verified that the device is online.
186
187
Mauro Carvalho Chehab8b4a5032019-06-08 23:27:16 -0300188notify:
189 This function is called by the common I/O layer for some state changes
Linus Torvalds1da177e2005-04-16 15:20:36 -0700190 of the device.
Mauro Carvalho Chehab8b4a5032019-06-08 23:27:16 -0300191
Linus Torvalds1da177e2005-04-16 15:20:36 -0700192 Signalled to the driver are:
Mauro Carvalho Chehab8b4a5032019-06-08 23:27:16 -0300193
Linus Torvalds1da177e2005-04-16 15:20:36 -0700194 * In online state, device detached (CIO_GONE) or last path gone
195 (CIO_NO_PATH). The driver must return !0 to keep the device; for
196 return code 0, the device will be deleted as usual (also when no
Matt LaPlanted6bc8ac2006-10-03 22:54:15 +0200197 notify function is registered). If the driver wants to keep the
Linus Torvalds1da177e2005-04-16 15:20:36 -0700198 device, it is moved into disconnected state.
199 * In disconnected state, device operational again (CIO_OPER). The
200 common I/O layer performs some sanity checks on device number and
201 Device / CU to be reasonably sure if it is still the same device.
202 If not, the old device is removed and a new one registered. By the
203 return code of the notify function the device driver signals if it
204 wants the device back: !0 for keeping, 0 to make the device being
205 removed and re-registered.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700206
Mauro Carvalho Chehab8b4a5032019-06-08 23:27:16 -0300207::
208
209 int (*notify) (struct ccw_device *, int);
210
211Parameters:
212 cdev
213 - the device whose state changed.
214
215 event
216 - the event that happened. This can be one of CIO_GONE,
217 CIO_NO_PATH or CIO_OPER.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700218
219The handler field of the struct ccw_device is meant to be set to the interrupt
Mauro Carvalho Chehab8b4a5032019-06-08 23:27:16 -0300220handler for the device. In order to accommodate drivers which use several
Linus Torvalds1da177e2005-04-16 15:20:36 -0700221distinct handlers (e.g. multi subchannel devices), this is a member of ccw_device
222instead of ccw_driver.
223The handler is registered with the common layer during set_online() processing
224before the driver is called, and is deregistered during set_offline() after the
Mauro Carvalho Chehab8b4a5032019-06-08 23:27:16 -0300225driver has been called. Also, after registering / before deregistering, path
Linus Torvalds1da177e2005-04-16 15:20:36 -0700226grouping resp. disbanding of the path group (if applicable) are performed.
227
Mauro Carvalho Chehab8b4a5032019-06-08 23:27:16 -0300228::
Linus Torvalds1da177e2005-04-16 15:20:36 -0700229
Mauro Carvalho Chehab8b4a5032019-06-08 23:27:16 -0300230 void (*handler) (struct ccw_device *dev, unsigned long intparm, struct irb *irb);
231
232Parameters: dev - the device the handler is called for
Linus Torvalds1da177e2005-04-16 15:20:36 -0700233 intparm - the intparm which allows the device driver to identify
Mauro Carvalho Chehab8b4a5032019-06-08 23:27:16 -0300234 the i/o the interrupt is associated with, or to recognize
235 the interrupt as unsolicited.
236 irb - interruption response block which contains the accumulated
237 status.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700238
Mauro Carvalho Chehab8b4a5032019-06-08 23:27:16 -0300239The device driver is called from the common ccw_device layer and can retrieve
Linus Torvalds1da177e2005-04-16 15:20:36 -0700240information about the interrupt from the irb parameter.
241
242
2431.3 ccwgroup devices
244--------------------
245
246The ccwgroup mechanism is designed to handle devices consisting of multiple ccw
247devices, like lcs or ctc.
248
249The ccw driver provides a 'group' attribute. Piping bus ids of ccw devices to
250this attributes creates a ccwgroup device consisting of these ccw devices (if
251possible). This ccwgroup device can be set online or offline just like a normal
252ccw device.
253
254Each ccwgroup device also provides an 'ungroup' attribute to destroy the device
255again (only when offline). This is a generic ccwgroup mechanism (the driver does
256not need to implement anything beyond normal removal routines).
257
Cornelia Huckdc060102006-03-24 03:15:13 -0800258A ccw device which is a member of a ccwgroup device carries a pointer to the
259ccwgroup device in the driver_data of its device struct. This field must not be
260touched by the driver - it should use the ccwgroup device's driver_data for its
261private data.
262
Linus Torvalds1da177e2005-04-16 15:20:36 -0700263To implement a ccwgroup driver, please refer to include/asm/ccwgroup.h. Keep in
Ursula Braun6f5d09a2010-02-26 22:37:23 +0100264mind that most drivers will need to implement both a ccwgroup and a ccw
265driver.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700266
267
2682. Channel paths
269-----------------
270
271Channel paths show up, like subchannels, under the channel subsystem root (css0)
272and are called 'chp0.<chpid>'. They have no driver and do not belong to any bus.
273Please note, that unlike /proc/chpids in 2.4, the channel path objects reflect
274only the logical state and not the physical state, since we cannot track the
275latter consistently due to lacking machine support (we don't need to be aware
Cornelia Huck373c4912005-11-07 00:59:03 -0800276of it anyway).
Linus Torvalds1da177e2005-04-16 15:20:36 -0700277
Mauro Carvalho Chehab8b4a5032019-06-08 23:27:16 -0300278status
279 - Can be 'online' or 'offline'.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700280 Piping 'on' or 'off' sets the chpid logically online/offline.
281 Piping 'on' to an online chpid triggers path reprobing for all devices
282 the chpid connects to. This can be used to force the kernel to re-use
283 a channel path the user knows to be online, but the machine hasn't
284 created a machine check for.
285
Mauro Carvalho Chehab8b4a5032019-06-08 23:27:16 -0300286type
287 - The physical type of the channel path.
Cornelia Huckdc060102006-03-24 03:15:13 -0800288
Mauro Carvalho Chehab8b4a5032019-06-08 23:27:16 -0300289shared
290 - Whether the channel path is shared.
Cornelia Huck9b10fe52006-10-18 18:30:55 +0200291
Mauro Carvalho Chehab8b4a5032019-06-08 23:27:16 -0300292cmg
293 - The channel measurement group.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700294
2953. System devices
296-----------------
297
Mauro Carvalho Chehab8b4a5032019-06-08 23:27:16 -03002983.1 xpram
Linus Torvalds1da177e2005-04-16 15:20:36 -0700299---------
300
Cornelia Huck373c4912005-11-07 00:59:03 -0800301xpram shows up under devices/system/ as 'xpram'.
302
3033.2 cpus
304--------
305
306For each cpu, a directory is created under devices/system/cpu/. Each cpu has an
307attribute 'online' which can be 0 or 1.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700308
309
3104. Other devices
311----------------
312
3134.1 Netiucv
314-----------
315
316The netiucv driver creates an attribute 'connection' under
Matt LaPlante3f6dee92006-10-03 22:45:33 +0200317bus/iucv/drivers/netiucv. Piping to this attribute creates a new netiucv
Linus Torvalds1da177e2005-04-16 15:20:36 -0700318connection to the specified host.
319
320Netiucv connections show up under devices/iucv/ as "netiucv<ifnum>". The interface
321number is assigned sequentially to the connections defined via the 'connection'
322attribute.
323
Mauro Carvalho Chehab8b4a5032019-06-08 23:27:16 -0300324user
325 - shows the connection partner.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700326
Mauro Carvalho Chehab8b4a5032019-06-08 23:27:16 -0300327buffer
328 - maximum buffer size. Pipe to it to change buffer size.