Commit e5d56763 authored by Nathan Lynch's avatar Nathan Lynch Committed by Michael Ellerman

powerpc/rtas: rename RTAS_RMOBUF_MAX to RTAS_USER_REGION_SIZE

RTAS_RMOBUF_MAX doesn't actually describe a "maximum" value in any
sense. It represents the size of an area of memory set aside for user
space to use as work areas for certain RTAS calls.

Rename it to RTAS_USER_REGION_SIZE.
Signed-off-by: default avatarNathan Lynch <nathanl@linux.ibm.com>
Reviewed-by: default avatarAndrew Donnellan <ajd@linux.ibm.com>
Signed-off-by: default avatarMichael Ellerman <mpe@ellerman.id.au>
Link: https://lore.kernel.org/r/20210408140630.205502-6-nathanl@linux.ibm.com
parent 0649cdc8
...@@ -19,8 +19,8 @@ ...@@ -19,8 +19,8 @@
#define RTAS_UNKNOWN_SERVICE (-1) #define RTAS_UNKNOWN_SERVICE (-1)
#define RTAS_INSTANTIATE_MAX (1ULL<<30) /* Don't instantiate rtas at/above this value */ #define RTAS_INSTANTIATE_MAX (1ULL<<30) /* Don't instantiate rtas at/above this value */
/* Buffer size for ppc_rtas system call. */ /* Memory set aside for sys_rtas to use with calls that need a work area. */
#define RTAS_RMOBUF_MAX (64 * 1024) #define RTAS_USER_REGION_SIZE (64 * 1024)
/* RTAS return status codes */ /* RTAS return status codes */
#define RTAS_BUSY -2 /* RTAS Busy */ #define RTAS_BUSY -2 /* RTAS Busy */
...@@ -357,7 +357,7 @@ extern void rtas_take_timebase(void); ...@@ -357,7 +357,7 @@ extern void rtas_take_timebase(void);
static inline int page_is_rtas_user_buf(unsigned long pfn) static inline int page_is_rtas_user_buf(unsigned long pfn)
{ {
unsigned long paddr = (pfn << PAGE_SHIFT); unsigned long paddr = (pfn << PAGE_SHIFT);
if (paddr >= rtas_rmo_buf && paddr < (rtas_rmo_buf + RTAS_RMOBUF_MAX)) if (paddr >= rtas_rmo_buf && paddr < (rtas_rmo_buf + RTAS_USER_REGION_SIZE))
return 1; return 1;
return 0; return 0;
} }
......
...@@ -767,6 +767,6 @@ static int ppc_rtas_tone_volume_show(struct seq_file *m, void *v) ...@@ -767,6 +767,6 @@ static int ppc_rtas_tone_volume_show(struct seq_file *m, void *v)
*/ */
static int ppc_rtas_rmo_buf_show(struct seq_file *m, void *v) static int ppc_rtas_rmo_buf_show(struct seq_file *m, void *v)
{ {
seq_printf(m, "%016lx %x\n", rtas_rmo_buf, RTAS_RMOBUF_MAX); seq_printf(m, "%016lx %x\n", rtas_rmo_buf, RTAS_USER_REGION_SIZE);
return 0; return 0;
} }
...@@ -987,10 +987,10 @@ static struct rtas_filter rtas_filters[] __ro_after_init = { ...@@ -987,10 +987,10 @@ static struct rtas_filter rtas_filters[] __ro_after_init = {
static bool in_rmo_buf(u32 base, u32 end) static bool in_rmo_buf(u32 base, u32 end)
{ {
return base >= rtas_rmo_buf && return base >= rtas_rmo_buf &&
base < (rtas_rmo_buf + RTAS_RMOBUF_MAX) && base < (rtas_rmo_buf + RTAS_USER_REGION_SIZE) &&
base <= end && base <= end &&
end >= rtas_rmo_buf && end >= rtas_rmo_buf &&
end < (rtas_rmo_buf + RTAS_RMOBUF_MAX); end < (rtas_rmo_buf + RTAS_USER_REGION_SIZE);
} }
static bool block_rtas_call(int token, int nargs, static bool block_rtas_call(int token, int nargs,
...@@ -1202,7 +1202,7 @@ void __init rtas_initialize(void) ...@@ -1202,7 +1202,7 @@ void __init rtas_initialize(void)
if (firmware_has_feature(FW_FEATURE_LPAR)) if (firmware_has_feature(FW_FEATURE_LPAR))
rtas_region = min(ppc64_rma_size, RTAS_INSTANTIATE_MAX); rtas_region = min(ppc64_rma_size, RTAS_INSTANTIATE_MAX);
#endif #endif
rtas_rmo_buf = memblock_phys_alloc_range(RTAS_RMOBUF_MAX, PAGE_SIZE, rtas_rmo_buf = memblock_phys_alloc_range(RTAS_USER_REGION_SIZE, PAGE_SIZE,
0, rtas_region); 0, rtas_region);
if (!rtas_rmo_buf) if (!rtas_rmo_buf)
panic("ERROR: RTAS: Failed to allocate %lx bytes below %pa\n", panic("ERROR: RTAS: Failed to allocate %lx bytes below %pa\n",
......
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