diff options
| author | Harald Welte <laforge@gnumonks.org> | 2018-05-11 17:39:21 +0200 | 
|---|---|---|
| committer | Harald Welte <laforge@gnumonks.org> | 2018-05-11 21:57:46 +0200 | 
| commit | 9da77abb6b7a023f2dcc1564835e89d9436d6793 (patch) | |
| tree | 716a8cec6d2e2e4b9ce3a57a251e67504d5e5997 /include/osmocom/core | |
| parent | 85b9fbae7e1a6bcf62597877f4b3a13474fac956 (diff) | |
isdnhdlc: Port from kernel to userspace
* prefix all symbols/constants with osmo_
* use stdint.h types instead of kernel types
* use Doxygen API documentation
* use Osmocom CRC16-CCITT functions
* use Osmocom bit-reversal functions
* integrate with Automake
Change-Id: I109085ab3e412c20b19cd42fb7137aa0e4167542
Diffstat (limited to 'include/osmocom/core')
| -rw-r--r-- | include/osmocom/core/isdnhdlc.h | 48 | 
1 files changed, 25 insertions, 23 deletions
diff --git a/include/osmocom/core/isdnhdlc.h b/include/osmocom/core/isdnhdlc.h index 96521370..56369bfd 100644 --- a/include/osmocom/core/isdnhdlc.h +++ b/include/osmocom/core/isdnhdlc.h @@ -1,5 +1,5 @@  /* - * hdlc.h  --  General purpose ISDN HDLC decoder. + * isdnhdlc.h  --  General purpose ISDN HDLC decoder.   *   * Implementation of a HDLC decoder/encoder in software.   * Necessary because some ISDN devices don't have HDLC @@ -29,7 +29,9 @@  #ifndef __ISDNHDLC_H__  #define __ISDNHDLC_H__ -struct isdnhdlc_vars { +#include <stdint.h> + +struct osmo_isdnhdlc_vars {  	int bit_shift;  	int hdlc_bits1;  	int data_bits; @@ -37,46 +39,46 @@ struct isdnhdlc_vars {  	int state;  	int dstpos; -	u16 crc; +	uint16_t crc; -	u8 cbin; -	u8 shift_reg; -	u8 ffvalue; +	uint8_t cbin; +	uint8_t shift_reg; +	uint8_t ffvalue;  	/* set if transferring data */ -	u32 data_received:1; +	uint32_t data_received:1;  	/* set if D channel (send idle instead of flags) */ -	u32 dchannel:1; +	uint32_t dchannel:1;  	/* set if 56K adaptation */ -	u32 do_adapt56:1; +	uint32_t do_adapt56:1;  	/* set if in closing phase (need to send CRC + flag) */ -	u32 do_closing:1; +	uint32_t do_closing:1;  	/* set if data is bitreverse */ -	u32 do_bitreverse:1; +	uint32_t do_bitreverse:1;  };  /* Feature Flags */ -#define HDLC_56KBIT	0x01 -#define HDLC_DCHANNEL	0x02 -#define HDLC_BITREVERSE	0x04 +#define OSMO_HDLC_F_56KBIT	0x01 +#define OSMO_HDLC_F_DCHANNEL	0x02 +#define OSMO_HDLC_F_BITREVERSE	0x04  /*    The return value from isdnhdlc_decode is    the frame length, 0 if no complete frame was decoded,    or a negative error number  */ -#define HDLC_FRAMING_ERROR     1 -#define HDLC_CRC_ERROR         2 -#define HDLC_LENGTH_ERROR      3 +#define OSMO_HDLC_FRAMING_ERROR     1 +#define OSMO_HDLC_CRC_ERROR         2 +#define OSMO_HDLC_LENGTH_ERROR      3 -extern void	isdnhdlc_rcv_init(struct isdnhdlc_vars *hdlc, u32 features); +extern void	osmo_isdnhdlc_rcv_init(struct osmo_isdnhdlc_vars *hdlc, uint32_t features); -extern int	isdnhdlc_decode(struct isdnhdlc_vars *hdlc, const u8 *src, -			int slen, int *count, u8 *dst, int dsize); +extern int	osmo_isdnhdlc_decode(struct osmo_isdnhdlc_vars *hdlc, const uint8_t *src, +				     int slen, int *count, uint8_t *dst, int dsize); -extern void	isdnhdlc_out_init(struct isdnhdlc_vars *hdlc, u32 features); +extern void	osmo_isdnhdlc_out_init(struct osmo_isdnhdlc_vars *hdlc, uint32_t features); -extern int	isdnhdlc_encode(struct isdnhdlc_vars *hdlc, const u8 *src, -			u16 slen, int *count, u8 *dst, int dsize); +extern int	osmo_isdnhdlc_encode(struct osmo_isdnhdlc_vars *hdlc, const uint8_t *src, +				     uint16_t slen, int *count, uint8_t *dst, int dsize);  #endif /* __ISDNHDLC_H__ */  | 
