mirror of
https://github.com/torvalds/linux.git
synced 2026-01-24 23:16:46 +00:00
Input: ibm-panel - use guard notation when acquiring spinlock
Using guard notation makes the code more compact and error handling more robust by ensuring that locks are released in all code paths when control leaves critical section. Reviewed-by: Eddie James <eajames@linux.ibm.com> Reviewed-by: Javier Carrasco <javier.carrasco.cruz@gmail.com> Link: https://lore.kernel.org/r/20240904044735.1047285-1-dmitry.torokhov@gmail.com Signed-off-by: Dmitry Torokhov <dmitry.torokhov@gmail.com>
This commit is contained in:
@@ -77,12 +77,11 @@ static void ibm_panel_process_command(struct ibm_panel *panel)
|
||||
static int ibm_panel_i2c_slave_cb(struct i2c_client *client,
|
||||
enum i2c_slave_event event, u8 *val)
|
||||
{
|
||||
unsigned long flags;
|
||||
struct ibm_panel *panel = i2c_get_clientdata(client);
|
||||
|
||||
dev_dbg(&panel->input->dev, "event: %u data: %02x\n", event, *val);
|
||||
|
||||
spin_lock_irqsave(&panel->lock, flags);
|
||||
guard(spinlock_irqsave)(&panel->lock);
|
||||
|
||||
switch (event) {
|
||||
case I2C_SLAVE_STOP:
|
||||
@@ -114,8 +113,6 @@ static int ibm_panel_i2c_slave_cb(struct i2c_client *client,
|
||||
break;
|
||||
}
|
||||
|
||||
spin_unlock_irqrestore(&panel->lock, flags);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user