i2c: core: Allocate temp client on the stack in i2c_detect
authorHeiner Kallweit <hkallweit1@gmail.com>
Tue, 7 Jan 2025 20:24:29 +0000 (21:24 +0100)
committerWolfram Sang <wsa+renesas@sang-engineering.com>
Thu, 9 Jan 2025 10:23:27 +0000 (11:23 +0100)
The temp client is used only in scope of this function, so there's no
benefit in dynamic allocation.

Signed-off-by: Heiner Kallweit <hkallweit1@gmail.com>
Signed-off-by: Wolfram Sang <wsa+renesas@sang-engineering.com>
drivers/i2c/i2c-core-base.c

index bd90a6084fc0d632794ce8233304b3fb7dfc0452..b072030a9105ad5c4a299b0422ec716eea6165ca 100644 (file)
@@ -2461,7 +2461,7 @@ static int i2c_detect_address(struct i2c_client *temp_client,
 static int i2c_detect(struct i2c_adapter *adapter, struct i2c_driver *driver)
 {
        const unsigned short *address_list;
-       struct i2c_client *temp_client;
+       struct i2c_client temp_client;
        int i, err = 0;
 
        address_list = driver->address_list;
@@ -2482,22 +2482,19 @@ static int i2c_detect(struct i2c_adapter *adapter, struct i2c_driver *driver)
                return 0;
 
        /* Set up a temporary client to help detect callback */
-       temp_client = kzalloc(sizeof(struct i2c_client), GFP_KERNEL);
-       if (!temp_client)
-               return -ENOMEM;
-       temp_client->adapter = adapter;
+       memset(&temp_client, 0, sizeof(temp_client));
+       temp_client.adapter = adapter;
 
        for (i = 0; address_list[i] != I2C_CLIENT_END; i += 1) {
                dev_dbg(&adapter->dev,
                        "found normal entry for adapter %d, addr 0x%02x\n",
                        i2c_adapter_id(adapter), address_list[i]);
-               temp_client->addr = address_list[i];
-               err = i2c_detect_address(temp_client, driver);
+               temp_client.addr = address_list[i];
+               err = i2c_detect_address(&temp_client, driver);
                if (unlikely(err))
                        break;
        }
 
-       kfree(temp_client);
        return err;
 }