From: Ahmad Fatoum <a.fatoum@barebox.org>
To: barebox@lists.infradead.org
Subject: [PATCH v2 3/6] resource: add MEMATTRS_ definitions for common attribute sets
Date: Mon, 26 May 2025 16:19:11 +0200 [thread overview]
Message-ID: <20250526141914.185212-4-a.fatoum@barebox.org> (raw)
In-Reply-To: <20250526141914.185212-1-a.fatoum@barebox.org>
Most SDRAM mapped by barebox falls into one of these categories,
so add some readily usable MEMATTRS_ constants.
Anything more special can OR the individual MEMATTR_ bits together.
Signed-off-by: Ahmad Fatoum <a.fatoum@pengutronix.de>
---
include/linux/ioport.h | 27 +++++++++++++++++++++++++++
1 file changed, 27 insertions(+)
diff --git a/include/linux/ioport.h b/include/linux/ioport.h
index 1e266185651f..425928df3bfe 100644
--- a/include/linux/ioport.h
+++ b/include/linux/ioport.h
@@ -133,6 +133,14 @@ enum resource_memtype {
#define MEMATTR_RO 0x00020000 /* read-only */
#define MEMATTR_SP 0x00040000 /* specific-purpose */
+#define MEMATTRS_CACHEABLE (MEMATTR_WT | MEMATTR_WC | MEMATTR_WB)
+#define MEMATTRS_RW (MEMATTRS_CACHEABLE | MEMATTR_XP)
+#define MEMATTRS_RO (MEMATTRS_CACHEABLE | MEMATTR_XP | MEMATTR_RO)
+#define MEMATTRS_RX (MEMATTRS_CACHEABLE | MEMATTR_RO)
+#define MEMATTRS_RWX (MEMATTRS_CACHEABLE) /* TODO: remove all */
+#define MEMATTRS_RW_DEVICE (MEMATTR_UC | MEMATTR_XP)
+#define MEMATTRS_FAULT (MEMATTR_UC | MEMATTR_XP | MEMATTR_RP | MEMATTR_RO)
+
/* PnP I/O specific bits (IORESOURCE_BITS) */
#define IORESOURCE_IO_16BIT_ADDR (1<<0)
#define IORESOURCE_IO_FIXED (1<<1)
@@ -204,5 +212,24 @@ int release_region(struct resource *res);
extern struct resource iomem_resource;
extern struct resource ioport_resource;
+static inline void reserve_resource(struct resource *res)
+{
+ res->type = MEMTYPE_RESERVED;
+ /* Reserved memory is used for secure memory that should
+ * be hardware-protected independently of MMU flags.
+ * We map it as device memory, so we can still test
+ * if it's indeed inaccessible
+ */
+ res->attrs = MEMATTRS_RW_DEVICE;
+ res->flags |= IORESOURCE_TYPE_VALID;
+}
+
+static inline bool is_reserved_resource(const struct resource *res)
+{
+ if (res->flags & IORESOURCE_TYPE_VALID)
+ return res->type == MEMTYPE_RESERVED;
+ return false;
+}
+
#endif /* __ASSEMBLY__ */
#endif /* _LINUX_IOPORT_H */
--
2.39.5
next prev parent reply other threads:[~2025-05-26 14:19 UTC|newest]
Thread overview: 7+ messages / expand[flat|nested] mbox.gz Atom feed top
2025-05-26 14:19 [PATCH v2 0/6] resource: record memory type/attrs on all SDRAM Ahmad Fatoum
2025-05-26 14:19 ` [PATCH v2 1/6] memory: export inside_barebox_area Ahmad Fatoum
2025-05-26 14:19 ` [PATCH v2 2/6] resource: record EFI memory type and attributes Ahmad Fatoum
2025-05-26 14:19 ` Ahmad Fatoum [this message]
2025-05-26 14:19 ` [PATCH v2 4/6] drivers: tee: optee: separate local variables for each resource Ahmad Fatoum
2025-05-26 14:19 ` [PATCH v2 5/6] resource: supply memory type/attrs on all SDRAM requests Ahmad Fatoum
2025-05-26 14:19 ` [PATCH v2 6/6] resource: retire IORESOURCE_BUSY in favor of resource::type Ahmad Fatoum
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20250526141914.185212-4-a.fatoum@barebox.org \
--to=a.fatoum@barebox.org \
--cc=barebox@lists.infradead.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox