On Mon, Feb 06, 2023 at 11:13:38PM +0900, Tetsuo Handa wrote: > On 2023/02/05 10:23, Alan Stern wrote: > > I suppose we could create separate lockdep classes for every bus_type > > and device_type combination, as well as for the different sorts of > > devices -- treat things like class devices separately from normal > > devices, and so on. But even then there would be trouble. > > Sorry, since I'm not familiar with devices, I can't interpret what you > are talking about in this response. But why don't you try test5() approach > in an example module shown below (i.e. treat all dev->mutex instances > independent to each other) ? > > Sharing mutex_init() (like test2() approach) causes false positives, > but allocating a key on each dev->mutex (like test5() approach) should > avoid false positives. Interesting idea. I'm doubtful that it will accomplish all that you want. After all, one of lockdep's biggest advantages is that it can detect the potential for deadlocks without a deadlock actually occurring. By putting each mutex into its own class, you lose much of this ability. But who knows? Maybe it will be a big help. Anyway, below is a patch you can try, based on the code for your test5. Let me know what happens. Alan Stern Index: usb-devel/drivers/base/core.c =================================================================== --- usb-devel.orig/drivers/base/core.c +++ usb-devel/drivers/base/core.c @@ -2322,6 +2322,8 @@ static void device_release(struct kobjec devres_release_all(dev); kfree(dev->dma_range_map); + mutex_destroy(&dev->mutex); + lockdep_unregister_key(&dev->mutex_key); if (dev->release) dev->release(dev); @@ -2941,7 +2943,8 @@ void device_initialize(struct device *de kobject_init(&dev->kobj, &device_ktype); INIT_LIST_HEAD(&dev->dma_pools); mutex_init(&dev->mutex); - lockdep_set_novalidate_class(&dev->mutex); + lockdep_register_key(&dev->mutex_key); + lockdep_set_class(&dev->mutex, &dev->mutex_key); spin_lock_init(&dev->devres_lock); INIT_LIST_HEAD(&dev->devres_head); device_pm_init(dev); Index: usb-devel/include/linux/device.h =================================================================== --- usb-devel.orig/include/linux/device.h +++ usb-devel/include/linux/device.h @@ -570,6 +570,7 @@ struct device { struct mutex mutex; /* mutex to synchronize calls to * its driver. */ + struct lock_class_key mutex_key; /* Unique key for each device */ struct dev_links_info links; struct dev_pm_info power;