Skip to content
Snippets Groups Projects
Select Git revision
  • ffba29c9ebd0977dbf77bf6064776716a51b8ae5
  • seco_lf-6.6.52-2.2.1 default protected
  • integrate/gitlab-ci/use-board-only-instead-codename-and-board-in-the-configuration/into/seco_lf-6.6.52-2.2.1
  • seco_lf-6.6.52-2.2.1-tr8mp-dtb
  • seco_lf-6.6.52-2.2.1-tr8mp-mcu
  • integrate/gitlab-ci/use-board-only-instead-codename-and-board-in-the-configuration/into/seco_lf-5.10.y
  • seco_lf-6.6.23-2.0.0_e39-e83-p4-devicetree
  • integrate/gitlab-ci/cleaos-894-rename-distros-into-build-tergets/into/seco_lf-5.10.y
  • integrate/gitlab-ci/cleaos-894-rename-distros-into-build-tergets/into/seco_lf-6.6.52-2.2.1
  • seco_lf-5.10.y protected
  • seco_lf-6.6.52-2.2.1_e88-dev
  • seco_lf-6.6.52-2.2.1_ov5640-mx95-dev
  • seco_lf-6.6.52-2.2.1-tr8mp-rgb-defconfig
  • seco_lf-6.6.52-2.2.1-tr8mp-dev
  • seco_lf-6.6.52-2.2.1-tr8mp-dtbo
  • seco_lf-6.6.52-2.2.1-tr8mp-rv3028
  • seco_lf-6.6.52-2.2.1-tr8mp-fpga
  • seco_lf-6.6.52-2.2.1_stm32g0-dev
  • seco_lf-6.6.52-2.2.1_remove-mwifiex_d18
  • seco_lf-6.6.52-2.2.1_e88-dbg-uart-dev
  • seco_lf_v2024.04_6.6.52_2.2.x-e39-e83-devicetrees
  • lf-6.6.52-2.2.1
  • lf-6.1.55-2.2.1
  • lf-6.6.3-1.0.0
  • lf-6.6.3-imx95-er2
  • lf-6.1.55-2.2.0
  • lf-6.6.y-imx95-er1
  • lf-5.15.71-2.2.2
  • lf-6.1.36-2.1.0
  • lf-5.15.71-2.2.1
  • lf-6.1.22-2.0.0
  • lf-6.1.1-1.0.1
  • rel_imx_5.4.24_2.1.4
  • rel_imx_4.9.88_2.0.13
  • rel_imx_4.14.98_2.3.5
  • lf-6.1.1-1.0.0
  • rel_imx_5.4.3_2.0.2
  • lf-5.15.71-2.2.0
  • lf-5.10.72-2.2.3
  • lf-5.15.52-2.1.0
  • imx_5.15.52_imx8ulp_er1
41 results

hardware.h

Blame
  • Code owners
    Assign users and groups as approvers for specific file changes. Learn more.
    cacheflush.h 2.61 KiB
    /*
     * include/asm-sh/cpu-sh3/cacheflush.h
     *
     * Copyright (C) 1999 Niibe Yutaka
     *
     * This file is subject to the terms and conditions of the GNU General Public
     * License.  See the file "COPYING" in the main directory of this archive
     * for more details.
     */
    #ifndef __ASM_CPU_SH3_CACHEFLUSH_H
    #define __ASM_CPU_SH3_CACHEFLUSH_H
    
    /*
     * Cache flushing:
     *
     *  - flush_cache_all() flushes entire cache
     *  - flush_cache_mm(mm) flushes the specified mm context's cache lines
     *  - flush_cache_dup mm(mm) handles cache flushing when forking
     *  - flush_cache_page(mm, vmaddr, pfn) flushes a single page
     *  - flush_cache_range(vma, start, end) flushes a range of pages
     *
     *  - flush_dcache_page(pg) flushes(wback&invalidates) a page for dcache
     *  - flush_icache_range(start, end) flushes(invalidates) a range for icache
     *  - flush_icache_page(vma, pg) flushes(invalidates) a page for icache
     *
     *  Caches are indexed (effectively) by physical address on SH-3, so
     *  we don't need them.
     */
    
    #if defined(CONFIG_SH7705_CACHE_32KB)
    
    /* SH7705 is an SH3 processor with 32KB cache. This has alias issues like the
     * SH4. Unlike the SH4 this is a unified cache so we need to do some work
     * in mmap when 'exec'ing a new binary
     */
     /* 32KB cache, 4kb PAGE sizes need to check bit 12 */
    #define CACHE_ALIAS 0x00001000
    
    #define PG_mapped	PG_arch_1
    
    void flush_cache_all(void);
    void flush_cache_mm(struct mm_struct *mm);
    #define flush_cache_dup_mm(mm) flush_cache_mm(mm)
    void flush_cache_range(struct vm_area_struct *vma, unsigned long start,
                                  unsigned long end);
    void flush_cache_page(struct vm_area_struct *vma, unsigned long addr, unsigned long pfn);
    void flush_dcache_page(struct page *pg);
    void flush_icache_range(unsigned long start, unsigned long end);
    void flush_icache_page(struct vm_area_struct *vma, struct page *page);
    #else
    #define flush_cache_all()			do { } while (0)
    #define flush_cache_mm(mm)			do { } while (0)
    #define flush_cache_dup_mm(mm)			do { } while (0)
    #define flush_cache_range(vma, start, end)	do { } while (0)
    #define flush_cache_page(vma, vmaddr, pfn)	do { } while (0)
    #define flush_dcache_page(page)			do { } while (0)
    #define flush_icache_range(start, end)		do { } while (0)
    #define flush_icache_page(vma,pg)		do { } while (0)
    #endif
    
    #define flush_dcache_mmap_lock(mapping)		do { } while (0)
    #define flush_dcache_mmap_unlock(mapping)	do { } while (0)
    
    /* SH3 has unified cache so no special action needed here */
    #define flush_cache_sigtramp(vaddr)		do { } while (0)
    #define flush_icache_user_range(vma,pg,adr,len)	do { } while (0)
    
    #define p3_cache_init()				do { } while (0)
    
    #endif /* __ASM_CPU_SH3_CACHEFLUSH_H */