ppdev.h 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100
  1. /*
  2. * linux/include/linux/ppdev.h
  3. *
  4. * User-space parallel port device driver (header file).
  5. *
  6. * Copyright (C) 1998-9 Tim Waugh <tim@cyberelk.demon.co.uk>
  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. * Added PPGETTIME/PPSETTIME, Fred Barnes, 1999
  14. * Added PPGETMODES/PPGETMODE/PPGETPHASE, Fred Barnes <frmb2@ukc.ac.uk>, 03/01/2001
  15. */
  16. #define PP_IOCTL 'p'
  17. /* Set mode for read/write (e.g. IEEE1284_MODE_EPP) */
  18. #define PPSETMODE _IOW(PP_IOCTL, 0x80, int)
  19. /* Read status */
  20. #define PPRSTATUS _IOR(PP_IOCTL, 0x81, unsigned char)
  21. #define PPWSTATUS OBSOLETE__IOW(PP_IOCTL, 0x82, unsigned char)
  22. /* Read/write control */
  23. #define PPRCONTROL _IOR(PP_IOCTL, 0x83, unsigned char)
  24. #define PPWCONTROL _IOW(PP_IOCTL, 0x84, unsigned char)
  25. struct ppdev_frob_struct {
  26. unsigned char mask;
  27. unsigned char val;
  28. };
  29. #define PPFCONTROL _IOW(PP_IOCTL, 0x8e, struct ppdev_frob_struct)
  30. /* Read/write data */
  31. #define PPRDATA _IOR(PP_IOCTL, 0x85, unsigned char)
  32. #define PPWDATA _IOW(PP_IOCTL, 0x86, unsigned char)
  33. /* Read/write econtrol (not used) */
  34. #define PPRECONTROL OBSOLETE__IOR(PP_IOCTL, 0x87, unsigned char)
  35. #define PPWECONTROL OBSOLETE__IOW(PP_IOCTL, 0x88, unsigned char)
  36. /* Read/write FIFO (not used) */
  37. #define PPRFIFO OBSOLETE__IOR(PP_IOCTL, 0x89, unsigned char)
  38. #define PPWFIFO OBSOLETE__IOW(PP_IOCTL, 0x8a, unsigned char)
  39. /* Claim the port to start using it */
  40. #define PPCLAIM _IO(PP_IOCTL, 0x8b)
  41. /* Release the port when you aren't using it */
  42. #define PPRELEASE _IO(PP_IOCTL, 0x8c)
  43. /* Yield the port (release it if another driver is waiting,
  44. * then reclaim) */
  45. #define PPYIELD _IO(PP_IOCTL, 0x8d)
  46. /* Register device exclusively (must be before PPCLAIM). */
  47. #define PPEXCL _IO(PP_IOCTL, 0x8f)
  48. /* Data line direction: non-zero for input mode. */
  49. #define PPDATADIR _IOW(PP_IOCTL, 0x90, int)
  50. /* Negotiate a particular IEEE 1284 mode. */
  51. #define PPNEGOT _IOW(PP_IOCTL, 0x91, int)
  52. /* Set control lines when an interrupt occurs. */
  53. #define PPWCTLONIRQ _IOW(PP_IOCTL, 0x92, unsigned char)
  54. /* Clear (and return) interrupt count. */
  55. #define PPCLRIRQ _IOR(PP_IOCTL, 0x93, int)
  56. /* Set the IEEE 1284 phase that we're in (e.g. IEEE1284_PH_FWD_IDLE) */
  57. #define PPSETPHASE _IOW(PP_IOCTL, 0x94, int)
  58. /* Set and get port timeout (struct timeval's) */
  59. #define PPGETTIME _IOR(PP_IOCTL, 0x95, struct timeval)
  60. #define PPSETTIME _IOW(PP_IOCTL, 0x96, struct timeval)
  61. /* Get available modes (what the hardware can do) */
  62. #define PPGETMODES _IOR(PP_IOCTL, 0x97, unsigned int)
  63. /* Get the current mode and phaze */
  64. #define PPGETMODE _IOR(PP_IOCTL, 0x98, int)
  65. #define PPGETPHASE _IOR(PP_IOCTL, 0x99, int)
  66. /* get/set flags */
  67. #define PPGETFLAGS _IOR(PP_IOCTL, 0x9a, int)
  68. #define PPSETFLAGS _IOW(PP_IOCTL, 0x9b, int)
  69. /* flags visible to the world */
  70. #define PP_FASTWRITE (1<<2)
  71. #define PP_FASTREAD (1<<3)
  72. #define PP_W91284PIC (1<<4)
  73. /* only masks user-visible flags */
  74. #define PP_FLAGMASK (PP_FASTWRITE | PP_FASTREAD | PP_W91284PIC)