Commit b48dbe58 authored by Russell King's avatar Russell King

Merge flint.arm.linux.org.uk:/usr/src/linux-bk-2.5/linux-2.5

into flint.arm.linux.org.uk:/usr/src/linux-bk-2.5/linux-2.5-rmk
parents 0b2e8f29 2031ab46
...@@ -18,14 +18,14 @@ ...@@ -18,14 +18,14 @@
* Please select one of the following when turning on debugging. * Please select one of the following when turning on debugging.
*/ */
#ifdef DEBUG #ifdef DEBUG
#if 0 /* DC21285-type */ #if defined(CONFIG_DEBUG_DC21285_PORT)
.macro loadsp, rb .macro loadsp, rb
mov \rb, #0x7c000000 mov \rb, #0x7c000000
.endm .endm
.macro writeb, rb .macro writeb, rb
strb \rb, [r3, #0x3f8] strb \rb, [r3, #0x3f8]
.endm .endm
#elif 0 /* RiscPC-type */ #elif defined(CONFIG_ARCH_RPC)
.macro loadsp, rb .macro loadsp, rb
mov \rb, #0x03000000 mov \rb, #0x03000000
orr \rb, \rb, #0x00010000 orr \rb, \rb, #0x00010000
...@@ -33,7 +33,7 @@ ...@@ -33,7 +33,7 @@
.macro writeb, rb .macro writeb, rb
strb \rb, [r3, #0x3f8 << 2] strb \rb, [r3, #0x3f8 << 2]
.endm .endm
#elif 0 /* integrator-type */ #elif defined(CONFIG_ARCH_INTEGRATOR)
.macro loadsp, rb .macro loadsp, rb
mov \rb, #0x16000000 mov \rb, #0x16000000
.endm .endm
......
...@@ -694,7 +694,6 @@ dep_bool ' Verbose kernel error messages' CONFIG_DEBUG_ERRORS $CONFIG_DEBUG_KER ...@@ -694,7 +694,6 @@ dep_bool ' Verbose kernel error messages' CONFIG_DEBUG_ERRORS $CONFIG_DEBUG_KER
dep_bool ' Kernel low-level debugging functions' CONFIG_DEBUG_LL $CONFIG_DEBUG_KERNEL dep_bool ' Kernel low-level debugging functions' CONFIG_DEBUG_LL $CONFIG_DEBUG_KERNEL
dep_bool ' Kernel low-level debugging messages via footbridge serial port' CONFIG_DEBUG_DC21285_PORT $CONFIG_DEBUG_LL $CONFIG_FOOTBRIDGE dep_bool ' Kernel low-level debugging messages via footbridge serial port' CONFIG_DEBUG_DC21285_PORT $CONFIG_DEBUG_LL $CONFIG_FOOTBRIDGE
dep_bool ' Kernel low-level debugging messages via UART2' CONFIG_DEBUG_CLPS711X_UART2 $CONFIG_DEBUG_LL $CONFIG_ARCH_CLPS711X dep_bool ' Kernel low-level debugging messages via UART2' CONFIG_DEBUG_CLPS711X_UART2 $CONFIG_DEBUG_LL $CONFIG_ARCH_CLPS711X
dep_bool ' Kernel low-level debugging messages via SA1100 Ser3 (otherwise Ser1)' CONFIG_DEBUG_LL_SER3 $CONFIG_DEBUG_LL $CONFIG_ARCH_SA1100
endmenu endmenu
source lib/Config.in source lib/Config.in
...@@ -385,6 +385,55 @@ ...@@ -385,6 +385,55 @@
bne 1001b bne 1001b
.endm .endm
#elif defined(CONFIG_ARCH_IQ80310)
.macro addruart,rx
mov \rx, #0xfe000000 @ physical
orr \rx, \rx, #0x00810000
.endm
.macro senduart,rd,rx
strb \rd, [\rx]
.endm
.macro busyuart,rd,rx
1002: ldrb \rd, [\rx, #0x5]
and \rd, \rd, #0x60
teq \rd, #0x60
bne 1002b
.endm
.macro waituart,rd,rx
1001: ldrb \rd, [\rx, #0x6]
tst \rd, #0x10
beq 1001b
.endm
#elif defined(CONFIG_ARCH_ADI_EVB)
.macro addruart,rx
mrc p15, 0, \rx, c1, c0
tst \rx, #1 @ MMU enabled?
mov \rx, #0x00400000 @ physical base address
orrne \rx, \rx, #0xff000000 @ virtual base
.endm
.macro senduart,rd,rx
strb \rd, [\rx]
.endm
.macro busyuart,rd,rx
1002: ldrb \rd, [\rx, #0x5]
and \rd, \rd, #0x60
teq \rd, #0x60
bne 1002b
.endm
.macro waituart,rd,rx
1001: ldrb \rd, [\rx, #0x6]
tst \rd, #0x10
beq 1001b
.endm
#else #else
#error Unknown architecture #error Unknown architecture
#endif #endif
......
...@@ -6,7 +6,6 @@ ...@@ -6,7 +6,6 @@
#include <asm/errno.h> #include <asm/errno.h>
#include <asm/hardware.h> #include <asm/hardware.h>
#include <asm/arch/irqs.h> #include <asm/arch/irqs.h>
#include <asm/proc-fns.h>
#ifndef MODE_SVC #ifndef MODE_SVC
#define MODE_SVC 0x13 #define MODE_SVC 0x13
......
...@@ -27,6 +27,7 @@ ...@@ -27,6 +27,7 @@
#include <asm/atomic.h> #include <asm/atomic.h>
#include <asm/io.h> #include <asm/io.h>
#include <asm/pgalloc.h>
#include <asm/pgtable.h> #include <asm/pgtable.h>
#include <asm/system.h> #include <asm/system.h>
#include <asm/uaccess.h> #include <asm/uaccess.h>
...@@ -335,6 +336,25 @@ static int bad_syscall(int n, struct pt_regs *regs) ...@@ -335,6 +336,25 @@ static int bad_syscall(int n, struct pt_regs *regs)
return regs->ARM_r0; return regs->ARM_r0;
} }
static inline void
do_cache_op(unsigned long start, unsigned long end, int flags)
{
struct vm_area_struct *vma;
if (end < start)
return;
vma = find_vma(current->active_mm, start);
if (vma && vma->vm_start < end) {
if (start < vma->vm_start)
start = vma->vm_start;
if (end > vma->vm_end)
end = vma->vm_end;
flush_cache_range(vma, start, end);
}
}
/* /*
* Handle all unrecognised system calls. * Handle all unrecognised system calls.
* 0x9f0000 - 0x9fffff are some more esoteric system calls * 0x9f0000 - 0x9fffff are some more esoteric system calls
...@@ -392,7 +412,7 @@ asmlinkage int arm_syscall(int no, struct pt_regs *regs) ...@@ -392,7 +412,7 @@ asmlinkage int arm_syscall(int no, struct pt_regs *regs)
* the specified region). * the specified region).
*/ */
case NR(cacheflush): case NR(cacheflush):
cpu_cache_clean_invalidate_range(regs->ARM_r0, regs->ARM_r1, 1); do_cache_op(regs->ARM_r0, regs->ARM_r1, regs->ARM_r2);
return 0; return 0;
case NR(usr26): case NR(usr26):
......
...@@ -62,7 +62,7 @@ static u_long iq80310_read_timer (void) ...@@ -62,7 +62,7 @@ static u_long iq80310_read_timer (void)
*/ */
static unsigned long iq80310_gettimeoffset (void) static unsigned long iq80310_gettimeoffset (void)
{ {
unsigned long elapsed, usec, tmp1; unsigned long elapsed, usec;
unsigned int stat1, stat2; unsigned int stat1, stat2;
stat1 = *(volatile u8 *)IQ80310_INT_STAT; stat1 = *(volatile u8 *)IQ80310_INT_STAT;
......
...@@ -187,9 +187,9 @@ fixup_badge4(struct machine_desc *desc, struct param_struct *params, ...@@ -187,9 +187,9 @@ fixup_badge4(struct machine_desc *desc, struct param_struct *params,
static struct map_desc badge4_io_desc[] __initdata = { static struct map_desc badge4_io_desc[] __initdata = {
/* virtual physical length domain r w c b */ /* virtual physical length domain r w c b */
{0xf1000000, 0x08000000, 0x00100000, DOMAIN_IO, 1,1,0,0},/* SRAM bank 1 */ {0xf1000000, 0x08000000, 0x00100000, DOMAIN_IO, 0,1,0,0},/* SRAM bank 1 */
{0xf2000000, 0x10000000, 0x00100000, DOMAIN_IO, 1,1,0,0},/* SRAM bank 2 */ {0xf2000000, 0x10000000, 0x00100000, DOMAIN_IO, 0,1,0,0},/* SRAM bank 2 */
{0xf4000000, 0x48000000, 0x00100000, DOMAIN_IO, 1,1,0,0},/* SA-1111 */ {0xf4000000, 0x48000000, 0x00100000, DOMAIN_IO, 0,1,0,0},/* SA-1111 */
LAST_DESC LAST_DESC
}; };
......
...@@ -399,24 +399,6 @@ static u_int h3600_uart_get_mctrl(struct uart_port *port) ...@@ -399,24 +399,6 @@ static u_int h3600_uart_get_mctrl(struct uart_port *port)
return ret; return ret;
} }
static void h3600_dcd_intr(int irq, void *dev_id, struct pt_regs *regs)
{
struct uart_info *info = dev_id;
/* Note: should only call this if something has changed */
spin_lock_irq(&info->lock);
uart_handle_dcd_change(info, !(GPLR & GPIO_H3600_COM_DCD));
spin_unlock_irq(&info->lock);
}
static void h3600_cts_intr(int irq, void *dev_id, struct pt_regs *regs)
{
struct uart_info *info = dev_id;
/* Note: should only call this if something has changed */
spin_lock_irq(&info->lock);
uart_handle_cts_change(info, !(GPLR & GPIO_H3600_COM_CTS));
spin_unlock_irq(&info->lock);
}
static void h3600_uart_pm(struct uart_port *port, u_int state, u_int oldstate) static void h3600_uart_pm(struct uart_port *port, u_int state, u_int oldstate)
{ {
if (port->mapbase == _Ser2UTCR0) { if (port->mapbase == _Ser2UTCR0) {
...@@ -444,47 +426,11 @@ static int h3600_uart_set_wake(struct uart_port *port, u_int enable) ...@@ -444,47 +426,11 @@ static int h3600_uart_set_wake(struct uart_port *port, u_int enable)
return err; return err;
} }
static int h3600_uart_open(struct uart_port *port, struct uart_info *info)
{
int ret = 0;
if (port->mapbase == _Ser2UTCR0) {
Ser2UTCR4 = UTCR4_HSE;
Ser2HSCR0 = 0;
Ser2HSSR0 = HSSR0_EIF | HSSR0_TUR |
HSSR0_RAB | HSSR0_FRE;
} else if (port->mapbase == _Ser3UTCR0) {
set_GPIO_IRQ_edge(GPIO_H3600_COM_DCD|GPIO_H3600_COM_CTS,
GPIO_BOTH_EDGES);
ret = request_irq(IRQ_GPIO_H3600_COM_DCD, h3600_dcd_intr,
0, "RS232 DCD", info);
if (ret)
return ret;
ret = request_irq(IRQ_GPIO_H3600_COM_CTS, h3600_cts_intr,
0, "RS232 CTS", info);
if (ret)
free_irq(IRQ_GPIO_H3600_COM_DCD, info);
}
return ret;
}
static void h3600_uart_close(struct uart_port *port, struct uart_info *info)
{
if (port->mapbase == _Ser3UTCR0) {
free_irq(IRQ_GPIO_H3600_COM_DCD, info);
free_irq(IRQ_GPIO_H3600_COM_CTS, info);
}
}
static struct sa1100_port_fns h3600_port_fns __initdata = { static struct sa1100_port_fns h3600_port_fns __initdata = {
set_mctrl: h3600_uart_set_mctrl, set_mctrl: h3600_uart_set_mctrl,
get_mctrl: h3600_uart_get_mctrl, get_mctrl: h3600_uart_get_mctrl,
pm: h3600_uart_pm, pm: h3600_uart_pm,
set_wake: h3600_uart_set_wake, set_wake: h3600_uart_set_wake,
open: h3600_uart_open,
close: h3600_uart_close,
}; };
static struct map_desc h3600_io_desc[] __initdata = { static struct map_desc h3600_io_desc[] __initdata = {
......
...@@ -17,6 +17,8 @@ sa1100_leds_init(void) ...@@ -17,6 +17,8 @@ sa1100_leds_init(void)
{ {
if (machine_is_assabet()) if (machine_is_assabet())
leds_event = assabet_leds_event; leds_event = assabet_leds_event;
if (machine_is_consus())
leds_event = consus_leds_event;
if (machine_is_brutus()) if (machine_is_brutus())
leds_event = brutus_leds_event; leds_event = brutus_leds_event;
if (machine_is_cerf()) if (machine_is_cerf())
......
extern void assabet_leds_event(led_event_t evt); extern void assabet_leds_event(led_event_t evt);
extern void consus_leds_event(led_event_t evt);
extern void brutus_leds_event(led_event_t evt); extern void brutus_leds_event(led_event_t evt);
extern void cerf_leds_event(led_event_t evt); extern void cerf_leds_event(led_event_t evt);
extern void flexanet_leds_event(led_event_t evt); extern void flexanet_leds_event(led_event_t evt);
......
...@@ -243,10 +243,8 @@ void update_mmu_cache(struct vm_area_struct *vma, unsigned long addr, pte_t pte) ...@@ -243,10 +243,8 @@ void update_mmu_cache(struct vm_area_struct *vma, unsigned long addr, pte_t pte)
struct page *page = pte_page(pte); struct page *page = pte_page(pte);
if (VALID_PAGE(page) && page->mapping) { if (VALID_PAGE(page) && page->mapping) {
if (test_and_clear_bit(PG_dcache_dirty, &page->flags)) { if (test_and_clear_bit(PG_dcache_dirty, &page->flags))
unsigned long kvirt = (unsigned long)page_address(page); __flush_dcache_page(page);
cpu_cache_clean_invalidate_range(kvirt, kvirt + PAGE_SIZE, 0);
}
make_coherent(vma, addr, page); make_coherent(vma, addr, page);
} }
......
...@@ -60,10 +60,6 @@ __setup("nowb", nowrite_setup); ...@@ -60,10 +60,6 @@ __setup("nowb", nowrite_setup);
#define FIRST_KERNEL_PGD_NR (FIRST_USER_PGD_NR + USER_PTRS_PER_PGD) #define FIRST_KERNEL_PGD_NR (FIRST_USER_PGD_NR + USER_PTRS_PER_PGD)
#define clean_cache_area(start,size) \
cpu_cache_clean_invalidate_range((unsigned long)start, ((unsigned long)start) + size, 0);
/* /*
* need to get a 16k page for level 1 * need to get a 16k page for level 1
*/ */
...@@ -114,10 +110,7 @@ pgd_t *get_pgd_slow(struct mm_struct *mm) ...@@ -114,10 +110,7 @@ pgd_t *get_pgd_slow(struct mm_struct *mm)
memcpy(new_pgd + FIRST_KERNEL_PGD_NR, init_pgd + FIRST_KERNEL_PGD_NR, memcpy(new_pgd + FIRST_KERNEL_PGD_NR, init_pgd + FIRST_KERNEL_PGD_NR,
(PTRS_PER_PGD - FIRST_KERNEL_PGD_NR) * sizeof(pgd_t)); (PTRS_PER_PGD - FIRST_KERNEL_PGD_NR) * sizeof(pgd_t));
/* clean_dcache_area(new_pgd, PTRS_PER_PGD * sizeof(pgd_t));
* FIXME: this should not be necessary
*/
clean_cache_area(new_pgd, PTRS_PER_PGD * sizeof(pgd_t));
return new_pgd; return new_pgd;
......
/*
* We need constants.h for:
* VMA_VM_MM
* VMA_VM_FLAGS
* VM_EXEC
*/
#include <asm/constants.h>
#include <asm/thread_info.h> #include <asm/thread_info.h>
/* /*
......
...@@ -79,10 +79,12 @@ ENTRY(v3_flush_kern_tlb_page) ...@@ -79,10 +79,12 @@ ENTRY(v3_flush_kern_tlb_page)
mcr p15, 0, r0, c6, c0, 0 @ invalidate TLB entry mcr p15, 0, r0, c6, c0, 0 @ invalidate TLB entry
mov pc, lr mov pc, lr
.section ".text.init", #alloc, #execinstr
ENTRY(v3_tlb_fns) ENTRY(v3_tlb_fns)
.word v3_flush_kern_tlb_all .long v3_flush_kern_tlb_all
.word v3_flush_user_tlb_mm .long v3_flush_user_tlb_mm
.word v3_flush_user_tlb_range .long v3_flush_user_tlb_range
.word v3_flush_user_tlb_page .long v3_flush_user_tlb_page
.word v3_flush_kern_tlb_page .long v3_flush_kern_tlb_page
...@@ -98,9 +98,11 @@ ENTRY(v4_flush_kern_tlb_page) ...@@ -98,9 +98,11 @@ ENTRY(v4_flush_kern_tlb_page)
mcr p15, 0, r0, c8, c6, 1 @ invalidate D TLB entry mcr p15, 0, r0, c8, c6, 1 @ invalidate D TLB entry
mov pc, lr mov pc, lr
.section ".text.init", #alloc, #execinstr
ENTRY(v4_tlb_fns) ENTRY(v4_tlb_fns)
.word v4_flush_kern_tlb_all .long v4_flush_kern_tlb_all
.word v4_flush_user_tlb_mm .long v4_flush_user_tlb_mm
.word v4_flush_user_tlb_range .long v4_flush_user_tlb_range
.word v4_flush_user_tlb_page .long v4_flush_user_tlb_page
.word v4_flush_kern_tlb_page .long v4_flush_kern_tlb_page
...@@ -144,17 +144,19 @@ ENTRY(v4wbi_flush_kern_tlb_page) ...@@ -144,17 +144,19 @@ ENTRY(v4wbi_flush_kern_tlb_page)
mcr p15, 0, r0, c8, c6, 1 @ invalidate D TLB entry mcr p15, 0, r0, c8, c6, 1 @ invalidate D TLB entry
mov pc, lr mov pc, lr
.section ".text.init", #alloc, #execinstr
ENTRY(v4wb_tlb_fns) ENTRY(v4wb_tlb_fns)
.word v4wb_flush_kern_tlb_all .long v4wb_flush_kern_tlb_all
.word v4wb_flush_user_tlb_mm .long v4wb_flush_user_tlb_mm
.word v4wb_flush_user_tlb_range .long v4wb_flush_user_tlb_range
.word v4wb_flush_user_tlb_page .long v4wb_flush_user_tlb_page
.word v4wb_flush_kern_tlb_page .long v4wb_flush_kern_tlb_page
ENTRY(v4wbi_tlb_fns) ENTRY(v4wbi_tlb_fns)
.word v4wbi_flush_kern_tlb_all .long v4wbi_flush_kern_tlb_all
.word v4wbi_flush_user_tlb_mm .long v4wbi_flush_user_tlb_mm
.word v4wbi_flush_user_tlb_range .long v4wbi_flush_user_tlb_range
.word v4wbi_flush_user_tlb_page .long v4wbi_flush_user_tlb_page
.word v4wbi_flush_kern_tlb_page .long v4wbi_flush_kern_tlb_page
...@@ -6,7 +6,7 @@ ...@@ -6,7 +6,7 @@
# To add an entry into this database, please see Documentation/arm/README, # To add an entry into this database, please see Documentation/arm/README,
# or contact rmk@arm.linux.org.uk # or contact rmk@arm.linux.org.uk
# #
# Last update: Sun Feb 24 17:43:42 2002 # Last update: Fri Mar 8 20:08:02 2002
# #
# machine_is_xxx CONFIG_xxxx MACH_TYPE_xxx number # machine_is_xxx CONFIG_xxxx MACH_TYPE_xxx number
# #
...@@ -147,7 +147,7 @@ whitechapel SA1100_WHITECHAPEL WHITECHAPEL 135 ...@@ -147,7 +147,7 @@ whitechapel SA1100_WHITECHAPEL WHITECHAPEL 135
h3100 SA1100_H3100 H3100 136 h3100 SA1100_H3100 H3100 136
h3800 SA1100_H3800 H3800 137 h3800 SA1100_H3800 H3800 137
blue_v1 ARCH_BLUE_V1 BLUE_V1 138 blue_v1 ARCH_BLUE_V1 BLUE_V1 138
xscale_cerf ARCH_XSCALE_CERF XSCALE_CERF 139 pxa_cerf ARCH_PXA_CERF PXA_CERF 139
arm7tevb ARCH_ARM7TEVB ARM7TEVB 140 arm7tevb ARCH_ARM7TEVB ARM7TEVB 140
d7400 ARCH_D7400 D7400 141 d7400 ARCH_D7400 D7400 141
piranha ARCH_PIRANHA PIRANHA 142 piranha ARCH_PIRANHA PIRANHA 142
...@@ -174,3 +174,5 @@ h7202 ARCH_H7202 H7202 162 ...@@ -174,3 +174,5 @@ h7202 ARCH_H7202 H7202 162
amico ARCH_AMICO AMICO 163 amico ARCH_AMICO AMICO 163
iam SA1100_IAM IAM 164 iam SA1100_IAM IAM 164
tt530 SA1100_TT530 TT530 165 tt530 SA1100_TT530 TT530 165
sam2400 ARCH_SAM2400 SAM2400 166
jornada56x ARCH_JORNADA56X JORNADA56X 167
...@@ -348,7 +348,7 @@ static struct miscdevice ds1620_miscdev = { ...@@ -348,7 +348,7 @@ static struct miscdevice ds1620_miscdev = {
&ds1620_fops &ds1620_fops
}; };
int __init ds1620_init(void) static int __init ds1620_init(void)
{ {
int ret; int ret;
struct therm th, th_start; struct therm th, th_start;
...@@ -400,7 +400,7 @@ int __init ds1620_init(void) ...@@ -400,7 +400,7 @@ int __init ds1620_init(void)
return 0; return 0;
} }
void __exit ds1620_exit(void) static void __exit ds1620_exit(void)
{ {
#ifdef THERM_USE_PROC #ifdef THERM_USE_PROC
remove_proc_entry("therm", NULL); remove_proc_entry("therm", NULL);
......
...@@ -672,7 +672,7 @@ static int __init nwflash_init(void) ...@@ -672,7 +672,7 @@ static int __init nwflash_init(void)
if (machine_is_netwinder()) { if (machine_is_netwinder()) {
int id; int id;
FLASH_BASE = __ioremap(DC21285_FLASH, KFLASH_SIZE4, 0); FLASH_BASE = ioremap(DC21285_FLASH, KFLASH_SIZE4);
if (!FLASH_BASE) if (!FLASH_BASE)
goto out; goto out;
......
...@@ -27,13 +27,23 @@ if [ "$CONFIG_FB" = "y" ]; then ...@@ -27,13 +27,23 @@ if [ "$CONFIG_FB" = "y" ]; then
fi fi
fi fi
fi fi
if [ "$CONFIG_ARCH_ACORN" = "y" ]; then if [ "$CONFIG_ARM" = "y" ]; then
bool ' Acorn VIDC support' CONFIG_FB_ACORN dep_bool ' Acorn VIDC support' CONFIG_FB_ACORN $CONFIG_ARCH_ACORN
fi dep_bool ' Anakin LCD support' CONFIG_FB_ANAKIN $CONFIG_ARCH_ANAKIN
dep_tristate ' Cyber2000 support' CONFIG_FB_CYBER2000 $CONFIG_PCI dep_bool ' CLPS711X LCD support' CONFIG_FB_CLPS711X $CONFIG_ARCH_CLPS711X
if [ "$CONFIG_ARCH_SA1100" = "y" ]; then dep_bool ' SA-1100 LCD support' CONFIG_FB_SA1100 $CONFIG_ARCH_SA1100
bool ' SA-1100 LCD support' CONFIG_FB_SA1100 if [ "$CONFIG_FB_SA1100" = "y" -a "$CONFIG_SA1100_CERF" = "y" ]; then
fi choice 'CerfBoard LCD Display Size' \
"3.8_Color CONFIG_CERF_LCD_38_A \
3.8_Mono CONFIG_CERF_LCD_38_B \
5.7 CONFIG_CERF_LCD_57_A \
7.2 CONFIG_CERF_LCD_72_A" 5.7
fi
if [ "$CONFIG_FB_SA1100" = "y" -a "$CONFIG_SA1100_CERF_CPLD" = "y" ]; then
bool 'Cerfboard Backlight (CerfPDA)' CONFIG_SA1100_CERF_LCD_BACKLIGHT
fi
fi
dep_tristate ' CyberPro 2000/2010/5000 support' CONFIG_FB_CYBER2000 $CONFIG_PCI
if [ "$CONFIG_APOLLO" = "y" ]; then if [ "$CONFIG_APOLLO" = "y" ]; then
define_bool CONFIG_FB_APOLLO y define_bool CONFIG_FB_APOLLO y
fi fi
......
...@@ -55,6 +55,8 @@ obj-$(CONFIG_FB_CONTROL) += controlfb.o ...@@ -55,6 +55,8 @@ obj-$(CONFIG_FB_CONTROL) += controlfb.o
obj-$(CONFIG_FB_PLATINUM) += platinumfb.o obj-$(CONFIG_FB_PLATINUM) += platinumfb.o
obj-$(CONFIG_FB_VALKYRIE) += valkyriefb.o obj-$(CONFIG_FB_VALKYRIE) += valkyriefb.o
obj-$(CONFIG_FB_CT65550) += chipsfb.o obj-$(CONFIG_FB_CT65550) += chipsfb.o
obj-$(CONFIG_FB_ANAKIN) += anakinfb.o
obj-$(CONFIG_FB_CLPS711X) += clps711xfb.o
obj-$(CONFIG_FB_CYBER) += cyberfb.o obj-$(CONFIG_FB_CYBER) += cyberfb.o
obj-$(CONFIG_FB_CYBER2000) += cyber2000fb.o obj-$(CONFIG_FB_CYBER2000) += cyber2000fb.o
obj-$(CONFIG_FB_SGIVW) += sgivwfb.o obj-$(CONFIG_FB_SGIVW) += sgivwfb.o
......
/*
* linux/drivers/video/anakinfb.c
*
* Copyright (C) 2001 Aleph One Ltd. for Acunia N.V.
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License version 2 as
* published by the Free Software Foundation.
*
* Changelog:
* 23-Apr-2001 TTC Created
*/
#include <linux/types.h>
#include <linux/fb.h>
#include <linux/string.h>
#include <linux/errno.h>
#include <linux/init.h>
#include <linux/module.h>
#include <asm/io.h>
#include <video/fbcon.h>
#include <video/fbcon-cfb16.h>
static u16 colreg[16];
static int currcon = 0;
static struct fb_info fb_info;
static struct display display;
static int
anakinfb_getcolreg(u_int regno, u_int *red, u_int *green, u_int *blue,
u_int *transp, struct fb_info *info)
{
if (regno > 15)
return 1;
*red = colreg[regno] & 0xf800;
*green = colreg[regno] & 0x7e0 << 5;
*blue = colreg[regno] & 0x1f << 11;
*transp = 0;
return 0;
}
static int
anakinfb_setcolreg(u_int regno, u_int red, u_int green, u_int blue,
u_int transp, struct fb_info *info)
{
if (regno > 15)
return 1;
colreg[regno] = (red & 0xf800) | (green & 0xfc00 >> 5) |
(blue & 0xf800 >> 11);
return 0;
}
static int
anakinfb_get_fix(struct fb_fix_screeninfo *fix, int con, struct fb_info *info)
{
memset(fix, 0, sizeof(struct fb_fix_screeninfo));
strcpy(fix->id, "AnakinFB");
fix->smem_start = VGA_START;
fix->smem_len = VGA_SIZE;
fix->type = FB_TYPE_PACKED_PIXELS;
fix->type_aux = 0;
fix->visual = FB_VISUAL_TRUECOLOR;
fix->xpanstep = 0;
fix->ypanstep = 0;
fix->ywrapstep = 0;
fix->line_length = 400 * 2;
fix->accel = FB_ACCEL_NONE;
return 0;
}
static int
anakinfb_get_var(struct fb_var_screeninfo *var, int con, struct fb_info *info)
{
memset(var, 0, sizeof(struct fb_var_screeninfo));
var->xres = 400;
var->yres = 234;
var->xres_virtual = 400;
var->yres_virtual = 234;
var->xoffset = 0;
var->yoffset = 0;
var->bits_per_pixel = 16;
var->grayscale = 0;
var->red.offset = 11;
var->red.length = 5;
var->green.offset = 5;
var->green.length = 6;
var->blue.offset = 0;
var->blue.length = 5;
var->transp.offset = 0;
var->transp.length = 0;
var->nonstd = 0;
var->activate = FB_ACTIVATE_NOW;
var->height = -1;
var->width = -1;
var->pixclock = 0;
var->left_margin = 0;
var->right_margin = 0;
var->upper_margin = 0;
var->lower_margin = 0;
var->hsync_len = 0;
var->vsync_len = 0;
var->sync = 0;
var->vmode = FB_VMODE_NONINTERLACED;
return 0;
}
static int
anakinfb_set_var(struct fb_var_screeninfo *var, int con, struct fb_info *info)
{
return -EINVAL;
}
static int
anakinfb_get_cmap(struct fb_cmap *cmap, int kspc, int con,
struct fb_info *info)
{
if (con == currcon)
return fb_get_cmap(cmap, kspc, anakinfb_getcolreg, info);
else if (fb_display[con].cmap.len)
fb_copy_cmap(&fb_display[con].cmap, cmap, kspc ? 0 : 2);
else
fb_copy_cmap(fb_default_cmap(16), cmap, kspc ? 0 : 2);
return 0;
}
static int
anakinfb_set_cmap(struct fb_cmap *cmap, int kspc, int con,
struct fb_info *info)
{
int err;
if (!fb_display[con].cmap.len) {
if ((err = fb_alloc_cmap(&fb_display[con].cmap, 16, 0)))
return err;
}
if (con == currcon)
return fb_set_cmap(cmap, kspc, anakinfb_setcolreg, info);
else
fb_copy_cmap(cmap, &fb_display[con].cmap, kspc ? 0 : 1);
return 0;
}
static int
anakinfb_switch_con(int con, struct fb_info *info)
{
currcon = con;
return 0;
}
static int
anakinfb_updatevar(int con, struct fb_info *info)
{
return 0;
}
static void
anakinfb_blank(int blank, struct fb_info *info)
{
/*
* TODO: use I2C to blank/unblank the screen
*/
}
static struct fb_ops anakinfb_ops = {
owner: THIS_MODULE,
fb_get_fix: anakinfb_get_fix,
fb_get_var: anakinfb_get_var,
fb_set_var: anakinfb_set_var,
fb_get_cmap: anakinfb_get_cmap,
fb_set_cmap: anakinfb_set_cmap,
};
int __init
anakinfb_init(void)
{
memset(&fb_info, 0, sizeof(struct fb_info));
strcpy(fb_info.modename, "AnakinFB");
fb_info.node = -1;
fb_info.flags = FBINFO_FLAG_DEFAULT;
fb_info.fbops = &anakinfb_ops;
fb_info.disp = &display;
strcpy(fb_info.fontname, "VGA8x16");
fb_info.changevar = NULL;
fb_info.switch_con = &anakinfb_switch_con;
fb_info.updatevar = &anakinfb_updatevar;
fb_info.blank = &anakinfb_blank;
memset(&display, 0, sizeof(struct display));
anakinfb_get_var(&display.var, 0, &fb_info);
display.screen_base = ioremap(VGA_START, VGA_SIZE);
display.visual = FB_VISUAL_TRUECOLOR;
display.type = FB_TYPE_PACKED_PIXELS;
display.type_aux = 0;
display.ypanstep = 0;
display.ywrapstep = 0;
display.line_length = 400 * 2;
display.can_soft_blank = 1;
display.inverse = 0;
#ifdef FBCON_HAS_CFB16
display.dispsw = &fbcon_cfb16;
display.dispsw_data = colreg;
#else
display.dispsw = &fbcon_dummy;
#endif
if (register_framebuffer(&fb_info) < 0)
return -EINVAL;
MOD_INC_USE_COUNT;
return 0;
}
MODULE_AUTHOR("Tak-Shing Chan <chan@aleph1.co.uk>");
MODULE_DESCRIPTION("Anakin framebuffer driver");
MODULE_SUPPORTED_DEVICE("fb");
This diff is collapsed.
This diff is collapsed.
This diff is collapsed.
...@@ -52,6 +52,7 @@ extern int acornfb_init(void); ...@@ -52,6 +52,7 @@ extern int acornfb_init(void);
extern int acornfb_setup(char*); extern int acornfb_setup(char*);
extern int amifb_init(void); extern int amifb_init(void);
extern int amifb_setup(char*); extern int amifb_setup(char*);
extern int anakinfb_init(void);
extern int atafb_init(void); extern int atafb_init(void);
extern int atafb_setup(char*); extern int atafb_setup(char*);
extern int macfb_init(void); extern int macfb_init(void);
...@@ -60,7 +61,9 @@ extern int cyberfb_init(void); ...@@ -60,7 +61,9 @@ extern int cyberfb_init(void);
extern int cyberfb_setup(char*); extern int cyberfb_setup(char*);
extern int pm2fb_init(void); extern int pm2fb_init(void);
extern int pm2fb_setup(char*); extern int pm2fb_setup(char*);
extern int clps711xfb_init(void);
extern int cyber2000fb_init(void); extern int cyber2000fb_init(void);
extern int cyber2000fb_setup(char*);
extern int retz3fb_init(void); extern int retz3fb_init(void);
extern int retz3fb_setup(char*); extern int retz3fb_setup(char*);
extern int clgenfb_init(void); extern int clgenfb_init(void);
...@@ -154,11 +157,17 @@ static struct { ...@@ -154,11 +157,17 @@ static struct {
#ifdef CONFIG_FB_AMIGA #ifdef CONFIG_FB_AMIGA
{ "amifb", amifb_init, amifb_setup }, { "amifb", amifb_init, amifb_setup },
#endif #endif
#ifdef CONFIG_FB_ANAKIN
{ "anakinfb", anakinfb_init, NULL },
#endif
#ifdef CONFIG_FB_CLPS711X
{ "clps711xfb", clps711xfb_init, NULL },
#endif
#ifdef CONFIG_FB_CYBER #ifdef CONFIG_FB_CYBER
{ "cyber", cyberfb_init, cyberfb_setup }, { "cyber", cyberfb_init, cyberfb_setup },
#endif #endif
#ifdef CONFIG_FB_CYBER2000 #ifdef CONFIG_FB_CYBER2000
{ "cyber2000", cyber2000fb_init, NULL }, { "cyber2000", cyber2000fb_init, cyber2000fb_setup },
#endif #endif
#ifdef CONFIG_FB_PM2 #ifdef CONFIG_FB_PM2
{ "pm2fb", pm2fb_init, pm2fb_setup }, { "pm2fb", pm2fb_init, pm2fb_setup },
......
This diff is collapsed.
...@@ -127,6 +127,8 @@ struct sa1100fb_info { ...@@ -127,6 +127,8 @@ struct sa1100fb_info {
#define C_DISABLE_CLKCHANGE (2) #define C_DISABLE_CLKCHANGE (2)
#define C_ENABLE_CLKCHANGE (3) #define C_ENABLE_CLKCHANGE (3)
#define C_REENABLE (4) #define C_REENABLE (4)
#define C_DISABLE_PM (5)
#define C_ENABLE_PM (6)
#define SA1100_NAME "SA1100" #define SA1100_NAME "SA1100"
......
...@@ -19,6 +19,8 @@ ...@@ -19,6 +19,8 @@
#define NO_IRQ ((unsigned int)(-1)) #define NO_IRQ ((unsigned int)(-1))
#endif #endif
struct irqaction;
#define disable_irq_nosync(i) disable_irq(i) #define disable_irq_nosync(i) disable_irq(i)
extern void disable_irq(unsigned int); extern void disable_irq(unsigned int);
...@@ -38,5 +40,7 @@ extern void enable_irq(unsigned int); ...@@ -38,5 +40,7 @@ extern void enable_irq(unsigned int);
int set_irq_type(unsigned int irq, unsigned int type); int set_irq_type(unsigned int irq, unsigned int type);
int setup_irq(unsigned int, struct irqaction *);
#endif #endif
...@@ -23,12 +23,16 @@ typedef enum { ...@@ -23,12 +23,16 @@ typedef enum {
led_stop, led_stop,
led_claim, /* override idle & timer leds */ led_claim, /* override idle & timer leds */
led_release, /* restore idle & timer leds */ led_release, /* restore idle & timer leds */
led_start_timer_mode,
led_stop_timer_mode,
led_green_on, led_green_on,
led_green_off, led_green_off,
led_amber_on, led_amber_on,
led_amber_off, led_amber_off,
led_red_on, led_red_on,
led_red_off, led_red_off,
led_blue_on,
led_blue_off,
/* /*
* I want this between led_timer and led_start, but * I want this between led_timer and led_start, but
* someone has decided to export this to user space * someone has decided to export this to user space
......
...@@ -75,7 +75,6 @@ extern void (*init_arch_irq)(void); ...@@ -75,7 +75,6 @@ extern void (*init_arch_irq)(void);
extern void init_FIQ(void); extern void init_FIQ(void);
extern int show_fiq_list(struct seq_file *, void *); extern int show_fiq_list(struct seq_file *, void *);
void __set_irq_handler(unsigned int irq, irq_handler_t, int); void __set_irq_handler(unsigned int irq, irq_handler_t, int);
int setup_irq(unsigned int, struct irqaction *);
/* /*
* External stuff. * External stuff.
......
...@@ -61,6 +61,7 @@ u8 pci_std_swizzle(struct pci_dev *dev, u8 *pinp); ...@@ -61,6 +61,7 @@ u8 pci_std_swizzle(struct pci_dev *dev, u8 *pinp);
*/ */
extern int iop310_setup(int nr, struct pci_sys_data *); extern int iop310_setup(int nr, struct pci_sys_data *);
extern struct pci_bus *iop310_scan_bus(int nr, struct pci_sys_data *); extern struct pci_bus *iop310_scan_bus(int nr, struct pci_sys_data *);
extern void iop310_init(void);
extern int dc21285_setup(int nr, struct pci_sys_data *); extern int dc21285_setup(int nr, struct pci_sys_data *);
extern struct pci_bus *dc21285_scan_bus(int nr, struct pci_sys_data *); extern struct pci_bus *dc21285_scan_bus(int nr, struct pci_sys_data *);
...@@ -75,4 +76,3 @@ extern int pci_v3_setup(int nr, struct pci_sys_data *); ...@@ -75,4 +76,3 @@ extern int pci_v3_setup(int nr, struct pci_sys_data *);
extern struct pci_bus *pci_v3_scan_bus(int nr, struct pci_sys_data *); extern struct pci_bus *pci_v3_scan_bus(int nr, struct pci_sys_data *);
extern void pci_v3_preinit(void); extern void pci_v3_preinit(void);
extern void pci_v3_postinit(void); extern void pci_v3_postinit(void);
...@@ -26,13 +26,10 @@ struct sa1100_port_fns { ...@@ -26,13 +26,10 @@ struct sa1100_port_fns {
void (*close)(struct uart_port *, struct uart_info *); void (*close)(struct uart_port *, struct uart_info *);
}; };
#if defined(CONFIG_SERIAL_SA1100) && !defined(CONFIG_SERIAL_SA1100_OLD) #ifdef CONFIG_SERIAL_SA1100
void sa1100_register_uart_fns(struct sa1100_port_fns *fns); void sa1100_register_uart_fns(struct sa1100_port_fns *fns);
void sa1100_register_uart(int idx, int port); void sa1100_register_uart(int idx, int port);
#else #else
#define sa1100_register_uart_fns(fns) do { } while (0) #define sa1100_register_uart_fns(fns) do { } while (0)
#define sa1100_register_uart(idx,port) do { } while (0) #define sa1100_register_uart(idx,port) do { } while (0)
#endif #endif
void sa1100_uart1_altgpio(void);
...@@ -58,74 +58,6 @@ ...@@ -58,74 +58,6 @@
} \ } \
} while (0) } while (0)
/*
* This flushes back any buffered write data. We have to clean the entries
* in the cache for this page. This does not invalidate either I or D caches.
*
* Called from:
* 1. fs/exec.c:put_dirty_page - ok
* - page came from alloc_page(), so page->mapping = NULL.
* - flush_dcache_page called immediately prior.
*
* 2. kernel/ptrace.c:access_one_page - flush_icache_page
* - flush_cache_page takes care of the user space side of the mapping.
* - page is either a page cache page (with page->mapping set, and
* hence page->mapping->i_mmap{,shared} also set) or an anonymous
* page. I think this is ok.
*
* 3. kernel/ptrace.c:access_one_page - bad
* - flush_cache_page takes care of the user space side of the mapping.
* - no apparant cache protection, reading the kernel virtual alias
*
* 4. mm/filemap.c:filemap_no_page - ok
* - add_to_page_cache_* clears PG_arch_1.
* - page->mapping != NULL.
* - i_mmap or i_mmap_shared will be non-null if mmap'd
* - called from (8).
*
* 5. mm/memory.c:break_cow,do_wp_page - {copy,clear}_user_page
* - need to ensure that copy_cow_page has pushed all data from the dcache
* to the page.
* - calls
* - clear_user_highpage -> clear_user_page
* - copy_user_highpage -> copy_user_page
*
* 6. mm/memory.c:do_swap_page - flush_icache_page
* - flush_icache_page called afterwards - if flush_icache_page does the
* same as flush_dcache_page, update_mmu_cache will do the work for us.
* - update_mmu_cache called.
*
* 7. mm/memory.c:do_anonymous_page - {copy,clear}_user_page
* - calls clear_user_highpage. See (5)
*
* 8. mm/memory.c:do_no_page - flush_icache_page
* - flush_icache_page called afterwards - if flush_icache_page does the
* same as flush_dcache_page, update_mmu_cache will do the work for us.
* - update_mmu_cache called.
* - When we place a user mapping, we will call update_mmu_cache,
* which will catch PG_arch_1 set.
*
* 9. mm/shmem.c:shmem_no_page - ok
* - shmem_get_page clears PG_arch_1, as does add_to_page_cache (duplicate)
* - page->mapping != NULL.
* - i_mmap or i_mmap_shared will be non-null if mmap'd
* - called from (8).
*
* 10. mm/swapfile.c:try_to_unuse - bad
* - this looks really dodgy - we're putting pages from the swap cache
* straight into processes, and the only cache handling appears to
* be flush_page_to_ram.
*/
#define flush_page_to_ram_ok
#ifdef flush_page_to_ram_ok
#define flush_page_to_ram(page) do { } while (0)
#else
static __inline__ void flush_page_to_ram(struct page *page)
{
cpu_flush_ram_page(page_address(page));
}
#endif
/* /*
* D cache only * D cache only
*/ */
...@@ -134,8 +66,16 @@ static __inline__ void flush_page_to_ram(struct page *page) ...@@ -134,8 +66,16 @@ static __inline__ void flush_page_to_ram(struct page *page)
#define clean_dcache_range(_s,_e) cpu_dcache_clean_range((_s),(_e)) #define clean_dcache_range(_s,_e) cpu_dcache_clean_range((_s),(_e))
#define flush_dcache_range(_s,_e) cpu_cache_clean_invalidate_range((_s),(_e),0) #define flush_dcache_range(_s,_e) cpu_cache_clean_invalidate_range((_s),(_e),0)
#define mapping_mapped(map) (!list_empty(&(map)->i_mmap) || \ #define clean_dcache_area(start,size) \
!list_empty(&(map)->i_mmap_shared)) cpu_cache_clean_invalidate_range((unsigned long)start, \
((unsigned long)start) + size, 0);
/*
* This is an obsolete interface; the functionality that was provided by this
* function is now merged into our flush_dcache_page, flush_icache_page,
* copy_user_page and clear_user_page functions.
*/
#define flush_page_to_ram(page) do { } while (0)
/* /*
* flush_dcache_page is used when the kernel has written to the page * flush_dcache_page is used when the kernel has written to the page
...@@ -150,39 +90,31 @@ static __inline__ void flush_page_to_ram(struct page *page) ...@@ -150,39 +90,31 @@ static __inline__ void flush_page_to_ram(struct page *page)
* about to change to user space. This is the same method as used on SPARC64. * about to change to user space. This is the same method as used on SPARC64.
* See update_mmu_cache for the user space part. * See update_mmu_cache for the user space part.
*/ */
static inline void flush_dcache_page(struct page *page) #define mapping_mapped(map) (!list_empty(&(map)->i_mmap) || \
!list_empty(&(map)->i_mmap_shared))
static inline void __flush_dcache_page(struct page *page)
{ {
if (page->mapping && !mapping_mapped(page->mapping))
set_bit(PG_dcache_dirty, &page->flags);
else {
unsigned long virt = (unsigned long)page_address(page); unsigned long virt = (unsigned long)page_address(page);
cpu_cache_clean_invalidate_range(virt, virt + PAGE_SIZE, 0); cpu_cache_clean_invalidate_range(virt, virt + PAGE_SIZE, 0);
}
} }
/* static inline void flush_dcache_page(struct page *page)
* flush_icache_page makes the kernel page address consistent with the
* user space mappings. The functionality is the same as flush_dcache_page,
* except we can do an optimisation and only clean the caches here if
* vma->vm_mm == current->active_mm.
*
* This function is misnamed IMHO. There are three places where it
* is called, each of which is preceded immediately by a call to
* flush_page_to_ram:
*/
#ifdef flush_page_to_ram_ok
static inline void flush_icache_page(struct vm_area_struct *vma, struct page *page)
{ {
if (page->mapping && !mapping_mapped(page->mapping)) if (page->mapping && !mapping_mapped(page->mapping))
set_bit(PG_dcache_dirty, &page->flags); set_bit(PG_dcache_dirty, &page->flags);
else if (vma->vm_mm == current->active_mm) { else
unsigned long virt = (unsigned long)page_address(page); __flush_dcache_page(page);
cpu_cache_clean_invalidate_range(virt, virt + PAGE_SIZE, 0);
}
} }
#else
#define flush_icache_page(vma,pg) do { } while (0) #define flush_icache_user_range(vma,page,addr,len) \
#endif flush_dcache_page(page)
/*
* We don't appear to need to do anything here. In fact, if we did, we'd
* duplicate cache flushing elsewhere performed by flush_dcache_page().
*/
#define flush_icache_page(vma,page) do { } while (0)
#define clean_dcache_entry(_s) cpu_dcache_clean_entry((unsigned long)(_s)) #define clean_dcache_entry(_s) cpu_dcache_clean_entry((unsigned long)(_s))
......
...@@ -40,11 +40,11 @@ ...@@ -40,11 +40,11 @@
#define modify_domain(dom,type) \ #define modify_domain(dom,type) \
do { \ do { \
unsigned int domain = current->thread.domain; \ struct thread_info *thread = current_thread_info(); \
unsigned int domain = thread->cpu_domain; \
domain &= ~domain_val(dom, DOMAIN_MANAGER); \ domain &= ~domain_val(dom, DOMAIN_MANAGER); \
domain |= domain_val(dom, type); \ thread->cpu_domain = domain | domain_val(dom, type); \
current->thread.domain = domain; \ set_domain(thread->cpu_domain); \
set_domain(current->thread.domain); \
} while (0) } while (0)
#endif #endif
...@@ -108,6 +108,7 @@ typedef struct siginfo { ...@@ -108,6 +108,7 @@ typedef struct siginfo {
#define SI_ASYNCIO -4 /* sent by AIO completion */ #define SI_ASYNCIO -4 /* sent by AIO completion */
#define SI_SIGIO -5 /* sent by queued SIGIO */ #define SI_SIGIO -5 /* sent by queued SIGIO */
#define SI_TKILL -6 /* sent by tkill system call */ #define SI_TKILL -6 /* sent by tkill system call */
#define SI_DETHREAD -7 /* sent by execve() killing subsidiary threads */
#define SI_FROMUSER(siptr) ((siptr)->si_code <= 0) #define SI_FROMUSER(siptr) ((siptr)->si_code <= 0)
#define SI_FROMKERNEL(siptr) ((siptr)->si_code > 0) #define SI_FROMKERNEL(siptr) ((siptr)->si_code > 0)
......
...@@ -84,7 +84,6 @@ extern struct task_struct *__switch_to(struct thread_info *, struct thread_info ...@@ -84,7 +84,6 @@ extern struct task_struct *__switch_to(struct thread_info *, struct thread_info
#define stf() __stf() #define stf() __stf()
#define save_flags(x) __save_flags(x) #define save_flags(x) __save_flags(x)
#define restore_flags(x) __restore_flags(x) #define restore_flags(x) __restore_flags(x)
#define save_flags_cli(x) __save_flags_cli(x)
#endif /* CONFIG_SMP */ #endif /* CONFIG_SMP */
......
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