10f9cfa09Swdenk /* 20f9cfa09Swdenk * (C) Copyright 2000 30f9cfa09Swdenk * Wolfgang Denk, DENX Software Engineering, wd@denx.de. 40f9cfa09Swdenk * 51a459660SWolfgang Denk * SPDX-License-Identifier: GPL-2.0+ 60f9cfa09Swdenk */ 70f9cfa09Swdenk 80f9cfa09Swdenk #ifndef _IDE_H 90f9cfa09Swdenk #define _IDE_H 100f9cfa09Swdenk 111a73661bSSimon Glass #include <blk.h> 121a73661bSSimon Glass 138a10180dSLuka Perkov #define IDE_BUS(dev) (dev / (CONFIG_SYS_IDE_MAXDEVICE / CONFIG_SYS_IDE_MAXBUS)) 140f9cfa09Swdenk 156d0f6bcfSJean-Christophe PLAGNIOL-VILLARD #define ATA_CURR_BASE(dev) (CONFIG_SYS_ATA_BASE_ADDR+ide_bus_offset[IDE_BUS(dev)]) 16f5b82c0fSPavel Herrmann extern ulong ide_bus_offset[]; 17f98984cbSHeiko Schocher 180f9cfa09Swdenk #ifdef CONFIG_IDE_LED 190f9cfa09Swdenk 200f9cfa09Swdenk /* 210f9cfa09Swdenk * LED Port 220f9cfa09Swdenk */ 230f9cfa09Swdenk #define LED_PORT ((uchar *)(PER8_BASE + 0x3000)) 240f9cfa09Swdenk #define LED_IDE1 0x01 250f9cfa09Swdenk #define LED_IDE2 0x02 260f9cfa09Swdenk #define DEVICE_LED(d) ((d & 2) | ((d & 2) == 0)) /* depends on bit positions! */ 270f9cfa09Swdenk 28611aee2bSJeroen Hofstee void ide_led(uchar led, uchar status); 290f9cfa09Swdenk #endif /* CONFIG_IDE_LED */ 300f9cfa09Swdenk 310f9cfa09Swdenk /* 320f9cfa09Swdenk * Function Prototypes 330f9cfa09Swdenk */ 340f9cfa09Swdenk 350f9cfa09Swdenk void ide_init(void); 364101f687SSimon Glass struct blk_desc; 37*145df842SSimon Glass struct udevice; 38*145df842SSimon Glass #ifdef CONFIG_BLK 39*145df842SSimon Glass ulong ide_read(struct udevice *dev, lbaint_t blknr, lbaint_t blkcnt, 40*145df842SSimon Glass void *buffer); 41*145df842SSimon Glass ulong ide_write(struct udevice *dev, lbaint_t blknr, lbaint_t blkcnt, 42*145df842SSimon Glass const void *buffer); 43*145df842SSimon Glass #else 444101f687SSimon Glass ulong ide_read(struct blk_desc *block_dev, lbaint_t blknr, lbaint_t blkcnt, 457c4213f6SStephen Warren void *buffer); 464101f687SSimon Glass ulong ide_write(struct blk_desc *block_dev, lbaint_t blknr, lbaint_t blkcnt, 47ff8fef56SSascha Silbe const void *buffer); 48*145df842SSimon Glass #endif 490f9cfa09Swdenk 508d1165e1SPavel Herrmann #ifdef CONFIG_IDE_PREINIT 518d1165e1SPavel Herrmann int ide_preinit(void); 528d1165e1SPavel Herrmann #endif 538d1165e1SPavel Herrmann 548d1165e1SPavel Herrmann #ifdef CONFIG_IDE_INIT_POSTRESET 558d1165e1SPavel Herrmann int ide_init_postreset(void); 568d1165e1SPavel Herrmann #endif 578d1165e1SPavel Herrmann 583887c3fbSHeiko Schocher #if defined(CONFIG_OF_IDE_FIXUP) 593887c3fbSHeiko Schocher int ide_device_present(int dev); 603887c3fbSHeiko Schocher #endif 610abddf82SMacpaul Lin 620abddf82SMacpaul Lin #if defined(CONFIG_IDE_AHB) 630abddf82SMacpaul Lin unsigned char ide_read_register(int dev, unsigned int port); 640abddf82SMacpaul Lin void ide_write_register(int dev, unsigned int port, unsigned char val); 650abddf82SMacpaul Lin void ide_read_data(int dev, ulong *sect_buf, int words); 66c575180bSGabor Juhos void ide_write_data(int dev, const ulong *sect_buf, int words); 670abddf82SMacpaul Lin #endif 68f5b82c0fSPavel Herrmann 69f5b82c0fSPavel Herrmann /* 70f5b82c0fSPavel Herrmann * I/O function overrides 71f5b82c0fSPavel Herrmann */ 72288afdc9SJeroen Hofstee unsigned char ide_inb(int dev, int port); 73288afdc9SJeroen Hofstee void ide_outb(int dev, int port, unsigned char val); 74f5b82c0fSPavel Herrmann void ide_input_swap_data(int dev, ulong *sect_buf, int words); 75f5b82c0fSPavel Herrmann void ide_input_data(int dev, ulong *sect_buf, int words); 76f5b82c0fSPavel Herrmann void ide_output_data(int dev, const ulong *sect_buf, int words); 77f5b82c0fSPavel Herrmann void ide_input_data_shorts(int dev, ushort *sect_buf, int shorts); 78f5b82c0fSPavel Herrmann void ide_output_data_shorts(int dev, ushort *sect_buf, int shorts); 79f5b82c0fSPavel Herrmann 80288afdc9SJeroen Hofstee void ide_led(uchar led, uchar status); 81288afdc9SJeroen Hofstee 82c2240d4dSSimon Glass /** 83c2240d4dSSimon Glass * board_start_ide() - Start up the board IDE interfac 84c2240d4dSSimon Glass * 85c2240d4dSSimon Glass * @return 0 if ok 86c2240d4dSSimon Glass */ 87c2240d4dSSimon Glass int board_start_ide(void); 88c2240d4dSSimon Glass 890f9cfa09Swdenk #endif /* _IDE_H */ 90