Skip to content
Snippets Groups Projects
Select Git revision
  • 99313414dda451a8c00b139afc77a803e647f309
  • vme-testing default
  • ci-test
  • master
  • remoteproc
  • am625-sk-ov5640
  • pcal6534-upstreaming
  • lps22df-upstreaming
  • msc-upstreaming
  • imx8mp
  • iio/noa1305
  • vme-next
  • vme-next-4.14-rc4
  • v4.14-rc4
  • v4.14-rc3
  • v4.14-rc2
  • v4.14-rc1
  • v4.13
  • vme-next-4.13-rc7
  • v4.13-rc7
  • v4.13-rc6
  • v4.13-rc5
  • v4.13-rc4
  • v4.13-rc3
  • v4.13-rc2
  • v4.13-rc1
  • v4.12
  • v4.12-rc7
  • v4.12-rc6
  • v4.12-rc5
  • v4.12-rc4
  • v4.12-rc3
32 results

readdir.c

Blame
  • virt.h 2.75 KiB
    /*
     * Copyright (C) 2012 ARM Ltd.
     * Author: Marc Zyngier <marc.zyngier@arm.com>
     *
     * This program is free software: you can redistribute it and/or modify
     * it under the terms of the GNU General Public License version 2 as
     * published by the Free Software Foundation.
     *
     * This program is distributed in the hope that it will be useful,
     * but WITHOUT ANY WARRANTY; without even the implied warranty of
     * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
     * GNU General Public License for more details.
     *
     * You should have received a copy of the GNU General Public License
     * along with this program.  If not, see <http://www.gnu.org/licenses/>.
     */
    
    #ifndef __ASM__VIRT_H
    #define __ASM__VIRT_H
    
    /*
     * The arm64 hcall implementation uses x0 to specify the hcall type. A value
     * less than 0xfff indicates a special hcall, such as get/set vector.
     * Any other value is used as a pointer to the function to call.
     */
    
    /* HVC_GET_VECTORS - Return the value of the vbar_el2 register. */
    #define HVC_GET_VECTORS 0
    
    /*
     * HVC_SET_VECTORS - Set the value of the vbar_el2 register.
     *
     * @x1: Physical address of the new vector table.
     */
    #define HVC_SET_VECTORS 1
    
    /*
     * HVC_SOFT_RESTART - CPU soft reset, used by the cpu_soft_restart routine.
     */
    #define HVC_SOFT_RESTART 2
    
    #define BOOT_CPU_MODE_EL1	(0xe11)
    #define BOOT_CPU_MODE_EL2	(0xe12)
    
    #ifndef __ASSEMBLY__
    
    #include <asm/ptrace.h>
    #include <asm/sections.h>
    #include <asm/sysreg.h>
    #include <asm/cpufeature.h>
    
    /*
     * __boot_cpu_mode records what mode CPUs were booted in.
     * A correctly-implemented bootloader must start all CPUs in the same mode:
     * In this case, both 32bit halves of __boot_cpu_mode will contain the
     * same value (either 0 if booted in EL1, BOOT_CPU_MODE_EL2 if booted in EL2).
     *
     * Should the bootloader fail to do this, the two values will be different.
     * This allows the kernel to flag an error when the secondaries have come up.
     */
    extern u32 __boot_cpu_mode[2];
    
    void __hyp_set_vectors(phys_addr_t phys_vector_base);
    phys_addr_t __hyp_get_vectors(void);
    
    /* Reports the availability of HYP mode */
    static inline bool is_hyp_mode_available(void)
    {
    	return (__boot_cpu_mode[0] == BOOT_CPU_MODE_EL2 &&
    		__boot_cpu_mode[1] == BOOT_CPU_MODE_EL2);
    }
    
    /* Check if the bootloader has booted CPUs in different modes */
    static inline bool is_hyp_mode_mismatched(void)
    {
    	return __boot_cpu_mode[0] != __boot_cpu_mode[1];
    }
    
    static inline bool is_kernel_in_hyp_mode(void)
    {
    	return read_sysreg(CurrentEL) == CurrentEL_EL2;
    }
    
    static inline bool has_vhe(void)
    {
    	if (cpus_have_const_cap(ARM64_HAS_VIRT_HOST_EXTN))
    		return true;
    
    	return false;
    }
    
    #ifdef CONFIG_ARM64_VHE
    extern void verify_cpu_run_el(void);
    #else
    static inline void verify_cpu_run_el(void) {}
    #endif
    
    #endif /* __ASSEMBLY__ */
    
    #endif /* ! __ASM__VIRT_H */