diff options
author | Chuanhong Guo <gch981213@gmail.com> | 2022-02-21 03:22:02 +0100 |
---|---|---|
committer | Chuanhong Guo <gch981213@gmail.com> | 2022-02-22 20:48:46 +0800 |
commit | 7612ecb201eebd0b273aa9225539fd45d538a1db (patch) | |
tree | 70df40423970c482968d5f637d446cc174a1eb69 /target/linux/generic | |
parent | 7fc336484b1e4727f419dd930955048f323580be (diff) | |
download | upstream-7612ecb201eebd0b273aa9225539fd45d538a1db.tar.gz upstream-7612ecb201eebd0b273aa9225539fd45d538a1db.tar.bz2 upstream-7612ecb201eebd0b273aa9225539fd45d538a1db.zip |
ramips: mt7621: do memory detection on KSEG1
It's reported that current memory detection code occasionally detects
larger memory under some bootloaders.
Current memory detection code tests whether address space wraps around
on KSEG0, which is unreliable because it's cached.
Rewrite memory size detection to perform the same test on KSEG1 instead.
While at it, this patch also does the following two things:
1. use a fixed pattern instead of a random function pointer as the magic
value.
2. add an additional memory write and a second comparison as part of the
test to prevent possible smaller memory detection result due to
leftover values in memory.
Fixes: 6d91ddf517 ("ramips: mt7621: add support for memory detection")
Reported-by: Rui Salvaterra <rsalvaterra@gmail.com>
Tested-by: Rui Salvaterra <rsalvaterra@gmail.com>
Signed-off-by: Chuanhong Guo <gch981213@gmail.com>
(cherry picked from commit 2f024b79331141e2a62c9bf3601c803b26bde77b)
[backport for OpenWrt 21.02 as it was reproducible with Kernel 5.4, see [1]]
[1]: https://forum.openwrt.org/t/113081
Tested-by: Dimitri Souza <dimitri.souza@gmail.com> [mt7621/archer-c6-v3]
Signed-off-by: Szabolcs Hubai <szab.hu@gmail.com>
Diffstat (limited to 'target/linux/generic')
0 files changed, 0 insertions, 0 deletions