Commit 63322f88 authored by Stephen Lord's avatar Stephen Lord

Merge ssh://lord@kernel.bkbits.net/xfs-2.5

into laptop.americas.sgi.com:/home/lord/src/xfs-2.5
parents 1ca335e9 7609f11e
...@@ -3185,7 +3185,7 @@ S: Germany ...@@ -3185,7 +3185,7 @@ S: Germany
N: Geert Uytterhoeven N: Geert Uytterhoeven
E: geert@linux-m68k.org E: geert@linux-m68k.org
W: http://home.tvd.be/cr26864/ W: http://home.tvd.be/cr26864/
P: 1024/EC4A1EE1 8B 88 38 35 88 1E 95 A1 CD 9E AE DC 4B 4A 2F 41 P: 1024/862678A6 C51D 361C 0BD1 4C90 B275 C553 6EEA 11BA 8626 78A6
D: m68k/Amiga and PPC/CHRP Longtrail coordinator D: m68k/Amiga and PPC/CHRP Longtrail coordinator
D: Frame buffer device and XF68_FBDev maintainer D: Frame buffer device and XF68_FBDev maintainer
D: m68k IDE maintainer D: m68k IDE maintainer
...@@ -3194,8 +3194,8 @@ D: Amiga Buddha and Catweasel chipset IDE ...@@ -3194,8 +3194,8 @@ D: Amiga Buddha and Catweasel chipset IDE
D: Atari Falcon chipset IDE D: Atari Falcon chipset IDE
D: Amiga Gayle chipset IDE D: Amiga Gayle chipset IDE
D: mipsel NEC DDB Vrc-5074 D: mipsel NEC DDB Vrc-5074
S: C. Huysmansstraat 12 S: Holsbeeksesteenweg 166
S: B-3128 Baal S: B-3010 Kessel-Lo
S: Belgium S: Belgium
N: Chris Vance N: Chris Vance
......
...@@ -8,9 +8,20 @@ us to generate 'watchdog NMI interrupts'. (NMI: Non Maskable Interrupt ...@@ -8,9 +8,20 @@ us to generate 'watchdog NMI interrupts'. (NMI: Non Maskable Interrupt
which get executed even if the system is otherwise locked up hard). which get executed even if the system is otherwise locked up hard).
This can be used to debug hard kernel lockups. By executing periodic This can be used to debug hard kernel lockups. By executing periodic
NMI interrupts, the kernel can monitor whether any CPU has locked up, NMI interrupts, the kernel can monitor whether any CPU has locked up,
and print out debugging messages if so. You must enable the NMI and print out debugging messages if so.
watchdog at boot time with the 'nmi_watchdog=n' boot parameter. Eg.
the relevant lilo.conf entry: In order to use the NMI watchdoc, you need to have APIC support in your
kernel. For SMP kernels, APIC support gets compiled in automatically. For
UP, enable either CONFIG_X86_UP_APIC (Processor type and features -> Local
APIC support on uniprocessors) or CONFIG_X86_UP_IOAPIC (Processor type and
features -> IO-APIC support on uniprocessors) in your kernel config.
CONFIG_X86_UP_APIC is for uniprocessor machines without an IO-APIC.
CONFIG_X86_UP_IOAPIC is for uniprocessor with an IO-APIC. [Note: certain
kernel debugging options, such as Kernel Stack Meter or Kernel Tracer,
may implicitly disable the NMI watchdog.]
To actually enable the NMI watchdog, use the 'nmi_watchdog=N' boot
parameter. Eg. the relevant lilo.conf entry:
append="nmi_watchdog=1" append="nmi_watchdog=1"
......
...@@ -57,13 +57,11 @@ not yet in use. This is done using the I/O memory space resource management ...@@ -57,13 +57,11 @@ not yet in use. This is done using the I/O memory space resource management
functions: functions:
request_mem_region() request_mem_region()
check_mem_region() (deprecated)
release_mem_region() release_mem_region()
Shortcuts to claim the whole device's address space are provided as well: Shortcuts to claim the whole device's address space are provided as well:
zorro_request_device zorro_request_device
zorro_check_device (deprecated)
zorro_release_device zorro_release_device
......
VERSION = 2 VERSION = 2
PATCHLEVEL = 6 PATCHLEVEL = 6
SUBLEVEL = 0 SUBLEVEL = 0
EXTRAVERSION = -test1 EXTRAVERSION = -test2
# *DOCUMENTATION* # *DOCUMENTATION*
# To see a list of typical targets execute "make help" # To see a list of typical targets execute "make help"
......
...@@ -1126,37 +1126,8 @@ config SOFT_WATCHDOG ...@@ -1126,37 +1126,8 @@ config SOFT_WATCHDOG
<file:Documentation/modules.txt>. The module will be called <file:Documentation/modules.txt>. The module will be called
softdog. softdog.
config RTC
bool "Enhanced Real Time Clock Support"
depends on ATARI
---help---
If you say Y here and create a character special file /dev/rtc with
major number 10 and minor number 135 using mknod ("man mknod"), you
will get access to the real time clock (or hardware clock) built
into your computer.
Every PC has such a clock built in. It can be used to generate
signals from as low as 1Hz up to 8192Hz, and can also be used
as a 24 hour alarm. It reports status information via the file
/proc/driver/rtc and its behaviour is set by various ioctls on
/dev/rtc.
If you run Linux on a multiprocessor machine and said Y to
"Symmetric Multi Processing" above, you should say Y here to read
and set the RTC in an SMP compatible fashion.
If you think you have a use for such a device (such as periodic data
sampling), then say Y here, and read <file:Documentation/rtc.txt>
for details.
This driver is also available as a module ( = code which can be
inserted in and removed from the running kernel whenever you want).
The module is called rtc. If you want to compile it as a module,
say M here and read <file:Documentation/modules.txt>.
config GEN_RTC config GEN_RTC
tristate "Generic /dev/rtc emulation" if !SUN3 tristate "Generic /dev/rtc emulation" if !SUN3
depends on !ATARI
default y if SUN3 default y if SUN3
---help--- ---help---
If you say Y here and create a character special file /dev/rtc with If you say Y here and create a character special file /dev/rtc with
......
...@@ -174,10 +174,6 @@ void config_apollo(void) { ...@@ -174,10 +174,6 @@ void config_apollo(void) {
mach_hwclk = dn_dummy_hwclk; /* */ mach_hwclk = dn_dummy_hwclk; /* */
mach_set_clock_mmss = dn_dummy_set_clock_mmss; /* */ mach_set_clock_mmss = dn_dummy_set_clock_mmss; /* */
mach_process_int = dn_process_int; mach_process_int = dn_process_int;
#ifdef CONFIG_BLK_DEV_FD
mach_floppy_init = dn_dummy_floppy_init;
mach_floppy_setup = dn_dummy_floppy_setup;
#endif
mach_reset = dn_dummy_reset; /* */ mach_reset = dn_dummy_reset; /* */
#ifdef CONFIG_DUMMY_CONSOLE #ifdef CONFIG_DUMMY_CONSOLE
conswitchp = &dummy_con; conswitchp = &dummy_con;
......
...@@ -28,16 +28,8 @@ EXPORT_SYMBOL(stdma_islocked); ...@@ -28,16 +28,8 @@ EXPORT_SYMBOL(stdma_islocked);
EXPORT_SYMBOL(atari_stram_alloc); EXPORT_SYMBOL(atari_stram_alloc);
EXPORT_SYMBOL(atari_stram_free); EXPORT_SYMBOL(atari_stram_free);
EXPORT_SYMBOL(atari_mouse_buttons);
EXPORT_SYMBOL(atari_mouse_interrupt_hook);
EXPORT_SYMBOL(atari_MIDI_interrupt_hook);
EXPORT_SYMBOL(atari_MFP_init_done); EXPORT_SYMBOL(atari_MFP_init_done);
EXPORT_SYMBOL(atari_SCC_init_done); EXPORT_SYMBOL(atari_SCC_init_done);
EXPORT_SYMBOL(atari_SCC_reset_done); EXPORT_SYMBOL(atari_SCC_reset_done);
EXPORT_SYMBOL(ikbd_write);
EXPORT_SYMBOL(ikbd_mouse_y0_top);
EXPORT_SYMBOL(ikbd_mouse_thresh);
EXPORT_SYMBOL(ikbd_mouse_rel_pos);
EXPORT_SYMBOL(ikbd_mouse_disable);
EXPORT_SYMBOL(atari_microwire_cmd); EXPORT_SYMBOL(atari_microwire_cmd);
...@@ -21,6 +21,7 @@ ...@@ -21,6 +21,7 @@
#include <linux/pagemap.h> #include <linux/pagemap.h>
#include <linux/shm.h> #include <linux/shm.h>
#include <linux/bootmem.h> #include <linux/bootmem.h>
#include <linux/mount.h>
#include <asm/setup.h> #include <asm/setup.h>
#include <asm/machdep.h> #include <asm/machdep.h>
......
...@@ -17,7 +17,7 @@ ...@@ -17,7 +17,7 @@
#include <linux/rtc.h> #include <linux/rtc.h>
#include <linux/bcd.h> #include <linux/bcd.h>
#include <asm/rtc.h> #include <asm/atariints.h>
void __init void __init
atari_sched_init(irqreturn_t (*timer_routine)(int, void *, struct pt_regs *)) atari_sched_init(irqreturn_t (*timer_routine)(int, void *, struct pt_regs *))
......
...@@ -177,7 +177,7 @@ CONFIG_NETDEVICES=y ...@@ -177,7 +177,7 @@ CONFIG_NETDEVICES=y
# CONFIG_PPP is not set # CONFIG_PPP is not set
# CONFIG_EQUALIZER is not set # CONFIG_EQUALIZER is not set
# CONFIG_ARIADNE is not set # CONFIG_ARIADNE is not set
# CONFIG_ARIADNE2 is not set # CONFIG_ZORRO8390 is not set
# CONFIG_A2065 is not set # CONFIG_A2065 is not set
# CONFIG_HYDRA is not set # CONFIG_HYDRA is not set
......
...@@ -68,11 +68,13 @@ ENTRY(trap) ...@@ -68,11 +68,13 @@ ENTRY(trap)
addql #4,%sp addql #4,%sp
jra ret_from_exception jra ret_from_exception
| schedule_tail is only used with CONFIG_SMP | After a fork we jump here directly from resume,
| so that %d1 contains the previous task
| schedule_tail now used regardless of CONFIG_SMP
ENTRY(ret_from_fork) ENTRY(ret_from_fork)
#ifdef CONFIG_SMP movel %d1,%sp@-
jsr schedule_tail jsr schedule_tail
#endif addql #4,%sp
jra ret_from_exception jra ret_from_exception
badsys: badsys:
......
...@@ -71,7 +71,6 @@ int main(void) ...@@ -71,7 +71,6 @@ int main(void)
/* offsets into the irq_cpustat_t struct */ /* offsets into the irq_cpustat_t struct */
DEFINE(CPUSTAT_SOFTIRQ_PENDING, offsetof(irq_cpustat_t, __softirq_pending)); DEFINE(CPUSTAT_SOFTIRQ_PENDING, offsetof(irq_cpustat_t, __softirq_pending));
DEFINE(CPUSTAT_SYSCALL_COUNT, offsetof(irq_cpustat_t, __syscall_count));
/* offsets into the bi_record struct */ /* offsets into the bi_record struct */
DEFINE(BIR_TAG, offsetof(struct bi_record, tag)); DEFINE(BIR_TAG, offsetof(struct bi_record, tag));
......
...@@ -93,3 +93,7 @@ int module_finalize(const Elf_Ehdr *hdr, ...@@ -93,3 +93,7 @@ int module_finalize(const Elf_Ehdr *hdr,
{ {
return 0; return 0;
} }
void module_arch_cleanup(struct module *mod)
{
}
...@@ -202,24 +202,19 @@ void flush_thread(void) ...@@ -202,24 +202,19 @@ void flush_thread(void)
asmlinkage int m68k_fork(struct pt_regs *regs) asmlinkage int m68k_fork(struct pt_regs *regs)
{ {
struct task_struct *p; return do_fork(SIGCHLD, rdusp(), regs, 0, NULL, NULL);
p = do_fork(SIGCHLD, rdusp(), regs, 0, NULL, NULL);
return IS_ERR(p) ? PTR_ERR(p) : p->pid;
} }
asmlinkage int m68k_vfork(struct pt_regs *regs) asmlinkage int m68k_vfork(struct pt_regs *regs)
{ {
struct task_struct *p; return do_fork(CLONE_VFORK | CLONE_VM | SIGCHLD, rdusp(), regs, 0,
p = do_fork(CLONE_VFORK | CLONE_VM | SIGCHLD, rdusp(), regs, 0, NULL, NULL, NULL);
NULL);
return IS_ERR(p) ? PTR_ERR(p) : p->pid;
} }
asmlinkage int m68k_clone(struct pt_regs *regs) asmlinkage int m68k_clone(struct pt_regs *regs)
{ {
unsigned long clone_flags; unsigned long clone_flags;
unsigned long newsp; unsigned long newsp;
struct task_struct *p;
int *parent_tidptr, *child_tidptr; int *parent_tidptr, *child_tidptr;
/* syscall2 puts clone_flags in d1 and usp in d2 */ /* syscall2 puts clone_flags in d1 and usp in d2 */
...@@ -229,9 +224,8 @@ asmlinkage int m68k_clone(struct pt_regs *regs) ...@@ -229,9 +224,8 @@ asmlinkage int m68k_clone(struct pt_regs *regs)
child_tidptr = (int *)regs->d4; child_tidptr = (int *)regs->d4;
if (!newsp) if (!newsp)
newsp = rdusp(); newsp = rdusp();
p = do_fork(clone_flags & ~CLONE_IDLETASK, newsp, regs, 0, return do_fork(clone_flags & ~CLONE_IDLETASK, newsp, regs, 0,
parent_tidptr, child_tidptr); parent_tidptr, child_tidptr);
return IS_ERR(p) ? PTR_ERR(p) : p->pid;
} }
int copy_thread(int nr, unsigned long clone_flags, unsigned long usp, int copy_thread(int nr, unsigned long clone_flags, unsigned long usp,
......
...@@ -852,11 +852,6 @@ void show_trace(unsigned long *stack) ...@@ -852,11 +852,6 @@ void show_trace(unsigned long *stack)
printk("\n"); printk("\n");
} }
void show_trace_task(struct task_struct *tsk)
{
show_trace((unsigned long *)tsk->thread.esp0);
}
void show_registers(struct pt_regs *regs) void show_registers(struct pt_regs *regs)
{ {
struct frame *fp = (struct frame *)regs; struct frame *fp = (struct frame *)regs;
...@@ -915,7 +910,7 @@ void show_registers(struct pt_regs *regs) ...@@ -915,7 +910,7 @@ void show_registers(struct pt_regs *regs)
default: default:
printk("\n"); printk("\n");
} }
show_stack((unsigned long *)addr); show_stack(NULL, (unsigned long *)addr);
printk("Code: "); printk("Code: ");
for (i = 0; i < 10; i++) for (i = 0; i < 10; i++)
...@@ -923,13 +918,17 @@ void show_registers(struct pt_regs *regs) ...@@ -923,13 +918,17 @@ void show_registers(struct pt_regs *regs)
printk ("\n"); printk ("\n");
} }
extern void show_stack(unsigned long *stack) extern void show_stack(struct task_struct *task, unsigned long *stack)
{ {
unsigned long *endstack; unsigned long *endstack;
int i; int i;
if (!stack) if (!stack) {
if (task)
stack = (unsigned long *)task->thread.esp0;
else
stack = (unsigned long *)&stack; stack = (unsigned long *)&stack;
}
endstack = (unsigned long *)(((unsigned long)stack + THREAD_SIZE - 1) & -THREAD_SIZE); endstack = (unsigned long *)(((unsigned long)stack + THREAD_SIZE - 1) & -THREAD_SIZE);
printk("Stack from %08lx:", (unsigned long)stack); printk("Stack from %08lx:", (unsigned long)stack);
...@@ -1124,7 +1123,7 @@ void die_if_kernel (char *str, struct pt_regs *fp, int nr) ...@@ -1124,7 +1123,7 @@ void die_if_kernel (char *str, struct pt_regs *fp, int nr)
printk("Process %s (pid: %d, stackpage=%08lx)\n", printk("Process %s (pid: %d, stackpage=%08lx)\n",
current->comm, current->pid, PAGE_SIZE+(unsigned long)current); current->comm, current->pid, PAGE_SIZE+(unsigned long)current);
show_stack((unsigned long *)fp); show_stack(NULL, (unsigned long *)fp);
do_exit(SIGSEGV); do_exit(SIGSEGV);
} }
......
...@@ -115,6 +115,15 @@ extern const struct fp_ext fp_Inf; ...@@ -115,6 +115,15 @@ extern const struct fp_ext fp_Inf;
__res; \ __res; \
}) })
#define fp_conv_long2ext(dest, src) ({ \
register struct fp_ext *__dest asm ("a0") = dest; \
register int __src asm ("d0") = src; \
\
asm volatile ("jsr fp_conv_ext2long" \
: : "d" (__src), "a" (__dest) \
: "a1", "d1", "d2", "memory"); \
})
#else /* __ASSEMBLY__ */ #else /* __ASSEMBLY__ */
/* /*
......
...@@ -17,10 +17,22 @@ ...@@ -17,10 +17,22 @@
#include "fp_emu.h" #include "fp_emu.h"
static const struct fp_ext fp_one =
{
0, 0, 0x3fff, { 0 }
};
extern struct fp_ext *fp_fadd(struct fp_ext *dest, const struct fp_ext *src);
extern struct fp_ext *fp_fdiv(struct fp_ext *dest, const struct fp_ext *src);
extern struct fp_ext *fp_fmul(struct fp_ext *dest, const struct fp_ext *src);
struct fp_ext * struct fp_ext *
fp_fsqrt(struct fp_ext *dest, struct fp_ext *src) fp_fsqrt(struct fp_ext *dest, struct fp_ext *src)
{ {
uprint("fsqrt\n"); struct fp_ext tmp, src2;
int i, exp;
dprint(PINSTR, "fsqrt\n");
fp_monadic_check(dest, src); fp_monadic_check(dest, src);
...@@ -34,6 +46,56 @@ fp_fsqrt(struct fp_ext *dest, struct fp_ext *src) ...@@ -34,6 +46,56 @@ fp_fsqrt(struct fp_ext *dest, struct fp_ext *src)
if (IS_INF(dest)) if (IS_INF(dest))
return dest; return dest;
/*
* sqrt(m) * 2^(p) , if e = 2*p
* sqrt(m*2^e) =
* sqrt(2*m) * 2^(p) , if e = 2*p + 1
*
* So we use the last bit of the exponent to decide wether to
* use the m or 2*m.
*
* Since only the fractional part of the mantissa is stored and
* the integer part is assumed to be one, we place a 1 or 2 into
* the fixed point representation.
*/
exp = dest->exp;
dest->exp = 0x3FFF;
if (!(exp & 1)) /* lowest bit of exponent is set */
dest->exp++;
fp_copy_ext(&src2, dest);
/*
* The taylor row arround a for sqrt(x) is:
* sqrt(x) = sqrt(a) + 1/(2*sqrt(a))*(x-a) + R
* With a=1 this gives:
* sqrt(x) = 1 + 1/2*(x-1)
* = 1/2*(1+x)
*/
fp_fadd(dest, &fp_one);
dest->exp--; /* * 1/2 */
/*
* We now apply the newton rule to the function
* f(x) := x^2 - r
* which has a null point on x = sqrt(r).
*
* It gives:
* x' := x - f(x)/f'(x)
* = x - (x^2 -r)/(2*x)
* = x - (x - r/x)/2
* = (2*x - x + r/x)/2
* = (x + r/x)/2
*/
for (i = 0; i < 9; i++) {
fp_copy_ext(&tmp, &src2);
fp_fdiv(&tmp, dest);
fp_fadd(dest, &tmp);
dest->exp--;
}
dest->exp += (exp - 0x3FFF) / 2;
return dest; return dest;
} }
...@@ -123,20 +185,39 @@ fp_flog2(struct fp_ext *dest, struct fp_ext *src) ...@@ -123,20 +185,39 @@ fp_flog2(struct fp_ext *dest, struct fp_ext *src)
struct fp_ext * struct fp_ext *
fp_fgetexp(struct fp_ext *dest, struct fp_ext *src) fp_fgetexp(struct fp_ext *dest, struct fp_ext *src)
{ {
uprint("fgetexp\n"); dprint(PINSTR, "fgetexp\n");
fp_monadic_check(dest, src); fp_monadic_check(dest, src);
if (IS_INF(dest)) {
fp_set_nan(dest);
return dest;
}
if (IS_ZERO(dest))
return dest;
fp_conv_long2ext(dest, (int)dest->exp - 0x3FFF);
fp_normalize_ext(dest);
return dest; return dest;
} }
struct fp_ext * struct fp_ext *
fp_fgetman(struct fp_ext *dest, struct fp_ext *src) fp_fgetman(struct fp_ext *dest, struct fp_ext *src)
{ {
uprint("fgetman\n"); dprint(PINSTR, "fgetman\n");
fp_monadic_check(dest, src); fp_monadic_check(dest, src);
if (IS_ZERO(dest))
return dest;
if (IS_INF(dest))
return dest;
dest->exp = 0x3FFF;
return dest; return dest;
} }
...@@ -19,11 +19,7 @@ ...@@ -19,11 +19,7 @@
#include <asm/pgalloc.h> #include <asm/pgalloc.h>
#include <asm/system.h> #include <asm/system.h>
#include <asm/traps.h> #include <asm/traps.h>
#include <asm/io.h>
#include <asm/machdep.h> #include <asm/machdep.h>
#ifdef CONFIG_AMIGA
#include <asm/amigahw.h>
#endif
/* ++andreas: {get,free}_pointer_table rewritten to use unused fields from /* ++andreas: {get,free}_pointer_table rewritten to use unused fields from
...@@ -358,6 +354,109 @@ void cache_push (unsigned long paddr, int len) ...@@ -358,6 +354,109 @@ void cache_push (unsigned long paddr, int len)
#endif #endif
} }
static unsigned long virt_to_phys_slow(unsigned long vaddr)
{
if (CPU_IS_060) {
mm_segment_t fs = get_fs();
unsigned long paddr;
set_fs(get_ds());
/* The PLPAR instruction causes an access error if the translation
* is not possible. To catch this we use the same exception mechanism
* as for user space accesses in <asm/uaccess.h>. */
asm volatile (".chip 68060\n"
"1: plpar (%0)\n"
".chip 68k\n"
"2:\n"
".section .fixup,\"ax\"\n"
" .even\n"
"3: sub.l %0,%0\n"
" jra 2b\n"
".previous\n"
".section __ex_table,\"a\"\n"
" .align 4\n"
" .long 1b,3b\n"
".previous"
: "=a" (paddr)
: "0" (vaddr));
set_fs(fs);
return paddr;
} else if (CPU_IS_040) {
mm_segment_t fs = get_fs();
unsigned long mmusr;
set_fs(get_ds());
asm volatile (".chip 68040\n\t"
"ptestr (%1)\n\t"
"movec %%mmusr, %0\n\t"
".chip 68k"
: "=r" (mmusr)
: "a" (vaddr));
set_fs(fs);
if (mmusr & MMU_R_040)
return (mmusr & PAGE_MASK) | (vaddr & ~PAGE_MASK);
} else {
unsigned short mmusr;
unsigned long *descaddr;
asm volatile ("ptestr #5,%2@,#7,%0\n\t"
"pmove %%psr,%1@"
: "=a&" (descaddr)
: "a" (&mmusr), "a" (vaddr));
if (mmusr & (MMU_I|MMU_B|MMU_L))
return 0;
descaddr = phys_to_virt((unsigned long)descaddr);
switch (mmusr & MMU_NUM) {
case 1:
return (*descaddr & 0xfe000000) | (vaddr & 0x01ffffff);
case 2:
return (*descaddr & 0xfffc0000) | (vaddr & 0x0003ffff);
case 3:
return (*descaddr & PAGE_MASK) | (vaddr & ~PAGE_MASK);
}
}
return 0;
}
/* Push n pages at kernel virtual address and clear the icache */
/* RZ: use cpush %bc instead of cpush %dc, cinv %ic */
void flush_icache_range(unsigned long address, unsigned long endaddr)
{
if (CPU_IS_040_OR_060) {
address &= PAGE_MASK;
if (address >= PAGE_OFFSET && address < (unsigned long)high_memory) {
do {
asm volatile ("nop\n\t"
".chip 68040\n\t"
"cpushp %%bc,(%0)\n\t"
".chip 68k"
: : "a" (virt_to_phys((void *)address)));
address += PAGE_SIZE;
} while (address < endaddr);
} else {
do {
asm volatile ("nop\n\t"
".chip 68040\n\t"
"cpushp %%bc,(%0)\n\t"
".chip 68k"
: : "a" (virt_to_phys_slow(address)));
address += PAGE_SIZE;
} while (address < endaddr);
}
} else {
unsigned long tmp;
asm volatile ("movec %%cacr,%0\n\t"
"orw %1,%0\n\t"
"movec %0,%%cacr"
: "=&d" (tmp)
: "di" (FLUSH_I));
}
}
#ifndef CONFIG_SINGLE_MEMORY_CHUNK #ifndef CONFIG_SINGLE_MEMORY_CHUNK
int mm_end_of_chunk (unsigned long addr, int len) int mm_end_of_chunk (unsigned long addr, int len)
......
...@@ -220,18 +220,6 @@ void __init paging_init(void) ...@@ -220,18 +220,6 @@ void __init paging_init(void)
for (i = 0; i < 16; i++) for (i = 0; i < 16; i++)
pgprot_val(protection_map[i]) |= _PAGE_CACHE040; pgprot_val(protection_map[i]) |= _PAGE_CACHE040;
} }
/* Fix the PAGE_NONE value. */
if (CPU_IS_040_OR_060) {
/* On the 680[46]0 we can use the _PAGE_SUPER bit. */
pgprot_val(protection_map[0]) |= _PAGE_SUPER;
pgprot_val(protection_map[VM_SHARED]) |= _PAGE_SUPER;
} else {
/* Otherwise we must fake it. */
pgprot_val(protection_map[0]) &= ~_PAGE_PRESENT;
pgprot_val(protection_map[0]) |= _PAGE_FAKE_SUPER;
pgprot_val(protection_map[VM_SHARED]) &= ~_PAGE_PRESENT;
pgprot_val(protection_map[VM_SHARED]) |= _PAGE_FAKE_SUPER;
}
/* /*
* Map the physical memory available into the kernel virtual * Map the physical memory available into the kernel virtual
......
...@@ -421,8 +421,7 @@ CONFIG_NET_ETHERNET=y ...@@ -421,8 +421,7 @@ CONFIG_NET_ETHERNET=y
# CONFIG_MII is not set # CONFIG_MII is not set
# CONFIG_OAKNET is not set # CONFIG_OAKNET is not set
CONFIG_ARIADNE=y CONFIG_ARIADNE=y
# CONFIG_ARIADNE2 is not set # CONFIG_ZORRO8390 is not set
CONFIG_NE2K_ZORRO=y
CONFIG_A2065=y CONFIG_A2065=y
CONFIG_HYDRA=y CONFIG_HYDRA=y
# CONFIG_HAPPYMEAL is not set # CONFIG_HAPPYMEAL is not set
......
config IOSCHED_AS
bool "Anticipatory I/O scheduler" if EMBEDDED
default y
config IOSCHED_DEADLINE
bool "Deadline I/O scheduler" if EMBEDDED
default y
...@@ -13,9 +13,10 @@ ...@@ -13,9 +13,10 @@
# kblockd threads # kblockd threads
# #
obj-y := elevator.o ll_rw_blk.o ioctl.o genhd.o scsi_ioctl.o \ obj-y := elevator.o ll_rw_blk.o ioctl.o genhd.o scsi_ioctl.o
deadline-iosched.o as-iosched.o
obj-$(CONFIG_IOSCHED_AS) += as-iosched.o
obj-$(CONFIG_IOSCHED_DEADLINE) += deadline-iosched.o
obj-$(CONFIG_MAC_FLOPPY) += swim3.o obj-$(CONFIG_MAC_FLOPPY) += swim3.o
obj-$(CONFIG_BLK_DEV_FD) += floppy.o obj-$(CONFIG_BLK_DEV_FD) += floppy.o
obj-$(CONFIG_BLK_DEV_FD98) += floppy98.o obj-$(CONFIG_BLK_DEV_FD98) += floppy98.o
......
...@@ -999,7 +999,7 @@ int slm_init( void ) ...@@ -999,7 +999,7 @@ int slm_init( void )
return -EBUSY; return -EBUSY;
} }
if (!(SLMBuffer = atari_stram_alloc( SLM_BUFFER_SIZE, NULL, "SLM" ))) { if (!(SLMBuffer = atari_stram_alloc( SLM_BUFFER_SIZE, "SLM" ))) {
printk( KERN_ERR "Unable to get SLM ST-Ram buffer.\n" ); printk( KERN_ERR "Unable to get SLM ST-Ram buffer.\n" );
unregister_chrdev( ACSI_MAJOR, "slm" ); unregister_chrdev( ACSI_MAJOR, "slm" );
return -ENOMEM; return -ENOMEM;
......
...@@ -1842,6 +1842,7 @@ elevator_t iosched_as = { ...@@ -1842,6 +1842,7 @@ elevator_t iosched_as = {
.elevator_exit_fn = as_exit, .elevator_exit_fn = as_exit,
.elevator_ktype = &as_ktype, .elevator_ktype = &as_ktype,
.elevator_name = "anticipatory scheduling",
}; };
EXPORT_SYMBOL(iosched_as); EXPORT_SYMBOL(iosched_as);
...@@ -940,6 +940,7 @@ elevator_t iosched_deadline = { ...@@ -940,6 +940,7 @@ elevator_t iosched_deadline = {
.elevator_exit_fn = deadline_exit, .elevator_exit_fn = deadline_exit,
.elevator_ktype = &deadline_ktype, .elevator_ktype = &deadline_ktype,
.elevator_name = "deadline",
}; };
EXPORT_SYMBOL(iosched_deadline); EXPORT_SYMBOL(iosched_deadline);
...@@ -420,6 +420,7 @@ elevator_t elevator_noop = { ...@@ -420,6 +420,7 @@ elevator_t elevator_noop = {
.elevator_merge_req_fn = elevator_noop_merge_requests, .elevator_merge_req_fn = elevator_noop_merge_requests,
.elevator_next_req_fn = elevator_noop_next_request, .elevator_next_req_fn = elevator_noop_next_request,
.elevator_add_req_fn = elevator_noop_add_request, .elevator_add_req_fn = elevator_noop_add_request,
.elevator_name = "noop",
}; };
module_init(elevator_global_init); module_init(elevator_global_init);
......
...@@ -1209,17 +1209,31 @@ static int blk_init_free_list(request_queue_t *q) ...@@ -1209,17 +1209,31 @@ static int blk_init_free_list(request_queue_t *q)
static int __make_request(request_queue_t *, struct bio *); static int __make_request(request_queue_t *, struct bio *);
static elevator_t *chosen_elevator = &iosched_as; static elevator_t *chosen_elevator =
#if defined(CONFIG_IOSCHED_AS)
&iosched_as;
#elif defined(CONFIG_IOSCHED_DEADLINE)
&iosched_deadline;
#else
&elevator_noop;
#endif
#if defined(CONFIG_IOSCHED_AS) || defined(CONFIG_IOSCHED_DEADLINE)
static int __init elevator_setup(char *str) static int __init elevator_setup(char *str)
{ {
#ifdef CONFIG_IOSCHED_DEADLINE
if (!strcmp(str, "deadline")) if (!strcmp(str, "deadline"))
chosen_elevator = &iosched_deadline; chosen_elevator = &iosched_deadline;
#endif
#ifdef CONFIG_IOSCHED_AS
if (!strcmp(str, "as")) if (!strcmp(str, "as"))
chosen_elevator = &iosched_as; chosen_elevator = &iosched_as;
#endif
return 1; return 1;
} }
__setup("elevator=", elevator_setup); __setup("elevator=", elevator_setup);
#endif /* CONFIG_IOSCHED_AS || CONFIG_IOSCHED_DEADLINE */
/** /**
* blk_init_queue - prepare a request queue for use with a block device * blk_init_queue - prepare a request queue for use with a block device
...@@ -1259,10 +1273,7 @@ int blk_init_queue(request_queue_t *q, request_fn_proc *rfn, spinlock_t *lock) ...@@ -1259,10 +1273,7 @@ int blk_init_queue(request_queue_t *q, request_fn_proc *rfn, spinlock_t *lock)
if (!printed) { if (!printed) {
printed = 1; printed = 1;
if (chosen_elevator == &iosched_deadline) printk("Using %s elevator\n", chosen_elevator->elevator_name);
printk("deadline elevator\n");
else if (chosen_elevator == &iosched_as)
printk("anticipatory scheduling elevator\n");
} }
if ((ret = elevator_init(q, chosen_elevator))) { if ((ret = elevator_init(q, chosen_elevator))) {
...@@ -2296,8 +2307,8 @@ static int __end_that_request_first(struct request *req, int uptodate, ...@@ -2296,8 +2307,8 @@ static int __end_that_request_first(struct request *req, int uptodate,
* not a complete bvec done * not a complete bvec done
*/ */
if (unlikely(nbytes > nr_bytes)) { if (unlikely(nbytes > nr_bytes)) {
bio_iovec(bio)->bv_offset += nr_bytes; bio_iovec_idx(bio, idx)->bv_offset += nr_bytes;
bio_iovec(bio)->bv_len -= nr_bytes; bio_iovec_idx(bio, idx)->bv_len -= nr_bytes;
bio_nbytes += nr_bytes; bio_nbytes += nr_bytes;
total_bytes += nr_bytes; total_bytes += nr_bytes;
break; break;
......
...@@ -2145,14 +2145,14 @@ static int __init rs_init(void) ...@@ -2145,14 +2145,14 @@ static int __init rs_init(void)
static __exit void rs_exit(void) static __exit void rs_exit(void)
{ {
int e1, e2; int error;
struct async_struct *info = rs_table[0].info; struct async_struct *info = rs_table[0].info;
/* printk("Unloading %s: version %s\n", serial_name, serial_version); */ /* printk("Unloading %s: version %s\n", serial_name, serial_version); */
tasklet_kill(&info->tlet); tasklet_kill(&info->tlet);
if ((e1 = tty_unregister_driver(serial_driver))) if ((error = tty_unregister_driver(serial_driver)))
printk("SERIAL: failed to unregister serial driver (%d)\n", printk("SERIAL: failed to unregister serial driver (%d)\n",
e1); error);
put_tty_driver(serial_driver); put_tty_driver(serial_driver);
if (info) { if (info) {
......
...@@ -243,7 +243,7 @@ static struct pnp_driver ns558_pnp_driver = { ...@@ -243,7 +243,7 @@ static struct pnp_driver ns558_pnp_driver = {
#else #else
static const struct pnp_driver ns558_pnp_driver; static struct pnp_driver ns558_pnp_driver;
#endif #endif
......
...@@ -66,12 +66,14 @@ static struct serio q40kbd_port = ...@@ -66,12 +66,14 @@ static struct serio q40kbd_port =
.close = q40kbd_close, .close = q40kbd_close,
}; };
static void q40kbd_interrupt(int irq, void *dev_id, struct pt_regs *regs) static irqreturn_t q40kbd_interrupt(int irq, void *dev_id,
struct pt_regs *regs)
{ {
if (Q40_IRQ_KEYB_MASK & master_inb(INTERRUPT_REG)) if (Q40_IRQ_KEYB_MASK & master_inb(INTERRUPT_REG))
serio_interrupt(&q40kbd_port, master_inb(KEYCODE_REG), 0, regs); serio_interrupt(&q40kbd_port, master_inb(KEYCODE_REG), 0, regs);
master_outb(-1, KEYBOARD_UNLOCK_REG); master_outb(-1, KEYBOARD_UNLOCK_REG);
return IRQ_HANDLED;
} }
static int __init q40kbd_init(void) static int __init q40kbd_init(void)
......
...@@ -44,7 +44,9 @@ ...@@ -44,7 +44,9 @@
#include <linux/pmu.h> #include <linux/pmu.h>
#include <asm/machdep.h> #include <asm/machdep.h>
#ifdef CONFIG_PPC_PMAC
#include <asm/pmac_feature.h> #include <asm/pmac_feature.h>
#endif
#ifdef CONFIG_PMAC_BACKLIGHT #ifdef CONFIG_PMAC_BACKLIGHT
#include <asm/backlight.h> #include <asm/backlight.h>
...@@ -160,6 +162,7 @@ adbhid_input_keycode(int id, int keycode, int repeat, struct pt_regs *regs) ...@@ -160,6 +162,7 @@ adbhid_input_keycode(int id, int keycode, int repeat, struct pt_regs *regs)
return; return;
case 0x3f: /* ignore Powerbook Fn key */ case 0x3f: /* ignore Powerbook Fn key */
return; return;
#ifdef CONFIG_PPC_PMAC
case 0x7e: /* Power key on PBook 3400 needs remapping */ case 0x7e: /* Power key on PBook 3400 needs remapping */
switch(pmac_call_feature(PMAC_FTR_GET_MB_INFO, switch(pmac_call_feature(PMAC_FTR_GET_MB_INFO,
NULL, PMAC_MB_INFO_MODEL, 0)) { NULL, PMAC_MB_INFO_MODEL, 0)) {
...@@ -169,6 +172,7 @@ adbhid_input_keycode(int id, int keycode, int repeat, struct pt_regs *regs) ...@@ -169,6 +172,7 @@ adbhid_input_keycode(int id, int keycode, int repeat, struct pt_regs *regs)
keycode = 0x7f; keycode = 0x7f;
} }
break; break;
#endif /* CONFIG_PPC_PMAC */
} }
if (adbhid[id]->keycode[keycode]) { if (adbhid[id]->keycode[keycode]) {
......
...@@ -110,7 +110,7 @@ struct ei_device { ...@@ -110,7 +110,7 @@ struct ei_device {
*/ */
#if defined(CONFIG_MAC) || \ #if defined(CONFIG_MAC) || \
defined(CONFIG_ARIADNE2) || defined(CONFIG_ARIADNE2_MODULE) || \ defined(CONFIG_ZORRO8390) || defined(CONFIG_ZORRO8390_MODULE) || \
defined(CONFIG_HYDRA) || defined(CONFIG_HYDRA_MODULE) defined(CONFIG_HYDRA) || defined(CONFIG_HYDRA_MODULE)
#define EI_SHIFT(x) (ei_local->reg_offset[x]) #define EI_SHIFT(x) (ei_local->reg_offset[x])
#undef inb #undef inb
......
...@@ -282,23 +282,6 @@ config ARIADNE ...@@ -282,23 +282,6 @@ config ARIADNE
want). The module is called ariadne. If you want to compile it as want). The module is called ariadne. If you want to compile it as
a module, say M here and read <file:Documentation/modules.txt>. a module, say M here and read <file:Documentation/modules.txt>.
config ARIADNE2
tristate "Ariadne II support"
depends on NETDEVICES && ZORRO
help
This driver is for the Village Tronic Ariadne II and the Individual
Computers X-Surf Ethernet cards. If you have such a card, say Y.
Otherwise, say N.
This driver is also available as a module ( = code which can be
inserted in and removed from the running kernel whenever you want).
The module will be called ariadne2. If you want to compile it as
a module, say M here and read <file:Documentation/modules.txt>.
config NE2K_ZORRO
tristate "Ariadne II and X-Surf support"
depends on NET_ETHERNET && ZORRO
config A2065 config A2065
tristate "A2065 support" tristate "A2065 support"
depends on NET_ETHERNET && ZORRO depends on NET_ETHERNET && ZORRO
...@@ -322,6 +305,20 @@ config HYDRA ...@@ -322,6 +305,20 @@ config HYDRA
want). The module is called hydra. If you want to compile it as a want). The module is called hydra. If you want to compile it as a
module, say M here and read <file:Documentation/modules.txt>. module, say M here and read <file:Documentation/modules.txt>.
config ZORRO8390
tristate "Zorro NS8390-based Ethernet support"
depends on NET_ETHERNET && ZORRO
help
This driver is for Zorro Ethernet cards using an NS8390-compatible
chipset, like the Village Tronic Ariadne II and the Individual
Computers X-Surf Ethernet cards. If you have such a card, say Y.
Otherwise, say N.
This driver is also available as a module ( = code which can be
inserted in and removed from the running kernel whenever you want).
The module is called zorro8390. If you want to compile it as
a module, say M here and read <file:Documentation/modules.txt>.
config APNE config APNE
tristate "PCMCIA NE2000 support" tristate "PCMCIA NE2000 support"
depends on NETDEVICES && AMIGA_PCMCIA depends on NETDEVICES && AMIGA_PCMCIA
......
...@@ -151,7 +151,7 @@ obj-$(CONFIG_BVME6000_NET) += 82596.o ...@@ -151,7 +151,7 @@ obj-$(CONFIG_BVME6000_NET) += 82596.o
obj-$(CONFIG_LP486E) += lp486e.o obj-$(CONFIG_LP486E) += lp486e.o
obj-$(CONFIG_ETH16I) += eth16i.o obj-$(CONFIG_ETH16I) += eth16i.o
obj-$(CONFIG_ARIADNE2) += ariadne2.o 8390.o obj-$(CONFIG_ZORRO8390) += zorro8390.o 8390.o
obj-$(CONFIG_HPLANCE) += hplance.o 7990.o obj-$(CONFIG_HPLANCE) += hplance.o 7990.o
obj-$(CONFIG_MVME147_NET) += mvme147.o 7990.o obj-$(CONFIG_MVME147_NET) += mvme147.o 7990.o
obj-$(CONFIG_EQUALIZER) += eql.o obj-$(CONFIG_EQUALIZER) += eql.o
......
...@@ -70,5 +70,5 @@ obj-$(CONFIG_ES3210) += crc32.o ...@@ -70,5 +70,5 @@ obj-$(CONFIG_ES3210) += crc32.o
obj-$(CONFIG_LNE390) += crc32.o obj-$(CONFIG_LNE390) += crc32.o
obj-$(CONFIG_NE3210) += crc32.o obj-$(CONFIG_NE3210) += crc32.o
obj-$(CONFIG_AC3200) += crc32.o obj-$(CONFIG_AC3200) += crc32.o
obj-$(CONFIG_ARIADNE2) += crc32.o obj-$(CONFIG_ZORRO8390) += crc32.o
obj-$(CONFIG_HYDRA) += crc32.o obj-$(CONFIG_HYDRA) += crc32.o
...@@ -169,7 +169,7 @@ static void pamsnet_tick(unsigned long); ...@@ -169,7 +169,7 @@ static void pamsnet_tick(unsigned long);
static irqreturn_t pamsnet_intr(int irq, void *data, struct pt_regs *fp); static irqreturn_t pamsnet_intr(int irq, void *data, struct pt_regs *fp);
static struct timer_list pamsnet_timer = TIMER_INITIALIZER(amsnet_tick, 0, 0); static struct timer_list pamsnet_timer = TIMER_INITIALIZER(pamsnet_tick, 0, 0);
#define STRAM_ADDR(a) (((a) & 0xff000000) == 0) #define STRAM_ADDR(a) (((a) & 0xff000000) == 0)
......
...@@ -378,7 +378,7 @@ int __init mac8390_probe(struct net_device * dev) ...@@ -378,7 +378,7 @@ int __init mac8390_probe(struct net_device * dev)
#ifdef MODULE #ifdef MODULE
MODULE_AUTHOR("David Huggins-Daines <dhd@debian.org> and others"); MODULE_AUTHOR("David Huggins-Daines <dhd@debian.org> and others");
MODULE_DESCRIPTION("Macintosh NS8390-based Nubus Ethernet driver"); MODULE_DESCRIPTION("Macintosh NS8390-based Nubus Ethernet driver");
MODUEL_LICENSE("GPL"); MODULE_LICENSE("GPL");
int init_module(void) int init_module(void)
{ {
......
...@@ -138,7 +138,7 @@ static inline void bit_reverse_addr(unsigned char addr[6]) ...@@ -138,7 +138,7 @@ static inline void bit_reverse_addr(unsigned char addr[6])
int __init macsonic_init(struct net_device* dev) int __init macsonic_init(struct net_device* dev)
{ {
struct sonic_local* lp; struct sonic_local* lp = NULL;
int i; int i;
/* Allocate the entire chunk of memory for the descriptors. /* Allocate the entire chunk of memory for the descriptors.
......
...@@ -113,15 +113,6 @@ static int sonic_send_packet(struct sk_buff *skb, struct net_device *dev) ...@@ -113,15 +113,6 @@ static int sonic_send_packet(struct sk_buff *skb, struct net_device *dev)
if (sonic_debug > 2) if (sonic_debug > 2)
printk("sonic_send_packet: skb=%p, dev=%p\n", skb, dev); printk("sonic_send_packet: skb=%p, dev=%p\n", skb, dev);
/*
* Block a timer-based transmit from overlapping. This could better be
* done with atomic_swap(1, dev->tbusy), but set_bit() works as well.
*/
if (test_and_set_bit(0, (void *) &dev->tbusy) != 0) {
printk("%s: Transmitter access conflict.\n", dev->name);
return 1;
}
/* /*
* Map the packet data into the logical DMA address space * Map the packet data into the logical DMA address space
*/ */
......
...@@ -43,7 +43,7 @@ ...@@ -43,7 +43,7 @@
#include <asm/bitops.h> #include <asm/bitops.h>
#include <asm/io.h> #include <asm/io.h>
#include <asm/dma.h> #include <asm/dma.h>
#include <asm/smp.h> #include <linux/smp.h>
#include "lmc.h" #include "lmc.h"
#include "lmc_var.h" #include "lmc_var.h"
......
/* /*
* Amiga Linux/m68k and Linux/PPC Ariadne II and X-Surf Ethernet Driver * Amiga Linux/m68k and Linux/PPC Zorro NS8390 Ethernet Driver
* *
* (C) Copyright 1998-2000 by some Elitist 680x0 Users(TM) * (C) Copyright 1998-2000 by some Elitist 680x0 Users(TM)
* *
...@@ -60,7 +60,7 @@ ...@@ -60,7 +60,7 @@
#define WORDSWAP(a) ((((a)>>8)&0xff) | ((a)<<8)) #define WORDSWAP(a) ((((a)>>8)&0xff) | ((a)<<8))
#ifdef MODULE #ifdef MODULE
static struct net_device *root_ariadne2_dev; static struct net_device *root_zorro8390_dev;
#endif #endif
static const struct card_info { static const struct card_info {
...@@ -72,22 +72,22 @@ static const struct card_info { ...@@ -72,22 +72,22 @@ static const struct card_info {
{ ZORRO_PROD_INDIVIDUAL_COMPUTERS_X_SURF, "X-Surf", 0x8600 }, { ZORRO_PROD_INDIVIDUAL_COMPUTERS_X_SURF, "X-Surf", 0x8600 },
}; };
static int __init ariadne2_probe(void); static int __init zorro8390_probe(void);
static int __init ariadne2_init(struct net_device *dev, unsigned long board, static int __init zorro8390_init(struct net_device *dev, unsigned long board,
const char *name, unsigned long ioaddr); const char *name, unsigned long ioaddr);
static int ariadne2_open(struct net_device *dev); static int zorro8390_open(struct net_device *dev);
static int ariadne2_close(struct net_device *dev); static int zorro8390_close(struct net_device *dev);
static void ariadne2_reset_8390(struct net_device *dev); static void zorro8390_reset_8390(struct net_device *dev);
static void ariadne2_get_8390_hdr(struct net_device *dev, static void zorro8390_get_8390_hdr(struct net_device *dev,
struct e8390_pkt_hdr *hdr, int ring_page); struct e8390_pkt_hdr *hdr, int ring_page);
static void ariadne2_block_input(struct net_device *dev, int count, static void zorro8390_block_input(struct net_device *dev, int count,
struct sk_buff *skb, int ring_offset); struct sk_buff *skb, int ring_offset);
static void ariadne2_block_output(struct net_device *dev, const int count, static void zorro8390_block_output(struct net_device *dev, const int count,
const unsigned char *buf, const unsigned char *buf,
const int start_page); const int start_page);
static void __exit ariadne2_cleanup(void); static void __exit zorro8390_cleanup(void);
static int __init ariadne2_probe(void) static int __init zorro8390_probe(void)
{ {
struct net_device *dev; struct net_device *dev;
struct zorro_dev *z = NULL; struct zorro_dev *z = NULL;
...@@ -111,7 +111,7 @@ static int __init ariadne2_probe(void) ...@@ -111,7 +111,7 @@ static int __init ariadne2_probe(void)
kfree(dev); kfree(dev);
continue; continue;
} }
if ((err = ariadne2_init(dev, board, cards[i].name, if ((err = zorro8390_init(dev, board, cards[i].name,
ZTWO_VADDR(ioaddr)))) { ZTWO_VADDR(ioaddr)))) {
release_mem_region(ioaddr, NE_IO_EXTENT*2); release_mem_region(ioaddr, NE_IO_EXTENT*2);
kfree(dev); kfree(dev);
...@@ -125,13 +125,13 @@ static int __init ariadne2_probe(void) ...@@ -125,13 +125,13 @@ static int __init ariadne2_probe(void)
return err; return err;
} }
static int __init ariadne2_init(struct net_device *dev, unsigned long board, static int __init zorro8390_init(struct net_device *dev, unsigned long board,
const char *name, unsigned long ioaddr) const char *name, unsigned long ioaddr)
{ {
int i; int i;
unsigned char SA_prom[32]; unsigned char SA_prom[32];
int start_page, stop_page; int start_page, stop_page;
static u32 ariadne2_offsets[16] = { static u32 zorro8390_offsets[16] = {
0x00, 0x02, 0x04, 0x06, 0x08, 0x0a, 0x0c, 0x0e, 0x00, 0x02, 0x04, 0x06, 0x08, 0x0a, 0x0c, 0x0e,
0x10, 0x12, 0x14, 0x16, 0x18, 0x1a, 0x1c, 0x1e, 0x10, 0x12, 0x14, 0x16, 0x18, 0x1a, 0x1c, 0x1e,
}; };
...@@ -220,28 +220,28 @@ static int __init ariadne2_init(struct net_device *dev, unsigned long board, ...@@ -220,28 +220,28 @@ static int __init ariadne2_init(struct net_device *dev, unsigned long board,
ei_status.rx_start_page = start_page + TX_PAGES; ei_status.rx_start_page = start_page + TX_PAGES;
ei_status.reset_8390 = &ariadne2_reset_8390; ei_status.reset_8390 = &zorro8390_reset_8390;
ei_status.block_input = &ariadne2_block_input; ei_status.block_input = &zorro8390_block_input;
ei_status.block_output = &ariadne2_block_output; ei_status.block_output = &zorro8390_block_output;
ei_status.get_8390_hdr = &ariadne2_get_8390_hdr; ei_status.get_8390_hdr = &zorro8390_get_8390_hdr;
ei_status.reg_offset = ariadne2_offsets; ei_status.reg_offset = zorro8390_offsets;
dev->open = &ariadne2_open; dev->open = &zorro8390_open;
dev->stop = &ariadne2_close; dev->stop = &zorro8390_close;
#ifdef MODULE #ifdef MODULE
ei_status.priv = (unsigned long)root_ariadne2_dev; ei_status.priv = (unsigned long)root_zorro8390_dev;
root_ariadne2_dev = dev; root_zorro8390_dev = dev;
#endif #endif
NS8390_init(dev, 0); NS8390_init(dev, 0);
return 0; return 0;
} }
static int ariadne2_open(struct net_device *dev) static int zorro8390_open(struct net_device *dev)
{ {
ei_open(dev); ei_open(dev);
return 0; return 0;
} }
static int ariadne2_close(struct net_device *dev) static int zorro8390_close(struct net_device *dev)
{ {
if (ei_debug > 1) if (ei_debug > 1)
printk("%s: Shutting down ethercard.\n", dev->name); printk("%s: Shutting down ethercard.\n", dev->name);
...@@ -251,7 +251,7 @@ static int ariadne2_close(struct net_device *dev) ...@@ -251,7 +251,7 @@ static int ariadne2_close(struct net_device *dev)
/* Hard reset the card. This used to pause for the same period that a /* Hard reset the card. This used to pause for the same period that a
8390 reset command required, but that shouldn't be necessary. */ 8390 reset command required, but that shouldn't be necessary. */
static void ariadne2_reset_8390(struct net_device *dev) static void zorro8390_reset_8390(struct net_device *dev)
{ {
unsigned long reset_start_time = jiffies; unsigned long reset_start_time = jiffies;
...@@ -276,7 +276,7 @@ static void ariadne2_reset_8390(struct net_device *dev) ...@@ -276,7 +276,7 @@ static void ariadne2_reset_8390(struct net_device *dev)
we don't need to be concerned with ring wrap as the header will be at we don't need to be concerned with ring wrap as the header will be at
the start of a page, so we optimize accordingly. */ the start of a page, so we optimize accordingly. */
static void ariadne2_get_8390_hdr(struct net_device *dev, static void zorro8390_get_8390_hdr(struct net_device *dev,
struct e8390_pkt_hdr *hdr, int ring_page) struct e8390_pkt_hdr *hdr, int ring_page)
{ {
int nic_base = dev->base_addr; int nic_base = dev->base_addr;
...@@ -316,7 +316,7 @@ static void ariadne2_get_8390_hdr(struct net_device *dev, ...@@ -316,7 +316,7 @@ static void ariadne2_get_8390_hdr(struct net_device *dev,
The NEx000 doesn't share the on-board packet memory -- you have to put The NEx000 doesn't share the on-board packet memory -- you have to put
the packet out through the "remote DMA" dataport using z_writeb. */ the packet out through the "remote DMA" dataport using z_writeb. */
static void ariadne2_block_input(struct net_device *dev, int count, static void zorro8390_block_input(struct net_device *dev, int count,
struct sk_buff *skb, int ring_offset) struct sk_buff *skb, int ring_offset)
{ {
int nic_base = dev->base_addr; int nic_base = dev->base_addr;
...@@ -349,7 +349,7 @@ static void ariadne2_block_input(struct net_device *dev, int count, ...@@ -349,7 +349,7 @@ static void ariadne2_block_input(struct net_device *dev, int count,
ei_status.dmaing &= ~0x01; ei_status.dmaing &= ~0x01;
} }
static void ariadne2_block_output(struct net_device *dev, int count, static void zorro8390_block_output(struct net_device *dev, int count,
const unsigned char *buf, const unsigned char *buf,
const int start_page) const int start_page)
{ {
...@@ -393,7 +393,7 @@ static void ariadne2_block_output(struct net_device *dev, int count, ...@@ -393,7 +393,7 @@ static void ariadne2_block_output(struct net_device *dev, int count,
while ((z_readb(NE_BASE + NE_EN0_ISR) & ENISR_RDC) == 0) while ((z_readb(NE_BASE + NE_EN0_ISR) & ENISR_RDC) == 0)
if (jiffies - dma_start > 2*HZ/100) { /* 20ms */ if (jiffies - dma_start > 2*HZ/100) { /* 20ms */
printk("%s: timeout waiting for Tx RDC.\n", dev->name); printk("%s: timeout waiting for Tx RDC.\n", dev->name);
ariadne2_reset_8390(dev); zorro8390_reset_8390(dev);
NS8390_init(dev,1); NS8390_init(dev,1);
break; break;
} }
...@@ -403,23 +403,23 @@ static void ariadne2_block_output(struct net_device *dev, int count, ...@@ -403,23 +403,23 @@ static void ariadne2_block_output(struct net_device *dev, int count,
return; return;
} }
static void __exit ariadne2_cleanup(void) static void __exit zorro8390_cleanup(void)
{ {
#ifdef MODULE #ifdef MODULE
struct net_device *dev, *next; struct net_device *dev, *next;
while ((dev = root_ariadne2_dev)) { while ((dev = root_zorro8390_dev)) {
next = (struct net_device *)(ei_status.priv); next = (struct net_device *)(ei_status.priv);
unregister_netdev(dev); unregister_netdev(dev);
free_irq(IRQ_AMIGA_PORTS, dev); free_irq(IRQ_AMIGA_PORTS, dev);
release_mem_region(ZTWO_PADDR(dev->base_addr), NE_IO_EXTENT*2); release_mem_region(ZTWO_PADDR(dev->base_addr), NE_IO_EXTENT*2);
kfree(dev); kfree(dev);
root_ariadne2_dev = next; root_zorro8390_dev = next;
} }
#endif #endif
} }
module_init(ariadne2_probe); module_init(zorro8390_probe);
module_exit(ariadne2_cleanup); module_exit(zorro8390_cleanup);
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
...@@ -911,7 +911,7 @@ static void esp_get_dmabufs(struct NCR_ESP *esp, Scsi_Cmnd *sp) ...@@ -911,7 +911,7 @@ static void esp_get_dmabufs(struct NCR_ESP *esp, Scsi_Cmnd *sp)
if (esp->dma_mmu_get_scsi_one) if (esp->dma_mmu_get_scsi_one)
esp->dma_mmu_get_scsi_one(esp, sp); esp->dma_mmu_get_scsi_one(esp, sp);
else else
sp->SCp.have_data_in = (int) sp->SCp.ptr = sp->SCp.ptr =
(char *) virt_to_phys(sp->request_buffer); (char *) virt_to_phys(sp->request_buffer);
} else { } else {
sp->SCp.buffer = (struct scatterlist *) sp->buffer; sp->SCp.buffer = (struct scatterlist *) sp->buffer;
......
...@@ -43,9 +43,9 @@ static irqreturn_t a2091_intr (int irq, void *dummy, struct pt_regs *fp) ...@@ -43,9 +43,9 @@ static irqreturn_t a2091_intr (int irq, void *dummy, struct pt_regs *fp)
continue; continue;
if (status & ISTR_INTS) { if (status & ISTR_INTS) {
spin_lock_irqsave(&instance->host_lock, flags); spin_lock_irqsave(instance->host_lock, flags);
wd33c93_intr (instance); wd33c93_intr (instance);
spin_unlock_irqrestore(&instance->host_lock, flags); spin_unlock_irqrestore(instance->host_lock, flags);
handled = 1; handled = 1;
} }
} }
......
...@@ -36,9 +36,9 @@ static irqreturn_t a3000_intr (int irq, void *dummy, struct pt_regs *fp) ...@@ -36,9 +36,9 @@ static irqreturn_t a3000_intr (int irq, void *dummy, struct pt_regs *fp)
return IRQ_NONE; return IRQ_NONE;
if (status & ISTR_INTS) if (status & ISTR_INTS)
{ {
spin_lock_irqsave(&a3000_host->host_lock, flags); spin_lock_irqsave(a3000_host->host_lock, flags);
wd33c93_intr (a3000_host); wd33c93_intr (a3000_host);
spin_unlock_irqrestore(&a3000_host->host_lock, flags); spin_unlock_irqrestore(a3000_host->host_lock, flags);
return IRQ_HANDLED; return IRQ_HANDLED;
} }
printk("Non-serviced A3000 SCSI-interrupt? ISTR = %02x\n", status); printk("Non-serviced A3000 SCSI-interrupt? ISTR = %02x\n", status);
......
...@@ -348,7 +348,7 @@ static int dma_bytes_sent(struct NCR_ESP *esp, int fifo_count) ...@@ -348,7 +348,7 @@ static int dma_bytes_sent(struct NCR_ESP *esp, int fifo_count)
static void dma_drain(struct NCR_ESP *esp) static void dma_drain(struct NCR_ESP *esp)
{ {
unsigned long nw = *scsi_scr; unsigned long nw = *scsi_scr;
unsigned short *p = KSEG1ADDR((unsigned short *) ((*scsi_dma_ptr) >> 3)); unsigned short *p = (unsigned short *)KSEG1ADDR((*scsi_dma_ptr) >> 3);
/* /*
* Is there something in the dma buffers left? * Is there something in the dma buffers left?
...@@ -478,8 +478,7 @@ static void dma_setup(struct NCR_ESP *esp, __u32 addr, int count, int write) ...@@ -478,8 +478,7 @@ static void dma_setup(struct NCR_ESP *esp, __u32 addr, int count, int write)
*/ */
static void dma_mmu_get_scsi_one(struct NCR_ESP *esp, Scsi_Cmnd * sp) static void dma_mmu_get_scsi_one(struct NCR_ESP *esp, Scsi_Cmnd * sp)
{ {
sp->SCp.have_data_in = PHYSADDR(sp->SCp.buffer); sp->SCp.ptr = (char *)PHYSADDR(sp->SCp.buffer);
sp->SCp.ptr = (char *) ((unsigned long) sp->SCp.have_data_in);
} }
static void dma_mmu_get_scsi_sgl(struct NCR_ESP *esp, Scsi_Cmnd * sp) static void dma_mmu_get_scsi_sgl(struct NCR_ESP *esp, Scsi_Cmnd * sp)
...@@ -523,8 +522,8 @@ static void pmaz_dma_init_write(struct NCR_ESP *esp, __u32 vaddress, int length) ...@@ -523,8 +522,8 @@ static void pmaz_dma_init_write(struct NCR_ESP *esp, __u32 vaddress, int length)
{ {
volatile int *dmareg = (volatile int *) ( esp->slot + DEC_SCSI_DMAREG ); volatile int *dmareg = (volatile int *) ( esp->slot + DEC_SCSI_DMAREG );
memcpy((void *) (esp->slot + DEC_SCSI_SRAM + ESP_TGT_DMA_SIZE), memcpy((void *)(esp->slot + DEC_SCSI_SRAM + ESP_TGT_DMA_SIZE),
KSEG0ADDR((void *) vaddress), length); (void *)KSEG0ADDR(vaddress), length);
*dmareg = TC_ESP_DMAR_WRITE | *dmareg = TC_ESP_DMAR_WRITE |
TC_ESP_DMA_ADDR(esp->slot + DEC_SCSI_SRAM + ESP_TGT_DMA_SIZE); TC_ESP_DMA_ADDR(esp->slot + DEC_SCSI_SRAM + ESP_TGT_DMA_SIZE);
...@@ -554,7 +553,5 @@ static void pmaz_dma_setup(struct NCR_ESP *esp, __u32 addr, int count, int write ...@@ -554,7 +553,5 @@ static void pmaz_dma_setup(struct NCR_ESP *esp, __u32 addr, int count, int write
static void pmaz_dma_mmu_get_scsi_one(struct NCR_ESP *esp, Scsi_Cmnd * sp) static void pmaz_dma_mmu_get_scsi_one(struct NCR_ESP *esp, Scsi_Cmnd * sp)
{ {
sp->SCp.have_data_in = (int) sp->SCp.ptr = sp->SCp.ptr = (char *)KSEG0ADDR((sp->request_buffer));
(char *) KSEG0ADDR((sp->request_buffer));
} }
...@@ -42,9 +42,9 @@ static irqreturn_t gvp11_intr (int irq, void *dummy, struct pt_regs *fp) ...@@ -42,9 +42,9 @@ static irqreturn_t gvp11_intr (int irq, void *dummy, struct pt_regs *fp)
if (!(status & GVP11_DMAC_INT_PENDING)) if (!(status & GVP11_DMAC_INT_PENDING))
continue; continue;
spin_lock_irqsave(&instance->host_lock, flags); spin_lock_irqsave(instance->host_lock, flags);
wd33c93_intr (instance); wd33c93_intr (instance);
spin_unlock_irqrestore(&instance->host_lock, flags); spin_unlock_irqrestore(instance->host_lock, flags);
handled = 1; handled = 1;
} }
return IRQ_RETVAL(handled); return IRQ_RETVAL(handled);
......
...@@ -550,7 +550,7 @@ static void dma_invalidate(struct NCR_ESP *esp) ...@@ -550,7 +550,7 @@ static void dma_invalidate(struct NCR_ESP *esp)
void dma_mmu_get_scsi_one(struct NCR_ESP *esp, Scsi_Cmnd *sp) void dma_mmu_get_scsi_one(struct NCR_ESP *esp, Scsi_Cmnd *sp)
{ {
sp->SCp.have_data_in = (int) sp->SCp.ptr = sp->SCp.ptr =
sp->request_buffer; sp->request_buffer;
} }
......
...@@ -754,8 +754,8 @@ static void NCR5380_print_status (struct Scsi_Host *instance) ...@@ -754,8 +754,8 @@ static void NCR5380_print_status (struct Scsi_Host *instance)
static static
char *lprint_Scsi_Cmnd (Scsi_Cmnd *cmd, char *pos, char *buffer, int length); char *lprint_Scsi_Cmnd (Scsi_Cmnd *cmd, char *pos, char *buffer, int length);
static int NCR5380_proc_info (struct Scsi_Host *instance, char *buffer, char **start, off_t offset, int NCR5380_proc_info (struct Scsi_Host *instance, char *buffer, char **start,
int length, int inout) off_t offset, int length, int inout)
{ {
char *pos = buffer; char *pos = buffer;
struct NCR5380_hostdata *hostdata; struct NCR5380_hostdata *hostdata;
......
...@@ -1920,7 +1920,7 @@ wd33c93_proc_info(struct Scsi_Host *instance, char *buf, char **start, off_t off ...@@ -1920,7 +1920,7 @@ wd33c93_proc_info(struct Scsi_Host *instance, char *buf, char **start, off_t off
char *bp; char *bp;
char tbuf[128]; char tbuf[128];
struct Scsi_Host *instance; struct WD33C93_hostdata *hd;
Scsi_Cmnd *cmd; Scsi_Cmnd *cmd;
int x, i; int x, i;
static int stop = 0; static int stop = 0;
......
...@@ -26,7 +26,7 @@ obj-$(CONFIG_FB_NEOMAGIC) += neofb.o cfbfillrect.o cfbcopyarea.o cfbimgb ...@@ -26,7 +26,7 @@ obj-$(CONFIG_FB_NEOMAGIC) += neofb.o cfbfillrect.o cfbcopyarea.o cfbimgb
obj-$(CONFIG_FB_IGA) += igafb.o cfbfillrect.o cfbcopyarea.o cfbimgblt.o obj-$(CONFIG_FB_IGA) += igafb.o cfbfillrect.o cfbcopyarea.o cfbimgblt.o
obj-$(CONFIG_FB_CONTROL) += controlfb.o 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 macmodes.o cfbfillrect.o cfbcopyarea.o cfbimgblt.o
obj-$(CONFIG_FB_CT65550) += chipsfb.o cfbfillrect.o cfbcopyarea.o cfbimgblt.o obj-$(CONFIG_FB_CT65550) += chipsfb.o cfbfillrect.o cfbcopyarea.o cfbimgblt.o
obj-$(CONFIG_FB_ANAKIN) += anakinfb.o cfbfillrect.o cfbcopyarea.o cfbimgblt.o obj-$(CONFIG_FB_ANAKIN) += anakinfb.o cfbfillrect.o cfbcopyarea.o cfbimgblt.o
obj-$(CONFIG_FB_CLPS711X) += clps711xfb.o cfbfillrect.o cfbcopyarea.o cfbimgblt.o obj-$(CONFIG_FB_CLPS711X) += clps711xfb.o cfbfillrect.o cfbcopyarea.o cfbimgblt.o
......
...@@ -66,7 +66,7 @@ const struct linux_logo *fb_find_logo(int depth) ...@@ -66,7 +66,7 @@ const struct linux_logo *fb_find_logo(int depth)
#endif #endif
#ifdef CONFIG_LOGO_DEC_CLUT224 #ifdef CONFIG_LOGO_DEC_CLUT224
/* DEC Linux logo on MIPS/MIPS64 */ /* DEC Linux logo on MIPS/MIPS64 */
if (mips_machgroup == MACH_GROUP_SGI) if (mips_machgroup == MACH_GROUP_DEC)
logo = &logo_dec_clut224; logo = &logo_dec_clut224;
#endif #endif
#ifdef CONFIG_LOGO_MAC_CLUT224 #ifdef CONFIG_LOGO_MAC_CLUT224
......
...@@ -233,11 +233,11 @@ static int dafb_setpalette (unsigned int regno, unsigned int red, ...@@ -233,11 +233,11 @@ static int dafb_setpalette (unsigned int regno, unsigned int red,
/* Loop until we get to the register we want */ /* Loop until we get to the register we want */
for (i = 0; i < regno; i++) { for (i = 0; i < regno; i++) {
nubus_writeb(info->cmap[i].red >> 8, &dafb_cmap_regs->lut); nubus_writeb(info->cmap.red[i] >> 8, &dafb_cmap_regs->lut);
nop(); nop();
nubus_writeb(info->cmap[i].green >> 8, &dafb_cmap_regs->lut); nubus_writeb(info->cmap.green[i] >> 8, &dafb_cmap_regs->lut);
nop(); nop();
nubus_writeb(info->cmap[i].blue >> 8, &dafb_cmap_regs->lut); nubus_writeb(info->cmap.blue[i] >> 8, &dafb_cmap_regs->lut);
nop(); nop();
} }
} }
...@@ -528,10 +528,10 @@ static int macfb_setcolreg(unsigned regno, unsigned red, unsigned green, ...@@ -528,10 +528,10 @@ static int macfb_setcolreg(unsigned regno, unsigned red, unsigned green,
* != 0 for invalid regno. * != 0 for invalid regno.
*/ */
if (regno >= info->cmap.len) if (regno >= fb_info->cmap.len)
return 1; return 1;
switch (info->var.bits_per_pixel) { switch (fb_info->var.bits_per_pixel) {
case 1: case 1:
/* We shouldn't get here */ /* We shouldn't get here */
break; break;
...@@ -539,21 +539,21 @@ static int macfb_setcolreg(unsigned regno, unsigned red, unsigned green, ...@@ -539,21 +539,21 @@ static int macfb_setcolreg(unsigned regno, unsigned red, unsigned green,
case 4: case 4:
case 8: case 8:
if (macfb_setpalette) if (macfb_setpalette)
macfb_setpalette(regno, red, green, blue, info); macfb_setpalette(regno, red, green, blue, fb_info);
else else
return 1; return 1;
break; break;
case 16: case 16:
if (info->var.red.offset == 10) { if (fb_info->var.red.offset == 10) {
/* 1:5:5:5 */ /* 1:5:5:5 */
((u32*) (info->pseudo_palette))[regno] = ((u32*) (fb_info->pseudo_palette))[regno] =
((red & 0xf800) >> 1) | ((red & 0xf800) >> 1) |
((green & 0xf800) >> 6) | ((green & 0xf800) >> 6) |
((blue & 0xf800) >> 11) | ((blue & 0xf800) >> 11) |
((transp != 0) << 15); ((transp != 0) << 15);
} else { } else {
/* 0:5:6:5 */ /* 0:5:6:5 */
((u32*) (info->pseudo_palette))[regno] = ((u32*) (fb_info->pseudo_palette))[regno] =
((red & 0xf800) ) | ((red & 0xf800) ) |
((green & 0xfc00) >> 5) | ((green & 0xfc00) >> 5) |
((blue & 0xf800) >> 11); ((blue & 0xf800) >> 11);
...@@ -565,19 +565,19 @@ static int macfb_setcolreg(unsigned regno, unsigned red, unsigned green, ...@@ -565,19 +565,19 @@ static int macfb_setcolreg(unsigned regno, unsigned red, unsigned green,
red >>= 8; red >>= 8;
green >>= 8; green >>= 8;
blue >>= 8; blue >>= 8;
((u32 *)(info->pseudo_palette))[regno] = ((u32 *)(fb_info->pseudo_palette))[regno] =
(red << info->var.red.offset) | (red << fb_info->var.red.offset) |
(green << info->var.green.offset) | (green << fb_info->var.green.offset) |
(blue << info->var.blue.offset); (blue << fb_info->var.blue.offset);
break; break;
case 32: case 32:
red >>= 8; red >>= 8;
green >>= 8; green >>= 8;
blue >>= 8; blue >>= 8;
((u32 *)(info->pseudo_palette))[regno] = ((u32 *)(fb_info->pseudo_palette))[regno] =
(red << info->var.red.offset) | (red << fb_info->var.red.offset) |
(green << info->var.green.offset) | (green << fb_info->var.green.offset) |
(blue << info->var.blue.offset); (blue << fb_info->var.blue.offset);
break; break;
} }
return 0; return 0;
......
This diff is collapsed.
...@@ -125,33 +125,9 @@ extern inline void __flush_page_to_ram(void *vaddr) ...@@ -125,33 +125,9 @@ extern inline void __flush_page_to_ram(void *vaddr)
} }
#define flush_dcache_page(page) __flush_page_to_ram(page_address(page)) #define flush_dcache_page(page) __flush_page_to_ram(page_address(page))
#define flush_icache_page(vma,pg) do { } while (0) #define flush_icache_page(vma, page) __flush_page_to_ram(page_address(page))
#define flush_icache_user_range(vma,pg,adr,len) do { } while (0) #define flush_icache_user_range(vma,pg,adr,len) do { } while (0)
/* Push n pages at kernel virtual address and clear the icache */ extern void flush_icache_range(unsigned long address, unsigned long endaddr);
/* RZ: use cpush %bc instead of cpush %dc, cinv %ic */
extern inline void flush_icache_range (unsigned long address,
unsigned long endaddr)
{
if (CPU_IS_040_OR_060) {
short n = (endaddr - address + PAGE_SIZE - 1) / PAGE_SIZE;
while (--n >= 0) {
__asm__ __volatile__("nop\n\t"
".chip 68040\n\t"
"cpushp %%bc,(%0)\n\t"
".chip 68k"
: : "a" (virt_to_phys((void *)address)));
address += PAGE_SIZE;
}
} else {
unsigned long tmp;
__asm__ __volatile__("movec %%cacr,%0\n\t"
"orw %1,%0\n\t"
"movec %0,%%cacr"
: "=&d" (tmp)
: "di" (FLUSH_I));
}
}
#endif /* _M68K_CACHEFLUSH_H */ #endif /* _M68K_CACHEFLUSH_H */
#ifndef _M68K_CHECKSUM_H #ifndef _M68K_CHECKSUM_H
#define _M68K_CHECKSUM_H #define _M68K_CHECKSUM_H
#include <linux/in6.h>
/* /*
* computes the checksum of a memory block at buff, length len, * computes the checksum of a memory block at buff, length len,
* and adds in "sum" (32-bit) * and adds in "sum" (32-bit)
......
#ifndef _M68K_DMA_MAPPING_H
#define _M68K_DMA_MAPPING_H
#include <linux/config.h>
#ifdef CONFIG_PCI
#include <asm-generic/dma-mapping.h> #include <asm-generic/dma-mapping.h>
#endif
#endif /* _M68K_DMA_MAPPING_H */
...@@ -34,11 +34,11 @@ ...@@ -34,11 +34,11 @@
/* the following macro is used when enabling interrupts */ /* the following macro is used when enabling interrupts */
#if defined(MACH_ATARI_ONLY) && !defined(CONFIG_HADES) #if defined(MACH_ATARI_ONLY) && !defined(CONFIG_HADES)
/* block out HSYNC on the atari */ /* block out HSYNC on the atari */
#define ALLOWINT 0xfbff #define ALLOWINT (~0x400)
#define MAX_NOINT_IPL 3 #define MAX_NOINT_IPL 3
#else #else
/* portable version */ /* portable version */
#define ALLOWINT 0xf8ff #define ALLOWINT (~0x700)
#define MAX_NOINT_IPL 0 #define MAX_NOINT_IPL 0
#endif /* machine compilation types */ #endif /* machine compilation types */
......
...@@ -17,7 +17,8 @@ ...@@ -17,7 +17,8 @@
#include <linux/vmalloc.h> #include <linux/vmalloc.h>
asmlinkage void floppy_hardint(int irq, void *dev_id, struct pt_regs * regs); asmlinkage irqreturn_t floppy_hardint(int irq, void *dev_id,
struct pt_regs *regs);
/* constants... */ /* constants... */
...@@ -72,6 +73,7 @@ static __inline__ unsigned char fd_inb(int port) ...@@ -72,6 +73,7 @@ static __inline__ unsigned char fd_inb(int port)
return inb_p(port); return inb_p(port);
else if(MACH_IS_SUN3X) else if(MACH_IS_SUN3X)
return sun3x_82072_fd_inb(port); return sun3x_82072_fd_inb(port);
return 0;
} }
static __inline__ void fd_outb(unsigned char value, int port) static __inline__ void fd_outb(unsigned char value, int port)
...@@ -90,7 +92,7 @@ static int fd_request_irq(void) ...@@ -90,7 +92,7 @@ static int fd_request_irq(void)
"floppy", floppy_hardint); "floppy", floppy_hardint);
else if(MACH_IS_SUN3X) else if(MACH_IS_SUN3X)
return sun3xflop_request_irq(); return sun3xflop_request_irq();
return -ENXIO;
} }
static void fd_free_irq(void) static void fd_free_irq(void)
...@@ -182,7 +184,8 @@ static void fd_disable_dma(void) ...@@ -182,7 +184,8 @@ static void fd_disable_dma(void)
/* this is the only truly Q40 specific function */ /* this is the only truly Q40 specific function */
asmlinkage void floppy_hardint(int irq, void *dev_id, struct pt_regs * regs) asmlinkage irqreturn_t floppy_hardint(int irq, void *dev_id,
struct pt_regs *regs)
{ {
register unsigned char st; register unsigned char st;
...@@ -196,7 +199,7 @@ asmlinkage void floppy_hardint(int irq, void *dev_id, struct pt_regs * regs) ...@@ -196,7 +199,7 @@ asmlinkage void floppy_hardint(int irq, void *dev_id, struct pt_regs * regs)
#endif #endif
if(!doing_pdma) { if(!doing_pdma) {
floppy_interrupt(irq, dev_id, regs); floppy_interrupt(irq, dev_id, regs);
return; return IRQ_HANDLED;
} }
#ifdef TRACE_FLPY_INT #ifdef TRACE_FLPY_INT
...@@ -231,7 +234,7 @@ asmlinkage void floppy_hardint(int irq, void *dev_id, struct pt_regs * regs) ...@@ -231,7 +234,7 @@ asmlinkage void floppy_hardint(int irq, void *dev_id, struct pt_regs * regs)
calls++; calls++;
#endif #endif
if(st == 0x20) if(st == 0x20)
return; return IRQ_HANDLED;
if(!(st & 0x20)) { if(!(st & 0x20)) {
virtual_dma_residue += virtual_dma_count; virtual_dma_residue += virtual_dma_count;
virtual_dma_count=0; virtual_dma_count=0;
...@@ -244,12 +247,13 @@ asmlinkage void floppy_hardint(int irq, void *dev_id, struct pt_regs * regs) ...@@ -244,12 +247,13 @@ asmlinkage void floppy_hardint(int irq, void *dev_id, struct pt_regs * regs)
#endif #endif
doing_pdma = 0; doing_pdma = 0;
floppy_interrupt(irq, dev_id, regs); floppy_interrupt(irq, dev_id, regs);
return; return IRQ_HANDLED;
} }
#ifdef TRACE_FLPY_INT #ifdef TRACE_FLPY_INT
if(!virtual_dma_count) if(!virtual_dma_count)
dma_wait++; dma_wait++;
#endif #endif
return IRQ_HANDLED;
} }
#define EXTRA_FLOPPY_PARAMS #define EXTRA_FLOPPY_PARAMS
...@@ -7,8 +7,6 @@ ...@@ -7,8 +7,6 @@
/* entry.S is sensitive to the offsets of these fields */ /* entry.S is sensitive to the offsets of these fields */
typedef struct { typedef struct {
unsigned int __softirq_pending; unsigned int __softirq_pending;
unsigned int __syscall_count;
struct task_struct * __ksoftirqd_task;
} ____cacheline_aligned irq_cpustat_t; } ____cacheline_aligned irq_cpustat_t;
#include <linux/irq_cpustat.h> /* Standard mappings for irq_cpustat_t above */ #include <linux/irq_cpustat.h> /* Standard mappings for irq_cpustat_t above */
......
#ifndef __ASM_M68K_KMAP_TYPES_H #ifndef __ASM_M68K_KMAP_TYPES_H
#define __ASM_M68K_KMAP_TYPES_H #define __ASM_M68K_KMAP_TYPES_H
#include <linux/config.h>
enum km_type { enum km_type {
KM_BOUNCE_READ, KM_BOUNCE_READ,
KM_SKB_SUNRPC_DATA, KM_SKB_SUNRPC_DATA,
......
...@@ -4,37 +4,12 @@ ...@@ -4,37 +4,12 @@
#ifndef _ASM_MC146818RTC_H #ifndef _ASM_MC146818RTC_H
#define _ASM_MC146818RTC_H #define _ASM_MC146818RTC_H
#include <linux/config.h>
#include <asm/atarihw.h>
#ifdef CONFIG_ATARI #ifdef CONFIG_ATARI
/* RTC in Atari machines */ /* RTC in Atari machines */
#include <asm/atarihw.h> #include <asm/atarihw.h>
#include <asm/atariints.h>
#include <asm/io.h>
#define RTC_HAS_IRQ (ATARIHW_PRESENT(TT_MFP))
#define RTC_IRQ IRQ_TT_MFP_RTC
#define RTC_IRQ_FLAGS IRQ_TYPE_FAST
#define RTC_PORT(x) (TT_RTC_BAS + 2*(x))
#define RTC_ALWAYS_BCD 0 /* TOS uses binary mode, Linux should be able
* to deal with both modes */
#define RTC_CHECK_DRIVER_INIT() (MACH_IS_ATARI && ATARIHW_PRESENT(TT_CLK)) #define RTC_PORT(x) (TT_RTC_BAS + 2*(x))
#define RTC_MACH_INIT() \
do { \
epoch = atari_rtc_year_offset + 1900; \
if (RTC_HAS_IRQ) \
/* select RTC int on H->L edge */ \
tt_mfp.active_edge &= ~0x40; \
} while(0)
#define RTC_MACH_EXIT()
/* On Atari, the year was stored with base 1970 in old TOS versions (before
* 3.06). Later, Atari recognized that this broke leap year recognition, and
* changed the base to 1968. Medusa and Hades always use the new version. */
#define RTC_CENTURY_SWITCH -1 /* no century switch */
#define RTC_MINYEAR epoch
#define CMOS_READ(addr) ({ \ #define CMOS_READ(addr) ({ \
atari_outb_p((addr),RTC_PORT(0)); \ atari_outb_p((addr),RTC_PORT(0)); \
......
...@@ -12,9 +12,7 @@ ...@@ -12,9 +12,7 @@
#define _PAGE_ACCESSED 0x008 #define _PAGE_ACCESSED 0x008
#define _PAGE_DIRTY 0x010 #define _PAGE_DIRTY 0x010
#define _PAGE_SUPER 0x080 /* 68040 supervisor only */ #define _PAGE_SUPER 0x080 /* 68040 supervisor only */
#define _PAGE_FAKE_SUPER 0x200 /* fake supervisor only on 680[23]0 */
#define _PAGE_GLOBAL040 0x400 /* 68040 global bit, used for kva descs */ #define _PAGE_GLOBAL040 0x400 /* 68040 global bit, used for kva descs */
#define _PAGE_FILE 0x800 /* pagecache or swap? */
#define _PAGE_NOCACHE030 0x040 /* 68030 no-cache mode */ #define _PAGE_NOCACHE030 0x040 /* 68030 no-cache mode */
#define _PAGE_NOCACHE 0x060 /* 68040 cache mode, non-serialized */ #define _PAGE_NOCACHE 0x060 /* 68040 cache mode, non-serialized */
#define _PAGE_NOCACHE_S 0x040 /* 68040 no-cache mode, serialized */ #define _PAGE_NOCACHE_S 0x040 /* 68040 no-cache mode, serialized */
...@@ -29,6 +27,9 @@ ...@@ -29,6 +27,9 @@
#define _PAGE_TABLE (_PAGE_SHORT) #define _PAGE_TABLE (_PAGE_SHORT)
#define _PAGE_CHG_MASK (PAGE_MASK | _PAGE_ACCESSED | _PAGE_DIRTY | _PAGE_NOCACHE) #define _PAGE_CHG_MASK (PAGE_MASK | _PAGE_ACCESSED | _PAGE_DIRTY | _PAGE_NOCACHE)
#define _PAGE_PROTNONE 0x004
#define _PAGE_FILE 0x008 /* pagecache or swap? */
#ifndef __ASSEMBLY__ #ifndef __ASSEMBLY__
/* This is the cache mode to be used for pages containing page descriptors for /* This is the cache mode to be used for pages containing page descriptors for
...@@ -54,7 +55,7 @@ extern int m68k_supervisor_cachemode; ...@@ -54,7 +55,7 @@ extern int m68k_supervisor_cachemode;
extern unsigned long mm_cachebits; extern unsigned long mm_cachebits;
#endif #endif
#define PAGE_NONE __pgprot(_PAGE_PRESENT | _PAGE_RONLY | _PAGE_ACCESSED | mm_cachebits) #define PAGE_NONE __pgprot(_PAGE_PROTNONE | _PAGE_ACCESSED | mm_cachebits)
#define PAGE_SHARED __pgprot(_PAGE_PRESENT | _PAGE_ACCESSED | mm_cachebits) #define PAGE_SHARED __pgprot(_PAGE_PRESENT | _PAGE_ACCESSED | mm_cachebits)
#define PAGE_COPY __pgprot(_PAGE_PRESENT | _PAGE_RONLY | _PAGE_ACCESSED | mm_cachebits) #define PAGE_COPY __pgprot(_PAGE_PRESENT | _PAGE_RONLY | _PAGE_ACCESSED | mm_cachebits)
#define PAGE_READONLY __pgprot(_PAGE_PRESENT | _PAGE_RONLY | _PAGE_ACCESSED | mm_cachebits) #define PAGE_READONLY __pgprot(_PAGE_PRESENT | _PAGE_RONLY | _PAGE_ACCESSED | mm_cachebits)
...@@ -62,7 +63,7 @@ extern unsigned long mm_cachebits; ...@@ -62,7 +63,7 @@ extern unsigned long mm_cachebits;
/* Alternate definitions that are compile time constants, for /* Alternate definitions that are compile time constants, for
initializing protection_map. The cachebits are fixed later. */ initializing protection_map. The cachebits are fixed later. */
#define PAGE_NONE_C __pgprot(_PAGE_PRESENT | _PAGE_RONLY | _PAGE_ACCESSED) #define PAGE_NONE_C __pgprot(_PAGE_PROTNONE | _PAGE_ACCESSED)
#define PAGE_SHARED_C __pgprot(_PAGE_PRESENT | _PAGE_ACCESSED) #define PAGE_SHARED_C __pgprot(_PAGE_PRESENT | _PAGE_ACCESSED)
#define PAGE_COPY_C __pgprot(_PAGE_PRESENT | _PAGE_RONLY | _PAGE_ACCESSED) #define PAGE_COPY_C __pgprot(_PAGE_PRESENT | _PAGE_RONLY | _PAGE_ACCESSED)
#define PAGE_READONLY_C __pgprot(_PAGE_PRESENT | _PAGE_RONLY | _PAGE_ACCESSED) #define PAGE_READONLY_C __pgprot(_PAGE_PRESENT | _PAGE_RONLY | _PAGE_ACCESSED)
...@@ -118,7 +119,7 @@ extern inline void pgd_set(pgd_t * pgdp, pmd_t * pmdp) ...@@ -118,7 +119,7 @@ extern inline void pgd_set(pgd_t * pgdp, pmd_t * pmdp)
#define pte_none(pte) (!pte_val(pte)) #define pte_none(pte) (!pte_val(pte))
#define pte_present(pte) (pte_val(pte) & (_PAGE_PRESENT | _PAGE_FAKE_SUPER)) #define pte_present(pte) (pte_val(pte) & (_PAGE_PRESENT | _PAGE_PROTNONE))
#define pte_clear(ptep) ({ pte_val(*(ptep)) = 0; }) #define pte_clear(ptep) ({ pte_val(*(ptep)) = 0; })
#define pte_page(pte) (mem_map + ((unsigned long)(__va(pte_val(pte)) - PAGE_OFFSET) >> PAGE_SHIFT)) #define pte_page(pte) (mem_map + ((unsigned long)(__va(pte_val(pte)) - PAGE_OFFSET) >> PAGE_SHIFT))
...@@ -256,23 +257,23 @@ static inline void cache_page(void *vaddr) ...@@ -256,23 +257,23 @@ static inline void cache_page(void *vaddr)
} }
} }
#define PTE_FILE_MAX_BITS 29 #define PTE_FILE_MAX_BITS 28
static inline unsigned long pte_to_pgoff(pte_t pte) static inline unsigned long pte_to_pgoff(pte_t pte)
{ {
return ((pte.pte >> 12) << 7) + ((pte.pte >> 2) & 0x1ff); return pte.pte >> 4;
} }
static inline pte_t pgoff_to_pte(inline unsigned off) static inline pte_t pgoff_to_pte(unsigned off)
{ {
pte_t pte = { ((off >> 7) << 12) + ((off & 0x1ff) << 2) + _PAGE_FILE }; pte_t pte = { (off << 4) + _PAGE_FILE };
return pte; return pte;
} }
/* Encode and de-code a swap entry (must be !pte_none(e) && !pte_present(e)) */ /* Encode and de-code a swap entry (must be !pte_none(e) && !pte_present(e)) */
#define __swp_type(x) (((x).val >> 2) & 0x1ff) #define __swp_type(x) (((x).val >> 4) & 0xff)
#define __swp_offset(x) ((x).val >> 12) #define __swp_offset(x) ((x).val >> 12)
#define __swp_entry(type, offset) ((swp_entry_t) { ((type) << 2) | ((offset) << 12) }) #define __swp_entry(type, offset) ((swp_entry_t) { ((type) << 4) | ((offset) << 12) })
#define __pte_to_swp_entry(pte) ((swp_entry_t) { pte_val(pte) }) #define __pte_to_swp_entry(pte) ((swp_entry_t) { pte_val(pte) })
#define __swp_entry_to_pte(x) ((pte_t) { (x).val }) #define __swp_entry_to_pte(x) ((pte_t) { (x).val })
......
...@@ -38,6 +38,8 @@ ...@@ -38,6 +38,8 @@
#define _PAGE_PRESENT (SUN3_PAGE_VALID) #define _PAGE_PRESENT (SUN3_PAGE_VALID)
#define _PAGE_ACCESSED (SUN3_PAGE_ACCESSED) #define _PAGE_ACCESSED (SUN3_PAGE_ACCESSED)
#define PTE_FILE_MAX_BITS 28
/* Compound page protection values. */ /* Compound page protection values. */
//todo: work out which ones *should* have SUN3_PAGE_NOCACHE and fix... //todo: work out which ones *should* have SUN3_PAGE_NOCACHE and fix...
// is it just PAGE_KERNEL and PAGE_SHARED? // is it just PAGE_KERNEL and PAGE_SHARED?
...@@ -160,6 +162,7 @@ extern inline int pte_write(pte_t pte) { return pte_val(pte) & SUN3_PAGE_WRITEA ...@@ -160,6 +162,7 @@ extern inline int pte_write(pte_t pte) { return pte_val(pte) & SUN3_PAGE_WRITEA
extern inline int pte_exec(pte_t pte) { return 1; } extern inline int pte_exec(pte_t pte) { return 1; }
extern inline int pte_dirty(pte_t pte) { return pte_val(pte) & SUN3_PAGE_MODIFIED; } extern inline int pte_dirty(pte_t pte) { return pte_val(pte) & SUN3_PAGE_MODIFIED; }
extern inline int pte_young(pte_t pte) { return pte_val(pte) & SUN3_PAGE_ACCESSED; } extern inline int pte_young(pte_t pte) { return pte_val(pte) & SUN3_PAGE_ACCESSED; }
extern inline int pte_file(pte_t pte) { return pte_val(pte) & SUN3_PAGE_ACCESSED; }
extern inline pte_t pte_wrprotect(pte_t pte) { pte_val(pte) &= ~SUN3_PAGE_WRITEABLE; return pte; } extern inline pte_t pte_wrprotect(pte_t pte) { pte_val(pte) &= ~SUN3_PAGE_WRITEABLE; return pte; }
extern inline pte_t pte_rdprotect(pte_t pte) { return pte; } extern inline pte_t pte_rdprotect(pte_t pte) { return pte; }
...@@ -195,6 +198,18 @@ extern inline pmd_t *pmd_offset (pgd_t *pgd, unsigned long address) ...@@ -195,6 +198,18 @@ extern inline pmd_t *pmd_offset (pgd_t *pgd, unsigned long address)
return (pmd_t *) pgd; return (pmd_t *) pgd;
} }
static inline unsigned long pte_to_pgoff(pte_t pte)
{
return pte.pte & SUN3_PAGE_PGNUM_MASK;
}
static inline pte_t pgoff_to_pte(inline unsigned off)
{
pte_t pte = { off + SUN3_PAGE_ACCESSED };
return pte;
}
/* Find an entry in the third-level pagetable. */ /* Find an entry in the third-level pagetable. */
#define pte_index(address) ((address >> PAGE_SHIFT) & (PTRS_PER_PTE-1)) #define pte_index(address) ((address >> PAGE_SHIFT) & (PTRS_PER_PTE-1))
#define pte_offset_kernel(pmd, address) ((pte_t *) __pmd_page(*pmd) + pte_index(address)) #define pte_offset_kernel(pmd, address) ((pte_t *) __pmd_page(*pmd) + pte_index(address))
......
...@@ -113,7 +113,8 @@ static void sun3x_82072_fd_outb(unsigned char value, int port) ...@@ -113,7 +113,8 @@ static void sun3x_82072_fd_outb(unsigned char value, int port)
} }
asmlinkage void sun3xflop_hardint(int irq, void *dev_id, struct pt_regs * regs) asmlinkage irqreturn_t sun3xflop_hardint(int irq, void *dev_id,
struct pt_regs * regs)
{ {
register unsigned char st; register unsigned char st;
...@@ -127,7 +128,7 @@ asmlinkage void sun3xflop_hardint(int irq, void *dev_id, struct pt_regs * regs) ...@@ -127,7 +128,7 @@ asmlinkage void sun3xflop_hardint(int irq, void *dev_id, struct pt_regs * regs)
#endif #endif
if(!doing_pdma) { if(!doing_pdma) {
floppy_interrupt(irq, dev_id, regs); floppy_interrupt(irq, dev_id, regs);
return; return IRQ_HANDLED;
} }
// printk("doing pdma\n");// st %x\n", sun_fdc->status_82072); // printk("doing pdma\n");// st %x\n", sun_fdc->status_82072);
...@@ -151,7 +152,7 @@ asmlinkage void sun3xflop_hardint(int irq, void *dev_id, struct pt_regs * regs) ...@@ -151,7 +152,7 @@ asmlinkage void sun3xflop_hardint(int irq, void *dev_id, struct pt_regs * regs)
if((st & 0x80) == 0) { if((st & 0x80) == 0) {
virtual_dma_count = lcount; virtual_dma_count = lcount;
virtual_dma_addr = lptr; virtual_dma_addr = lptr;
return; return IRQ_HANDLED;
} }
if((st & 0x20) == 0) if((st & 0x20) == 0)
...@@ -176,7 +177,7 @@ asmlinkage void sun3xflop_hardint(int irq, void *dev_id, struct pt_regs * regs) ...@@ -176,7 +177,7 @@ asmlinkage void sun3xflop_hardint(int irq, void *dev_id, struct pt_regs * regs)
#endif #endif
// printk("st=%02x\n", st); // printk("st=%02x\n", st);
if(st == 0x20) if(st == 0x20)
return; return IRQ_HANDLED;
if(!(st & 0x20)) { if(!(st & 0x20)) {
virtual_dma_residue += virtual_dma_count; virtual_dma_residue += virtual_dma_count;
virtual_dma_count=0; virtual_dma_count=0;
...@@ -191,7 +192,7 @@ asmlinkage void sun3xflop_hardint(int irq, void *dev_id, struct pt_regs * regs) ...@@ -191,7 +192,7 @@ asmlinkage void sun3xflop_hardint(int irq, void *dev_id, struct pt_regs * regs)
#endif #endif
floppy_interrupt(irq, dev_id, regs); floppy_interrupt(irq, dev_id, regs);
return; return IRQ_HANDLED;
} }
...@@ -199,6 +200,7 @@ asmlinkage void sun3xflop_hardint(int irq, void *dev_id, struct pt_regs * regs) ...@@ -199,6 +200,7 @@ asmlinkage void sun3xflop_hardint(int irq, void *dev_id, struct pt_regs * regs)
if(!virtual_dma_count) if(!virtual_dma_count)
dma_wait++; dma_wait++;
#endif #endif
return IRQ_HANDLED;
} }
static int sun3xflop_request_irq(void) static int sun3xflop_request_irq(void)
......
...@@ -54,6 +54,7 @@ struct elevator_s ...@@ -54,6 +54,7 @@ struct elevator_s
struct kobject kobj; struct kobject kobj;
struct kobj_type *elevator_ktype; struct kobj_type *elevator_ktype;
const char *elevator_name;
}; };
/* /*
......
...@@ -182,9 +182,6 @@ extern struct zorro_dev *zorro_find_device(zorro_id id, ...@@ -182,9 +182,6 @@ extern struct zorro_dev *zorro_find_device(zorro_id id,
#define zorro_request_device(z, name) \ #define zorro_request_device(z, name) \
request_mem_region((z)->resource.start, \ request_mem_region((z)->resource.start, \
(z)->resource.end-(z)->resource.start+1, (name)) (z)->resource.end-(z)->resource.start+1, (name))
#define zorro_check_device(z) \
check_mem_region((z)->resource.start, \
(z)->resource.end-(z)->resource.start+1)
#define zorro_release_device(z) \ #define zorro_release_device(z) \
release_mem_region((z)->resource.start, \ release_mem_region((z)->resource.start, \
(z)->resource.end-(z)->resource.start+1) (z)->resource.end-(z)->resource.start+1)
......
...@@ -141,6 +141,8 @@ config EPOLL ...@@ -141,6 +141,8 @@ config EPOLL
Disabling this option will cause the kernel to be built without Disabling this option will cause the kernel to be built without
support for epoll family of system calls. support for epoll family of system calls.
source "drivers/block/Kconfig.iosched"
endmenu # General setup endmenu # General setup
......
...@@ -1000,6 +1000,15 @@ void zap_other_threads(struct task_struct *p) ...@@ -1000,6 +1000,15 @@ void zap_other_threads(struct task_struct *p)
return; return;
for (t = next_thread(p); t != p; t = next_thread(t)) { for (t = next_thread(p); t != p; t = next_thread(t)) {
/*
* We don't want to notify the parent, since we are
* killed as part of a thread group due to another
* thread doing an execve() or similar. So set the
* exit signal to -1 to allow immediate reaping of
* the process.
*/
t->exit_signal = -1;
sigaddset(&t->pending.signal, SIGKILL); sigaddset(&t->pending.signal, SIGKILL);
rm_from_queue(SIG_KERNEL_STOP_MASK, &t->pending); rm_from_queue(SIG_KERNEL_STOP_MASK, &t->pending);
signal_wake_up(t, 1); signal_wake_up(t, 1);
......
...@@ -3,6 +3,7 @@ ...@@ -3,6 +3,7 @@
obj-$(CONFIG_SOUND) += soundcore.o obj-$(CONFIG_SOUND) += soundcore.o
obj-$(CONFIG_SOUND_PRIME) += oss/ obj-$(CONFIG_SOUND_PRIME) += oss/
obj-$(CONFIG_DMASOUND) += oss/
obj-$(CONFIG_SND) += core/ i2c/ drivers/ isa/ pci/ ppc/ arm/ synth/ usb/ sparc/ parisc/ pcmcia/ obj-$(CONFIG_SND) += core/ i2c/ drivers/ isa/ pci/ ppc/ arm/ synth/ usb/ sparc/ parisc/ pcmcia/
ifeq ($(CONFIG_SND),y) ifeq ($(CONFIG_SND),y)
......
...@@ -1210,6 +1210,8 @@ static int sq_ioctl(struct inode *inode, struct file *file, u_int cmd, ...@@ -1210,6 +1210,8 @@ static int sq_ioctl(struct inode *inode, struct file *file, u_int cmd,
shared_resources_initialised = 0 ; shared_resources_initialised = 0 ;
return result ; return result ;
break ; break ;
case SOUND_PCM_READ_RATE:
return IOCTL_OUT(arg, dmasound.soft.speed);
case SNDCTL_DSP_SPEED: case SNDCTL_DSP_SPEED:
/* changing this on the fly will have weird effects on the sound. /* changing this on the fly will have weird effects on the sound.
Where there are rate conversions implemented in soft form - it Where there are rate conversions implemented in soft form - it
......
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