* [PATCH v4 2/4] usb: gadget: hid: Convert to use list_count()
2022-11-23 14:48 [PATCH v4 1/4] i915: Move list_count() to list.h for broader use Andy Shevchenko
@ 2022-11-23 14:48 ` Andy Shevchenko
2022-11-23 14:49 ` [PATCH v4 3/4] usb: gadget: udc: bcm63xx: " Andy Shevchenko
` (2 subsequent siblings)
3 siblings, 0 replies; 5+ messages in thread
From: Andy Shevchenko @ 2022-11-23 14:48 UTC (permalink / raw)
To: Jakob Koschel, Andy Shevchenko, Greg Kroah-Hartman, Mathias Nyman,
intel-gfx, dri-devel, linux-kernel, linux-usb
Cc: Jani Nikula, Joonas Lahtinen, Rodrigo Vivi, Tvrtko Ursulin,
David Airlie, Daniel Vetter, Kevin Cernekee, Mathias Nyman,
Hans de Goede
The list API now provides the list_count() to help with counting
existing nodes in the list. Utilise it.
Signed-off-by: Andy Shevchenko <andriy.shevchenko@linux.intel.com>
---
v4: no change
v3: fixed typo in the commit message (Fabio)
v2: no change
drivers/usb/gadget/legacy/hid.c | 7 ++-----
1 file changed, 2 insertions(+), 5 deletions(-)
diff --git a/drivers/usb/gadget/legacy/hid.c b/drivers/usb/gadget/legacy/hid.c
index 1187ee4f316a..6196c3456e0b 100644
--- a/drivers/usb/gadget/legacy/hid.c
+++ b/drivers/usb/gadget/legacy/hid.c
@@ -133,14 +133,11 @@ static struct usb_configuration config_driver = {
static int hid_bind(struct usb_composite_dev *cdev)
{
struct usb_gadget *gadget = cdev->gadget;
- struct list_head *tmp;
struct hidg_func_node *n = NULL, *m, *iter_n;
struct f_hid_opts *hid_opts;
- int status, funcs = 0;
-
- list_for_each(tmp, &hidg_func_list)
- funcs++;
+ int status, funcs;
+ funcs = list_count(&hidg_func_list);
if (!funcs)
return -ENODEV;
--
2.35.1
^ permalink raw reply related [flat|nested] 5+ messages in thread* [PATCH v4 3/4] usb: gadget: udc: bcm63xx: Convert to use list_count()
2022-11-23 14:48 [PATCH v4 1/4] i915: Move list_count() to list.h for broader use Andy Shevchenko
2022-11-23 14:48 ` [PATCH v4 2/4] usb: gadget: hid: Convert to use list_count() Andy Shevchenko
@ 2022-11-23 14:49 ` Andy Shevchenko
2022-11-23 14:49 ` [PATCH v4 4/4] xhci: " Andy Shevchenko
2022-11-23 15:06 ` [PATCH v4 1/4] i915: Move list_count() to list.h for broader use Lucas De Marchi
3 siblings, 0 replies; 5+ messages in thread
From: Andy Shevchenko @ 2022-11-23 14:49 UTC (permalink / raw)
To: Jakob Koschel, Andy Shevchenko, Greg Kroah-Hartman, Mathias Nyman,
intel-gfx, dri-devel, linux-kernel, linux-usb
Cc: Jani Nikula, Joonas Lahtinen, Rodrigo Vivi, Tvrtko Ursulin,
David Airlie, Daniel Vetter, Kevin Cernekee, Mathias Nyman,
Hans de Goede
The list API now provides the list_count() to help with counting
existing nodes in the list. Utilise it.
Signed-off-by: Andy Shevchenko <andriy.shevchenko@linux.intel.com>
---
v4: no change
v3: no change
v2: no change
drivers/usb/gadget/udc/bcm63xx_udc.c | 11 +++--------
1 file changed, 3 insertions(+), 8 deletions(-)
diff --git a/drivers/usb/gadget/udc/bcm63xx_udc.c b/drivers/usb/gadget/udc/bcm63xx_udc.c
index 2cdb07905bde..0762e49e85f8 100644
--- a/drivers/usb/gadget/udc/bcm63xx_udc.c
+++ b/drivers/usb/gadget/udc/bcm63xx_udc.c
@@ -2172,7 +2172,6 @@ static int bcm63xx_iudma_dbg_show(struct seq_file *s, void *p)
for (ch_idx = 0; ch_idx < BCM63XX_NUM_IUDMA; ch_idx++) {
struct iudma_ch *iudma = &udc->iudma[ch_idx];
- struct list_head *pos;
seq_printf(s, "IUDMA channel %d -- ", ch_idx);
switch (iudma_defaults[ch_idx].ep_type) {
@@ -2205,14 +2204,10 @@ static int bcm63xx_iudma_dbg_show(struct seq_file *s, void *p)
seq_printf(s, " desc: %d/%d used", iudma->n_bds_used,
iudma->n_bds);
- if (iudma->bep) {
- i = 0;
- list_for_each(pos, &iudma->bep->queue)
- i++;
- seq_printf(s, "; %d queued\n", i);
- } else {
+ if (iudma->bep)
+ seq_printf(s, "; %zu queued\n", list_count(&iudma->bep->queue));
+ else
seq_printf(s, "\n");
- }
for (i = 0; i < iudma->n_bds; i++) {
struct bcm_enet_desc *d = &iudma->bd_ring[i];
--
2.35.1
^ permalink raw reply related [flat|nested] 5+ messages in thread* [PATCH v4 4/4] xhci: Convert to use list_count()
2022-11-23 14:48 [PATCH v4 1/4] i915: Move list_count() to list.h for broader use Andy Shevchenko
2022-11-23 14:48 ` [PATCH v4 2/4] usb: gadget: hid: Convert to use list_count() Andy Shevchenko
2022-11-23 14:49 ` [PATCH v4 3/4] usb: gadget: udc: bcm63xx: " Andy Shevchenko
@ 2022-11-23 14:49 ` Andy Shevchenko
2022-11-23 15:06 ` [PATCH v4 1/4] i915: Move list_count() to list.h for broader use Lucas De Marchi
3 siblings, 0 replies; 5+ messages in thread
From: Andy Shevchenko @ 2022-11-23 14:49 UTC (permalink / raw)
To: Jakob Koschel, Andy Shevchenko, Greg Kroah-Hartman, Mathias Nyman,
intel-gfx, dri-devel, linux-kernel, linux-usb
Cc: Jani Nikula, Joonas Lahtinen, Rodrigo Vivi, Tvrtko Ursulin,
David Airlie, Daniel Vetter, Kevin Cernekee, Mathias Nyman,
Hans de Goede
The list API now provides the list_count() to help with counting
existing nodes in the list. Utilise it.
Signed-off-by: Andy Shevchenko <andriy.shevchenko@linux.intel.com>
Acked-by: Mathias Nyman <mathias.nyman@linux.intel.com>
---
v4: added tag (Mathias)
v3: no change
v2: no change
drivers/usb/host/xhci-ring.c | 7 ++-----
1 file changed, 2 insertions(+), 5 deletions(-)
diff --git a/drivers/usb/host/xhci-ring.c b/drivers/usb/host/xhci-ring.c
index ad81e9a508b1..817c31e3b0c8 100644
--- a/drivers/usb/host/xhci-ring.c
+++ b/drivers/usb/host/xhci-ring.c
@@ -2532,7 +2532,6 @@ static int handle_tx_event(struct xhci_hcd *xhci,
union xhci_trb *ep_trb;
int status = -EINPROGRESS;
struct xhci_ep_ctx *ep_ctx;
- struct list_head *tmp;
u32 trb_comp_code;
int td_num = 0;
bool handling_skipped_tds = false;
@@ -2580,10 +2579,8 @@ static int handle_tx_event(struct xhci_hcd *xhci,
}
/* Count current td numbers if ep->skip is set */
- if (ep->skip) {
- list_for_each(tmp, &ep_ring->td_list)
- td_num++;
- }
+ if (ep->skip)
+ td_num += list_count(&ep_ring->td_list);
/* Look for common error cases */
switch (trb_comp_code) {
--
2.35.1
^ permalink raw reply related [flat|nested] 5+ messages in thread* Re: [PATCH v4 1/4] i915: Move list_count() to list.h for broader use
2022-11-23 14:48 [PATCH v4 1/4] i915: Move list_count() to list.h for broader use Andy Shevchenko
` (2 preceding siblings ...)
2022-11-23 14:49 ` [PATCH v4 4/4] xhci: " Andy Shevchenko
@ 2022-11-23 15:06 ` Lucas De Marchi
3 siblings, 0 replies; 5+ messages in thread
From: Lucas De Marchi @ 2022-11-23 15:06 UTC (permalink / raw)
To: Andy Shevchenko
Cc: Jakob Koschel, Greg Kroah-Hartman, Mathias Nyman, intel-gfx,
dri-devel, linux-kernel, linux-usb, Tvrtko Ursulin,
Kevin Cernekee, Mathias Nyman, Jani Nikula, Hans de Goede,
Rodrigo Vivi
On Wed, Nov 23, 2022 at 04:48:58PM +0200, Andy Shevchenko wrote:
>Some of the existing users, and definitely will be new ones, want to
>count existing nodes in the list. Provide a generic API for that by
>moving code from i915 to list.h.
>
>Signed-off-by: Andy Shevchenko <andriy.shevchenko@linux.intel.com>
>Acked-by: Jani Nikula <jani.nikula@intel.com>
Reviewed-by: Lucas De Marchi <lucas.demarchi@intel.com>
thanks
Lucas De Marchi
>---
>v4: fixed prototype when converting to static inline
>v3: added tag (Jani), changed to be static inline (Mike)
>v2: dropped the duplicate code in i915 (LKP)
> drivers/gpu/drm/i915/gt/intel_engine_cs.c | 13 +------------
> include/linux/list.h | 15 +++++++++++++++
> 2 files changed, 16 insertions(+), 12 deletions(-)
>
>diff --git a/drivers/gpu/drm/i915/gt/intel_engine_cs.c b/drivers/gpu/drm/i915/gt/intel_engine_cs.c
>index c33e0d72d670..b96c8217743c 100644
>--- a/drivers/gpu/drm/i915/gt/intel_engine_cs.c
>+++ b/drivers/gpu/drm/i915/gt/intel_engine_cs.c
>@@ -2094,17 +2094,6 @@ static void print_request_ring(struct drm_printer *m, struct i915_request *rq)
> }
> }
>
>-static unsigned long list_count(struct list_head *list)
>-{
>- struct list_head *pos;
>- unsigned long count = 0;
>-
>- list_for_each(pos, list)
>- count++;
>-
>- return count;
>-}
>-
> static unsigned long read_ul(void *p, size_t x)
> {
> return *(unsigned long *)(p + x);
>@@ -2279,7 +2268,7 @@ void intel_engine_dump(struct intel_engine_cs *engine,
> spin_lock_irqsave(&engine->sched_engine->lock, flags);
> engine_dump_active_requests(engine, m);
>
>- drm_printf(m, "\tOn hold?: %lu\n",
>+ drm_printf(m, "\tOn hold?: %zu\n",
> list_count(&engine->sched_engine->hold));
> spin_unlock_irqrestore(&engine->sched_engine->lock, flags);
>
>diff --git a/include/linux/list.h b/include/linux/list.h
>index 61762054b4be..632a298c7018 100644
>--- a/include/linux/list.h
>+++ b/include/linux/list.h
>@@ -655,6 +655,21 @@ static inline void list_splice_tail_init(struct list_head *list,
> !list_is_head(pos, (head)); \
> pos = n, n = pos->prev)
>
>+/**
>+ * list_count - count nodes in the list
>+ * @head: the head for your list.
>+ */
>+static inline size_t list_count(struct list_head *head)
>+{
>+ struct list_head *pos;
>+ size_t count = 0;
>+
>+ list_for_each(pos, head)
>+ count++;
>+
>+ return count;
>+}
>+
> /**
> * list_entry_is_head - test if the entry points to the head of the list
> * @pos: the type * to cursor
>--
>2.35.1
>
^ permalink raw reply [flat|nested] 5+ messages in thread