kernel/0022-feat-spram-Treat-spram-as-part-of-the-sys-memory-spa.patch

242 lines
6.9 KiB
Diff

From dcf766b00e3600ff8d0475019f4024adf16d7089 Mon Sep 17 00:00:00 2001
From: linmin <linmin@eswincomputing.com>
Date: Thu, 23 May 2024 16:30:23 +0800
Subject: [PATCH 022/222] feat(spram):Treat spram as part of the sys memory
space
Changelogs:
1.Move spram space into the system memory space of the eic7700-evb.dts
and eic7700-evb-a2.dts. Then there is no need to call memblock_reserve()
for adding spram into memblock.
---
arch/riscv/boot/dts/eswin/eic7700-evb-a2.dts | 11 ++--
arch/riscv/boot/dts/eswin/eic7700-evb.dts | 11 ++--
drivers/memory/eswin/codacache/llc_spram.c | 53 ++++----------------
3 files changed, 17 insertions(+), 58 deletions(-)
diff --git a/arch/riscv/boot/dts/eswin/eic7700-evb-a2.dts b/arch/riscv/boot/dts/eswin/eic7700-evb-a2.dts
index cddfc166e851..8c2b945ed8a9 100644
--- a/arch/riscv/boot/dts/eswin/eic7700-evb-a2.dts
+++ b/arch/riscv/boot/dts/eswin/eic7700-evb-a2.dts
@@ -56,13 +56,13 @@ chosen {
cpus {
timebase-frequency = <RTCCLK_FREQ>;
};
-/*
+
memory@59000000 {
device_type = "memory";
reg = <0x0 0x59000000 0x0 0x400000>;
numa-node-id = <0>;
};
-*/
+
memory@80000000 {
device_type = "memory";
reg = <0x0 0x80000000 MEMORY_SIZE_H MEMORY_SIZE_L>;
@@ -82,12 +82,12 @@ linux,cma {
alloc-ranges = <0x0 0x80000000 MEMORY_SIZE_H MEMORY_SIZE_L>;
linux,cma-default;
};
-/*
+
npu0_reserved: sprammemory@59000000 {
no-map;
reg = <0x0 0x59000000 0x0 0x400000>;
};
-*/
+
/*
dsp_reserved0: dsp@90000000 {
compatible = "shared-dma-pool";
@@ -146,9 +146,6 @@ reset_test@1e00e000 {
reset-names = "bus", "core", "dbg";
};
};
- npu0_reserved: sprammemory@59000000 {
- reg = <0x0 0x59000000 0x0 0x400000>;
- };
leds {
compatible = "gpio-leds";
diff --git a/arch/riscv/boot/dts/eswin/eic7700-evb.dts b/arch/riscv/boot/dts/eswin/eic7700-evb.dts
index 34bc531d58f9..c627133f179c 100644
--- a/arch/riscv/boot/dts/eswin/eic7700-evb.dts
+++ b/arch/riscv/boot/dts/eswin/eic7700-evb.dts
@@ -55,13 +55,13 @@ chosen {
cpus {
timebase-frequency = <RTCCLK_FREQ>;
};
-/*
+
memory@59000000 {
device_type = "memory";
reg = <0x0 0x59000000 0x0 0x400000>;
numa-node-id = <0>;
};
-*/
+
memory@80000000 {
device_type = "memory";
reg = <0x0 0x80000000 MEMORY_SIZE_H MEMORY_SIZE_L>;
@@ -81,12 +81,12 @@ linux,cma {
alloc-ranges = <0x0 0x80000000 MEMORY_SIZE_H MEMORY_SIZE_L>;
linux,cma-default;
};
-/*
+
npu0_reserved: sprammemory@59000000 {
no-map;
reg = <0x0 0x59000000 0x0 0x400000>;
};
-*/
+
/*
dsp_reserved0: dsp@90000000 {
compatible = "shared-dma-pool";
@@ -145,9 +145,6 @@ reset_test@1e00e000 {
reset-names = "bus", "core", "dbg";
};
};
- npu0_reserved: sprammemory@59000000 {
- reg = <0x0 0x59000000 0x0 0x400000>;
- };
};
&d0_clock {
diff --git a/drivers/memory/eswin/codacache/llc_spram.c b/drivers/memory/eswin/codacache/llc_spram.c
index 8bd0912af4b7..2e343f1da43f 100644
--- a/drivers/memory/eswin/codacache/llc_spram.c
+++ b/drivers/memory/eswin/codacache/llc_spram.c
@@ -895,13 +895,6 @@ static int llc_resource_parse(struct platform_device *pdev)
(unsigned int)resource_size(&res_spram),
npu_spram_size);
- /* add to memblock and reserve it */
- ret = memblock_reserve(res_spram.start, npu_spram_size);
- if (ret) {
- dev_err(dev, "Failed to reserve spram!!!\n");
- goto out_spram_region;
- }
-
spram->phys_addr = res_spram.start;
spram->virt_base = devm_ioremap(&pdev->dev, spram->phys_addr, npu_spram_size);
if (spram->virt_base == NULL) {
@@ -1174,7 +1167,7 @@ static void spram_heap_dma_buf_release(struct dma_buf *dmabuf)
struct sg_table *table;
struct spram_dev *spram = buffer->heap->spram;
struct scatterlist *sg;
- int i, page_num = 0;
+ int i;
table = &buffer->sg_table;
for_each_sgtable_sg(table, sg, i) {
@@ -1184,15 +1177,10 @@ static void spram_heap_dma_buf_release(struct dma_buf *dmabuf)
#else
void *vaddr = spram_phys_to_virt(spram, page_to_phys(page));
#endif
- gen_pool_free(spram->pool, (unsigned long)vaddr, PAGE_SIZE);
- page_num++;
+ gen_pool_free(spram->pool, (unsigned long)vaddr, page_size(page));
}
sg_free_table(table);
kfree(buffer);
- pr_info("%s, ---buffer->len=0x%lx, freed size=0x%x, Available:0x%lx\n",
- __func__, buffer->len,
- (page_num << PAGE_SHIFT), gen_pool_avail(spram->pool));
-
}
static const struct dma_buf_ops spram_heap_buf_ops = {
@@ -1208,34 +1196,17 @@ static const struct dma_buf_ops spram_heap_buf_ops = {
.release = spram_heap_dma_buf_release,
};
-struct spram_page {
- struct list_head lru;
- struct page *page;
-};
-
static int spram_noncontiguous_alloc(struct spram_dev *spram, size_t len, struct sg_table *table)
{
struct gen_pool *pool = spram->pool;
struct list_head pages;
- struct page *page;
+ struct page *page, *tmp_page;
struct scatterlist *sg;
unsigned long size_remaining = len;
phys_addr_t phys_addr;
void *vaddr;
- unsigned int page_num;
- struct spram_page *spram_pages, *spram_page, *tmp_spram_page;
int i, ret = -ENOMEM;
- page_num = size_remaining / PAGE_SIZE;
- pr_info("%s, ---try to alloc len=0x%lx, Available:0x%lx\n", __func__, len, gen_pool_avail(spram->pool));
-
- spram_pages = kzalloc(page_num * sizeof(struct spram_page), GFP_KERNEL);
- if (!spram_pages) {
- pr_err("unable to allocate memory.\n");
- return -ENOMEM;
- }
- spram_page = spram_pages;
-
INIT_LIST_HEAD(&pages);
i = 0;
while (size_remaining > 0) {
@@ -1253,45 +1224,39 @@ static int spram_noncontiguous_alloc(struct spram_dev *spram, size_t len, struct
goto free_spram;
page = phys_to_page(phys_addr);
- // pr_debug("---%s:%d, page_to_phys:0x%x,page:0x%px, spram_page:0x%px\n",
- // __func__, __LINE__, (unsigned int)page_to_phys(page), page, spram_page);
+ pr_debug("---%s:%d, phys_to_page->page_to_phys:0x%x,page:0x%px\n",
+ __func__, __LINE__, (unsigned int)page_to_phys(page), page);
/* page->virtual is used for recording the gen pool vaddr which is needed when releasing spram memory */
#ifdef WANT_PAGE_VIRTUAL
page->virtual = vaddr;
set_page_address(page, vaddr);
#endif
- spram_page->page = page;
- list_add_tail(&spram_page->lru, &pages);
+ list_add_tail(&page->lru, &pages);
size_remaining -= PAGE_SIZE;
i++;
- spram_page++;
}
if (sg_alloc_table(table, i, GFP_KERNEL))
goto free_spram;
sg = table->sgl;
- list_for_each_entry_safe(spram_page, tmp_spram_page, &pages, lru) {
- page = spram_page->page;
+ list_for_each_entry_safe(page, tmp_page, &pages, lru) {
sg_set_page(sg, page, PAGE_SIZE, 0);
sg = sg_next(sg);
- list_del(&spram_page->lru);
+ list_del(&page->lru);
}
- kfree(spram_pages);
return 0;
free_spram:
- list_for_each_entry_safe(spram_page, tmp_spram_page, &pages, lru) {
+ list_for_each_entry_safe(page, tmp_page, &pages, lru) {
#ifdef WANT_PAGE_VIRTUAL
vaddr = page_address(page);
#else
- page = spram_page->page;
vaddr = spram_phys_to_virt(spram, page_to_phys(page));
#endif
gen_pool_free(pool, (unsigned long)vaddr, PAGE_SIZE);
}
- kfree(spram_pages);
return ret;
}
--
2.47.0