Skip to content

Commit 49d66ed

Browse files
committed
Merge branch 'ibmvnic-null-pointer-dereference'
Lijun Pan says: ==================== ibmvnic: null pointer dereference Fix two NULL pointer dereference crash issues. Improve module removal procedure. ==================== Link: https://lore.kernel.org/r/20201123193547.57225-1-ljp@linux.ibm.com Signed-off-by: Jakub Kicinski <kuba@kernel.org>
2 parents 5fc145f + 3ada288 commit 49d66ed

2 files changed

Lines changed: 8 additions & 4 deletions

File tree

drivers/net/ethernet/ibm/ibmvnic.c

Lines changed: 7 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -2215,7 +2215,6 @@ static void __ibmvnic_reset(struct work_struct *work)
22152215

22162216
if (!saved_state) {
22172217
reset_state = adapter->state;
2218-
adapter->state = VNIC_RESETTING;
22192218
saved_state = true;
22202219
}
22212220
spin_unlock_irqrestore(&adapter->state_lock, flags);
@@ -2880,6 +2879,9 @@ static int reset_sub_crq_queues(struct ibmvnic_adapter *adapter)
28802879
{
28812880
int i, rc;
28822881

2882+
if (!adapter->tx_scrq || !adapter->rx_scrq)
2883+
return -EINVAL;
2884+
28832885
for (i = 0; i < adapter->req_tx_queues; i++) {
28842886
netdev_dbg(adapter->netdev, "Re-setting tx_scrq[%d]\n", i);
28852887
rc = reset_one_sub_crq_queue(adapter, adapter->tx_scrq[i]);
@@ -4970,6 +4972,9 @@ static int ibmvnic_reset_crq(struct ibmvnic_adapter *adapter)
49704972
} while (rc == H_BUSY || H_IS_LONG_BUSY(rc));
49714973

49724974
/* Clean out the queue */
4975+
if (!crq->msgs)
4976+
return -EINVAL;
4977+
49734978
memset(crq->msgs, 0, PAGE_SIZE);
49744979
crq->cur = 0;
49754980
crq->active = false;
@@ -5274,7 +5279,7 @@ static int ibmvnic_remove(struct vio_dev *dev)
52745279
unsigned long flags;
52755280

52765281
spin_lock_irqsave(&adapter->state_lock, flags);
5277-
if (adapter->state == VNIC_RESETTING) {
5282+
if (test_bit(0, &adapter->resetting)) {
52785283
spin_unlock_irqrestore(&adapter->state_lock, flags);
52795284
return -EBUSY;
52805285
}

drivers/net/ethernet/ibm/ibmvnic.h

Lines changed: 1 addition & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -942,8 +942,7 @@ enum vnic_state {VNIC_PROBING = 1,
942942
VNIC_CLOSING,
943943
VNIC_CLOSED,
944944
VNIC_REMOVING,
945-
VNIC_REMOVED,
946-
VNIC_RESETTING};
945+
VNIC_REMOVED};
947946

948947
enum ibmvnic_reset_reason {VNIC_RESET_FAILOVER = 1,
949948
VNIC_RESET_MOBILITY,

0 commit comments

Comments
 (0)