Loading...
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 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 | /* * linux/drivers/ide/macide.c -- Macintosh IDE Driver * * Copyright (C) 1998 by Michael Schmitz * * This driver was written based on information obtained from the MacOS IDE * driver binary by Mikael Forselius * * 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. */ #include <linux/config.h> #include <linux/types.h> #include <linux/mm.h> #include <linux/interrupt.h> #include <linux/blkdev.h> #include <linux/hdreg.h> #include <linux/delay.h> #include <linux/ide.h> #include <asm/machw.h> #include <asm/macintosh.h> #include <asm/macints.h> #include <asm/mac_baboon.h> #define IDE_BASE 0x50F1A000 /* Base address of IDE controller */ /* * Generic IDE registers as offsets from the base * These match MkLinux so they should be correct. */ #define IDE_DATA 0x00 #define IDE_ERROR 0x04 /* see err-bits */ #define IDE_NSECTOR 0x08 /* nr of sectors to read/write */ #define IDE_SECTOR 0x0c /* starting sector */ #define IDE_LCYL 0x10 /* starting cylinder */ #define IDE_HCYL 0x14 /* high byte of starting cyl */ #define IDE_SELECT 0x18 /* 101dhhhh , d=drive, hhhh=head */ #define IDE_STATUS 0x1c /* see status-bits */ #define IDE_CONTROL 0x38 /* control/altstatus */ /* * Mac-specific registers */ /* * this register is odd; it doesn't seem to do much and it's * not word-aligned like virtually every other hardware register * on the Mac... */ #define IDE_IFR 0x101 /* (0x101) IDE interrupt flags on Quadra: * * Bit 0+1: some interrupt flags * Bit 2+3: some interrupt enable * Bit 4: ?? * Bit 5: IDE interrupt flag (any hwif) * Bit 6: maybe IDE interrupt enable (any hwif) ?? * Bit 7: Any interrupt condition */ volatile unsigned char *ide_ifr = (unsigned char *) (IDE_BASE + IDE_IFR); static int macide_offsets[IDE_NR_PORTS] = { IDE_DATA, IDE_ERROR, IDE_NSECTOR, IDE_SECTOR, IDE_LCYL, IDE_HCYL, IDE_SELECT, IDE_STATUS, IDE_CONTROL }; int macide_ack_intr(struct ata_channel *hwif) { if (*ide_ifr & 0x20) { *ide_ifr &= ~0x20; return 1; } return 0; } #ifdef CONFIG_BLK_DEV_MAC_MEDIABAY static void macide_mediabay_interrupt(int irq, void *dev_id, struct pt_regs *regs) { int state = baboon->mb_status & 0x04; printk("macide: media bay %s detected\n", state? "removal":"insertion"); } #endif /* * Probe for a Macintosh IDE interface */ void macide_init(void) { hw_regs_t hw; int index = -1; switch (macintosh_config->ide_type) { case MAC_IDE_QUADRA: ide_setup_ports(&hw, (ide_ioreg_t)IDE_BASE, macide_offsets, 0, 0, macide_ack_intr, IRQ_NUBUS_F); index = ide_register_hw(&hw); break; case MAC_IDE_PB: ide_setup_ports(&hw, (ide_ioreg_t)IDE_BASE, macide_offsets, 0, 0, macide_ack_intr, IRQ_NUBUS_C); index = ide_register_hw(&hw); break; case MAC_IDE_BABOON: ide_setup_ports(&hw, (ide_ioreg_t)BABOON_BASE, macide_offsets, 0, 0, NULL, IRQ_BABOON_1); index = ide_register_hw(&hw); if (index == -1) break; if (macintosh_config->ident == MAC_MODEL_PB190) { /* Fix breakage in ide-disk.c: drive capacity */ /* is not initialized for drives without a */ /* hardware ID, and we cna't get that without */ /* probing the drive which freezes a 190. */ struct ata_device *drive = &ide_hwifs[index].drives[0]; drive->capacity = drive->cyl*drive->head*drive->sect; #ifdef CONFIG_BLK_DEV_MAC_MEDIABAY request_irq(IRQ_BABOON_2, macide_mediabay_interrupt, IRQ_FLG_FAST, "mediabay", macide_mediabay_interrupt); #endif } break; default: return; } if (index != -1) { if (macintosh_config->ide_type == MAC_IDE_QUADRA) printk("ide%d: Macintosh Quadra IDE interface\n", index); else if (macintosh_config->ide_type == MAC_IDE_PB) printk("ide%d: Macintosh Powerbook IDE interface\n", index); else if (macintosh_config->ide_type == MAC_IDE_BABOON) printk("ide%d: Macintosh Powerbook Baboon IDE interface\n", index); else printk("ide%d: Unknown Macintosh IDE interface\n", index); } } |