[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
Re: [Qemu-devel] [PATCH v2 2/7] target/m68k: add MC68040 MMU
From: |
Richard Henderson |
Subject: |
Re: [Qemu-devel] [PATCH v2 2/7] target/m68k: add MC68040 MMU |
Date: |
Mon, 15 Jan 2018 10:16:09 -0800 |
User-agent: |
Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Thunderbird/52.5.2 |
On 01/12/2018 04:43 PM, Laurent Vivier wrote:
> + ret = get_physical_address(&cpu->env, &physical, &prot,
> + address, access_type, &page_size);
> + if (ret == 0) {
> + tlb_set_page(cs, address & -page_size,
> + physical & -page_size,
> + prot, mmu_idx, page_size);
> + return 0;
> + }
Having raised TARGET_PAGE_BITS to 12 hasn't eliminated the tlb_add_large_page
path, merely reduced it to when the OS uses 8K pages.
What you'd do to eliminate it is
if (ret == 0) {
address &= TARGET_PAGE_MASK;
physical += address & (page_size - 1);
tlb_set_page(cs, address, physical, prot, mmu_idx, TARGET_PAGE_SIZE);
return 0;
}
Note that physical is always already aligned, because we pulled it out of the
page tables that way.
r~
- [Qemu-devel] [PATCH v2 0/7] target/m68k: supervisor mode (part 2), Laurent Vivier, 2018/01/12
- [Qemu-devel] [PATCH v2 5/7] target/m68k: add moves, Laurent Vivier, 2018/01/12
- [Qemu-devel] [PATCH v2 2/7] target/m68k: add MC68040 MMU, Laurent Vivier, 2018/01/12
- Re: [Qemu-devel] [PATCH v2 2/7] target/m68k: add MC68040 MMU,
Richard Henderson <=
- [Qemu-devel] [PATCH v2 3/7] target/m68k: add Transparent Translation, Laurent Vivier, 2018/01/12
- [Qemu-devel] [PATCH v2 4/7] target/m68k: add index parameter to gen_load()/gen_store() and Co., Laurent Vivier, 2018/01/12
- [Qemu-devel] [PATCH v2 6/7] target/m68k: add pflush/ptest, Laurent Vivier, 2018/01/12
- [Qemu-devel] [PATCH v2 7/7] target/m68k: add HMP command "info tlb", Laurent Vivier, 2018/01/12
- [Qemu-devel] [PATCH v2 1/7] accel/tcg: add size paremeter in tlb_fill(), Laurent Vivier, 2018/01/12
- Re: [Qemu-devel] [PATCH v2 0/7] target/m68k: supervisor mode (part 2), no-reply, 2018/01/12