Use a flexible array member to combine kzalloc and kcalloc in one
allocation so they can be freed together.

Add __counted_by for extra runtime analysis. Move counting variable
assignment right after allocation as done by kzalloc_flex with GCC >=
15.

Signed-off-by: Rosen Penev <[email protected]>
---
 drivers/clk/mvebu/common.c | 19 ++++++++-----------
 1 file changed, 8 insertions(+), 11 deletions(-)

diff --git a/drivers/clk/mvebu/common.c b/drivers/clk/mvebu/common.c
index 28f2e1b2a932..4129690fcae0 100644
--- a/drivers/clk/mvebu/common.c
+++ b/drivers/clk/mvebu/common.c
@@ -189,10 +189,10 @@ DEFINE_SPINLOCK(ctrl_gating_lock);
 
 struct clk_gating_ctrl {
        spinlock_t *lock;
-       struct clk **gates;
        int num_gates;
        void __iomem *base;
        u32 saved_reg;
+       struct clk *gates[] __counted_by(num_gates);
 };
 
 static struct clk_gating_ctrl *ctrl;
@@ -257,24 +257,21 @@ void __init mvebu_clk_gating_setup(struct device_node *np,
                clk_put(clk);
        }
 
-       ctrl = kzalloc_obj(*ctrl);
+       /* Count, allocate, and register clock gates */
+       for (n = 0; desc[n].name;)
+               n++;
+
+       ctrl = kzalloc_flex(*ctrl, gates, n);
        if (WARN_ON(!ctrl))
                goto ctrl_out;
 
+       ctrl->num_gates = n;
+
        /* lock must already be initialized */
        ctrl->lock = &ctrl_gating_lock;
 
        ctrl->base = base;
 
-       /* Count, allocate, and register clock gates */
-       for (n = 0; desc[n].name;)
-               n++;
-
-       ctrl->num_gates = n;
-       ctrl->gates = kzalloc_objs(*ctrl->gates, ctrl->num_gates);
-       if (WARN_ON(!ctrl->gates))
-               goto gates_out;
-
        for (n = 0; n < ctrl->num_gates; n++) {
                const char *parent =
                        (desc[n].parent) ? desc[n].parent : default_parent;
-- 
2.53.0


Reply via email to