Commit 7005b754 authored by Julian Wiedmann's avatar Julian Wiedmann Committed by David S. Miller

s390/qeth: return error when starting a reset fails

When starting the reset worker via sysfs is unsuccessful, return an
error to the user.
Modernize the sysfs input parsing while at it.
Signed-off-by: default avatarJulian Wiedmann <jwi@linux.ibm.com>
Reviewed-by: default avatarAlexandra Winter <wintera@linux.ibm.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 6ee091ef
...@@ -1053,7 +1053,7 @@ struct qeth_cmd_buffer *qeth_get_diag_cmd(struct qeth_card *card, ...@@ -1053,7 +1053,7 @@ struct qeth_cmd_buffer *qeth_get_diag_cmd(struct qeth_card *card,
void qeth_notify_cmd(struct qeth_cmd_buffer *iob, int reason); void qeth_notify_cmd(struct qeth_cmd_buffer *iob, int reason);
void qeth_put_cmd(struct qeth_cmd_buffer *iob); void qeth_put_cmd(struct qeth_cmd_buffer *iob);
void qeth_schedule_recovery(struct qeth_card *); int qeth_schedule_recovery(struct qeth_card *card);
void qeth_flush_local_addrs(struct qeth_card *card); void qeth_flush_local_addrs(struct qeth_card *card);
int qeth_poll(struct napi_struct *napi, int budget); int qeth_poll(struct napi_struct *napi, int budget);
void qeth_clear_ipacmd_list(struct qeth_card *); void qeth_clear_ipacmd_list(struct qeth_card *);
......
...@@ -1131,16 +1131,18 @@ static int qeth_set_thread_start_bit(struct qeth_card *card, ...@@ -1131,16 +1131,18 @@ static int qeth_set_thread_start_bit(struct qeth_card *card,
unsigned long thread) unsigned long thread)
{ {
unsigned long flags; unsigned long flags;
int rc = 0;
spin_lock_irqsave(&card->thread_mask_lock, flags); spin_lock_irqsave(&card->thread_mask_lock, flags);
if (!(card->thread_allowed_mask & thread) || if (!(card->thread_allowed_mask & thread))
(card->thread_start_mask & thread)) { rc = -EPERM;
spin_unlock_irqrestore(&card->thread_mask_lock, flags); else if (card->thread_start_mask & thread)
return -EPERM; rc = -EBUSY;
} else
card->thread_start_mask |= thread; card->thread_start_mask |= thread;
spin_unlock_irqrestore(&card->thread_mask_lock, flags); spin_unlock_irqrestore(&card->thread_mask_lock, flags);
return 0;
return rc;
} }
static void qeth_clear_thread_start_bit(struct qeth_card *card, static void qeth_clear_thread_start_bit(struct qeth_card *card,
...@@ -1193,11 +1195,17 @@ static int qeth_do_run_thread(struct qeth_card *card, unsigned long thread) ...@@ -1193,11 +1195,17 @@ static int qeth_do_run_thread(struct qeth_card *card, unsigned long thread)
return rc; return rc;
} }
void qeth_schedule_recovery(struct qeth_card *card) int qeth_schedule_recovery(struct qeth_card *card)
{ {
int rc;
QETH_CARD_TEXT(card, 2, "startrec"); QETH_CARD_TEXT(card, 2, "startrec");
if (qeth_set_thread_start_bit(card, QETH_RECOVER_THREAD) == 0)
rc = qeth_set_thread_start_bit(card, QETH_RECOVER_THREAD);
if (!rc)
schedule_work(&card->kernel_thread_starter); schedule_work(&card->kernel_thread_starter);
return rc;
} }
static int qeth_get_problem(struct qeth_card *card, struct ccw_device *cdev, static int qeth_get_problem(struct qeth_card *card, struct ccw_device *cdev,
......
...@@ -275,17 +275,20 @@ static ssize_t qeth_dev_recover_store(struct device *dev, ...@@ -275,17 +275,20 @@ static ssize_t qeth_dev_recover_store(struct device *dev,
struct device_attribute *attr, const char *buf, size_t count) struct device_attribute *attr, const char *buf, size_t count)
{ {
struct qeth_card *card = dev_get_drvdata(dev); struct qeth_card *card = dev_get_drvdata(dev);
char *tmp; bool reset;
int i; int rc;
rc = kstrtobool(buf, &reset);
if (rc)
return rc;
if (!qeth_card_hw_is_reachable(card)) if (!qeth_card_hw_is_reachable(card))
return -EPERM; return -EPERM;
i = simple_strtoul(buf, &tmp, 16); if (reset)
if (i == 1) rc = qeth_schedule_recovery(card);
qeth_schedule_recovery(card);
return count; return rc ? rc : count;
} }
static DEVICE_ATTR(recover, 0200, NULL, qeth_dev_recover_store); static DEVICE_ATTR(recover, 0200, NULL, qeth_dev_recover_store);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment