Commit a60715f5 authored by Kyle McMartin's avatar Kyle McMartin Committed by Kyle McMartin

parisc: factor out sid to protid conversion

Create a new __space_to_prot inline to convert the space id (mmu context)
to a protection id. Sadly it doesn't look like the #ifdef can be eliminated
since relying on the compiler to not truncate a bit on
	return (ctx >> SPACEID_SHIFT) << 1;
seems a little dodgy.
Signed-off-by: default avatarKyle McMartin <kyle@mcmartin.ca>
parent 0ca5506d
...@@ -34,16 +34,21 @@ destroy_context(struct mm_struct *mm) ...@@ -34,16 +34,21 @@ destroy_context(struct mm_struct *mm)
mm->context = 0; mm->context = 0;
} }
static inline void load_context(mm_context_t context) static inline unsigned long __space_to_prot(mm_context_t ctx)
{ {
mtsp(context, 3);
#if SPACEID_SHIFT == 0 #if SPACEID_SHIFT == 0
mtctl(context << 1,8); return context << 1;
#else #else
mtctl(context >> (SPACEID_SHIFT - 1),8); return context >> (SPACEID_SHIFT - 1);
#endif #endif
} }
static inline void load_context(mm_context_t context)
{
mtsp(context, 3);
mtctl(__space_to_prot(context), 8);
}
static inline void switch_mm(struct mm_struct *prev, struct mm_struct *next, struct task_struct *tsk) static inline void switch_mm(struct mm_struct *prev, struct mm_struct *next, struct task_struct *tsk)
{ {
......
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