Re: [PATCH 2/2] hcidump: parse extended control field in l2cap

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Hi Andrei,

* Emeltchenko Andrei <Andrei.Emeltchenko.news@xxxxxxxxx> [2011-08-25 13:34:09 +0300]:

> From: Andrei Emeltchenko <andrei.emeltchenko@xxxxxxxxx>
> 
> Adds support for parsing extended control field. Extended control
> field may be used for ERTM and streaming mode (if EWS specified).
> Remove magic numbers concerning the subject. Patch to bluez with
> definitinos shall be applied.
> ---
>  parser/l2cap.c |  129 ++++++++++++++++++++++++++++++++++++++++----------------
>  1 files changed, 93 insertions(+), 36 deletions(-)
> 
> diff --git a/parser/l2cap.c b/parser/l2cap.c
> index 217008d..42d3974 100644
> --- a/parser/l2cap.c
> +++ b/parser/l2cap.c
> @@ -60,6 +60,9 @@ typedef struct {
>  } cid_info;
>  #define CID_TABLE_SIZE 20
>  
> +/* FIXME */
> +static int ext_ctrl;
> +
>  static cid_info cid_table[2][CID_TABLE_SIZE];
>  
>  #define SCID cid_table[0]
> @@ -352,13 +355,13 @@ static char *fcs2str(uint8_t fcs)
>  static char *sar2str(uint8_t sar)
>  {
>  	switch (sar) {
> -	case 0x00:
> +	case L2CAP_SAR_UNSEGMENTED:
>  		return "Unsegmented";
> -	case 0x01:
> +	case L2CAP_SAR_START:
>  		return "Start";
> -	case 0x02:
> +	case L2CAP_SAR_END:
>  		return "End";
> -	case 0x03:
> +	case L2CAP_SAR_CONTINUE:
>  		return "Continuation";
>  	default:
>  		return "Bad SAR";
> @@ -369,13 +372,13 @@ static char *sar2str(uint8_t sar)
>  static char *supervisory2str(uint8_t supervisory)
>  {
>  	switch (supervisory) {
> -	case 0x00:
> +	case L2CAP_SUPER_RR:
>  		return "Receiver Ready (RR)";
> -	case 0x01:
> +	case L2CAP_SUPER_REJ:
>  		return "Reject (REJ)";
> -	case 0x02:
> +	case L2CAP_SUPER_RNR:
>  		return "Receiver Not Ready (RNR)";
> -	case 0x03:
> +	case L2CAP_SUPER_SREJ:
>  		return "Select Reject (SREJ)";
>  	default:
>  		return "Bad Supervisory";
> @@ -564,6 +567,7 @@ static void conf_opt(int level, void *ptr, int len, int in, uint16_t cid)
>  			printf("EWS");
>  			if (h->len > 0)
>  				printf(" %d", get_val(h->val, h->len));
> +			ext_ctrl = 1;
>  			break;
>  
>  		default:
> @@ -763,6 +767,63 @@ static inline void info_rsp(int level, l2cap_cmd_hdr *cmd, struct frame *frm)
>  	}
>  }
>  
> +static void l2cap_ctrl_ext_parse(int level, struct frame *frm, uint32_t ctrl)
> +{
> +	p_indent(level, frm);
> +
> +	printf("%s:", ctrl & L2CAP_EXT_CTRL_FRAME_TYPE ? "S-frame" : "I-frame");

Blank line here.

> +	if (ctrl & L2CAP_EXT_CTRL_FRAME_TYPE) {
> +		printf(" %s", supervisory2str((ctrl & L2CAP_EXT_CTRL_SUPERVISE_MASK) >>
> +					L2CAP_EXT_CTRL_SUPER_SHIFT));
> +	} else {
> +		uint8_t sar = (ctrl & L2CAP_EXT_CTRL_SAR_MASK) >>
> +			L2CAP_EXT_CTRL_SAR_SHIFT;
> +		printf(" %s", sar2str(sar));
> +		if (sar == L2CAP_SAR_START) {
> +			uint16_t len;
> +			len = btohs(bt_get_unaligned((uint16_t *) frm->ptr));
> +			frm->ptr += L2CAP_SDULEN_SIZE;
> +			frm->len -= L2CAP_SDULEN_SIZE;
> +			printf(" (len %d)", len);
> +		}
> +		printf(" TxSeq %d", (ctrl & L2CAP_EXT_CTRL_TXSEQ_MASK) >>
> +				L2CAP_EXT_CTRL_TXSEQ_SHIFT);
> +	}

and here.

> +	printf(" ReqSeq %d", (ctrl & L2CAP_EXT_CTRL_REQSEQ_MASK) >>
> +			L2CAP_EXT_CTRL_REQSEQ_SHIFT);

and here.

> +	if (ctrl & L2CAP_EXT_CTRL_FINAL)
> +		printf(" F-bit");

and here.

The same for the other function, these blank lines makes the code more
readable.

	Gustavo
--
To unsubscribe from this list: send the line "unsubscribe linux-bluetooth" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html


[Index of Archives]     [Bluez Devel]     [Linux Wireless Networking]     [Linux Wireless Personal Area Networking]     [Linux ATH6KL]     [Linux USB Devel]     [Linux Media Drivers]     [Linux Audio Users]     [Linux Kernel]     [Linux SCSI]     [Big List of Linux Books]

  Powered by Linux