Commit 2fd632a0 authored by Shanker Donthineni's avatar Shanker Donthineni Committed by Marc Zyngier

irqchip/gic-v3-its: Enable cacheable attribute Read-allocate hints

Read-allocation hints are not enabled for both the GIC-ITS and GICR
tables. This forces the hardware to always read the table contents
from an external memory (DDR) which is slow compared to cache memory.
Most of the tables are often read by hardware. So, it's better to
enable Read-allocate hints in addition to Write-allocate hints in
order to improve the GICR_PEND, GICR_PROP, Collection, Device, and
vCPU tables lookup time.
Signed-off-by: default avatarShanker Donthineni <shankerd@codeaurora.org>
Signed-off-by: default avatarMarc Zyngier <marc.zyngier@arm.com>
parent f20cc9b0
...@@ -960,7 +960,7 @@ static bool its_parse_baser_device(struct its_node *its, struct its_baser *baser ...@@ -960,7 +960,7 @@ static bool its_parse_baser_device(struct its_node *its, struct its_baser *baser
u32 psz, u32 *order) u32 psz, u32 *order)
{ {
u64 esz = GITS_BASER_ENTRY_SIZE(its_read_baser(its, baser)); u64 esz = GITS_BASER_ENTRY_SIZE(its_read_baser(its, baser));
u64 val = GITS_BASER_InnerShareable | GITS_BASER_WaWb; u64 val = GITS_BASER_InnerShareable | GITS_BASER_RaWaWb;
u32 ids = its->device_ids; u32 ids = its->device_ids;
u32 new_order = *order; u32 new_order = *order;
bool indirect = false; bool indirect = false;
...@@ -1025,7 +1025,7 @@ static int its_alloc_tables(struct its_node *its) ...@@ -1025,7 +1025,7 @@ static int its_alloc_tables(struct its_node *its)
u64 typer = gic_read_typer(its->base + GITS_TYPER); u64 typer = gic_read_typer(its->base + GITS_TYPER);
u32 ids = GITS_TYPER_DEVBITS(typer); u32 ids = GITS_TYPER_DEVBITS(typer);
u64 shr = GITS_BASER_InnerShareable; u64 shr = GITS_BASER_InnerShareable;
u64 cache = GITS_BASER_WaWb; u64 cache = GITS_BASER_RaWaWb;
u32 psz = SZ_64K; u32 psz = SZ_64K;
int err, i; int err, i;
...@@ -1122,7 +1122,7 @@ static void its_cpu_init_lpis(void) ...@@ -1122,7 +1122,7 @@ static void its_cpu_init_lpis(void)
/* set PROPBASE */ /* set PROPBASE */
val = (page_to_phys(gic_rdists->prop_page) | val = (page_to_phys(gic_rdists->prop_page) |
GICR_PROPBASER_InnerShareable | GICR_PROPBASER_InnerShareable |
GICR_PROPBASER_WaWb | GICR_PROPBASER_RaWaWb |
((LPI_NRBITS - 1) & GICR_PROPBASER_IDBITS_MASK)); ((LPI_NRBITS - 1) & GICR_PROPBASER_IDBITS_MASK));
gicr_write_propbaser(val, rbase + GICR_PROPBASER); gicr_write_propbaser(val, rbase + GICR_PROPBASER);
...@@ -1147,7 +1147,7 @@ static void its_cpu_init_lpis(void) ...@@ -1147,7 +1147,7 @@ static void its_cpu_init_lpis(void)
/* set PENDBASE */ /* set PENDBASE */
val = (page_to_phys(pend_page) | val = (page_to_phys(pend_page) |
GICR_PENDBASER_InnerShareable | GICR_PENDBASER_InnerShareable |
GICR_PENDBASER_WaWb); GICR_PENDBASER_RaWaWb);
gicr_write_pendbaser(val, rbase + GICR_PENDBASER); gicr_write_pendbaser(val, rbase + GICR_PENDBASER);
tmp = gicr_read_pendbaser(rbase + GICR_PENDBASER); tmp = gicr_read_pendbaser(rbase + GICR_PENDBASER);
...@@ -1711,7 +1711,7 @@ static int __init its_probe_one(struct resource *res, ...@@ -1711,7 +1711,7 @@ static int __init its_probe_one(struct resource *res,
goto out_free_tables; goto out_free_tables;
baser = (virt_to_phys(its->cmd_base) | baser = (virt_to_phys(its->cmd_base) |
GITS_CBASER_WaWb | GITS_CBASER_RaWaWb |
GITS_CBASER_InnerShareable | GITS_CBASER_InnerShareable |
(ITS_CMD_QUEUE_SZ / SZ_4K - 1) | (ITS_CMD_QUEUE_SZ / SZ_4K - 1) |
GITS_CBASER_VALID); GITS_CBASER_VALID);
......
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