1
2#ifndef S390_CCWGROUP_H
3#define S390_CCWGROUP_H
4
5struct ccw_device;
6struct ccw_driver;
7
8
9
10
11
12
13
14
15
16
17struct ccwgroup_device {
18 enum {
19 CCWGROUP_OFFLINE,
20 CCWGROUP_ONLINE,
21 } state;
22
23 atomic_t onoff;
24 struct mutex reg_mutex;
25
26 unsigned int count;
27 struct device dev;
28 struct work_struct ungroup_work;
29 struct ccw_device *cdev[0];
30};
31
32
33
34
35
36
37
38
39
40
41
42struct ccwgroup_driver {
43 int (*setup) (struct ccwgroup_device *);
44 void (*remove) (struct ccwgroup_device *);
45 int (*set_online) (struct ccwgroup_device *);
46 int (*set_offline) (struct ccwgroup_device *);
47 void (*shutdown)(struct ccwgroup_device *);
48
49 struct device_driver driver;
50 struct ccw_driver *ccw_driver;
51};
52
53extern int ccwgroup_driver_register (struct ccwgroup_driver *cdriver);
54extern void ccwgroup_driver_unregister (struct ccwgroup_driver *cdriver);
55int ccwgroup_create_dev(struct device *root, struct ccwgroup_driver *gdrv,
56 int num_devices, const char *buf);
57struct ccwgroup_device *get_ccwgroupdev_by_busid(struct ccwgroup_driver *gdrv,
58 char *bus_id);
59
60extern int ccwgroup_set_online(struct ccwgroup_device *gdev);
61extern int ccwgroup_set_offline(struct ccwgroup_device *gdev);
62
63extern int ccwgroup_probe_ccwdev(struct ccw_device *cdev);
64extern void ccwgroup_remove_ccwdev(struct ccw_device *cdev);
65
66#define to_ccwgroupdev(x) container_of((x), struct ccwgroup_device, dev)
67#define to_ccwgroupdrv(x) container_of((x), struct ccwgroup_driver, driver)
68
69#if IS_ENABLED(CONFIG_CCWGROUP)
70bool dev_is_ccwgroup(struct device *dev);
71#else
72static inline bool dev_is_ccwgroup(struct device *dev)
73{
74 return false;
75}
76#endif
77
78#endif
79