static void apply_timings(const u8 chipselect, const u8 pio, const struct ide_timing *timing, int use_iordy) { unsigned int t0, t1, t2, t6z; unsigned int cycle, setup, pulse, data_float; unsigned int mck_hz; struct clk *mck; /* see table 22 of Compact Flash standard 4.1 for the meaning, * we do not stretch active (t2) time, so setup (t1) + hold time (th) * assure at least minimal recovery (t2i) time */ t0 = timing->cyc8b; t1 = timing->setup; t2 = timing->act8b; t6z = (pio < 5) ? 30 : 20; pdbg("t0=%u t1=%u t2=%u t6z=%u\n", t0, t1, t2, t6z); mck = clk_get(NULL, "mck"); BUG_ON(IS_ERR(mck)); mck_hz = clk_get_rate(mck); pdbg("mck_hz=%u\n", mck_hz); cycle = calc_mck_cycles(t0, mck_hz); setup = calc_mck_cycles(t1, mck_hz); pulse = calc_mck_cycles(t2, mck_hz); data_float = calc_mck_cycles(t6z, mck_hz); pdbg("cycle=%u setup=%u pulse=%u data_float=%u\n", cycle, setup, pulse, data_float); set_smc_timings(chipselect, cycle, setup, pulse, data_float, use_iordy); }
static void at91_ide_output_data(ide_drive_t *drive, struct ide_cmd *cmd, void *buf, unsigned int len) { ide_hwif_t *hwif = drive->hwif; struct ide_io_ports *io_ports = &hwif->io_ports; u8 chipselect = hwif->select_data; unsigned long mode; pdbg("cs %u buf %p len %d\n", chipselect, buf, len); enter_16bit(chipselect, mode); writesw((void __iomem *)io_ports->data_addr, buf, len / 2); leave_16bit(chipselect, mode); }
static int __init lfdd_init( void ) { int ret; printk( KERN_INFO "lfdd: Linux Firmware Debug Driver Version %s\n", LFDD_VERSION ); ret = misc_register( &lfdd_dev ); if( ret < 0 ) { pdbg( "register lfdd driver failed.\n" ); return ret; } return 0; }
static void at91_ide_set_pio_mode(ide_drive_t *drive, const u8 pio) { struct ide_timing *timing; u8 chipselect = drive->hwif->select_data; int use_iordy = 0; pdbg("chipselect %u pio %u\n", chipselect, pio); timing = ide_timing_find_mode(XFER_PIO_0 + pio); BUG_ON(!timing); if (ide_pio_need_iordy(drive, pio)) use_iordy = 1; apply_timings(chipselect, pio, timing, use_iordy); }
/* * interrupt handler function */ static irqreturn_t emxx_cfi_irq_handler(int irq, void *dev_id) { int status, int_status; udelay(3); int_status = readl(EMXX_CFI_INTERRUPT); status = readl(EMXX_CFI_STATUS); pdbg("irq=0x%x status=0x%x\n", int_status, status); if (int_status) { writel(int_status, EMXX_CFI_INTERRUPT); if ((int_status & CFI_INT_RDYS)) return ide_intr(irq, dev_id); } return IRQ_HANDLED; }
static void __exit lfdd_exit( void ) { misc_deregister( &lfdd_dev ); pdbg( "driver unloaded.\n" ); }
static int __init at91_ide_probe(struct platform_device *pdev) { int ret; struct ide_hw hw, *hws[] = { &hw }; struct ide_host *host; struct resource *res; unsigned long tf_base = 0, ctl_base = 0; struct at91_cf_data *board = pdev->dev.platform_data; if (!board) return -ENODEV; if (board->det_pin && at91_get_gpio_value(board->det_pin) != 0) { perr("no device detected\n"); return -ENODEV; } res = platform_get_resource(pdev, IORESOURCE_MEM, 0); if (!res) { perr("can't get memory resource\n"); return -ENODEV; } if (!devm_request_mem_region(&pdev->dev, res->start + TASK_FILE, REGS_SIZE, "ide") || !devm_request_mem_region(&pdev->dev, res->start + ALT_MODE, REGS_SIZE, "alt")) { perr("memory resources in use\n"); return -EBUSY; } pdbg("chipselect %u irq %u res %08lx\n", board->chipselect, board->irq_pin, (unsigned long) res->start); tf_base = (unsigned long) devm_ioremap(&pdev->dev, res->start + TASK_FILE, REGS_SIZE); ctl_base = (unsigned long) devm_ioremap(&pdev->dev, res->start + ALT_MODE, REGS_SIZE); if (!tf_base || !ctl_base) { perr("can't map memory regions\n"); return -EBUSY; } memset(&hw, 0, sizeof(hw)); if (board->flags & AT91_IDE_SWAP_A0_A2) { hw.io_ports.data_addr = tf_base + 0; hw.io_ports.error_addr = tf_base + 4; hw.io_ports.nsect_addr = tf_base + 2; hw.io_ports.lbal_addr = tf_base + 6; hw.io_ports.lbam_addr = tf_base + 1; hw.io_ports.lbah_addr = tf_base + 5; hw.io_ports.device_addr = tf_base + 3; hw.io_ports.command_addr = tf_base + 7; hw.io_ports.ctl_addr = ctl_base + 3; } else ide_std_init_ports(&hw, tf_base, ctl_base + 6); hw.irq = board->irq_pin; hw.dev = &pdev->dev; host = ide_host_alloc(&at91_ide_port_info, hws, 1); if (!host) { perr("failed to allocate ide host\n"); return -ENOMEM; } /* setup Static Memory Controller - PIO 0 as default */ apply_timings(board->chipselect, 0, ide_timing_find_mode(XFER_PIO_0), 0); /* with GPIO interrupt we have to do quirks in handler */ if (board->irq_pin >= PIN_BASE) host->irq_handler = at91_irq_handler; host->ports[0]->select_data = board->chipselect; ret = ide_host_register(host, &at91_ide_port_info, hws); if (ret) { perr("failed to register ide host\n"); goto err_free_host; } platform_set_drvdata(pdev, host); return 0; err_free_host: ide_host_free(host); return ret; }