Skip to content

Commit

Permalink
sh: Make 29/32-bit mode check helper generally available.
Browse files Browse the repository at this point in the history
Presently __in_29bit_mode() is only defined for the PMB case, but
it's also easily derived from the CONFIG_29BIT and CONFIG_32BIT &&
CONFIG_PMB=n cases.

Signed-off-by: Paul Mundt <lethal@linux-sh.org>
  • Loading branch information
Paul Mundt committed Jan 20, 2010
1 parent 5f24071 commit 2efa53b
Show file tree
Hide file tree
Showing 4 changed files with 14 additions and 14 deletions.
6 changes: 0 additions & 6 deletions arch/sh/include/asm/addrspace.h
Original file line number Diff line number Diff line change
Expand Up @@ -65,11 +65,5 @@
#define P3_ADDR_MAX P4SEG
#endif

#ifndef __ASSEMBLY__
#ifdef CONFIG_PMB
extern int __in_29bit_mode(void);
#endif /* CONFIG_PMB */
#endif /* __ASSEMBLY__ */

#endif /* __KERNEL__ */
#endif /* __ASM_SH_ADDRSPACE_H */
10 changes: 9 additions & 1 deletion arch/sh/include/asm/mmu.h
Original file line number Diff line number Diff line change
Expand Up @@ -31,6 +31,7 @@

#ifndef __ASSEMBLY__
#include <linux/errno.h>
#include <linux/threads.h>

/* Default "unsigned long" context */
typedef unsigned long mm_context_id_t[NR_CPUS];
Expand Down Expand Up @@ -72,6 +73,7 @@ long pmb_remap(unsigned long virt, unsigned long phys,
unsigned long size, unsigned long flags);
void pmb_unmap(unsigned long addr);
int pmb_init(void);
bool __in_29bit_mode(void);
#else
static inline long pmb_remap(unsigned long virt, unsigned long phys,
unsigned long size, unsigned long flags)
Expand All @@ -87,8 +89,14 @@ static inline int pmb_init(void)
{
return -ENODEV;
}
#endif /* CONFIG_PMB */

#ifdef CONFIG_29BIT
#define __in_29bit_mode() (1)
#else
#define __in_29bit_mode() (0)
#endif

#endif /* CONFIG_PMB */
#endif /* __ASSEMBLY__ */

#endif /* __MMU_H */
7 changes: 0 additions & 7 deletions arch/sh/mm/init.c
Original file line number Diff line number Diff line change
Expand Up @@ -338,10 +338,3 @@ EXPORT_SYMBOL_GPL(memory_add_physaddr_to_nid);
#endif

#endif /* CONFIG_MEMORY_HOTPLUG */

#ifdef CONFIG_PMB
int __in_29bit_mode(void)
{
return !(ctrl_inl(PMB_PASCR) & PASCR_SE);
}
#endif /* CONFIG_PMB */
5 changes: 5 additions & 0 deletions arch/sh/mm/pmb.c
Original file line number Diff line number Diff line change
Expand Up @@ -436,6 +436,11 @@ int __uses_jump_to_uncached pmb_init(void)
return 0;
}

bool __in_29bit_mode(void)
{
return (__raw_readl(PMB_PASCR) & PASCR_SE) == 0;
}

static int pmb_seq_show(struct seq_file *file, void *iter)
{
int i;
Expand Down

0 comments on commit 2efa53b

Please sign in to comment.