[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

Re: [Xen-devel] [PATCH V3 13/15] add arm64 cache flushing code from linux v3.16



On Sun, 2014-09-07 at 20:53 -0700, Roy Franz wrote:
> __flush_dcache_all added from arch/arm64/mm/cache.S, with helper macros from
> arch/arm64/include/asm/assembler.h, from v3.16.  The cache flushing is 
> required
> when transitioning from EFI code that runs with cache enable to XEN startup
> code which expects the cache to be disabled.
> 
> Signed-off-by: Roy Franz <roy.franz@xxxxxxxxxx>

Acked-by: Ian Campbell <ian.campbell@xxxxxxxxxx>

> +     ENTRY(__flush_dcache_all)

This shouldn't be indented. If I come to be applying this version then
I'll fix that as I go, but if you repost please fix.

> +__flush_dcache_all:
> +     dmb     sy                              // ensure ordering with 
> previous memory accesses
> +     mrs     x0, clidr_el1                   // read clidr
> +     and     x3, x0, #0x7000000              // extract loc from clidr
> +     lsr     x3, x3, #23                     // left align loc bit field
> +     cbz     x3, finished                    // if loc is 0, then no need to 
> clean
> +     mov     x10, #0                         // start clean at cache level 0
> +loop1:
> +     add     x2, x10, x10, lsr #1            // work out 3x current cache 
> level
> +     lsr     x1, x0, x2                      // extract cache type bits from 
> clidr
> +     and     x1, x1, #7                      // mask of the bits for current 
> cache only
> +     cmp     x1, #2                          // see what cache we have at 
> this level
> +     b.lt    skip                            // skip if no cache, or just 
> i-cache
> +     save_and_disable_irqs x9                // make CSSELR and CCSIDR 
> access atomic
> +     msr     csselr_el1, x10                 // select current cache level 
> in csselr
> +     isb                                     // isb to sych the new 
> cssr&csidr
> +     mrs     x1, ccsidr_el1                  // read the new ccsidr
> +     restore_irqs x9
> +     and     x2, x1, #7                      // extract the length of the 
> cache lines
> +     add     x2, x2, #4                      // add 4 (line length offset)
> +     mov     x4, #0x3ff
> +     and     x4, x4, x1, lsr #3              // find maximum number on the 
> way size
> +     clz     w5, w4                          // find bit position of way 
> size increment
> +     mov     x7, #0x7fff
> +     and     x7, x7, x1, lsr #13             // extract max number of the 
> index size
> +loop2:
> +     mov     x9, x4                          // create working copy of max 
> way size
> +loop3:
> +     lsl     x6, x9, x5
> +     orr     x11, x10, x6                    // factor way and cache number 
> into x11
> +     lsl     x6, x7, x2
> +     orr     x11, x11, x6                    // factor index number into x11
> +     dc      cisw, x11                       // clean & invalidate by set/way
> +     subs    x9, x9, #1                      // decrement the way
> +     b.ge    loop3
> +     subs    x7, x7, #1                      // decrement the index
> +     b.ge    loop2
> +skip:
> +     add     x10, x10, #2                    // increment cache number
> +     cmp     x3, x10
> +     b.gt    loop1
> +finished:
> +     mov     x10, #0                         // swith back to cache level 0
> +     msr     csselr_el1, x10                 // select current cache level 
> in csselr
> +     dsb     sy
> +     isb
> +     ret
> +ENDPROC(__flush_dcache_all)



_______________________________________________
Xen-devel mailing list
Xen-devel@xxxxxxxxxxxxx
http://lists.xen.org/xen-devel


 


Rackspace

Lists.xenproject.org is hosted with RackSpace, monitoring our
servers 24x7x365 and backed by RackSpace's Fanatical Support®.