Skip to content

Commit 6adb8ef

Browse files
Tomas Winklergregkh
authored andcommitted
mei: limit the number of consecutive resets
give up reseting after 3 unsuccessful tries Signed-off-by: Tomas Winkler <tomas.winkler@intel.com> Signed-off-by: Alexander Usyskin <alexander.usyskin@intel.com> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
1 parent 33ec082 commit 6adb8ef

File tree

3 files changed

+18
-0
lines changed

3 files changed

+18
-0
lines changed

drivers/misc/mei/client.c

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -370,6 +370,7 @@ void mei_host_client_init(struct work_struct *work)
370370
}
371371

372372
dev->dev_state = MEI_DEV_ENABLED;
373+
dev->reset_count = 0;
373374

374375
mutex_unlock(&dev->device_lock);
375376
}

drivers/misc/mei/init.c

Lines changed: 10 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -89,6 +89,13 @@ int mei_reset(struct mei_device *dev)
8989
interrupts_enabled = state != MEI_DEV_POWER_DOWN;
9090
dev->dev_state = MEI_DEV_RESETTING;
9191

92+
dev->reset_count++;
93+
if (dev->reset_count > MEI_MAX_CONSEC_RESET) {
94+
dev_err(&dev->pdev->dev, "reset: reached maximal consecutive resets: disabling the device\n");
95+
dev->dev_state = MEI_DEV_DISABLED;
96+
return -ENODEV;
97+
}
98+
9299
ret = mei_hw_reset(dev, interrupts_enabled);
93100
/* fall through and remove the sw state even if hw reset has failed */
94101

@@ -169,6 +176,7 @@ int mei_start(struct mei_device *dev)
169176
dev_dbg(&dev->pdev->dev, "reset in start the mei device.\n");
170177

171178
dev->dev_state = MEI_DEV_INITIALIZING;
179+
dev->reset_count = 0;
172180
mei_reset(dev);
173181

174182
if (dev->dev_state == MEI_DEV_DISABLED) {
@@ -224,6 +232,7 @@ int mei_restart(struct mei_device *dev)
224232
mei_clear_interrupts(dev);
225233

226234
dev->dev_state = MEI_DEV_POWER_UP;
235+
dev->reset_count = 0;
227236

228237
err = mei_reset(dev);
229238

@@ -285,6 +294,7 @@ void mei_device_init(struct mei_device *dev)
285294
init_waitqueue_head(&dev->wait_recvd_msg);
286295
init_waitqueue_head(&dev->wait_stop_wd);
287296
dev->dev_state = MEI_DEV_INITIALIZING;
297+
dev->reset_count = 0;
288298

289299
mei_io_list_init(&dev->read_list);
290300
mei_io_list_init(&dev->write_list);

drivers/misc/mei/mei_dev.h

Lines changed: 7 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -60,6 +60,11 @@ extern const uuid_le mei_wd_guid;
6060
*/
6161
#define MEI_CLIENTS_MAX 256
6262

63+
/*
64+
* maximum number of consecutive resets
65+
*/
66+
#define MEI_MAX_CONSEC_RESET 3
67+
6368
/*
6469
* Number of File descriptors/handles
6570
* that can be opened to the driver.
@@ -327,6 +332,7 @@ struct mei_cl_device {
327332
/**
328333
* struct mei_device - MEI private device struct
329334
335+
* @reset_count - limits the number of consecutive resets
330336
* @hbm_state - state of host bus message protocol
331337
* @mem_addr - mem mapped base register address
332338
@@ -370,6 +376,7 @@ struct mei_device {
370376
/*
371377
* mei device states
372378
*/
379+
unsigned long reset_count;
373380
enum mei_dev_state dev_state;
374381
enum mei_hbm_state hbm_state;
375382
u16 init_clients_timer;

0 commit comments

Comments
 (0)