#ifndef _AIC7XXX_LINUX_H_
#define _AIC7XXX_LINUX_H_
#include <linux/types.h>
#include <linux/blkdev.h>
#include <linux/delay.h>
#include <linux/ioport.h>
#include <linux/pci.h>
#include <linux/interrupt.h>
#include <linux/module.h>
#include <linux/slab.h>
#include <asm/byteorder.h>
#include <asm/io.h>
#include <scsi/scsi.h>
#include <scsi/scsi_cmnd.h>
#include <scsi/scsi_eh.h>
#include <scsi/scsi_device.h>
#include <scsi/scsi_host.h>
#include <scsi/scsi_tcq.h>
#include <scsi/scsi_transport.h>
#include <scsi/scsi_transport_spi.h>
#define AIC_LIB_PREFIX …
#include "cam.h"
#include "queue.h"
#include "scsi_message.h"
#include "aiclib.h"
#ifdef CONFIG_AIC7XXX_DEBUG_ENABLE
#ifdef CONFIG_AIC7XXX_DEBUG_MASK
#define AHC_DEBUG …
#define AHC_DEBUG_OPTS …
#else
#define AHC_DEBUG …
#endif
#endif
struct ahc_softc;
ahc_dev_softc_t;
ahc_io_ctx_t;
#define ahc_htobe16(x) …
#define ahc_htobe32(x) …
#define ahc_htobe64(x) …
#define ahc_htole16(x) …
#define ahc_htole32(x) …
#define ahc_htole64(x) …
#define ahc_be16toh(x) …
#define ahc_be32toh(x) …
#define ahc_be64toh(x) …
#define ahc_le16toh(x) …
#define ahc_le32toh(x) …
#define ahc_le64toh(x) …
extern u_int aic7xxx_no_probe;
extern u_int aic7xxx_allow_memio;
extern struct scsi_host_template aic7xxx_driver_template;
bus_size_t;
bus_space_tag_t;
bus_space_handle_t;
bus_dma_segment_t;
struct ahc_linux_dma_tag
{ … };
bus_dma_tag_t;
bus_dmamap_t;
bus_dma_filter_t;
bus_dmamap_callback_t;
#define BUS_DMA_WAITOK …
#define BUS_DMA_NOWAIT …
#define BUS_DMA_ALLOCNOW …
#define BUS_DMA_LOAD_SEGS …
#define BUS_SPACE_MAXADDR …
#define BUS_SPACE_MAXADDR_32BIT …
#define BUS_SPACE_MAXSIZE_32BIT …
int ahc_dma_tag_create(struct ahc_softc *, bus_dma_tag_t ,
bus_size_t , bus_size_t ,
dma_addr_t , dma_addr_t ,
bus_dma_filter_t*, void *,
bus_size_t , int ,
bus_size_t , int ,
bus_dma_tag_t *);
void ahc_dma_tag_destroy(struct ahc_softc *, bus_dma_tag_t );
int ahc_dmamem_alloc(struct ahc_softc *, bus_dma_tag_t ,
void** , int ,
bus_dmamap_t* );
void ahc_dmamem_free(struct ahc_softc *, bus_dma_tag_t ,
void* , bus_dmamap_t );
void ahc_dmamap_destroy(struct ahc_softc *, bus_dma_tag_t ,
bus_dmamap_t );
int ahc_dmamap_load(struct ahc_softc *ahc, bus_dma_tag_t ,
bus_dmamap_t , void * ,
bus_size_t , bus_dmamap_callback_t *,
void *, int );
int ahc_dmamap_unload(struct ahc_softc *, bus_dma_tag_t, bus_dmamap_t);
#define BUS_DMASYNC_PREREAD …
#define BUS_DMASYNC_POSTREAD …
#define BUS_DMASYNC_PREWRITE …
#define BUS_DMASYNC_POSTWRITE …
#define ahc_dmamap_sync(ahc, dma_tag, dmamap, offset, len, op) …
#ifdef CONFIG_AIC7XXX_REG_PRETTY_PRINT
#define AIC_DEBUG_REGISTERS …
#else
#define AIC_DEBUG_REGISTERS …
#endif
#include "aic7xxx.h"
static inline void
ahc_scb_timer_reset(struct scb *scb, u_int usec)
{ … }
#include <linux/spinlock.h>
#define AIC7XXX_DRIVER_VERSION …
ahc_linux_dev_flags;
struct ahc_linux_device { … };
#define AHC_NSEG …
struct scb_platform_data { … };
struct ahc_platform_data { … };
void ahc_delay(long);
uint8_t ahc_inb(struct ahc_softc * ahc, long port);
void ahc_outb(struct ahc_softc * ahc, long port, uint8_t val);
void ahc_outsb(struct ahc_softc * ahc, long port,
uint8_t *, int count);
void ahc_insb(struct ahc_softc * ahc, long port,
uint8_t *, int count);
int ahc_linux_register_host(struct ahc_softc *,
struct scsi_host_template *);
static inline void
ahc_lockinit(struct ahc_softc *ahc)
{ … }
static inline void
ahc_lock(struct ahc_softc *ahc, unsigned long *flags)
{ … }
static inline void
ahc_unlock(struct ahc_softc *ahc, unsigned long *flags)
{ … }
#define PCIR_DEVVENDOR …
#define PCIR_VENDOR …
#define PCIR_DEVICE …
#define PCIR_COMMAND …
#define PCIM_CMD_PORTEN …
#define PCIM_CMD_MEMEN …
#define PCIM_CMD_BUSMASTEREN …
#define PCIM_CMD_MWRICEN …
#define PCIM_CMD_PERRESPEN …
#define PCIM_CMD_SERRESPEN …
#define PCIR_STATUS …
#define PCIR_REVID …
#define PCIR_PROGIF …
#define PCIR_SUBCLASS …
#define PCIR_CLASS …
#define PCIR_CACHELNSZ …
#define PCIR_LATTIMER …
#define PCIR_HEADERTYPE …
#define PCIM_MFDEV …
#define PCIR_BIST …
#define PCIR_CAP_PTR …
#define PCIR_MAPS …
ahc_power_state;
#ifdef CONFIG_EISA
int ahc_linux_eisa_init(void);
void ahc_linux_eisa_exit(void);
int aic7770_map_registers(struct ahc_softc *ahc,
u_int port);
int aic7770_map_int(struct ahc_softc *ahc, u_int irq);
#else
static inline int ahc_linux_eisa_init(void) {
return -ENODEV;
}
static inline void ahc_linux_eisa_exit(void) {
}
#endif
#ifdef CONFIG_PCI
int ahc_linux_pci_init(void);
void ahc_linux_pci_exit(void);
int ahc_pci_map_registers(struct ahc_softc *ahc);
int ahc_pci_map_int(struct ahc_softc *ahc);
uint32_t ahc_pci_read_config(ahc_dev_softc_t pci,
int reg, int width);
void ahc_pci_write_config(ahc_dev_softc_t pci,
int reg, uint32_t value,
int width);
static inline int ahc_get_pci_function(ahc_dev_softc_t);
static inline int
ahc_get_pci_function(ahc_dev_softc_t pci)
{ … }
static inline int ahc_get_pci_slot(ahc_dev_softc_t);
static inline int
ahc_get_pci_slot(ahc_dev_softc_t pci)
{ … }
static inline int ahc_get_pci_bus(ahc_dev_softc_t);
static inline int
ahc_get_pci_bus(ahc_dev_softc_t pci)
{ … }
#else
static inline int ahc_linux_pci_init(void) {
return 0;
}
static inline void ahc_linux_pci_exit(void) {
}
#endif
static inline void ahc_flush_device_writes(struct ahc_softc *);
static inline void
ahc_flush_device_writes(struct ahc_softc *ahc)
{ … }
int ahc_proc_write_seeprom(struct Scsi_Host *, char *, int);
int ahc_linux_show_info(struct seq_file *, struct Scsi_Host *);
static inline
void ahc_cmd_set_transaction_status(struct scsi_cmnd *cmd, uint32_t status)
{ … }
static inline
void ahc_set_transaction_status(struct scb *scb, uint32_t status)
{ … }
static inline
void ahc_cmd_set_scsi_status(struct scsi_cmnd *cmd, uint32_t status)
{ … }
static inline
void ahc_set_scsi_status(struct scb *scb, uint32_t status)
{ … }
static inline
uint32_t ahc_cmd_get_transaction_status(struct scsi_cmnd *cmd)
{ … }
static inline
uint32_t ahc_get_transaction_status(struct scb *scb)
{ … }
static inline
uint32_t ahc_cmd_get_scsi_status(struct scsi_cmnd *cmd)
{ … }
static inline
uint32_t ahc_get_scsi_status(struct scb *scb)
{ … }
static inline
void ahc_set_transaction_tag(struct scb *scb, int enabled, u_int type)
{ … }
static inline
u_long ahc_get_transfer_length(struct scb *scb)
{ … }
static inline
int ahc_get_transfer_dir(struct scb *scb)
{ … }
static inline
void ahc_set_residual(struct scb *scb, u_long resid)
{ … }
static inline
void ahc_set_sense_residual(struct scb *scb, u_long resid)
{ … }
static inline
u_long ahc_get_residual(struct scb *scb)
{ … }
static inline
u_long ahc_get_sense_residual(struct scb *scb)
{ … }
static inline
int ahc_perform_autosense(struct scb *scb)
{ … }
static inline uint32_t
ahc_get_sense_bufsize(struct ahc_softc *ahc, struct scb *scb)
{ … }
static inline void
ahc_notify_xfer_settings_change(struct ahc_softc *ahc,
struct ahc_devinfo *devinfo)
{ … }
static inline void
ahc_platform_scb_free(struct ahc_softc *ahc, struct scb *scb)
{ … }
int ahc_platform_alloc(struct ahc_softc *ahc, void *platform_arg);
void ahc_platform_free(struct ahc_softc *ahc);
void ahc_platform_freeze_devq(struct ahc_softc *ahc, struct scb *scb);
static inline void
ahc_freeze_scb(struct scb *scb)
{ … }
void ahc_platform_set_tags(struct ahc_softc *ahc, struct scsi_device *sdev,
struct ahc_devinfo *devinfo, ahc_queue_alg);
int ahc_platform_abort_scbs(struct ahc_softc *ahc, int target,
char channel, int lun, u_int tag,
role_t role, uint32_t status);
irqreturn_t
ahc_linux_isr(int irq, void *dev_id);
void ahc_platform_flushwork(struct ahc_softc *ahc);
void ahc_done(struct ahc_softc*, struct scb*);
void ahc_send_async(struct ahc_softc *, char channel,
u_int target, u_int lun, ac_code);
void ahc_print_path(struct ahc_softc *, struct scb *);
#ifdef CONFIG_PCI
#define AHC_PCI_CONFIG …
#else
#define AHC_PCI_CONFIG …
#endif
#define bootverbose …
extern u_int aic7xxx_verbose;
#endif