Skip to content

Commit 0f7aedb

Browse files
julianwiedmanndavem330
authored andcommitted
s390/qeth: drop redundant state checking
Now that qeth always uses dev_close() to shutdown the interface, we can trust the locking and remove some custom state checks. qeth_l?_stop_card() is no longer called for a card in UP state, so remove the checks there too. This basically makes the UP state obsolete, so rip out the whole thing (except for the sysfs-visible string). Signed-off-by: Julian Wiedmann <[email protected]> Signed-off-by: David S. Miller <[email protected]>
1 parent 62ca98d commit 0f7aedb

File tree

5 files changed

+13
-43
lines changed

5 files changed

+13
-43
lines changed

drivers/s390/net/qeth_core.h

Lines changed: 5 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -483,7 +483,6 @@ struct qeth_out_q_stats {
483483
u64 tx_bytes;
484484
u64 tx_errors;
485485
u64 tx_dropped;
486-
u64 tx_carrier_errors;
487486
};
488487

489488
struct qeth_qdio_out_q {
@@ -552,7 +551,6 @@ enum qeth_card_states {
552551
CARD_STATE_DOWN,
553552
CARD_STATE_HARDSETUP,
554553
CARD_STATE_SOFTSETUP,
555-
CARD_STATE_UP,
556554
};
557555

558556
/**
@@ -808,6 +806,11 @@ struct qeth_card {
808806
struct work_struct close_dev_work;
809807
};
810808

809+
static inline bool qeth_card_hw_is_reachable(struct qeth_card *card)
810+
{
811+
return card->state == CARD_STATE_SOFTSETUP;
812+
}
813+
811814
struct qeth_trap_id {
812815
__u16 lparnr;
813816
char vmname[8];
@@ -942,7 +945,6 @@ extern const struct attribute_group qeth_device_attr_group;
942945
extern const struct attribute_group qeth_device_blkt_group;
943946
extern const struct device_type qeth_generic_devtype;
944947

945-
int qeth_card_hw_is_reachable(struct qeth_card *);
946948
const char *qeth_get_cardname_short(struct qeth_card *);
947949
int qeth_realloc_buffer_pool(struct qeth_card *, int);
948950
int qeth_core_load_discipline(struct qeth_card *, enum qeth_discipline_id);

drivers/s390/net/qeth_core_main.c

Lines changed: 1 addition & 17 deletions
Original file line numberDiff line numberDiff line change
@@ -74,13 +74,6 @@ static void qeth_notify_skbs(struct qeth_qdio_out_q *queue,
7474
static void qeth_release_skbs(struct qeth_qdio_out_buffer *buf);
7575
static int qeth_init_qdio_out_buf(struct qeth_qdio_out_q *, int);
7676

77-
int qeth_card_hw_is_reachable(struct qeth_card *card)
78-
{
79-
return (card->state == CARD_STATE_SOFTSETUP) ||
80-
(card->state == CARD_STATE_UP);
81-
}
82-
EXPORT_SYMBOL_GPL(qeth_card_hw_is_reachable);
83-
8477
static void qeth_close_dev_handler(struct work_struct *work)
8578
{
8679
struct qeth_card *card;
@@ -6206,7 +6199,6 @@ void qeth_get_stats64(struct net_device *dev, struct rtnl_link_stats64 *stats)
62066199
stats->tx_bytes += queue->stats.tx_bytes;
62076200
stats->tx_errors += queue->stats.tx_errors;
62086201
stats->tx_dropped += queue->stats.tx_dropped;
6209-
stats->tx_carrier_errors += queue->stats.tx_carrier_errors;
62106202
}
62116203
}
62126204
EXPORT_SYMBOL_GPL(qeth_get_stats64);
@@ -6216,16 +6208,11 @@ int qeth_open(struct net_device *dev)
62166208
struct qeth_card *card = dev->ml_priv;
62176209

62186210
QETH_CARD_TEXT(card, 4, "qethopen");
6219-
if (card->state == CARD_STATE_UP)
6220-
return 0;
6221-
if (card->state != CARD_STATE_SOFTSETUP)
6222-
return -ENODEV;
62236211

62246212
if (qdio_stop_irq(CARD_DDEV(card), 0) < 0)
62256213
return -EIO;
62266214

62276215
card->data.state = CH_STATE_UP;
6228-
card->state = CARD_STATE_UP;
62296216
netif_start_queue(dev);
62306217

62316218
napi_enable(&card->napi);
@@ -6243,10 +6230,7 @@ int qeth_stop(struct net_device *dev)
62436230

62446231
QETH_CARD_TEXT(card, 4, "qethstop");
62456232
netif_tx_disable(dev);
6246-
if (card->state == CARD_STATE_UP) {
6247-
card->state = CARD_STATE_SOFTSETUP;
6248-
napi_disable(&card->napi);
6249-
}
6233+
napi_disable(&card->napi);
62506234
return 0;
62516235
}
62526236
EXPORT_SYMBOL_GPL(qeth_stop);

drivers/s390/net/qeth_core_sys.c

Lines changed: 4 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -29,11 +29,11 @@ static ssize_t qeth_dev_state_show(struct device *dev,
2929
case CARD_STATE_HARDSETUP:
3030
return sprintf(buf, "HARDSETUP\n");
3131
case CARD_STATE_SOFTSETUP:
32+
if (card->dev->flags & IFF_UP)
33+
return sprintf(buf, "UP (LAN %s)\n",
34+
netif_carrier_ok(card->dev) ? "ONLINE" :
35+
"OFFLINE");
3236
return sprintf(buf, "SOFTSETUP\n");
33-
case CARD_STATE_UP:
34-
return sprintf(buf, "UP (LAN %s)\n",
35-
netif_carrier_ok(card->dev) ? "ONLINE" :
36-
"OFFLINE");
3737
default:
3838
return sprintf(buf, "UNKNOWN\n");
3939
}

drivers/s390/net/qeth_l2_main.c

Lines changed: 1 addition & 10 deletions
Original file line numberDiff line numberDiff line change
@@ -291,10 +291,7 @@ static void qeth_l2_stop_card(struct qeth_card *card)
291291
QETH_DBF_HEX(SETUP, 2, &card, sizeof(void *));
292292

293293
qeth_set_allowed_threads(card, 0, 1);
294-
if (card->read.state == CH_STATE_UP &&
295-
card->write.state == CH_STATE_UP &&
296-
card->state == CARD_STATE_UP)
297-
card->state = CARD_STATE_SOFTSETUP;
294+
298295
if (card->state == CARD_STATE_SOFTSETUP) {
299296
qeth_l2_del_all_macs(card);
300297
qeth_clear_ipacmd_list(card);
@@ -614,11 +611,6 @@ static netdev_tx_t qeth_l2_hard_start_xmit(struct sk_buff *skb,
614611

615612
queue = qeth_get_tx_queue(card, skb, ipv, cast_type);
616613

617-
if (card->state != CARD_STATE_UP) {
618-
QETH_TXQ_STAT_INC(queue, tx_carrier_errors);
619-
goto tx_drop;
620-
}
621-
622614
netif_stop_queue(dev);
623615

624616
if (IS_OSN(card))
@@ -636,7 +628,6 @@ static netdev_tx_t qeth_l2_hard_start_xmit(struct sk_buff *skb,
636628
return NETDEV_TX_BUSY;
637629
} /* else fall through */
638630

639-
tx_drop:
640631
QETH_TXQ_STAT_INC(queue, tx_dropped);
641632
QETH_TXQ_STAT_INC(queue, tx_errors);
642633
dev_kfree_skb_any(skb);

drivers/s390/net/qeth_l3_main.c

Lines changed: 2 additions & 9 deletions
Original file line numberDiff line numberDiff line change
@@ -1412,13 +1412,11 @@ static void qeth_l3_stop_card(struct qeth_card *card)
14121412
QETH_DBF_HEX(SETUP, 2, &card, sizeof(void *));
14131413

14141414
qeth_set_allowed_threads(card, 0, 1);
1415+
14151416
if (card->options.sniffer &&
14161417
(card->info.promisc_mode == SET_PROMISC_MODE_ON))
14171418
qeth_diags_trace(card, QETH_DIAGS_CMD_TRACE_DISABLE);
1418-
if (card->read.state == CH_STATE_UP &&
1419-
card->write.state == CH_STATE_UP &&
1420-
card->state == CARD_STATE_UP)
1421-
card->state = CARD_STATE_SOFTSETUP;
1419+
14221420
if (card->state == CARD_STATE_SOFTSETUP) {
14231421
qeth_l3_clear_ip_htable(card, 1);
14241422
qeth_clear_ipacmd_list(card);
@@ -2076,11 +2074,6 @@ static netdev_tx_t qeth_l3_hard_start_xmit(struct sk_buff *skb,
20762074
goto tx_drop;
20772075
}
20782076

2079-
if (card->state != CARD_STATE_UP) {
2080-
QETH_TXQ_STAT_INC(queue, tx_carrier_errors);
2081-
goto tx_drop;
2082-
}
2083-
20842077
if (cast_type == RTN_BROADCAST && !card->info.broadcast_capable)
20852078
goto tx_drop;
20862079

0 commit comments

Comments
 (0)