Skip to content
Navigation Menu
Toggle navigation
Sign in
In this repository
All GitHub Enterprise
↵
Jump to
↵
No suggested jump to results
In this repository
All GitHub Enterprise
↵
Jump to
↵
In this organization
All GitHub Enterprise
↵
Jump to
↵
In this repository
All GitHub Enterprise
↵
Jump to
↵
Sign in
Reseting focus
You signed in with another tab or window.
Reload
to refresh your session.
You signed out in another tab or window.
Reload
to refresh your session.
You switched accounts on another tab or window.
Reload
to refresh your session.
Dismiss alert
{{ message }}
mariux64
/
linux
Public
Notifications
You must be signed in to change notification settings
Fork
0
Star
0
Code
Issues
2
Pull requests
0
Actions
Projects
0
Wiki
Security
Insights
Additional navigation options
Code
Issues
Pull requests
Actions
Projects
Wiki
Security
Insights
Files
91bf5ec
Documentation
LICENSES
arch
alpha
arc
arm
arm64
c6x
csky
h8300
hexagon
ia64
m68k
68000
amiga
apollo
atari
bvme6000
coldfire
configs
emu
fpsp040
hp300
ifpsp060
include
asm
Kbuild
MC68328.h
MC68EZ328.h
MC68VZ328.h
adb_iop.h
amigahw.h
amigaints.h
amigayle.h
amipcmcia.h
apollohw.h
asm-offsets.h
asm-prototypes.h
atari_joystick.h
atari_stdma.h
atari_stram.h
atarihw.h
atariints.h
atarikb.h
atomic.h
bitops.h
blinken.h
bootinfo.h
bootstd.h
bug.h
bugs.h
bvme6000hw.h
cache.h
cacheflush.h
cacheflush_mm.h
cacheflush_no.h
checksum.h
cmpxchg.h
coldfire.h
contregs.h
current.h
delay.h
div64.h
dma.h
dsp56k.h
dvma.h
elf.h
entry.h
export.h
fb.h
fbio.h
flat.h
floppy.h
fpu.h
ftrace.h
gpio.h
hash.h
hp300hw.h
hwtest.h
ide.h
idprom.h
intersil.h
io.h
io_mm.h
io_no.h
irq.h
irqflags.h
kexec.h
kmap.h
linkage.h
m5206sim.h
m520xsim.h
m523xsim.h
m525xsim.h
m5272sim.h
m527xsim.h
m528xsim.h
m52xxacr.h
m5307sim.h
m53xxacr.h
m53xxsim.h
m5407sim.h
m5441xsim.h
m54xxacr.h
m54xxgpt.h
m54xxpci.h
m54xxsim.h
mac_asc.h
mac_baboon.h
mac_iop.h
mac_oss.h
mac_psc.h
mac_via.h
machdep.h
machines.h
machw.h
macintosh.h
macints.h
math-emu.h
mc146818rtc.h
mcf8390.h
mcf_pgalloc.h
mcf_pgtable.h
mcfclk.h
mcfdma.h
mcfgpio.h
mcfintc.h
mcfmmu.h
mcfpit.h
mcfqspi.h
mcfsim.h
mcfslt.h
mcftimer.h
mcfuart.h
mcfwdebug.h
mmu.h
mmu_context.h
mmzone.h
module.h
motorola_pgalloc.h
motorola_pgtable.h
movs.h
mvme147hw.h
mvme16xhw.h
natfeat.h
nettel.h
nubus.h
openprom.h
oplib.h
page.h
page_mm.h
page_no.h
page_offset.h
parport.h
pci.h
pgalloc.h
pgtable.h
pgtable_mm.h
pgtable_no.h
processor.h
ptrace.h
q40_master.h
q40ints.h
quicc_simple.h
raw_io.h
segment.h
serial.h
setup.h
signal.h
smp.h
string.h
sun3-head.h
sun3_pgalloc.h
sun3_pgtable.h
sun3ints.h
sun3mmu.h
sun3x.h
sun3xflop.h
sun3xprom.h
switch_to.h
syscall.h
thread_info.h
timex.h
tlb.h
tlbflush.h
traps.h
uaccess.h
uaccess_mm.h
uaccess_no.h
ucontext.h
unaligned.h
unistd.h
user.h
vga.h
virtconvert.h
vmalloc.h
zorro.h
uapi
kernel
lib
mac
math-emu
mm
mvme147
mvme16x
q40
sun3
sun3x
tools
Kconfig
Kconfig.bus
Kconfig.cpu
Kconfig.debug
Kconfig.devices
Kconfig.machine
Makefile
install.sh
microblaze
mips
nds32
nios2
openrisc
parisc
powerpc
riscv
s390
sh
sparc
um
unicore32
x86
xtensa
.gitignore
Kconfig
block
certs
crypto
drivers
fs
include
init
ipc
kernel
lib
mm
net
samples
scripts
security
sound
tools
usr
virt
.clang-format
.cocciconfig
.get_maintainer.ignore
.gitattributes
.gitignore
.mailmap
COPYING
CREDITS
Kbuild
Kconfig
MAINTAINERS
Makefile
README
Breadcrumbs
linux
/
arch
/
m68k
/
include
/
asm
/
floppy.h
Blame
Blame
Latest commit
History
History
255 lines (197 loc) · 5.21 KB
Breadcrumbs
linux
/
arch
/
m68k
/
include
/
asm
/
floppy.h
Top
File metadata and controls
Code
Blame
255 lines (197 loc) · 5.21 KB
Raw
/* * Implementation independent bits of the Floppy driver. * * much of this file is derived from what was originally the Q40 floppy driver. * * This file is subject to the terms and conditions of the GNU General Public * License. See the file "COPYING" in the main directory of this archive * for more details. * * Copyright (C) 1999, 2000, 2001 * * Sun3x support added 2/4/2000 Sam Creasey (sammy@sammy.net) * */ #include <asm/io.h> #include <linux/vmalloc.h> asmlinkage irqreturn_t floppy_hardint(int irq, void *dev_id); /* constants... */ #undef MAX_DMA_ADDRESS #define MAX_DMA_ADDRESS 0x00 /* nothing like that */ /* * Again, the CMOS information doesn't work on m68k.. */ #define FLOPPY0_TYPE (MACH_IS_Q40 ? 6 : 4) #define FLOPPY1_TYPE 0 /* basically PC init + set use_virtual_dma */ #define FDC1 m68k_floppy_init() #define N_FDC 1 #define N_DRIVE 8 /* vdma globals adapted from asm-i386/floppy.h */ static int virtual_dma_count=0; static int virtual_dma_residue=0; static char *virtual_dma_addr=NULL; static int virtual_dma_mode=0; static int doing_pdma=0; #include <asm/sun3xflop.h> extern spinlock_t dma_spin_lock; static __inline__ unsigned long claim_dma_lock(void) { unsigned long flags; spin_lock_irqsave(&dma_spin_lock, flags); return flags; } static __inline__ void release_dma_lock(unsigned long flags) { spin_unlock_irqrestore(&dma_spin_lock, flags); } static __inline__ unsigned char fd_inb(int base, int reg) { if(MACH_IS_Q40) return inb_p(base + reg); else if(MACH_IS_SUN3X) return sun3x_82072_fd_inb(base + reg); return 0; } static __inline__ void fd_outb(unsigned char value, int base, int reg) { if(MACH_IS_Q40) outb_p(value, base + reg); else if(MACH_IS_SUN3X) sun3x_82072_fd_outb(value, base + reg); } static int fd_request_irq(void) { if(MACH_IS_Q40) return request_irq(FLOPPY_IRQ, floppy_hardint, 0, "floppy", floppy_hardint); else if(MACH_IS_SUN3X) return sun3xflop_request_irq(); return -ENXIO; } static void fd_free_irq(void) { if(MACH_IS_Q40) free_irq(FLOPPY_IRQ, floppy_hardint); } #define fd_request_dma() vdma_request_dma(FLOPPY_DMA,"floppy") #define fd_get_dma_residue() vdma_get_dma_residue(FLOPPY_DMA) #define fd_dma_mem_alloc(size) vdma_mem_alloc(size) #define fd_dma_setup(addr, size, mode, io) vdma_dma_setup(addr, size, mode, io) #define fd_enable_irq() /* nothing... */ #define fd_disable_irq() /* nothing... */ #define fd_free_dma() /* nothing */ /* No 64k boundary crossing problems on Q40 - no DMA at all */ #define CROSS_64KB(a,s) (0) #define DMA_MODE_READ 0x44 /* i386 look-alike */ #define DMA_MODE_WRITE 0x48 static int m68k_floppy_init(void) { use_virtual_dma =1; can_use_virtual_dma = 1; if (MACH_IS_Q40) return 0x3f0; else if(MACH_IS_SUN3X) return sun3xflop_init(); else return -1; } static int vdma_request_dma(unsigned int dmanr, const char * device_id) { return 0; } static int vdma_get_dma_residue(unsigned int dummy) { return virtual_dma_count + virtual_dma_residue; } static unsigned long vdma_mem_alloc(unsigned long size) { return (unsigned long) vmalloc(size); } static void _fd_dma_mem_free(unsigned long addr, unsigned long size) { vfree((void *)addr); } #define fd_dma_mem_free(addr,size) _fd_dma_mem_free(addr, size) /* choose_dma_mode ???*/ static int vdma_dma_setup(char *addr, unsigned long size, int mode, int io) { doing_pdma = 1; virtual_dma_port = (MACH_IS_Q40 ? io : 0); virtual_dma_mode = (mode == DMA_MODE_WRITE); virtual_dma_addr = addr; virtual_dma_count = size; virtual_dma_residue = 0; return 0; } static void fd_disable_dma(void) { doing_pdma = 0; virtual_dma_residue += virtual_dma_count; virtual_dma_count=0; } /* this is the only truly Q40 specific function */ asmlinkage irqreturn_t floppy_hardint(int irq, void *dev_id) { register unsigned char st; #undef TRACE_FLPY_INT #define NO_FLOPPY_ASSEMBLER #ifdef TRACE_FLPY_INT static int calls=0; static int bytes=0; static int dma_wait=0; #endif if(!doing_pdma) { floppy_interrupt(irq, dev_id); return IRQ_HANDLED; } #ifdef TRACE_FLPY_INT if(!calls) bytes = virtual_dma_count; #endif { register int lcount; register char *lptr; /* serve 1st byte fast: */ st=1; for(lcount=virtual_dma_count, lptr=virtual_dma_addr; lcount; lcount--, lptr++) { st = inb(virtual_dma_port + FD_STATUS); st &= STATUS_DMA | STATUS_READY; if (st != (STATUS_DMA | STATUS_READY)) break; if(virtual_dma_mode) outb_p(*lptr, virtual_dma_port + FD_DATA); else *lptr = inb_p(virtual_dma_port + FD_DATA); } virtual_dma_count = lcount; virtual_dma_addr = lptr; st = inb(virtual_dma_port + FD_STATUS); } #ifdef TRACE_FLPY_INT calls++; #endif if (st == STATUS_DMA) return IRQ_HANDLED; if (!(st & STATUS_DMA)) { virtual_dma_residue += virtual_dma_count; virtual_dma_count=0; #ifdef TRACE_FLPY_INT pr_info("count=%x, residue=%x calls=%d bytes=%d dma_wait=%d\n", virtual_dma_count, virtual_dma_residue, calls, bytes, dma_wait); calls = 0; dma_wait=0; #endif doing_pdma = 0; floppy_interrupt(irq, dev_id); return IRQ_HANDLED; } #ifdef TRACE_FLPY_INT if(!virtual_dma_count) dma_wait++; #endif return IRQ_HANDLED; } #define EXTRA_FLOPPY_PARAMS
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
You can’t perform that action at this time.