sdladrv.h
上传用户:szlgq88
上传日期:2009-04-28
资源大小:48287k
文件大小:3k
源码类别:

嵌入式Linux

开发平台:

Unix_Linux

  1. /*****************************************************************************
  2. * sdladrv.h SDLA Support Module.  Kernel API Definitions.
  3. *
  4. * Author:  Gideon Hack
  5. *
  6. * Copyright: (c) 1995-2000 Sangoma Technologies Inc.
  7. *
  8. * This program is free software; you can redistribute it and/or
  9. * modify it under the terms of the GNU General Public License
  10. * as published by the Free Software Foundation; either version
  11. * 2 of the License, or (at your option) any later version.
  12. * ============================================================================
  13. * Jun 02, 1999  Gideon Hack Added support for the S514 PCI adapter.
  14. * Dec 11, 1996 Gene Kozin Complete overhaul.
  15. * Oct 17, 1996 Gene Kozin Minor bug fixes.
  16. * Jun 12, 1996 Gene Kozin  Added support for S503 card.
  17. * Dec 06, 1995 Gene Kozin Initial version.
  18. *****************************************************************************/
  19. #ifndef _SDLADRV_H
  20. #define _SDLADRV_H
  21. #define SDLA_MAXIORANGE 4 /* maximum I/O port range */
  22. #define SDLA_WINDOWSIZE 0x2000 /* default dual-port memory window size */
  23. /****** Data Structures *****************************************************/
  24. /*----------------------------------------------------------------------------
  25.  * Adapter hardware configuration. Pointer to this structure is passed to all
  26.  * APIs.
  27.  */
  28. typedef struct sdlahw
  29. {
  30. unsigned type; /* adapter type */
  31. unsigned fwid; /* firmware ID */
  32. unsigned port; /* adapter I/O port base */
  33. int irq; /* interrupt request level */
  34. char S514_cpu_no[1]; /* PCI CPU Number */
  35. unsigned char S514_slot_no; /* PCI Slot Number */
  36. char auto_pci_cfg; /* Autodetect PCI Slot */
  37. struct pci_dev *pci_dev; /* PCI device */
  38. void * dpmbase; /* dual-port memory base */
  39. unsigned dpmsize; /* dual-port memory size */
  40. unsigned pclk; /* CPU clock rate, kHz */
  41. unsigned long memory; /* memory size */
  42. unsigned long vector; /* local offset of the DPM window */
  43. unsigned io_range; /* I/O port range */
  44. unsigned char regs[SDLA_MAXIORANGE]; /* was written to registers */
  45. unsigned reserved[5];
  46. } sdlahw_t;
  47. /****** Function Prototypes *************************************************/
  48. extern int sdla_setup (sdlahw_t* hw, void* sfm, unsigned len);
  49. extern int sdla_down (sdlahw_t* hw);
  50. extern int sdla_inten (sdlahw_t* hw);
  51. extern int sdla_intde (sdlahw_t* hw);
  52. extern int sdla_intack (sdlahw_t* hw);
  53. extern void S514_intack  (sdlahw_t* hw, u32 int_status);
  54. extern void read_S514_int_stat (sdlahw_t* hw, u32* int_status);
  55. extern int sdla_intr (sdlahw_t* hw);
  56. extern int sdla_mapmem (sdlahw_t* hw, unsigned long addr);
  57. extern int sdla_peek (sdlahw_t* hw, unsigned long addr, void* buf,
  58.  unsigned len);
  59. extern int sdla_poke (sdlahw_t* hw, unsigned long addr, void* buf,
  60.  unsigned len);
  61. extern int sdla_exec (void* opflag);
  62. extern unsigned wanpipe_hw_probe(void);
  63. #endif /* _SDLADRV_H */