1 // SPDX-License-Identifier: GPL-2.0
3 * Recognize and maintain s390 storage class memory.
5 * Copyright IBM Corp. 2012
6 * Author(s): Sebastian Ott <sebott@linux.vnet.ibm.com>
9 #include <linux/device.h>
10 #include <linux/module.h>
11 #include <linux/mutex.h>
12 #include <linux/slab.h>
13 #include <linux/init.h>
14 #include <linux/err.h>
18 static struct device
*scm_root
;
20 #define to_scm_dev(n) container_of(n, struct scm_device, dev)
21 #define to_scm_drv(d) container_of(d, struct scm_driver, drv)
23 static int scmdev_probe(struct device
*dev
)
25 struct scm_device
*scmdev
= to_scm_dev(dev
);
26 struct scm_driver
*scmdrv
= to_scm_drv(dev
->driver
);
28 return scmdrv
->probe
? scmdrv
->probe(scmdev
) : -ENODEV
;
31 static void scmdev_remove(struct device
*dev
)
33 struct scm_device
*scmdev
= to_scm_dev(dev
);
34 struct scm_driver
*scmdrv
= to_scm_drv(dev
->driver
);
37 scmdrv
->remove(scmdev
);
40 static int scmdev_uevent(const struct device
*dev
, struct kobj_uevent_env
*env
)
42 return add_uevent_var(env
, "MODALIAS=scm:scmdev");
45 static const struct bus_type scm_bus_type
= {
47 .probe
= scmdev_probe
,
48 .remove
= scmdev_remove
,
49 .uevent
= scmdev_uevent
,
53 * scm_driver_register() - register a scm driver
54 * @scmdrv: driver to be registered
56 int scm_driver_register(struct scm_driver
*scmdrv
)
58 struct device_driver
*drv
= &scmdrv
->drv
;
60 drv
->bus
= &scm_bus_type
;
62 return driver_register(drv
);
64 EXPORT_SYMBOL_GPL(scm_driver_register
);
67 * scm_driver_unregister() - deregister a scm driver
68 * @scmdrv: driver to be deregistered
70 void scm_driver_unregister(struct scm_driver
*scmdrv
)
72 driver_unregister(&scmdrv
->drv
);
74 EXPORT_SYMBOL_GPL(scm_driver_unregister
);
76 void scm_irq_handler(struct aob
*aob
, blk_status_t error
)
78 struct aob_rq_header
*aobrq
= (void *) aob
->request
.data
;
79 struct scm_device
*scmdev
= aobrq
->scmdev
;
80 struct scm_driver
*scmdrv
= to_scm_drv(scmdev
->dev
.driver
);
82 scmdrv
->handler(scmdev
, aobrq
->data
, error
);
84 EXPORT_SYMBOL_GPL(scm_irq_handler
);
86 #define scm_attr(name) \
87 static ssize_t show_##name(struct device *dev, \
88 struct device_attribute *attr, char *buf) \
90 struct scm_device *scmdev = to_scm_dev(dev); \
94 ret = sysfs_emit(buf, "%u\n", scmdev->attrs.name); \
99 static DEVICE_ATTR(name, S_IRUGO, show_##name, NULL);
101 scm_attr(persistence
);
102 scm_attr(oper_state
);
103 scm_attr(data_state
);
108 static struct attribute
*scmdev_attrs
[] = {
109 &dev_attr_persistence
.attr
,
110 &dev_attr_oper_state
.attr
,
111 &dev_attr_data_state
.attr
,
113 &dev_attr_release
.attr
,
114 &dev_attr_res_id
.attr
,
118 static struct attribute_group scmdev_attr_group
= {
119 .attrs
= scmdev_attrs
,
122 static const struct attribute_group
*scmdev_attr_groups
[] = {
127 static void scmdev_release(struct device
*dev
)
129 struct scm_device
*scmdev
= to_scm_dev(dev
);
134 static void scmdev_setup(struct scm_device
*scmdev
, struct sale
*sale
,
135 unsigned int size
, unsigned int max_blk_count
)
137 dev_set_name(&scmdev
->dev
, "%016llx", (unsigned long long) sale
->sa
);
138 scmdev
->nr_max_block
= max_blk_count
;
139 scmdev
->address
= sale
->sa
;
140 scmdev
->size
= 1UL << size
;
141 scmdev
->attrs
.rank
= sale
->rank
;
142 scmdev
->attrs
.persistence
= sale
->p
;
143 scmdev
->attrs
.oper_state
= sale
->op_state
;
144 scmdev
->attrs
.data_state
= sale
->data_state
;
145 scmdev
->attrs
.rank
= sale
->rank
;
146 scmdev
->attrs
.release
= sale
->r
;
147 scmdev
->attrs
.res_id
= sale
->rid
;
148 scmdev
->dev
.parent
= scm_root
;
149 scmdev
->dev
.bus
= &scm_bus_type
;
150 scmdev
->dev
.release
= scmdev_release
;
151 scmdev
->dev
.groups
= scmdev_attr_groups
;
155 * Check for state-changes, notify the driver and userspace.
157 static void scmdev_update(struct scm_device
*scmdev
, struct sale
*sale
)
159 struct scm_driver
*scmdrv
;
162 device_lock(&scmdev
->dev
);
163 changed
= scmdev
->attrs
.rank
!= sale
->rank
||
164 scmdev
->attrs
.oper_state
!= sale
->op_state
;
165 scmdev
->attrs
.rank
= sale
->rank
;
166 scmdev
->attrs
.oper_state
= sale
->op_state
;
167 if (!scmdev
->dev
.driver
)
169 scmdrv
= to_scm_drv(scmdev
->dev
.driver
);
170 if (changed
&& scmdrv
->notify
)
171 scmdrv
->notify(scmdev
, SCM_CHANGE
);
173 device_unlock(&scmdev
->dev
);
175 kobject_uevent(&scmdev
->dev
.kobj
, KOBJ_CHANGE
);
178 static int check_address(struct device
*dev
, const void *data
)
180 struct scm_device
*scmdev
= to_scm_dev(dev
);
181 const struct sale
*sale
= data
;
183 return scmdev
->address
== sale
->sa
;
186 static struct scm_device
*scmdev_find(struct sale
*sale
)
190 dev
= bus_find_device(&scm_bus_type
, NULL
, sale
, check_address
);
192 return dev
? to_scm_dev(dev
) : NULL
;
195 static int scm_add(struct chsc_scm_info
*scm_info
, size_t num
)
197 struct sale
*sale
, *scmal
= scm_info
->scmal
;
198 struct scm_device
*scmdev
;
201 for (sale
= scmal
; sale
< scmal
+ num
; sale
++) {
202 scmdev
= scmdev_find(sale
);
204 scmdev_update(scmdev
, sale
);
205 /* Release reference from scm_find(). */
206 put_device(&scmdev
->dev
);
209 scmdev
= kzalloc(sizeof(*scmdev
), GFP_KERNEL
);
212 scmdev_setup(scmdev
, sale
, scm_info
->is
, scm_info
->mbc
);
213 ret
= device_register(&scmdev
->dev
);
215 /* Release reference from device_initialize(). */
216 put_device(&scmdev
->dev
);
224 int scm_update_information(void)
226 struct chsc_scm_info
*scm_info
;
231 scm_info
= (void *)__get_free_page(GFP_KERNEL
);
236 ret
= chsc_scm_info(scm_info
, token
);
240 num
= (scm_info
->response
.length
-
241 (offsetof(struct chsc_scm_info
, scmal
) -
242 offsetof(struct chsc_scm_info
, response
))
243 ) / sizeof(struct sale
);
245 ret
= scm_add(scm_info
, num
);
249 token
= scm_info
->restok
;
252 free_page((unsigned long)scm_info
);
257 static int scm_dev_avail(struct device
*dev
, void *unused
)
259 struct scm_driver
*scmdrv
= to_scm_drv(dev
->driver
);
260 struct scm_device
*scmdev
= to_scm_dev(dev
);
262 if (dev
->driver
&& scmdrv
->notify
)
263 scmdrv
->notify(scmdev
, SCM_AVAIL
);
268 int scm_process_availability_information(void)
270 return bus_for_each_dev(&scm_bus_type
, NULL
, NULL
, scm_dev_avail
);
273 static int __init
scm_init(void)
277 ret
= bus_register(&scm_bus_type
);
281 scm_root
= root_device_register("scm");
282 if (IS_ERR(scm_root
)) {
283 bus_unregister(&scm_bus_type
);
284 return PTR_ERR(scm_root
);
287 scm_update_information();
290 subsys_initcall_sync(scm_init
);