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 34 #ifndef IRDA_PARAMS_H 35 #define IRDA_PARAMS_H 36 37 /* 38 * The currently supported types. Beware not to change the sequence since 39 * it a good reason why the sized integers has a value equal to their size 40 */ 41 typedef enum { 42 PV_INTEGER, /* Integer of any (pl) length */ 43 PV_INT_8_BITS, /* Integer of 8 bits in length */ 44 PV_INT_16_BITS, /* Integer of 16 bits in length */ 45 PV_STRING, /* \0 terminated string */ 46 PV_INT_32_BITS, /* Integer of 32 bits in length */ 47 PV_OCT_SEQ, /* Octet sequence */ 48 PV_NO_VALUE /* Does not contain any value (pl=0) */ 49 } PV_TYPE; 50 51 /* Bit 7 of type field */ 52 #define PV_BIG_ENDIAN 0x80 53 #define PV_LITTLE_ENDIAN 0x00 54 #define PV_MASK 0x7f /* To mask away endian bit */ 55 56 #define PV_PUT 0 57 #define PV_GET 1 58 59 typedef union { 60 char *c; 61 __u32 i; 62 __u32 *ip; 63 } irda_pv_t; 64 65 typedef struct { 66 __u8 pi; 67 __u8 pl; 68 irda_pv_t pv; 69 } irda_param_t; 70 71 typedef int (*PI_HANDLER)(void *self, irda_param_t *param, int get); 72 typedef int (*PV_HANDLER)(void *self, __u8 *buf, int len, __u8 pi, 73 PV_TYPE type, PI_HANDLER func); 74 75 typedef struct { 76 PI_HANDLER func; /* Handler for this parameter identifier */ 77 PV_TYPE type; /* Data type for this parameter */ 78 } pi_minor_info_t; 79 80 typedef struct { 81 pi_minor_info_t *pi_minor_call_table; 82 int len; 83 } pi_major_info_t; 84 85 typedef struct { 86 pi_major_info_t *tables; 87 int len; 88 __u8 pi_mask; 89 int pi_major_offset; 90 } pi_param_info_t; 91 92 int irda_param_pack(__u8 *buf, char *fmt, ...); 93 int irda_param_unpack(__u8 *buf, char *fmt, ...); 94 95 int irda_param_insert(void *self, __u8 pi, __u8 *buf, int len, 96 pi_param_info_t *info); 97 int irda_param_extract(void *self, __u8 *buf, int len, pi_param_info_t *info); 98 int irda_param_extract_all(void *self, __u8 *buf, int len, 99 pi_param_info_t *info); 100 101 #define irda_param_insert_byte(buf,pi,pv) irda_param_pack(buf,"bbb",pi,1,pv) 102 103 #endif /* IRDA_PARAMS_H */ 104 105