hc
2024-03-22 a0752693d998599af469473b8dc239ef973a012f
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
/* SPDX-License-Identifier: GPL-2.0-only */
/*
 *  arch/arm/include/asm/floppy.h
 *
 *  Copyright (C) 1996-2000 Russell King
 *
 *  Note that we don't touch FLOPPY_DMA nor FLOPPY_IRQ here
 */
#ifndef __ASM_ARM_FLOPPY_H
#define __ASM_ARM_FLOPPY_H
 
#define fd_outb(val, base, reg)                        \
   do {                                \
       int new_val = (val);                    \
       if ((reg) == FD_DOR) {                    \
           if (new_val & 0xf0)                \
               new_val = (new_val & 0x0c) |        \
                     floppy_selects[new_val & 3];    \
           else                        \
               new_val &= 0x0c;            \
       }                            \
       outb(new_val, (base) + (reg));                \
   } while(0)
 
#define fd_inb(base, reg)    inb((base) + (reg))
#define fd_request_irq()    request_irq(IRQ_FLOPPYDISK,floppy_interrupt,\
                       0,"floppy",NULL)
#define fd_free_irq()        free_irq(IRQ_FLOPPYDISK,NULL)
#define fd_disable_irq()    disable_irq(IRQ_FLOPPYDISK)
#define fd_enable_irq()        enable_irq(IRQ_FLOPPYDISK)
 
static inline int fd_dma_setup(void *data, unsigned int length,
                  unsigned int mode, unsigned long addr)
{
   set_dma_mode(DMA_FLOPPY, mode);
   __set_dma_addr(DMA_FLOPPY, data);
   set_dma_count(DMA_FLOPPY, length);
   virtual_dma_port = addr;
   enable_dma(DMA_FLOPPY);
   return 0;
}
#define fd_dma_setup        fd_dma_setup
 
#define fd_request_dma()    request_dma(DMA_FLOPPY,"floppy")
#define fd_free_dma()        free_dma(DMA_FLOPPY)
#define fd_disable_dma()    disable_dma(DMA_FLOPPY)
 
/* need to clean up dma.h */
#define DMA_FLOPPYDISK        DMA_FLOPPY
 
/* Floppy_selects is the list of DOR's to select drive fd
 *
 * On initialisation, the floppy list is scanned, and the drives allocated
 * in the order that they are found.  This is done by seeking the drive
 * to a non-zero track, and then restoring it to track 0.  If an error occurs,
 * then there is no floppy drive present.       [to be put back in again]
 */
static unsigned char floppy_selects[4] = { 0x10, 0x21, 0x23, 0x33 };
 
#define FDC1 (0x3f0)
 
#define FLOPPY0_TYPE 4
#define FLOPPY1_TYPE 4
 
#define N_FDC 1
#define N_DRIVE 4
 
#define CROSS_64KB(a,s) (0)
 
/*
 * This allows people to reverse the order of
 * fd0 and fd1, in case their hardware is
 * strangely connected (as some RiscPCs
 * and A5000s seem to be).
 */
static void driveswap(int *ints, int dummy, int dummy2)
{
   swap(floppy_selects[0], floppy_selects[1]);
}
 
#define EXTRA_FLOPPY_PARAMS ,{ "driveswap", &driveswap, NULL, 0, 0 }
   
#endif