Commit 1636f57c authored by Linus Torvalds's avatar Linus Torvalds

Merge tag 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/rmk/linux

Pull ARM updates from Russell King:

 - clean up TTBCR magic numbers and use u32 for this register

 - fix clang issue in VFP code leading to kernel oops, caused by
   compiler instruction scheduling.

 - switch 32-bit Arm to use GENERIC_CPU_DEVICES and use the
   arch_cpu_is_hotpluggable() hook.

 - pass struct device to arm_iommu_create_mapping() and move over to use
   iommu_paging_domain_alloc() rather than iommu_domain_alloc()

 - make amba_bustype constant

* tag 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/rmk/linux:
  ARM: 9418/1: dma-mapping: Use iommu_paging_domain_alloc()
  ARM: 9417/1: dma-mapping: Pass device to arm_iommu_create_mapping()
  ARM: 9416/1: amba: make amba_bustype constant
  ARM: 9412/1: Convert to arch_cpu_is_hotpluggable()
  ARM: 9411/1: Switch over to GENERIC_CPU_DEVICES using arch_register_cpu()
  ARM: 9410/1: vfp: Use asm volatile in fmrx/fmxr macros
  ARM: 9409/1: mmu: Do not use magic number for TTBCR settings
parents 85ffc6e4 61a3fc79
...@@ -64,6 +64,7 @@ config ARM ...@@ -64,6 +64,7 @@ config ARM
select GENERIC_CLOCKEVENTS_BROADCAST if SMP select GENERIC_CLOCKEVENTS_BROADCAST if SMP
select GENERIC_IRQ_IPI if SMP select GENERIC_IRQ_IPI if SMP
select GENERIC_CPU_AUTOPROBE select GENERIC_CPU_AUTOPROBE
select GENERIC_CPU_DEVICES
select GENERIC_EARLY_IOREMAP select GENERIC_EARLY_IOREMAP
select GENERIC_IDLE_POLL_SETUP select GENERIC_IDLE_POLL_SETUP
select GENERIC_IRQ_MULTI_HANDLER select GENERIC_IRQ_MULTI_HANDLER
......
...@@ -11,7 +11,6 @@ ...@@ -11,7 +11,6 @@
#include <linux/cpu.h> #include <linux/cpu.h>
struct cpuinfo_arm { struct cpuinfo_arm {
struct cpu cpu;
u32 cpuid; u32 cpuid;
#ifdef CONFIG_SMP #ifdef CONFIG_SMP
unsigned int loops_per_jiffy; unsigned int loops_per_jiffy;
......
...@@ -24,7 +24,7 @@ struct dma_iommu_mapping { ...@@ -24,7 +24,7 @@ struct dma_iommu_mapping {
}; };
struct dma_iommu_mapping * struct dma_iommu_mapping *
arm_iommu_create_mapping(const struct bus_type *bus, dma_addr_t base, u64 size); arm_iommu_create_mapping(struct device *dev, dma_addr_t base, u64 size);
void arm_iommu_release_mapping(struct dma_iommu_mapping *mapping); void arm_iommu_release_mapping(struct dma_iommu_mapping *mapping);
......
...@@ -106,6 +106,11 @@ ...@@ -106,6 +106,11 @@
/* /*
* TTBCR register bits. * TTBCR register bits.
*
* The ORGN0 and IRGN0 bits enables different forms of caching when
* walking the translation table. Clearing these bits (which is claimed
* to be the reset default) means "normal memory, [outer|inner]
* non-cacheable"
*/ */
#define TTBCR_EAE (1 << 31) #define TTBCR_EAE (1 << 31)
#define TTBCR_IMP (1 << 30) #define TTBCR_IMP (1 << 30)
......
...@@ -1201,20 +1201,10 @@ void __init setup_arch(char **cmdline_p) ...@@ -1201,20 +1201,10 @@ void __init setup_arch(char **cmdline_p)
mdesc->init_early(); mdesc->init_early();
} }
bool arch_cpu_is_hotpluggable(int num)
static int __init topology_init(void)
{ {
int cpu; return platform_can_hotplug_cpu(num);
for_each_possible_cpu(cpu) {
struct cpuinfo_arm *cpuinfo = &per_cpu(cpu_data, cpu);
cpuinfo->cpu.hotpluggable = platform_can_hotplug_cpu(cpu);
register_cpu(&cpuinfo->cpu, cpu);
}
return 0;
} }
subsys_initcall(topology_init);
#ifdef CONFIG_HAVE_PROC_CPU #ifdef CONFIG_HAVE_PROC_CPU
static int __init proc_cpu_init(void) static int __init proc_cpu_init(void)
......
...@@ -1532,7 +1532,7 @@ static const struct dma_map_ops iommu_ops = { ...@@ -1532,7 +1532,7 @@ static const struct dma_map_ops iommu_ops = {
/** /**
* arm_iommu_create_mapping * arm_iommu_create_mapping
* @bus: pointer to the bus holding the client device (for IOMMU calls) * @dev: pointer to the client device (for IOMMU calls)
* @base: start address of the valid IO address space * @base: start address of the valid IO address space
* @size: maximum size of the valid IO address space * @size: maximum size of the valid IO address space
* *
...@@ -1544,7 +1544,7 @@ static const struct dma_map_ops iommu_ops = { ...@@ -1544,7 +1544,7 @@ static const struct dma_map_ops iommu_ops = {
* arm_iommu_attach_device function. * arm_iommu_attach_device function.
*/ */
struct dma_iommu_mapping * struct dma_iommu_mapping *
arm_iommu_create_mapping(const struct bus_type *bus, dma_addr_t base, u64 size) arm_iommu_create_mapping(struct device *dev, dma_addr_t base, u64 size)
{ {
unsigned int bits = size >> PAGE_SHIFT; unsigned int bits = size >> PAGE_SHIFT;
unsigned int bitmap_size = BITS_TO_LONGS(bits) * sizeof(long); unsigned int bitmap_size = BITS_TO_LONGS(bits) * sizeof(long);
...@@ -1585,9 +1585,11 @@ arm_iommu_create_mapping(const struct bus_type *bus, dma_addr_t base, u64 size) ...@@ -1585,9 +1585,11 @@ arm_iommu_create_mapping(const struct bus_type *bus, dma_addr_t base, u64 size)
spin_lock_init(&mapping->lock); spin_lock_init(&mapping->lock);
mapping->domain = iommu_domain_alloc(bus); mapping->domain = iommu_paging_domain_alloc(dev);
if (!mapping->domain) if (IS_ERR(mapping->domain)) {
err = PTR_ERR(mapping->domain);
goto err4; goto err4;
}
kref_init(&mapping->kref); kref_init(&mapping->kref);
return mapping; return mapping;
...@@ -1718,7 +1720,7 @@ static void arm_setup_iommu_dma_ops(struct device *dev) ...@@ -1718,7 +1720,7 @@ static void arm_setup_iommu_dma_ops(struct device *dev)
dma_base = dma_range_map_min(dev->dma_range_map); dma_base = dma_range_map_min(dev->dma_range_map);
size = dma_range_map_max(dev->dma_range_map) - dma_base; size = dma_range_map_max(dev->dma_range_map) - dma_base;
} }
mapping = arm_iommu_create_mapping(dev->bus, dma_base, size); mapping = arm_iommu_create_mapping(dev, dma_base, size);
if (IS_ERR(mapping)) { if (IS_ERR(mapping)) {
pr_warn("Failed to create %llu-byte IOMMU mapping for device %s\n", pr_warn("Failed to create %llu-byte IOMMU mapping for device %s\n",
size, dev_name(dev)); size, dev_name(dev));
......
...@@ -1638,7 +1638,7 @@ static void __init early_paging_init(const struct machine_desc *mdesc) ...@@ -1638,7 +1638,7 @@ static void __init early_paging_init(const struct machine_desc *mdesc)
{ {
pgtables_remap *lpae_pgtables_remap; pgtables_remap *lpae_pgtables_remap;
unsigned long pa_pgd; unsigned long pa_pgd;
unsigned int cr, ttbcr; u32 cr, ttbcr, tmp;
long long offset; long long offset;
if (!mdesc->pv_fixup) if (!mdesc->pv_fixup)
...@@ -1688,7 +1688,9 @@ static void __init early_paging_init(const struct machine_desc *mdesc) ...@@ -1688,7 +1688,9 @@ static void __init early_paging_init(const struct machine_desc *mdesc)
cr = get_cr(); cr = get_cr();
set_cr(cr & ~(CR_I | CR_C)); set_cr(cr & ~(CR_I | CR_C));
ttbcr = cpu_get_ttbcr(); ttbcr = cpu_get_ttbcr();
cpu_set_ttbcr(ttbcr & ~(3 << 8 | 3 << 10)); /* Disable all kind of caching of the translation table */
tmp = ttbcr & ~(TTBCR_ORGN0_MASK | TTBCR_IRGN0_MASK);
cpu_set_ttbcr(tmp);
flush_cache_all(); flush_cache_all();
/* /*
......
...@@ -64,33 +64,37 @@ ...@@ -64,33 +64,37 @@
#ifdef CONFIG_AS_VFP_VMRS_FPINST #ifdef CONFIG_AS_VFP_VMRS_FPINST
#define fmrx(_vfp_) ({ \ #define fmrx(_vfp_) ({ \
u32 __v; \ u32 __v; \
asm(".fpu vfpv2\n" \ asm volatile (".fpu vfpv2\n" \
"vmrs %0, " #_vfp_ \ "vmrs %0, " #_vfp_ \
: "=r" (__v) : : "cc"); \ : "=r" (__v) : : "cc"); \
__v; \ __v; \
}) })
#define fmxr(_vfp_,_var_) \ #define fmxr(_vfp_, _var_) ({ \
asm(".fpu vfpv2\n" \ asm volatile (".fpu vfpv2\n" \
"vmsr " #_vfp_ ", %0" \ "vmsr " #_vfp_ ", %0" \
: : "r" (_var_) : "cc") : : "r" (_var_) : "cc"); \
})
#else #else
#define vfpreg(_vfp_) #_vfp_ #define vfpreg(_vfp_) #_vfp_
#define fmrx(_vfp_) ({ \ #define fmrx(_vfp_) ({ \
u32 __v; \ u32 __v; \
asm("mrc p10, 7, %0, " vfpreg(_vfp_) ", cr0, 0 @ fmrx %0, " #_vfp_ \ asm volatile ("mrc p10, 7, %0, " vfpreg(_vfp_) "," \
: "=r" (__v) : : "cc"); \ "cr0, 0 @ fmrx %0, " #_vfp_ \
__v; \ : "=r" (__v) : : "cc"); \
}) __v; \
})
#define fmxr(_vfp_,_var_) \
asm("mcr p10, 7, %0, " vfpreg(_vfp_) ", cr0, 0 @ fmxr " #_vfp_ ", %0" \ #define fmxr(_vfp_, _var_) ({ \
: : "r" (_var_) : "cc") asm volatile ("mcr p10, 7, %0, " vfpreg(_vfp_) "," \
"cr0, 0 @ fmxr " #_vfp_ ", %0" \
: : "r" (_var_) : "cc"); \
})
#endif #endif
......
...@@ -435,7 +435,7 @@ static const struct dev_pm_ops amba_pm = { ...@@ -435,7 +435,7 @@ static const struct dev_pm_ops amba_pm = {
* DMA configuration for platform and AMBA bus is same. So here we reuse * DMA configuration for platform and AMBA bus is same. So here we reuse
* platform's DMA config routine. * platform's DMA config routine.
*/ */
struct bus_type amba_bustype = { const struct bus_type amba_bustype = {
.name = "amba", .name = "amba",
.dev_groups = amba_dev_groups, .dev_groups = amba_dev_groups,
.match = amba_match, .match = amba_match,
......
...@@ -110,7 +110,7 @@ int exynos_drm_register_dma(struct drm_device *drm, struct device *dev, ...@@ -110,7 +110,7 @@ int exynos_drm_register_dma(struct drm_device *drm, struct device *dev,
void *mapping = NULL; void *mapping = NULL;
if (IS_ENABLED(CONFIG_ARM_DMA_USE_IOMMU)) if (IS_ENABLED(CONFIG_ARM_DMA_USE_IOMMU))
mapping = arm_iommu_create_mapping(&platform_bus_type, mapping = arm_iommu_create_mapping(dev,
EXYNOS_DEV_ADDR_START, EXYNOS_DEV_ADDR_SIZE); EXYNOS_DEV_ADDR_START, EXYNOS_DEV_ADDR_SIZE);
else if (IS_ENABLED(CONFIG_IOMMU_DMA)) else if (IS_ENABLED(CONFIG_IOMMU_DMA))
mapping = iommu_get_domain_for_dev(priv->dma_dev); mapping = iommu_get_domain_for_dev(priv->dma_dev);
......
...@@ -804,8 +804,7 @@ static int ipmmu_init_arm_mapping(struct device *dev) ...@@ -804,8 +804,7 @@ static int ipmmu_init_arm_mapping(struct device *dev)
if (!mmu->mapping) { if (!mmu->mapping) {
struct dma_iommu_mapping *mapping; struct dma_iommu_mapping *mapping;
mapping = arm_iommu_create_mapping(&platform_bus_type, mapping = arm_iommu_create_mapping(dev, SZ_1G, SZ_2G);
SZ_1G, SZ_2G);
if (IS_ERR(mapping)) { if (IS_ERR(mapping)) {
dev_err(mmu->dev, "failed to create ARM IOMMU mapping\n"); dev_err(mmu->dev, "failed to create ARM IOMMU mapping\n");
ret = PTR_ERR(mapping); ret = PTR_ERR(mapping);
......
...@@ -433,8 +433,7 @@ static int mtk_iommu_v1_create_mapping(struct device *dev, ...@@ -433,8 +433,7 @@ static int mtk_iommu_v1_create_mapping(struct device *dev,
mtk_mapping = data->mapping; mtk_mapping = data->mapping;
if (!mtk_mapping) { if (!mtk_mapping) {
/* MTK iommu support 4GB iova address space. */ /* MTK iommu support 4GB iova address space. */
mtk_mapping = arm_iommu_create_mapping(&platform_bus_type, mtk_mapping = arm_iommu_create_mapping(dev, 0, 1ULL << 32);
0, 1ULL << 32);
if (IS_ERR(mtk_mapping)) if (IS_ERR(mtk_mapping))
return PTR_ERR(mtk_mapping); return PTR_ERR(mtk_mapping);
......
...@@ -1965,7 +1965,7 @@ static int isp_attach_iommu(struct isp_device *isp) ...@@ -1965,7 +1965,7 @@ static int isp_attach_iommu(struct isp_device *isp)
* Create the ARM mapping, used by the ARM DMA mapping core to allocate * Create the ARM mapping, used by the ARM DMA mapping core to allocate
* VAs. This will allocate a corresponding IOMMU domain. * VAs. This will allocate a corresponding IOMMU domain.
*/ */
mapping = arm_iommu_create_mapping(&platform_bus_type, SZ_1G, SZ_2G); mapping = arm_iommu_create_mapping(isp->dev, SZ_1G, SZ_2G);
if (IS_ERR(mapping)) { if (IS_ERR(mapping)) {
dev_err(isp->dev, "failed to create ARM IOMMU mapping\n"); dev_err(isp->dev, "failed to create ARM IOMMU mapping\n");
return PTR_ERR(mapping); return PTR_ERR(mapping);
......
...@@ -105,7 +105,7 @@ enum amba_vendor { ...@@ -105,7 +105,7 @@ enum amba_vendor {
AMBA_VENDOR_LSI = 0xb6, AMBA_VENDOR_LSI = 0xb6,
}; };
extern struct bus_type amba_bustype; extern const struct bus_type amba_bustype;
#define to_amba_device(d) container_of_const(d, struct amba_device, dev) #define to_amba_device(d) container_of_const(d, struct amba_device, dev)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment