18c2ecf20Sopenharmony_ci/* SPDX-License-Identifier: GPL-2.0-only */ 28c2ecf20Sopenharmony_ci/* 38c2ecf20Sopenharmony_ci * arch/arm/include/asm/floppy.h 48c2ecf20Sopenharmony_ci * 58c2ecf20Sopenharmony_ci * Copyright (C) 1996-2000 Russell King 68c2ecf20Sopenharmony_ci * 78c2ecf20Sopenharmony_ci * Note that we don't touch FLOPPY_DMA nor FLOPPY_IRQ here 88c2ecf20Sopenharmony_ci */ 98c2ecf20Sopenharmony_ci#ifndef __ASM_ARM_FLOPPY_H 108c2ecf20Sopenharmony_ci#define __ASM_ARM_FLOPPY_H 118c2ecf20Sopenharmony_ci 128c2ecf20Sopenharmony_ci#define fd_outb(val, base, reg) \ 138c2ecf20Sopenharmony_ci do { \ 148c2ecf20Sopenharmony_ci int new_val = (val); \ 158c2ecf20Sopenharmony_ci if ((reg) == FD_DOR) { \ 168c2ecf20Sopenharmony_ci if (new_val & 0xf0) \ 178c2ecf20Sopenharmony_ci new_val = (new_val & 0x0c) | \ 188c2ecf20Sopenharmony_ci floppy_selects[new_val & 3]; \ 198c2ecf20Sopenharmony_ci else \ 208c2ecf20Sopenharmony_ci new_val &= 0x0c; \ 218c2ecf20Sopenharmony_ci } \ 228c2ecf20Sopenharmony_ci outb(new_val, (base) + (reg)); \ 238c2ecf20Sopenharmony_ci } while(0) 248c2ecf20Sopenharmony_ci 258c2ecf20Sopenharmony_ci#define fd_inb(base, reg) inb((base) + (reg)) 268c2ecf20Sopenharmony_ci#define fd_request_irq() request_irq(IRQ_FLOPPYDISK,floppy_interrupt,\ 278c2ecf20Sopenharmony_ci 0,"floppy",NULL) 288c2ecf20Sopenharmony_ci#define fd_free_irq() free_irq(IRQ_FLOPPYDISK,NULL) 298c2ecf20Sopenharmony_ci#define fd_disable_irq() disable_irq(IRQ_FLOPPYDISK) 308c2ecf20Sopenharmony_ci#define fd_enable_irq() enable_irq(IRQ_FLOPPYDISK) 318c2ecf20Sopenharmony_ci 328c2ecf20Sopenharmony_cistatic inline int fd_dma_setup(void *data, unsigned int length, 338c2ecf20Sopenharmony_ci unsigned int mode, unsigned long addr) 348c2ecf20Sopenharmony_ci{ 358c2ecf20Sopenharmony_ci set_dma_mode(DMA_FLOPPY, mode); 368c2ecf20Sopenharmony_ci __set_dma_addr(DMA_FLOPPY, data); 378c2ecf20Sopenharmony_ci set_dma_count(DMA_FLOPPY, length); 388c2ecf20Sopenharmony_ci virtual_dma_port = addr; 398c2ecf20Sopenharmony_ci enable_dma(DMA_FLOPPY); 408c2ecf20Sopenharmony_ci return 0; 418c2ecf20Sopenharmony_ci} 428c2ecf20Sopenharmony_ci#define fd_dma_setup fd_dma_setup 438c2ecf20Sopenharmony_ci 448c2ecf20Sopenharmony_ci#define fd_request_dma() request_dma(DMA_FLOPPY,"floppy") 458c2ecf20Sopenharmony_ci#define fd_free_dma() free_dma(DMA_FLOPPY) 468c2ecf20Sopenharmony_ci#define fd_disable_dma() disable_dma(DMA_FLOPPY) 478c2ecf20Sopenharmony_ci 488c2ecf20Sopenharmony_ci/* need to clean up dma.h */ 498c2ecf20Sopenharmony_ci#define DMA_FLOPPYDISK DMA_FLOPPY 508c2ecf20Sopenharmony_ci 518c2ecf20Sopenharmony_ci/* Floppy_selects is the list of DOR's to select drive fd 528c2ecf20Sopenharmony_ci * 538c2ecf20Sopenharmony_ci * On initialisation, the floppy list is scanned, and the drives allocated 548c2ecf20Sopenharmony_ci * in the order that they are found. This is done by seeking the drive 558c2ecf20Sopenharmony_ci * to a non-zero track, and then restoring it to track 0. If an error occurs, 568c2ecf20Sopenharmony_ci * then there is no floppy drive present. [to be put back in again] 578c2ecf20Sopenharmony_ci */ 588c2ecf20Sopenharmony_cistatic unsigned char floppy_selects[4] = { 0x10, 0x21, 0x23, 0x33 }; 598c2ecf20Sopenharmony_ci 608c2ecf20Sopenharmony_ci#define FDC1 (0x3f0) 618c2ecf20Sopenharmony_ci 628c2ecf20Sopenharmony_ci#define FLOPPY0_TYPE 4 638c2ecf20Sopenharmony_ci#define FLOPPY1_TYPE 4 648c2ecf20Sopenharmony_ci 658c2ecf20Sopenharmony_ci#define N_FDC 1 668c2ecf20Sopenharmony_ci#define N_DRIVE 4 678c2ecf20Sopenharmony_ci 688c2ecf20Sopenharmony_ci#define CROSS_64KB(a,s) (0) 698c2ecf20Sopenharmony_ci 708c2ecf20Sopenharmony_ci/* 718c2ecf20Sopenharmony_ci * This allows people to reverse the order of 728c2ecf20Sopenharmony_ci * fd0 and fd1, in case their hardware is 738c2ecf20Sopenharmony_ci * strangely connected (as some RiscPCs 748c2ecf20Sopenharmony_ci * and A5000s seem to be). 758c2ecf20Sopenharmony_ci */ 768c2ecf20Sopenharmony_cistatic void driveswap(int *ints, int dummy, int dummy2) 778c2ecf20Sopenharmony_ci{ 788c2ecf20Sopenharmony_ci swap(floppy_selects[0], floppy_selects[1]); 798c2ecf20Sopenharmony_ci} 808c2ecf20Sopenharmony_ci 818c2ecf20Sopenharmony_ci#define EXTRA_FLOPPY_PARAMS ,{ "driveswap", &driveswap, NULL, 0, 0 } 828c2ecf20Sopenharmony_ci 838c2ecf20Sopenharmony_ci#endif 84