• Max Filippov's avatar
    xtensa: fix TLBTEMP area placement · 481535c5
    Max Filippov authored
    fast_second_level_miss handler for the TLBTEMP area has an assumption
    that page table directory entry for the TLBTEMP address range is 0. For
    it to be true the TLBTEMP area must be aligned to 4MB boundary and not
    share its 4MB region with anything that may use a page table. This is
    not true currently: TLBTEMP shares space with vmalloc space which
    results in the following kinds of runtime errors when
    fast_second_level_miss loads page table directory entry for the vmalloc
    space instead of fixing up the TLBTEMP area:
    
     Unable to handle kernel paging request at virtual address c7ff0e00
      pc = d0009275, ra = 90009478
     Oops: sig: 9 [#1] PREEMPT
     CPU: 1 PID: 61 Comm: kworker/u9:2 Not tainted 5.10.0-rc3-next-20201110-00007-g1fe4962fa983-dirty #58
     Workqueue: xprtiod xs_stream_data_receive_workfn
     a00: 90009478 d11e1dc0 c7ff0e00 00000020 c7ff0000 00000001 7f8b8107 00000000
     a08: 900c5992 d11e1d90 d0cc88b8 5506e97c 00000000 5506e97c d06c8074 d11e1d90
     pc: d0009275, ps: 00060310, depc: 00000014, excvaddr: c7ff0e00
     lbeg: d0009275, lend: d0009287 lcount: 00000003, sar: 00000010
     Call Trace:
       xs_stream_data_receive_workfn+0x43c/0x770
       process_one_work+0x1a1/0x324
       worker_thread+0x1cc/0x3c0
       kthread+0x10d/0x124
       ret_from_kernel_thread+0xc/0x18
    
    Cc: stable@vger.kernel.org
    Signed-off-by: default avatarMax Filippov <jcmvbkbc@gmail.com>
    481535c5
pgtable.h 14 KB