blob: d2058d8c8f1d2116f973ca95a85397b17dd01e19 [file] [log] [blame]
Thomas Gleixnerd2912cb2019-06-04 10:11:33 +02001/* SPDX-License-Identifier: GPL-2.0-only */
Dave Gerlachcdd17372017-01-12 14:52:18 -06002/*
3 * Defines for the SRAM driver
Dave Gerlachcdd17372017-01-12 14:52:18 -06004 */
5#ifndef __SRAM_H
6#define __SRAM_H
7
Mikko Perttunenfec29bf2021-07-15 13:34:23 +03008struct sram_config {
9 int (*init)(void);
10 bool map_only_reserved;
11};
12
Dave Gerlachcdd17372017-01-12 14:52:18 -060013struct sram_partition {
14 void __iomem *base;
15
16 struct gen_pool *pool;
17 struct bin_attribute battr;
18 struct mutex lock;
19 struct list_head list;
20};
21
22struct sram_dev {
Mikko Perttunenfec29bf2021-07-15 13:34:23 +030023 const struct sram_config *config;
24
Dave Gerlachcdd17372017-01-12 14:52:18 -060025 struct device *dev;
26 void __iomem *virt_base;
Mikko Perttunenfec29bf2021-07-15 13:34:23 +030027 bool no_memory_wc;
Dave Gerlachcdd17372017-01-12 14:52:18 -060028
29 struct gen_pool *pool;
30 struct clk *clk;
31
32 struct sram_partition *partition;
33 u32 partitions;
34};
35
36struct sram_reserve {
37 struct list_head list;
38 u32 start;
39 u32 size;
Mikko Perttunenfec29bf2021-07-15 13:34:23 +030040 struct resource res;
Dave Gerlachcdd17372017-01-12 14:52:18 -060041 bool export;
42 bool pool;
Dave Gerlach37afff02017-01-12 14:52:20 -060043 bool protect_exec;
Dave Gerlachcdd17372017-01-12 14:52:18 -060044 const char *label;
45};
Dave Gerlach728bbe72017-01-12 14:52:19 -060046
47#ifdef CONFIG_SRAM_EXEC
48int sram_check_protect_exec(struct sram_dev *sram, struct sram_reserve *block,
49 struct sram_partition *part);
50int sram_add_protect_exec(struct sram_partition *part);
51#else
52static inline int sram_check_protect_exec(struct sram_dev *sram,
53 struct sram_reserve *block,
54 struct sram_partition *part)
55{
56 return -ENODEV;
57}
58
59static inline int sram_add_protect_exec(struct sram_partition *part)
60{
61 return -ENODEV;
62}
63#endif /* CONFIG_SRAM_EXEC */
Dave Gerlachcdd17372017-01-12 14:52:18 -060064#endif /* __SRAM_H */