-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
yaml --- r: 344322 b: refs/heads/master c: 4e76b1b h: refs/heads/master v: v3
- Loading branch information
Jason Cooper
committed
Nov 22, 2012
1 parent
37920ce
commit f3110c0
Showing
28 changed files
with
775 additions
and
16 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,2 +1,2 @@ | ||
--- | ||
refs/heads/master: 9bfd143ed247fc7a9e0573dc1fbaf6d124b5cac9 | ||
refs/heads/master: 4e76b1b2329b4a19adfacd187bc2920f68126a95 |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
20 changes: 20 additions & 0 deletions
20
trunk/Documentation/devicetree/bindings/arm/armada-370-xp-pmsu.txt
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,20 @@ | ||
Power Management Service Unit(PMSU) | ||
----------------------------------- | ||
Available on Marvell SOCs: Armada 370 and Armada XP | ||
|
||
Required properties: | ||
|
||
- compatible: "marvell,armada-370-xp-pmsu" | ||
|
||
- reg: Should contain PMSU registers location and length. First pair | ||
for the per-CPU SW Reset Control registers, second pair for the | ||
Power Management Service Unit. | ||
|
||
Example: | ||
|
||
armada-370-xp-pmsu@d0022000 { | ||
compatible = "marvell,armada-370-xp-pmsu"; | ||
reg = <0xd0022100 0x430>, | ||
<0xd0020800 0x20>; | ||
}; | ||
|
21 changes: 21 additions & 0 deletions
21
trunk/Documentation/devicetree/bindings/arm/coherency-fabric.txt
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,21 @@ | ||
Coherency fabric | ||
---------------- | ||
Available on Marvell SOCs: Armada 370 and Armada XP | ||
|
||
Required properties: | ||
|
||
- compatible: "marvell,coherency-fabric" | ||
|
||
- reg: Should contain coherency fabric registers location and | ||
length. First pair for the coherency fabric registers, second pair | ||
for the per-CPU fabric registers registers. | ||
|
||
Example: | ||
|
||
coherency-fabric@d0020200 { | ||
compatible = "marvell,coherency-fabric"; | ||
reg = <0xd0020200 0xb0>, | ||
<0xd0021810 0x1c>; | ||
|
||
}; | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,155 @@ | ||
/* | ||
* Coherency fabric (Aurora) support for Armada 370 and XP platforms. | ||
* | ||
* Copyright (C) 2012 Marvell | ||
* | ||
* Yehuda Yitschak <yehuday@marvell.com> | ||
* Gregory Clement <gregory.clement@free-electrons.com> | ||
* Thomas Petazzoni <thomas.petazzoni@free-electrons.com> | ||
* | ||
* This file is licensed under the terms of the GNU General Public | ||
* License version 2. This program is licensed "as is" without any | ||
* warranty of any kind, whether express or implied. | ||
* | ||
* The Armada 370 and Armada XP SOCs have a coherency fabric which is | ||
* responsible for ensuring hardware coherency between all CPUs and between | ||
* CPUs and I/O masters. This file initializes the coherency fabric and | ||
* supplies basic routines for configuring and controlling hardware coherency | ||
*/ | ||
|
||
#include <linux/kernel.h> | ||
#include <linux/init.h> | ||
#include <linux/of_address.h> | ||
#include <linux/io.h> | ||
#include <linux/smp.h> | ||
#include <linux/dma-mapping.h> | ||
#include <linux/platform_device.h> | ||
#include <asm/smp_plat.h> | ||
#include "armada-370-xp.h" | ||
|
||
/* | ||
* Some functions in this file are called very early during SMP | ||
* initialization. At that time the device tree framework is not yet | ||
* ready, and it is not possible to get the register address to | ||
* ioremap it. That's why the pointer below is given with an initial | ||
* value matching its virtual mapping | ||
*/ | ||
static void __iomem *coherency_base = ARMADA_370_XP_REGS_VIRT_BASE + 0x20200; | ||
static void __iomem *coherency_cpu_base; | ||
|
||
/* Coherency fabric registers */ | ||
#define COHERENCY_FABRIC_CFG_OFFSET 0x4 | ||
|
||
#define IO_SYNC_BARRIER_CTL_OFFSET 0x0 | ||
|
||
static struct of_device_id of_coherency_table[] = { | ||
{.compatible = "marvell,coherency-fabric"}, | ||
{ /* end of list */ }, | ||
}; | ||
|
||
#ifdef CONFIG_SMP | ||
int coherency_get_cpu_count(void) | ||
{ | ||
int reg, cnt; | ||
|
||
reg = readl(coherency_base + COHERENCY_FABRIC_CFG_OFFSET); | ||
cnt = (reg & 0xF) + 1; | ||
|
||
return cnt; | ||
} | ||
#endif | ||
|
||
/* Function defined in coherency_ll.S */ | ||
int ll_set_cpu_coherent(void __iomem *base_addr, unsigned int hw_cpu_id); | ||
|
||
int set_cpu_coherent(unsigned int hw_cpu_id, int smp_group_id) | ||
{ | ||
if (!coherency_base) { | ||
pr_warn("Can't make CPU %d cache coherent.\n", hw_cpu_id); | ||
pr_warn("Coherency fabric is not initialized\n"); | ||
return 1; | ||
} | ||
|
||
return ll_set_cpu_coherent(coherency_base, hw_cpu_id); | ||
} | ||
|
||
static inline void mvebu_hwcc_sync_io_barrier(void) | ||
{ | ||
writel(0x1, coherency_cpu_base + IO_SYNC_BARRIER_CTL_OFFSET); | ||
while (readl(coherency_cpu_base + IO_SYNC_BARRIER_CTL_OFFSET) & 0x1); | ||
} | ||
|
||
static dma_addr_t mvebu_hwcc_dma_map_page(struct device *dev, struct page *page, | ||
unsigned long offset, size_t size, | ||
enum dma_data_direction dir, | ||
struct dma_attrs *attrs) | ||
{ | ||
if (dir != DMA_TO_DEVICE) | ||
mvebu_hwcc_sync_io_barrier(); | ||
return pfn_to_dma(dev, page_to_pfn(page)) + offset; | ||
} | ||
|
||
|
||
static void mvebu_hwcc_dma_unmap_page(struct device *dev, dma_addr_t dma_handle, | ||
size_t size, enum dma_data_direction dir, | ||
struct dma_attrs *attrs) | ||
{ | ||
if (dir != DMA_TO_DEVICE) | ||
mvebu_hwcc_sync_io_barrier(); | ||
} | ||
|
||
static void mvebu_hwcc_dma_sync(struct device *dev, dma_addr_t dma_handle, | ||
size_t size, enum dma_data_direction dir) | ||
{ | ||
if (dir != DMA_TO_DEVICE) | ||
mvebu_hwcc_sync_io_barrier(); | ||
} | ||
|
||
static struct dma_map_ops mvebu_hwcc_dma_ops = { | ||
.alloc = arm_dma_alloc, | ||
.free = arm_dma_free, | ||
.mmap = arm_dma_mmap, | ||
.map_page = mvebu_hwcc_dma_map_page, | ||
.unmap_page = mvebu_hwcc_dma_unmap_page, | ||
.get_sgtable = arm_dma_get_sgtable, | ||
.map_sg = arm_dma_map_sg, | ||
.unmap_sg = arm_dma_unmap_sg, | ||
.sync_single_for_cpu = mvebu_hwcc_dma_sync, | ||
.sync_single_for_device = mvebu_hwcc_dma_sync, | ||
.sync_sg_for_cpu = arm_dma_sync_sg_for_cpu, | ||
.sync_sg_for_device = arm_dma_sync_sg_for_device, | ||
.set_dma_mask = arm_dma_set_mask, | ||
}; | ||
|
||
static int mvebu_hwcc_platform_notifier(struct notifier_block *nb, | ||
unsigned long event, void *__dev) | ||
{ | ||
struct device *dev = __dev; | ||
|
||
if (event != BUS_NOTIFY_ADD_DEVICE) | ||
return NOTIFY_DONE; | ||
set_dma_ops(dev, &mvebu_hwcc_dma_ops); | ||
|
||
return NOTIFY_OK; | ||
} | ||
|
||
static struct notifier_block mvebu_hwcc_platform_nb = { | ||
.notifier_call = mvebu_hwcc_platform_notifier, | ||
}; | ||
|
||
int __init coherency_init(void) | ||
{ | ||
struct device_node *np; | ||
|
||
np = of_find_matching_node(NULL, of_coherency_table); | ||
if (np) { | ||
pr_info("Initializing Coherency fabric\n"); | ||
coherency_base = of_iomap(np, 0); | ||
coherency_cpu_base = of_iomap(np, 1); | ||
set_cpu_coherent(cpu_logical_map(smp_processor_id()), 0); | ||
bus_register_notifier(&platform_bus_type, | ||
&mvebu_hwcc_platform_nb); | ||
} | ||
|
||
return 0; | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,24 @@ | ||
/* | ||
* arch/arm/mach-mvebu/include/mach/coherency.h | ||
* | ||
* | ||
* Coherency fabric (Aurora) support for Armada 370 and XP platforms. | ||
* | ||
* Copyright (C) 2012 Marvell | ||
* | ||
* This file is licensed under the terms of the GNU General Public | ||
* License version 2. This program is licensed "as is" without any | ||
* warranty of any kind, whether express or implied. | ||
*/ | ||
|
||
#ifndef __MACH_370_XP_COHERENCY_H | ||
#define __MACH_370_XP_COHERENCY_H | ||
|
||
#ifdef CONFIG_SMP | ||
int coherency_get_cpu_count(void); | ||
#endif | ||
|
||
int set_cpu_coherent(int cpu_id, int smp_group_id); | ||
int coherency_init(void); | ||
|
||
#endif /* __MACH_370_XP_COHERENCY_H */ |
Oops, something went wrong.