lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite for Android: free password hash cracker in your pocket
[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Date:   Mon, 3 Apr 2023 19:59:02 +0200
From:   "Rafael J. Wysocki" <rafael@...nel.org>
To:     Greg Kroah-Hartman <gregkh@...uxfoundation.org>
Cc:     linux-kernel@...r.kernel.org, rafael@...nel.org,
        Jean Delvare <jdelvare@...e.com>,
        Guenter Roeck <linux@...ck-us.net>,
        "David S. Miller" <davem@...emloft.net>,
        Eric Dumazet <edumazet@...gle.com>,
        Jakub Kicinski <kuba@...nel.org>,
        Paolo Abeni <pabeni@...hat.com>,
        Kurt Schwemmer <kurt.schwemmer@...rosemi.com>,
        Logan Gunthorpe <logang@...tatee.com>,
        Jon Mason <jdmason@...zu.us>,
        Dave Jiang <dave.jiang@...el.com>,
        Allen Hubbe <allenbh@...il.com>,
        Dominik Brodowski <linux@...inikbrodowski.net>,
        Matt Porter <mporter@...nel.crashing.org>,
        Alexandre Bounine <alex.bou9@...il.com>,
        "James E.J. Bottomley" <jejb@...ux.ibm.com>,
        "Martin K. Petersen" <martin.petersen@...cle.com>,
        Doug Gilbert <dgilbert@...erlog.com>,
        John Stultz <jstultz@...gle.com>,
        Thomas Gleixner <tglx@...utronix.de>,
        Stephen Boyd <sboyd@...nel.org>,
        Hans de Goede <hdegoede@...hat.com>,
        Andrew Morton <akpm@...ux-foundation.org>,
        Wang Weiyang <wangweiyang2@...wei.com>,
        Yang Yingliang <yangyingliang@...wei.com>,
        Jakob Koschel <jakobkoschel@...il.com>,
        Cai Xinchen <caixinchen1@...wei.com>
Subject: Re: [PATCH 4/5] driver core: class: remove struct class_interface *
 from callbacks

On Sun, Apr 2, 2023 at 7:59 PM Greg Kroah-Hartman
<gregkh@...uxfoundation.org> wrote:
>
> The add_dev and remove_dev callbacks in struct class_interface currently
> pass in a pointer back to the class_interface structure that is calling
> them, but none of the callback implementations actually use this pointer
> as it is pointless (the structure is known, the driver passed it in in
> the first place if it is really needed again.)
>
> So clean this up and just remove the pointer from the callbacks and fix
> up all callback functions.
>
> Cc: Jean Delvare <jdelvare@...e.com>
> Cc: Guenter Roeck <linux@...ck-us.net>
> Cc: "David S. Miller" <davem@...emloft.net>
> Cc: Eric Dumazet <edumazet@...gle.com>
> Cc: Jakub Kicinski <kuba@...nel.org>
> Cc: Paolo Abeni <pabeni@...hat.com>
> Cc: Kurt Schwemmer <kurt.schwemmer@...rosemi.com>
> Cc: Logan Gunthorpe <logang@...tatee.com>
> Cc: Jon Mason <jdmason@...zu.us>
> Cc: Dave Jiang <dave.jiang@...el.com>
> Cc: Allen Hubbe <allenbh@...il.com>
> Cc: Dominik Brodowski <linux@...inikbrodowski.net>
> Cc: Matt Porter <mporter@...nel.crashing.org>
> Cc: Alexandre Bounine <alex.bou9@...il.com>
> Cc: "James E.J. Bottomley" <jejb@...ux.ibm.com>
> Cc: "Martin K. Petersen" <martin.petersen@...cle.com>
> Cc: Doug Gilbert <dgilbert@...erlog.com>
> Cc: John Stultz <jstultz@...gle.com>
> Cc: Thomas Gleixner <tglx@...utronix.de>
> Cc: Stephen Boyd <sboyd@...nel.org>
> Cc: Hans de Goede <hdegoede@...hat.com>
> Cc: Andrew Morton <akpm@...ux-foundation.org>
> Cc: Wang Weiyang <wangweiyang2@...wei.com>
> Cc: Yang Yingliang <yangyingliang@...wei.com>
> Cc: Jakob Koschel <jakobkoschel@...il.com>
> Cc: Cai Xinchen <caixinchen1@...wei.com>
> Cc: "Rafael J. Wysocki" <rafael@...nel.org>
> Signed-off-by: Greg Kroah-Hartman <gregkh@...uxfoundation.org>

Acked-by: Rafael J. Wysocki <rafael@...nel.org>

> ---
> Note, subsystem maintainers, this should go through my driver-core tree
> as it's part of a larger cleanup of 'struct class' handling.  I'm cc:ing
> you all to get reviews to verify I didn't do something foolish, but it
> has passed 0-day bot build testing already (which caught many foolish
> mistakes of mine...)
>
>
>  drivers/base/class.c                     |  4 ++--
>  drivers/base/core.c                      | 10 ++++------
>  drivers/hwmon/drivetemp.c                |  4 ++--
>  drivers/net/rionet.c                     |  3 +--
>  drivers/ntb/hw/mscc/ntb_hw_switchtec.c   |  6 ++----
>  drivers/pcmcia/ds.c                      |  6 ++----
>  drivers/pcmcia/rsrc_nonstatic.c          |  6 ++----
>  drivers/rapidio/devices/rio_mport_cdev.c |  7 ++-----
>  drivers/rapidio/rio_cm.c                 |  8 ++------
>  drivers/scsi/ses.c                       |  6 ++----
>  drivers/scsi/sg.c                        |  8 ++++----
>  include/linux/device/class.h             |  4 ++--
>  kernel/time/alarmtimer.c                 |  3 +--
>  13 files changed, 28 insertions(+), 47 deletions(-)
>
> diff --git a/drivers/base/class.c b/drivers/base/class.c
> index ad8b9f163fd2..ac1808d1a2e8 100644
> --- a/drivers/base/class.c
> +++ b/drivers/base/class.c
> @@ -486,7 +486,7 @@ int class_interface_register(struct class_interface *class_intf)
>         if (class_intf->add_dev) {
>                 class_dev_iter_init(&iter, parent, NULL, NULL);
>                 while ((dev = class_dev_iter_next(&iter)))
> -                       class_intf->add_dev(dev, class_intf);
> +                       class_intf->add_dev(dev);
>                 class_dev_iter_exit(&iter);
>         }
>         mutex_unlock(&sp->mutex);
> @@ -514,7 +514,7 @@ void class_interface_unregister(struct class_interface *class_intf)
>         if (class_intf->remove_dev) {
>                 class_dev_iter_init(&iter, parent, NULL, NULL);
>                 while ((dev = class_dev_iter_next(&iter)))
> -                       class_intf->remove_dev(dev, class_intf);
> +                       class_intf->remove_dev(dev);
>                 class_dev_iter_exit(&iter);
>         }
>         mutex_unlock(&sp->mutex);
> diff --git a/drivers/base/core.c b/drivers/base/core.c
> index 64d188be4df9..7a42d1b6b721 100644
> --- a/drivers/base/core.c
> +++ b/drivers/base/core.c
> @@ -541,8 +541,7 @@ static struct class devlink_class = {
>         .dev_release = devlink_dev_release,
>  };
>
> -static int devlink_add_symlinks(struct device *dev,
> -                               struct class_interface *class_intf)
> +static int devlink_add_symlinks(struct device *dev)
>  {
>         int ret;
>         size_t len;
> @@ -591,8 +590,7 @@ static int devlink_add_symlinks(struct device *dev,
>         return ret;
>  }
>
> -static void devlink_remove_symlinks(struct device *dev,
> -                                  struct class_interface *class_intf)
> +static void devlink_remove_symlinks(struct device *dev)
>  {
>         struct device_link *link = to_devlink(dev);
>         size_t len;
> @@ -3647,7 +3645,7 @@ int device_add(struct device *dev)
>                 /* notify any interfaces that the device is here */
>                 list_for_each_entry(class_intf, &sp->interfaces, node)
>                         if (class_intf->add_dev)
> -                               class_intf->add_dev(dev, class_intf);
> +                               class_intf->add_dev(dev);
>                 mutex_unlock(&sp->mutex);
>                 subsys_put(sp);
>         }
> @@ -3805,7 +3803,7 @@ void device_del(struct device *dev)
>                 /* notify any interfaces that the device is now gone */
>                 list_for_each_entry(class_intf, &sp->interfaces, node)
>                         if (class_intf->remove_dev)
> -                               class_intf->remove_dev(dev, class_intf);
> +                               class_intf->remove_dev(dev);
>                 /* remove the device from the class list */
>                 klist_del(&dev->p->knode_class);
>                 mutex_unlock(&sp->mutex);
> diff --git a/drivers/hwmon/drivetemp.c b/drivers/hwmon/drivetemp.c
> index 8e5759b42390..86171031ddc5 100644
> --- a/drivers/hwmon/drivetemp.c
> +++ b/drivers/hwmon/drivetemp.c
> @@ -550,7 +550,7 @@ static const struct hwmon_chip_info drivetemp_chip_info = {
>   * The device argument points to sdev->sdev_dev. Its parent is
>   * sdev->sdev_gendev, which we can use to get the scsi_device pointer.
>   */
> -static int drivetemp_add(struct device *dev, struct class_interface *intf)
> +static int drivetemp_add(struct device *dev)
>  {
>         struct scsi_device *sdev = to_scsi_device(dev->parent);
>         struct drivetemp_data *st;
> @@ -585,7 +585,7 @@ static int drivetemp_add(struct device *dev, struct class_interface *intf)
>         return err;
>  }
>
> -static void drivetemp_remove(struct device *dev, struct class_interface *intf)
> +static void drivetemp_remove(struct device *dev)
>  {
>         struct drivetemp_data *st, *tmp;
>
> diff --git a/drivers/net/rionet.c b/drivers/net/rionet.c
> index fbcb9d05da64..4eececc94513 100644
> --- a/drivers/net/rionet.c
> +++ b/drivers/net/rionet.c
> @@ -662,8 +662,7 @@ static int rionet_shutdown(struct notifier_block *nb, unsigned long code,
>         return NOTIFY_DONE;
>  }
>
> -static void rionet_remove_mport(struct device *dev,
> -                               struct class_interface *class_intf)
> +static void rionet_remove_mport(struct device *dev)
>  {
>         struct rio_mport *mport = to_rio_mport(dev);
>         struct net_device *ndev;
> diff --git a/drivers/ntb/hw/mscc/ntb_hw_switchtec.c b/drivers/ntb/hw/mscc/ntb_hw_switchtec.c
> index 88ae18b0efa8..d6bbcc7b5b90 100644
> --- a/drivers/ntb/hw/mscc/ntb_hw_switchtec.c
> +++ b/drivers/ntb/hw/mscc/ntb_hw_switchtec.c
> @@ -1470,8 +1470,7 @@ static int switchtec_ntb_reinit_peer(struct switchtec_ntb *sndev)
>         return rc;
>  }
>
> -static int switchtec_ntb_add(struct device *dev,
> -                            struct class_interface *class_intf)
> +static int switchtec_ntb_add(struct device *dev)
>  {
>         struct switchtec_dev *stdev = to_stdev(dev);
>         struct switchtec_ntb *sndev;
> @@ -1541,8 +1540,7 @@ static int switchtec_ntb_add(struct device *dev,
>         return rc;
>  }
>
> -static void switchtec_ntb_remove(struct device *dev,
> -                                struct class_interface *class_intf)
> +static void switchtec_ntb_remove(struct device *dev)
>  {
>         struct switchtec_dev *stdev = to_stdev(dev);
>         struct switchtec_ntb *sndev = stdev->sndev;
> diff --git a/drivers/pcmcia/ds.c b/drivers/pcmcia/ds.c
> index c8087efa5e4a..d500e5dbbc3f 100644
> --- a/drivers/pcmcia/ds.c
> +++ b/drivers/pcmcia/ds.c
> @@ -1335,8 +1335,7 @@ static struct pcmcia_callback pcmcia_bus_callback = {
>         .resume = pcmcia_bus_resume,
>  };
>
> -static int pcmcia_bus_add_socket(struct device *dev,
> -                                          struct class_interface *class_intf)
> +static int pcmcia_bus_add_socket(struct device *dev)
>  {
>         struct pcmcia_socket *socket = dev_get_drvdata(dev);
>         int ret;
> @@ -1369,8 +1368,7 @@ static int pcmcia_bus_add_socket(struct device *dev,
>         return 0;
>  }
>
> -static void pcmcia_bus_remove_socket(struct device *dev,
> -                                    struct class_interface *class_intf)
> +static void pcmcia_bus_remove_socket(struct device *dev)
>  {
>         struct pcmcia_socket *socket = dev_get_drvdata(dev);
>
> diff --git a/drivers/pcmcia/rsrc_nonstatic.c b/drivers/pcmcia/rsrc_nonstatic.c
> index ad1141fddb4c..471e0c5815f3 100644
> --- a/drivers/pcmcia/rsrc_nonstatic.c
> +++ b/drivers/pcmcia/rsrc_nonstatic.c
> @@ -1200,8 +1200,7 @@ static const struct attribute_group rsrc_attributes = {
>         .attrs = pccard_rsrc_attributes,
>  };
>
> -static int pccard_sysfs_add_rsrc(struct device *dev,
> -                                          struct class_interface *class_intf)
> +static int pccard_sysfs_add_rsrc(struct device *dev)
>  {
>         struct pcmcia_socket *s = dev_get_drvdata(dev);
>
> @@ -1210,8 +1209,7 @@ static int pccard_sysfs_add_rsrc(struct device *dev,
>         return sysfs_create_group(&dev->kobj, &rsrc_attributes);
>  }
>
> -static void pccard_sysfs_remove_rsrc(struct device *dev,
> -                                              struct class_interface *class_intf)
> +static void pccard_sysfs_remove_rsrc(struct device *dev)
>  {
>         struct pcmcia_socket *s = dev_get_drvdata(dev);
>
> diff --git a/drivers/rapidio/devices/rio_mport_cdev.c b/drivers/rapidio/devices/rio_mport_cdev.c
> index deb96c3160a7..a115730ebf14 100644
> --- a/drivers/rapidio/devices/rio_mport_cdev.c
> +++ b/drivers/rapidio/devices/rio_mport_cdev.c
> @@ -2536,10 +2536,8 @@ static void mport_cdev_remove(struct mport_dev *md)
>  /*
>   * mport_add_mport() - Add rio_mport from LDM device struct
>   * @dev:               Linux device model struct
> - * @class_intf:        Linux class_interface
>   */
> -static int mport_add_mport(struct device *dev,
> -               struct class_interface *class_intf)
> +static int mport_add_mport(struct device *dev)
>  {
>         struct rio_mport *mport = NULL;
>         struct mport_dev *chdev = NULL;
> @@ -2559,8 +2557,7 @@ static int mport_add_mport(struct device *dev,
>   * mport_remove_mport() - Remove rio_mport from global list
>   * TODO remove device from global mport_dev list
>   */
> -static void mport_remove_mport(struct device *dev,
> -               struct class_interface *class_intf)
> +static void mport_remove_mport(struct device *dev)
>  {
>         struct rio_mport *mport = NULL;
>         struct mport_dev *chdev;
> diff --git a/drivers/rapidio/rio_cm.c b/drivers/rapidio/rio_cm.c
> index acaf9cda014c..49f8d111e546 100644
> --- a/drivers/rapidio/rio_cm.c
> +++ b/drivers/rapidio/rio_cm.c
> @@ -2087,13 +2087,11 @@ static int riocm_cdev_add(dev_t devno)
>  /*
>   * riocm_add_mport - add new local mport device into channel management core
>   * @dev: device object associated with mport
> - * @class_intf: class interface
>   *
>   * When a new mport device is added, CM immediately reserves inbound and
>   * outbound RapidIO mailboxes that will be used.
>   */
> -static int riocm_add_mport(struct device *dev,
> -                          struct class_interface *class_intf)
> +static int riocm_add_mport(struct device *dev)
>  {
>         int rc;
>         int i;
> @@ -2166,14 +2164,12 @@ static int riocm_add_mport(struct device *dev,
>  /*
>   * riocm_remove_mport - remove local mport device from channel management core
>   * @dev: device object associated with mport
> - * @class_intf: class interface
>   *
>   * Removes a local mport device from the list of registered devices that provide
>   * channel management services. Returns an error if the specified mport is not
>   * registered with the CM core.
>   */
> -static void riocm_remove_mport(struct device *dev,
> -                              struct class_interface *class_intf)
> +static void riocm_remove_mport(struct device *dev)
>  {
>         struct rio_mport *mport = to_rio_mport(dev);
>         struct cm_dev *cm;
> diff --git a/drivers/scsi/ses.c b/drivers/scsi/ses.c
> index b11a9162e73a..57feb0cae896 100644
> --- a/drivers/scsi/ses.c
> +++ b/drivers/scsi/ses.c
> @@ -663,8 +663,7 @@ static void ses_match_to_enclosure(struct enclosure_device *edev,
>         }
>  }
>
> -static int ses_intf_add(struct device *cdev,
> -                       struct class_interface *intf)
> +static int ses_intf_add(struct device *cdev)
>  {
>         struct scsi_device *sdev = to_scsi_device(cdev->parent);
>         struct scsi_device *tmp_sdev;
> @@ -869,8 +868,7 @@ static void ses_intf_remove_enclosure(struct scsi_device *sdev)
>         enclosure_unregister(edev);
>  }
>
> -static void ses_intf_remove(struct device *cdev,
> -                           struct class_interface *intf)
> +static void ses_intf_remove(struct device *cdev)
>  {
>         struct scsi_device *sdev = to_scsi_device(cdev->parent);
>
> diff --git a/drivers/scsi/sg.c b/drivers/scsi/sg.c
> index 4997f880d4a4..037f8c98a6d3 100644
> --- a/drivers/scsi/sg.c
> +++ b/drivers/scsi/sg.c
> @@ -96,8 +96,8 @@ static int scatter_elem_sz_prev = SG_SCATTER_SZ;
>
>  #define SG_SECTOR_SZ 512
>
> -static int sg_add_device(struct device *, struct class_interface *);
> -static void sg_remove_device(struct device *, struct class_interface *);
> +static int sg_add_device(struct device *);
> +static void sg_remove_device(struct device *);
>
>  static DEFINE_IDR(sg_index_idr);
>  static DEFINE_RWLOCK(sg_index_lock);   /* Also used to lock
> @@ -1488,7 +1488,7 @@ sg_alloc(struct scsi_device *scsidp)
>  }
>
>  static int
> -sg_add_device(struct device *cl_dev, struct class_interface *cl_intf)
> +sg_add_device(struct device *cl_dev)
>  {
>         struct scsi_device *scsidp = to_scsi_device(cl_dev->parent);
>         Sg_device *sdp = NULL;
> @@ -1578,7 +1578,7 @@ sg_device_destroy(struct kref *kref)
>  }
>
>  static void
> -sg_remove_device(struct device *cl_dev, struct class_interface *cl_intf)
> +sg_remove_device(struct device *cl_dev)
>  {
>         struct scsi_device *scsidp = to_scsi_device(cl_dev->parent);
>         Sg_device *sdp = dev_get_drvdata(cl_dev);
> diff --git a/include/linux/device/class.h b/include/linux/device/class.h
> index 53287aa105b8..9deeaeb457bb 100644
> --- a/include/linux/device/class.h
> +++ b/include/linux/device/class.h
> @@ -219,8 +219,8 @@ struct class_interface {
>         struct list_head        node;
>         const struct class      *class;
>
> -       int (*add_dev)          (struct device *, struct class_interface *);
> -       void (*remove_dev)      (struct device *, struct class_interface *);
> +       int (*add_dev)          (struct device *dev);
> +       void (*remove_dev)      (struct device *dev);
>  };
>
>  int __must_check class_interface_register(struct class_interface *);
> diff --git a/kernel/time/alarmtimer.c b/kernel/time/alarmtimer.c
> index 7e5dff602585..82b28ab0f328 100644
> --- a/kernel/time/alarmtimer.c
> +++ b/kernel/time/alarmtimer.c
> @@ -81,8 +81,7 @@ struct rtc_device *alarmtimer_get_rtcdev(void)
>  }
>  EXPORT_SYMBOL_GPL(alarmtimer_get_rtcdev);
>
> -static int alarmtimer_rtc_add_device(struct device *dev,
> -                               struct class_interface *class_intf)
> +static int alarmtimer_rtc_add_device(struct device *dev)
>  {
>         unsigned long flags;
>         struct rtc_device *rtc = to_rtc_device(dev);
> --
> 2.40.0
>

Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ