Lines Matching refs:devcd
84 struct devcd_entry *devcd = dev_to_devcd(dev); in devcd_dev_release() local
86 devcd->free(devcd->data); in devcd_dev_release()
87 module_put(devcd->owner); in devcd_dev_release()
93 if (devcd->failing_dev->kobj.sd) in devcd_dev_release()
94 sysfs_delete_link(&devcd->failing_dev->kobj, &dev->kobj, in devcd_dev_release()
97 put_device(devcd->failing_dev); in devcd_dev_release()
98 kfree(devcd); in devcd_dev_release()
103 struct devcd_entry *devcd; in devcd_del() local
105 devcd = container_of(wk, struct devcd_entry, del_wk.work); in devcd_del()
107 device_del(&devcd->devcd_dev); in devcd_del()
108 put_device(&devcd->devcd_dev); in devcd_del()
116 struct devcd_entry *devcd = dev_to_devcd(dev); in devcd_data_read() local
118 return devcd->read(buffer, offset, count, devcd->data, devcd->datalen); in devcd_data_read()
126 struct devcd_entry *devcd = dev_to_devcd(dev); in devcd_data_write() local
128 mutex_lock(&devcd->mutex); in devcd_data_write()
129 if (!devcd->delete_work) { in devcd_data_write()
130 devcd->delete_work = true; in devcd_data_write()
131 mod_delayed_work(system_wq, &devcd->del_wk, 0); in devcd_data_write()
133 mutex_unlock(&devcd->mutex); in devcd_data_write()
159 struct devcd_entry *devcd = dev_to_devcd(dev); in devcd_free() local
161 mutex_lock(&devcd->mutex); in devcd_free()
162 if (!devcd->delete_work) in devcd_free()
163 devcd->delete_work = true; in devcd_free()
165 flush_delayed_work(&devcd->del_wk); in devcd_free()
166 mutex_unlock(&devcd->mutex); in devcd_free()
264 struct devcd_entry *devcd = dev_to_devcd(dev); in devcd_match_failing() local
266 return devcd->failing_dev == failing; in devcd_match_failing()
329 struct devcd_entry *devcd; in dev_coredumpm() local
345 devcd = kzalloc(sizeof(*devcd), gfp); in dev_coredumpm()
346 if (!devcd) in dev_coredumpm()
349 devcd->owner = owner; in dev_coredumpm()
350 devcd->data = data; in dev_coredumpm()
351 devcd->datalen = datalen; in dev_coredumpm()
352 devcd->read = read; in dev_coredumpm()
353 devcd->free = free; in dev_coredumpm()
354 devcd->failing_dev = get_device(dev); in dev_coredumpm()
355 devcd->delete_work = false; in dev_coredumpm()
357 mutex_init(&devcd->mutex); in dev_coredumpm()
358 device_initialize(&devcd->devcd_dev); in dev_coredumpm()
360 dev_set_name(&devcd->devcd_dev, "devcd%d", in dev_coredumpm()
362 devcd->devcd_dev.class = &devcd_class; in dev_coredumpm()
364 mutex_lock(&devcd->mutex); in dev_coredumpm()
365 if (device_add(&devcd->devcd_dev)) in dev_coredumpm()
373 if (sysfs_create_link(&devcd->devcd_dev.kobj, &dev->kobj, in dev_coredumpm()
375 sysfs_create_link(&dev->kobj, &devcd->devcd_dev.kobj, in dev_coredumpm()
379 INIT_DELAYED_WORK(&devcd->del_wk, devcd_del); in dev_coredumpm()
380 schedule_delayed_work(&devcd->del_wk, DEVCD_TIMEOUT); in dev_coredumpm()
381 mutex_unlock(&devcd->mutex); in dev_coredumpm()
384 put_device(&devcd->devcd_dev); in dev_coredumpm()
385 mutex_unlock(&devcd->mutex); in dev_coredumpm()