parameters.h 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100
  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, see <http://www.gnu.org/licenses/>.
  26. *
  27. * Michel Dänzer <daenzer@debian.org>, 10/2001
  28. * - simplify irda_pv_t to avoid endianness issues
  29. *
  30. ********************************************************************/
  31. #ifndef IRDA_PARAMS_H
  32. #define IRDA_PARAMS_H
  33. /*
  34. * The currently supported types. Beware not to change the sequence since
  35. * it a good reason why the sized integers has a value equal to their size
  36. */
  37. typedef enum {
  38. PV_INTEGER, /* Integer of any (pl) length */
  39. PV_INT_8_BITS, /* Integer of 8 bits in length */
  40. PV_INT_16_BITS, /* Integer of 16 bits in length */
  41. PV_STRING, /* \0 terminated string */
  42. PV_INT_32_BITS, /* Integer of 32 bits in length */
  43. PV_OCT_SEQ, /* Octet sequence */
  44. PV_NO_VALUE /* Does not contain any value (pl=0) */
  45. } PV_TYPE;
  46. /* Bit 7 of type field */
  47. #define PV_BIG_ENDIAN 0x80
  48. #define PV_LITTLE_ENDIAN 0x00
  49. #define PV_MASK 0x7f /* To mask away endian bit */
  50. #define PV_PUT 0
  51. #define PV_GET 1
  52. typedef union {
  53. char *c;
  54. __u32 i;
  55. __u32 *ip;
  56. } irda_pv_t;
  57. typedef struct {
  58. __u8 pi;
  59. __u8 pl;
  60. irda_pv_t pv;
  61. } irda_param_t;
  62. typedef int (*PI_HANDLER)(void *self, irda_param_t *param, int get);
  63. typedef int (*PV_HANDLER)(void *self, __u8 *buf, int len, __u8 pi,
  64. PV_TYPE type, PI_HANDLER func);
  65. typedef struct {
  66. const PI_HANDLER func; /* Handler for this parameter identifier */
  67. PV_TYPE type; /* Data type for this parameter */
  68. } pi_minor_info_t;
  69. typedef struct {
  70. const pi_minor_info_t *pi_minor_call_table;
  71. int len;
  72. } pi_major_info_t;
  73. typedef struct {
  74. const pi_major_info_t *tables;
  75. int len;
  76. __u8 pi_mask;
  77. int pi_major_offset;
  78. } pi_param_info_t;
  79. int irda_param_pack(__u8 *buf, char *fmt, ...);
  80. int irda_param_insert(void *self, __u8 pi, __u8 *buf, int len,
  81. pi_param_info_t *info);
  82. int irda_param_extract_all(void *self, __u8 *buf, int len,
  83. pi_param_info_t *info);
  84. #define irda_param_insert_byte(buf,pi,pv) irda_param_pack(buf,"bbb",pi,1,pv)
  85. #endif /* IRDA_PARAMS_H */