2005-04-17 02:20:36 +04:00
/*
* H8 / 300 generic IDE interface
*/
# include <linux/init.h>
# include <linux/ide.h>
# include <asm/io.h>
# include <asm/irq.h>
2008-07-16 22:33:42 +04:00
# define DRV_NAME "ide-h8300"
2005-04-17 02:20:36 +04:00
# define bswap(d) \
( { \
u16 r ; \
__asm__ ( " mov.b %w1,r1h \n \t " \
" mov.b %x1,r1l \n \t " \
" mov.w r1,%0 " \
: " =r " ( r ) \
: " r " ( d ) \
: " er1 " ) ; \
( r ) ; \
} )
static void mm_outsw ( unsigned long addr , void * buf , u32 len )
{
unsigned short * bp = ( unsigned short * ) buf ;
for ( ; len > 0 ; len - - , bp + + )
* ( volatile u16 * ) addr = bswap ( * bp ) ;
}
static void mm_insw ( unsigned long addr , void * buf , u32 len )
{
unsigned short * bp = ( unsigned short * ) buf ;
for ( ; len > 0 ; len - - , bp + + )
* bp = bswap ( * ( volatile u16 * ) addr ) ;
}
2009-03-27 14:46:38 +03:00
static void h8300_input_data ( ide_drive_t * drive , struct ide_cmd * cmd ,
2008-04-29 01:44:37 +04:00
void * buf , unsigned int len )
{
mm_insw ( drive - > hwif - > io_ports . data_addr , buf , ( len + 1 ) / 2 ) ;
}
2009-03-27 14:46:38 +03:00
static void h8300_output_data ( ide_drive_t * drive , struct ide_cmd * cmd ,
2008-04-29 01:44:37 +04:00
void * buf , unsigned int len )
{
mm_outsw ( drive - > hwif - > io_ports . data_addr , buf , ( len + 1 ) / 2 ) ;
}
2008-07-23 21:55:56 +04:00
static const struct ide_tp_ops h8300_tp_ops = {
. exec_command = ide_exec_command ,
. read_status = ide_read_status ,
. read_altstatus = ide_read_altstatus ,
2009-03-31 22:15:30 +04:00
. write_devctl = ide_write_devctl ,
2008-07-23 21:55:56 +04:00
2009-03-31 22:15:32 +04:00
. dev_select = ide_dev_select ,
2009-04-08 16:12:51 +04:00
. tf_load = ide_tf_load ,
. tf_read = ide_tf_read ,
2008-07-23 21:55:56 +04:00
. input_data = h8300_input_data ,
. output_data = h8300_output_data ,
} ;
2005-04-17 02:20:36 +04:00
# define H8300_IDE_GAP (2)
static inline void hw_setup ( hw_regs_t * hw )
{
int i ;
memset ( hw , 0 , sizeof ( hw_regs_t ) ) ;
2008-04-27 17:38:32 +04:00
for ( i = 0 ; i < = 7 ; i + + )
hw - > io_ports_array [ i ] = CONFIG_H8300_IDE_BASE + H8300_IDE_GAP * i ;
hw - > io_ports . ctl_addr = CONFIG_H8300_IDE_ALT ;
2005-04-17 02:20:36 +04:00
hw - > irq = EXT_IRQ0 + CONFIG_H8300_IDE_IRQ ;
hw - > chipset = ide_generic ;
}
2008-07-16 22:33:42 +04:00
static const struct ide_port_info h8300_port_info = {
2008-07-23 21:55:56 +04:00
. tp_ops = & h8300_tp_ops ,
2008-07-16 22:33:42 +04:00
. host_flags = IDE_HFLAG_NO_IO_32BIT | IDE_HFLAG_NO_DMA ,
} ;
2008-01-26 22:13:07 +03:00
static int __init h8300_ide_init ( void )
2005-04-17 02:20:36 +04:00
{
2008-07-23 21:55:50 +04:00
hw_regs_t hw , * hws [ ] = { & hw , NULL , NULL , NULL } ;
2005-04-17 02:20:36 +04:00
2008-07-16 22:33:43 +04:00
printk ( KERN_INFO DRV_NAME " : H8/300 generic IDE interface \n " ) ;
2005-04-17 02:20:36 +04:00
if ( ! request_region ( CONFIG_H8300_IDE_BASE , H8300_IDE_GAP * 8 , " ide-h8300 " ) )
goto out_busy ;
if ( ! request_region ( CONFIG_H8300_IDE_ALT , H8300_IDE_GAP , " ide-h8300 " ) ) {
release_region ( CONFIG_H8300_IDE_BASE , H8300_IDE_GAP * 8 ) ;
goto out_busy ;
}
hw_setup ( & hw ) ;
ide: add ide_host_add() helper
Add ide_host_add() helper which does ide_host_alloc()+ide_host_register(),
then convert ide_setup_pci_device[s](), ide_legacy_device_add() and some
host drivers to use it.
While at it:
* Fix ide_setup_pci_device[s](), ide_arm.c, gayle.c, ide-4drives.c,
macide.c, q40ide.c, cmd640.c and cs5520.c to return correct error value.
* -ENOENT -> -ENOMEM in rapide.c, ide-h8300.c, ide-generic.c, au1xxx-ide.c
and pmac.c
* -ENODEV -> -ENOMEM in palm_bk3710.c, ide_platform.c and delkin_cb.c
* -1 -> -ENOMEM in ide-pnp.c
Signed-off-by: Bartlomiej Zolnierkiewicz <bzolnier@gmail.com>
2008-07-23 21:55:57 +04:00
return ide_host_add ( & h8300_port_info , hws , NULL ) ;
2005-04-17 02:20:36 +04:00
out_busy :
printk ( KERN_ERR " ide-h8300: IDE I/F resource already used. \n " ) ;
2008-01-26 22:13:07 +03:00
return - EBUSY ;
2005-04-17 02:20:36 +04:00
}
2008-01-26 22:13:07 +03:00
module_init ( h8300_ide_init ) ;
2008-04-02 23:22:03 +04:00
MODULE_LICENSE ( " GPL " ) ;