qemu-devel
[Top][All Lists]
Advanced

[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~



reply via email to

[Prev in Thread] Current Thread [Next in Thread]