Add patches to fix MTRR issues (rhbz 973185)
This commit is contained in:
parent
52b765c50c
commit
d08f67e2b7
@ -761,6 +761,9 @@ Patch25038: cdrom-use-kzalloc-for-failing-hardware.patch
|
|||||||
Patch25039: vhost_net-clear-msg.control-for-non-zerocopy-case-during-tx.patch
|
Patch25039: vhost_net-clear-msg.control-for-non-zerocopy-case-during-tx.patch
|
||||||
Patch25040: tuntap-set-SOCK_ZEROCOPY-flag-during-open.patch
|
Patch25040: tuntap-set-SOCK_ZEROCOPY-flag-during-open.patch
|
||||||
|
|
||||||
|
#rhbz 973185
|
||||||
|
Patch25041: x86-mtrr-Fix-original-mtrr-range-get-for-mtrr_cleanup.patch
|
||||||
|
Patch25042: x86-range-make-add_range-use-blank-slot.patch
|
||||||
|
|
||||||
# END OF PATCH DEFINITIONS
|
# END OF PATCH DEFINITIONS
|
||||||
|
|
||||||
@ -1466,6 +1469,10 @@ ApplyPatch cdrom-use-kzalloc-for-failing-hardware.patch
|
|||||||
ApplyPatch vhost_net-clear-msg.control-for-non-zerocopy-case-during-tx.patch
|
ApplyPatch vhost_net-clear-msg.control-for-non-zerocopy-case-during-tx.patch
|
||||||
ApplyPatch tuntap-set-SOCK_ZEROCOPY-flag-during-open.patch
|
ApplyPatch tuntap-set-SOCK_ZEROCOPY-flag-during-open.patch
|
||||||
|
|
||||||
|
#rhbz 973185
|
||||||
|
ApplyPatch x86-mtrr-Fix-original-mtrr-range-get-for-mtrr_cleanup.patch
|
||||||
|
ApplyPatch x86-range-make-add_range-use-blank-slot.patch
|
||||||
|
|
||||||
# END OF PATCH APPLICATIONS
|
# END OF PATCH APPLICATIONS
|
||||||
|
|
||||||
%endif
|
%endif
|
||||||
@ -2272,6 +2279,7 @@ fi
|
|||||||
# || ||
|
# || ||
|
||||||
%changelog
|
%changelog
|
||||||
* Tue Jun 11 2013 Josh Boyer <jwboyer@redhat.com>
|
* Tue Jun 11 2013 Josh Boyer <jwboyer@redhat.com>
|
||||||
|
- Add patches to fix MTRR issues in 3.9.5 (rhbz 973185)
|
||||||
- Add two patches to fix issues with vhost_net and macvlan (rhbz 954181)
|
- Add two patches to fix issues with vhost_net and macvlan (rhbz 954181)
|
||||||
|
|
||||||
* Tue Jun 11 2013 Josh Boyer <jwboyer@redhat.com> - 3.10.0-0.rc5.git0.1
|
* Tue Jun 11 2013 Josh Boyer <jwboyer@redhat.com> - 3.10.0-0.rc5.git0.1
|
||||||
|
63
x86-mtrr-Fix-original-mtrr-range-get-for-mtrr_cleanup.patch
Normal file
63
x86-mtrr-Fix-original-mtrr-range-get-for-mtrr_cleanup.patch
Normal file
@ -0,0 +1,63 @@
|
|||||||
|
Joshua reported: Commit cd7b304dfaf1 (x86, range: fix missing merge
|
||||||
|
during add range) broke mtrr cleanup on his setup in 3.9.5.
|
||||||
|
corresponding commit in upstream is fbe06b7bae7c.
|
||||||
|
|
||||||
|
*BAD*gran_size: 64K chunk_size: 16M num_reg: 6 lose cover RAM: -0G
|
||||||
|
|
||||||
|
https://bugzilla.kernel.org/show_bug.cgi?id=59491
|
||||||
|
|
||||||
|
So it rejects new var mtrr layout.
|
||||||
|
|
||||||
|
It turns out we have some problem with initial mtrr range retrievel.
|
||||||
|
current sequence is:
|
||||||
|
x86_get_mtrr_mem_range
|
||||||
|
==> bunchs of add_range_with_merge
|
||||||
|
==> bunchs of subract_range
|
||||||
|
==> clean_sort_range
|
||||||
|
add_range_with_merge for [0,1M)
|
||||||
|
sort_range()
|
||||||
|
|
||||||
|
add_range_with_merge could have blank slots, so we can not just
|
||||||
|
sort only, that will have final result have extra blank slot in head.
|
||||||
|
|
||||||
|
So move that calling add_range_with_merge for [0,1M), with that we
|
||||||
|
could avoid extra clean_sort_range calling.
|
||||||
|
|
||||||
|
Reported-by: Joshua Covington <joshuacov@googlemail.com>
|
||||||
|
Tested-by: Joshua Covington <joshuacov@googlemail.com>
|
||||||
|
Signed-off-by: Yinghai Lu <yinghai@kernel.org>
|
||||||
|
Cc: <stable@vger.kernel.org> v3.9
|
||||||
|
|
||||||
|
---
|
||||||
|
arch/x86/kernel/cpu/mtrr/cleanup.c | 8 ++++----
|
||||||
|
1 file changed, 4 insertions(+), 4 deletions(-)
|
||||||
|
|
||||||
|
Index: linux-2.6/arch/x86/kernel/cpu/mtrr/cleanup.c
|
||||||
|
===================================================================
|
||||||
|
--- linux-2.6.orig/arch/x86/kernel/cpu/mtrr/cleanup.c
|
||||||
|
+++ linux-2.6/arch/x86/kernel/cpu/mtrr/cleanup.c
|
||||||
|
@@ -714,15 +714,15 @@ int __init mtrr_cleanup(unsigned address
|
||||||
|
if (mtrr_tom2)
|
||||||
|
x_remove_size = (mtrr_tom2 >> PAGE_SHIFT) - x_remove_base;
|
||||||
|
|
||||||
|
- nr_range = x86_get_mtrr_mem_range(range, 0, x_remove_base, x_remove_size);
|
||||||
|
/*
|
||||||
|
* [0, 1M) should always be covered by var mtrr with WB
|
||||||
|
* and fixed mtrrs should take effect before var mtrr for it:
|
||||||
|
*/
|
||||||
|
- nr_range = add_range_with_merge(range, RANGE_NUM, nr_range, 0,
|
||||||
|
+ nr_range = add_range_with_merge(range, RANGE_NUM, 0, 0,
|
||||||
|
1ULL<<(20 - PAGE_SHIFT));
|
||||||
|
- /* Sort the ranges: */
|
||||||
|
- sort_range(range, nr_range);
|
||||||
|
+ /* add from var mtrr at last */
|
||||||
|
+ nr_range = x86_get_mtrr_mem_range(range, nr_range,
|
||||||
|
+ x_remove_base, x_remove_size);
|
||||||
|
|
||||||
|
range_sums = sum_ranges(range, nr_range);
|
||||||
|
printk(KERN_INFO "total RAM covered: %ldM\n",
|
||||||
|
--
|
||||||
|
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
|
||||||
|
the body of a message to majordomo@vger.kernel.org
|
||||||
|
More majordomo info at http://vger.kernel.org/majordomo-info.html
|
||||||
|
Please read the FAQ at http://www.tux.org/lkml/
|
80
x86-range-make-add_range-use-blank-slot.patch
Normal file
80
x86-range-make-add_range-use-blank-slot.patch
Normal file
@ -0,0 +1,80 @@
|
|||||||
|
Now add_range_with_merge will generate blank slot as subtract_range.
|
||||||
|
we could reach the array limit because of blank slots.
|
||||||
|
|
||||||
|
We can let add_range to have second try to use blank slot.
|
||||||
|
|
||||||
|
Also use WARN_ONCE to print trace.
|
||||||
|
|
||||||
|
Reported-by: Joshua Covington <joshuacov@googlemail.com>
|
||||||
|
Signed-off-by: Yinghai Lu <yinghai@kernel.org>
|
||||||
|
Cc: <stable@vger.kernel.org> v3.9
|
||||||
|
---
|
||||||
|
kernel/range.c | 34 ++++++++++++++++++++++------------
|
||||||
|
1 file changed, 22 insertions(+), 12 deletions(-)
|
||||||
|
|
||||||
|
Index: linux-2.6/kernel/range.c
|
||||||
|
===================================================================
|
||||||
|
--- linux-2.6.orig/kernel/range.c
|
||||||
|
+++ linux-2.6/kernel/range.c
|
||||||
|
@@ -3,23 +3,34 @@
|
||||||
|
*/
|
||||||
|
#include <linux/kernel.h>
|
||||||
|
#include <linux/init.h>
|
||||||
|
+#include <linux/bug.h>
|
||||||
|
#include <linux/sort.h>
|
||||||
|
-
|
||||||
|
#include <linux/range.h>
|
||||||
|
|
||||||
|
int add_range(struct range *range, int az, int nr_range, u64 start, u64 end)
|
||||||
|
{
|
||||||
|
- if (start >= end)
|
||||||
|
- return nr_range;
|
||||||
|
+ int i;
|
||||||
|
|
||||||
|
- /* Out of slots: */
|
||||||
|
- if (nr_range >= az)
|
||||||
|
+ if (start >= end)
|
||||||
|
return nr_range;
|
||||||
|
|
||||||
|
- range[nr_range].start = start;
|
||||||
|
- range[nr_range].end = end;
|
||||||
|
+ /* Out of slots ? */
|
||||||
|
+ if (nr_range < az) {
|
||||||
|
+ i = nr_range;
|
||||||
|
+ nr_range++;
|
||||||
|
+ } else {
|
||||||
|
+ /* find blank slot */
|
||||||
|
+ for (i = 0; i < az; i++)
|
||||||
|
+ if (!range[i].end)
|
||||||
|
+ break;
|
||||||
|
+ if (i == az) {
|
||||||
|
+ WARN_ONCE(1, "run out of slot in ranges\n");
|
||||||
|
+ return az;
|
||||||
|
+ }
|
||||||
|
+ }
|
||||||
|
|
||||||
|
- nr_range++;
|
||||||
|
+ range[i].start = start;
|
||||||
|
+ range[i].end = end;
|
||||||
|
|
||||||
|
return nr_range;
|
||||||
|
}
|
||||||
|
@@ -98,10 +109,9 @@ void subtract_range(struct range *range,
|
||||||
|
if (i < az) {
|
||||||
|
range[i].end = range[j].end;
|
||||||
|
range[i].start = end;
|
||||||
|
- } else {
|
||||||
|
- pr_err("%s: run out of slot in ranges\n",
|
||||||
|
- __func__);
|
||||||
|
- }
|
||||||
|
+ } else
|
||||||
|
+ WARN_ONCE(1, "run out of slot in ranges\n");
|
||||||
|
+
|
||||||
|
range[j].end = start;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
--
|
||||||
|
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
|
||||||
|
the body of a message to majordomo@vger.kernel.org
|
||||||
|
More majordomo info at http://vger.kernel.org/majordomo-info.html
|
||||||
|
Please read the FAQ at http://www.tux.org/lkml/
|
Loading…
Reference in New Issue
Block a user