2019-07-27 21:01:02 +00:00
|
|
|
From 32862c02a282688aa2b6eaf51e53a1a5cbd16bd4 Mon Sep 17 00:00:00 2001
|
2018-11-11 17:40:18 +00:00
|
|
|
From: =?UTF-8?q?Marek=20Marczykowski-G=C3=B3recki?=
|
|
|
|
<marmarek@invisiblethingslab.com>
|
|
|
|
Date: Thu, 6 Sep 2018 15:09:44 +0200
|
|
|
|
Subject: [PATCH] xen-netfront-detach-crash
|
|
|
|
|
2015-10-31 14:53:31 +00:00
|
|
|
When it get to free_page(queue->grant_tx_page[i]), the use counter on this page
|
|
|
|
is already 0, which cause a crash. Not sure if this is the proper fix
|
|
|
|
(according to git log this may introduce some memory leak), but at least it
|
|
|
|
prevent the crash.
|
|
|
|
|
|
|
|
Details in this thread:
|
|
|
|
http://xen.markmail.org/thread/pw5edbtqienjx4q5
|
2018-11-11 17:40:18 +00:00
|
|
|
---
|
|
|
|
drivers/net/xen-netfront.c | 7 ++++---
|
|
|
|
1 file changed, 4 insertions(+), 3 deletions(-)
|
2015-10-31 14:53:31 +00:00
|
|
|
|
|
|
|
diff --git a/drivers/net/xen-netfront.c b/drivers/net/xen-netfront.c
|
2019-07-27 21:01:02 +00:00
|
|
|
index 8d33970a2950..5c9a0226dc8d 100644
|
2015-10-31 14:53:31 +00:00
|
|
|
--- a/drivers/net/xen-netfront.c
|
|
|
|
+++ b/drivers/net/xen-netfront.c
|
2019-07-27 21:01:02 +00:00
|
|
|
@@ -1137,9 +1137,10 @@ static void xennet_release_tx_bufs(struct netfront_queue *queue)
|
2015-10-31 14:53:31 +00:00
|
|
|
|
|
|
|
skb = queue->tx_skbs[i].skb;
|
|
|
|
get_page(queue->grant_tx_page[i]);
|
|
|
|
- gnttab_end_foreign_access(queue->grant_tx_ref[i],
|
|
|
|
- GNTMAP_readonly,
|
|
|
|
- (unsigned long)page_address(queue->grant_tx_page[i]));
|
|
|
|
+ gnttab_end_foreign_access_ref(
|
|
|
|
+ queue->grant_tx_ref[i], GNTMAP_readonly);
|
|
|
|
+ gnttab_release_grant_reference(
|
|
|
|
+ &queue->gref_tx_head, queue->grant_tx_ref[i]);
|
|
|
|
queue->grant_tx_page[i] = NULL;
|
|
|
|
queue->grant_tx_ref[i] = GRANT_INVALID_REF;
|
|
|
|
add_id_to_freelist(&queue->tx_skb_freelist, queue->tx_skbs, i);
|
2018-11-11 17:40:18 +00:00
|
|
|
--
|
2019-03-15 21:28:57 +00:00
|
|
|
2.20.1
|
2018-11-11 17:40:18 +00:00
|
|
|
|