diff options
author | Max Filippov <jcmvbkbc@gmail.com> | 2016-09-21 02:58:20 +0200 |
---|---|---|
committer | Max Filippov <jcmvbkbc@gmail.com> | 2016-09-21 05:43:22 +0200 |
commit | 549409b4b584604f8eb225ebbb19be74204fe789 (patch) | |
tree | c85182b622a33bed1b69d4bccd34118c2e8156ba | |
parent | xtensa: ISS: define simc_exit and use it instead of inline asm (diff) | |
download | linux-549409b4b584604f8eb225ebbb19be74204fe789.tar.xz linux-549409b4b584604f8eb225ebbb19be74204fe789.zip |
xtensa: ISS: allow simdisk to use high memory buffers
ISS kernel by default has only low memory. But it may be configured to
support high memory and started in a simulator with more than 128M of
RAM. Simdisk driver in such configuration can get IO request with a
high memory page. There may be no TLB entry for that page, only page
table entry. However simulators don't do pagewalking, so such IO request
will fail. Touch IO buffer in the buffer read/write loop so that a TLB
entry is likely there when read or write simcall is invoked.
Signed-off-by: Max Filippov <jcmvbkbc@gmail.com>
-rw-r--r-- | arch/xtensa/platforms/iss/simdisk.c | 1 |
1 files changed, 1 insertions, 0 deletions
diff --git a/arch/xtensa/platforms/iss/simdisk.c b/arch/xtensa/platforms/iss/simdisk.c index f58a4e6472cb..ede04cca30dd 100644 --- a/arch/xtensa/platforms/iss/simdisk.c +++ b/arch/xtensa/platforms/iss/simdisk.c @@ -86,6 +86,7 @@ static void simdisk_transfer(struct simdisk *dev, unsigned long sector, unsigned long io; simc_lseek(dev->fd, offset, SEEK_SET); + READ_ONCE(*buffer); if (write) io = simc_write(dev->fd, buffer, nbytes); else |