2014-04-16 09:24:44 +02:00
/*
* Copyright ( C ) 2014 NVIDIA CORPORATION . All rights reserved .
*
* 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 .
*/
# ifndef MEMORY_TEGRA_MC_H
# define MEMORY_TEGRA_MC_H
# include <linux/io.h>
# include <linux/types.h>
# include <soc/tegra/mc.h>
2018-04-09 22:28:29 +03:00
# define MC_INT_DECERR_MTS (1 << 16)
# define MC_INT_SECERR_SEC (1 << 13)
# define MC_INT_DECERR_VPR (1 << 12)
# define MC_INT_INVALID_APB_ASID_UPDATE (1 << 11)
# define MC_INT_INVALID_SMMU_PAGE (1 << 10)
# define MC_INT_ARBITRATION_EMEM (1 << 9)
# define MC_INT_SECURITY_VIOLATION (1 << 8)
# define MC_INT_DECERR_EMEM (1 << 6)
2014-04-16 09:24:44 +02:00
static inline u32 mc_readl ( struct tegra_mc * mc , unsigned long offset )
{
return readl ( mc - > regs + offset ) ;
}
static inline void mc_writel ( struct tegra_mc * mc , u32 value ,
unsigned long offset )
{
writel ( value , mc - > regs + offset ) ;
}
# ifdef CONFIG_ARCH_TEGRA_3x_SOC
extern const struct tegra_mc_soc tegra30_mc_soc ;
# endif
# ifdef CONFIG_ARCH_TEGRA_114_SOC
extern const struct tegra_mc_soc tegra114_mc_soc ;
# endif
# ifdef CONFIG_ARCH_TEGRA_124_SOC
extern const struct tegra_mc_soc tegra124_mc_soc ;
# endif
2014-11-07 16:10:41 +01:00
# ifdef CONFIG_ARCH_TEGRA_132_SOC
extern const struct tegra_mc_soc tegra132_mc_soc ;
# endif
2015-03-23 10:45:12 +01:00
# ifdef CONFIG_ARCH_TEGRA_210_SOC
extern const struct tegra_mc_soc tegra210_mc_soc ;
# endif
2014-04-16 09:24:44 +02:00
# endif /* MEMORY_TEGRA_MC_H */