parameters.h 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103
  1. /*********************************************************************
  2. *
  3. * Filename: parameters.h
  4. * Version: 1.0
  5. * Description: A more general way to handle (pi,pl,pv) parameters
  6. * Status: Experimental.
  7. * Author: Dag Brattli <dagb@cs.uit.no>
  8. * Created at: Mon Jun 7 08:47:28 1999
  9. * Modified at: Sun Jan 30 14:05:14 2000
  10. * Modified by: Dag Brattli <dagb@cs.uit.no>
  11. *
  12. * Copyright (c) 1999-2000 Dag Brattli, All Rights Reserved.
  13. *
  14. * This program is free software; you can redistribute it and/or
  15. * modify it under the terms of the GNU General Public License as
  16. * published by the Free Software Foundation; either version 2 of
  17. * the License, or (at your option) any later version.
  18. *
  19. * This program is distributed in the hope that it will be useful,
  20. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  21. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  22. * GNU General Public License for more details.
  23. *
  24. * You should have received a copy of the GNU General Public License
  25. * along with this program; if not, write to the Free Software
  26. * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
  27. * MA 02111-1307 USA
  28. *
  29. * Michel Dänzer <daenzer@debian.org>, 10/2001
  30. * - simplify irda_pv_t to avoid endianness issues
  31. *
  32. ********************************************************************/
  33. #ifndef IRDA_PARAMS_H
  34. #define IRDA_PARAMS_H
  35. /*
  36. * The currently supported types. Beware not to change the sequence since
  37. * it a good reason why the sized integers has a value equal to their size
  38. */
  39. typedef enum {
  40. PV_INTEGER, /* Integer of any (pl) length */
  41. PV_INT_8_BITS, /* Integer of 8 bits in length */
  42. PV_INT_16_BITS, /* Integer of 16 bits in length */
  43. PV_STRING, /* \0 terminated string */
  44. PV_INT_32_BITS, /* Integer of 32 bits in length */
  45. PV_OCT_SEQ, /* Octet sequence */
  46. PV_NO_VALUE /* Does not contain any value (pl=0) */
  47. } PV_TYPE;
  48. /* Bit 7 of type field */
  49. #define PV_BIG_ENDIAN 0x80
  50. #define PV_LITTLE_ENDIAN 0x00
  51. #define PV_MASK 0x7f /* To mask away endian bit */
  52. #define PV_PUT 0
  53. #define PV_GET 1
  54. typedef union {
  55. char *c;
  56. __u32 i;
  57. __u32 *ip;
  58. } irda_pv_t;
  59. typedef struct {
  60. __u8 pi;
  61. __u8 pl;
  62. irda_pv_t pv;
  63. } irda_param_t;
  64. typedef int (*PI_HANDLER)(void *self, irda_param_t *param, int get);
  65. typedef int (*PV_HANDLER)(void *self, __u8 *buf, int len, __u8 pi,
  66. PV_TYPE type, PI_HANDLER func);
  67. typedef struct {
  68. PI_HANDLER func; /* Handler for this parameter identifier */
  69. PV_TYPE type; /* Data type for this parameter */
  70. } pi_minor_info_t;
  71. typedef struct {
  72. pi_minor_info_t *pi_minor_call_table;
  73. int len;
  74. } pi_major_info_t;
  75. typedef struct {
  76. pi_major_info_t *tables;
  77. int len;
  78. __u8 pi_mask;
  79. int pi_major_offset;
  80. } pi_param_info_t;
  81. int irda_param_pack(__u8 *buf, char *fmt, ...);
  82. int irda_param_insert(void *self, __u8 pi, __u8 *buf, int len,
  83. pi_param_info_t *info);
  84. int irda_param_extract_all(void *self, __u8 *buf, int len,
  85. pi_param_info_t *info);
  86. #define irda_param_insert_byte(buf,pi,pv) irda_param_pack(buf,"bbb",pi,1,pv)
  87. #endif /* IRDA_PARAMS_H */