linux-bluetooth.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
From: Szymon Janc <szymon.janc@tieto.com>
To: Andrei Emeltchenko <Andrei.Emeltchenko.news@gmail.com>
Cc: linux-bluetooth@vger.kernel.org
Subject: Re: [PATCH] android/gatt: Simplify gatt_db_attribute_get_permissions()
Date: Fri, 09 Jan 2015 11:10:34 +0100	[thread overview]
Message-ID: <2133713.7aeGTCSDGs@uw000953> (raw)
In-Reply-To: <1418984309-29896-1-git-send-email-Andrei.Emeltchenko.news@gmail.com>

Hi Andrei,

On Friday 19 of December 2014 12:18:29 Andrei Emeltchenko wrote:
> From: Andrei Emeltchenko <andrei.emeltchenko@intel.com>
> 
> Condition checks inside gatt_db_attribute_get_permissions() do not make
> sense. Simplify function.

In general I'm fine with this change but commit message should be improved.
ie. there is API change so this is not just simplification.


> ---
>  android/gatt.c           | 10 +++++-----
>  src/shared/gatt-db.c     | 10 ++--------
>  src/shared/gatt-db.h     |  3 +--
>  src/shared/gatt-server.c | 20 ++++----------------
>  4 files changed, 12 insertions(+), 31 deletions(-)
> 
> diff --git a/android/gatt.c b/android/gatt.c
> index 169f6db..6828f2f 100644
> --- a/android/gatt.c
> +++ b/android/gatt.c
> @@ -4790,7 +4790,7 @@ static void read_requested_attributes(void *data, void *user_data)
>  		return;
>  	}
>  
> -	gatt_db_attribute_get_permissions(attrib, &permissions);
> +	permissions = gatt_db_attribute_get_permissions(attrib);
>  
>  	/*
>  	 * Check if it is attribute we didn't declare permissions, like service
> @@ -6311,7 +6311,7 @@ static void write_cmd_request(const uint8_t *cmd, uint16_t cmd_len,
>  	if (!attrib)
>  		return;
>  
> -	gatt_db_attribute_get_permissions(attrib, &permissions);
> +	permissions = gatt_db_attribute_get_permissions(attrib);
>  
>  	if (check_device_permissions(dev, cmd[0], permissions))
>  		return;
> @@ -6359,7 +6359,7 @@ static void write_signed_cmd_request(const uint8_t *cmd, uint16_t cmd_len,
>  	if (!attrib)
>  		return;
>  
> -	gatt_db_attribute_get_permissions(attrib, &permissions);
> +	permissions = gatt_db_attribute_get_permissions(attrib);
>  
>  	if (check_device_permissions(dev, cmd[0], permissions))
>  		return;
> @@ -6430,7 +6430,7 @@ static uint8_t write_req_request(const uint8_t *cmd, uint16_t cmd_len,
>  	if (!attrib)
>  		return ATT_ECODE_ATTR_NOT_FOUND;
>  
> -	gatt_db_attribute_get_permissions(attrib, &permissions);
> +	permissions = gatt_db_attribute_get_permissions(attrib);
>  
>  	error = check_device_permissions(dev, cmd[0], permissions);
>  	if (error)
> @@ -6486,7 +6486,7 @@ static uint8_t write_prep_request(const uint8_t *cmd, uint16_t cmd_len,
>  	if (!attrib)
>  		return ATT_ECODE_ATTR_NOT_FOUND;
>  
> -	gatt_db_attribute_get_permissions(attrib, &permissions);
> +	permissions = gatt_db_attribute_get_permissions(attrib);
>  
>  	error = check_device_permissions(dev, cmd[0], permissions);
>  	if (error)
> diff --git a/src/shared/gatt-db.c b/src/shared/gatt-db.c
> index bb60904..4b91ae6 100644
> --- a/src/shared/gatt-db.c
> +++ b/src/shared/gatt-db.c
> @@ -1301,15 +1301,9 @@ bool gatt_db_attribute_get_incl_data(const struct gatt_db_attribute *attrib,
>  	return true;
>  }
>  
> -bool gatt_db_attribute_get_permissions(const struct gatt_db_attribute *attrib,
> -							uint32_t *permissions)
> +uint32_t gatt_db_attribute_get_permissions(const struct gatt_db_attribute *attrib)
>  {
> -	if (!attrib || !permissions)
> -		return false;
> -
> -	*permissions = attrib->permissions;
> -
> -	return true;
> +	return attrib->permissions;
>  }

Let check if attrib is NULL and return 0 in such case. This is to keep convention with
other getter-like functions.

>  
>  static void pending_read_result(struct pending_read *p, int err,
> diff --git a/src/shared/gatt-db.h b/src/shared/gatt-db.h
> index e5fe6bb..1379aae 100644
> --- a/src/shared/gatt-db.h
> +++ b/src/shared/gatt-db.h
> @@ -171,8 +171,7 @@ bool gatt_db_attribute_get_incl_data(const struct gatt_db_attribute *attrib,
>  							uint16_t *start_handle,
>  							uint16_t *end_handle);
>  
> -bool gatt_db_attribute_get_permissions(const struct gatt_db_attribute *attrib,
> -							uint32_t *permissions);
> +uint32_t gatt_db_attribute_get_permissions(const struct gatt_db_attribute *attrib);
>  
>  typedef void (*gatt_db_attribute_read_t) (struct gatt_db_attribute *attrib,
>  						int err, const uint8_t *value,
> diff --git a/src/shared/gatt-server.c b/src/shared/gatt-server.c
> index 00f36fd..f9e412d 100644
> --- a/src/shared/gatt-server.c
> +++ b/src/shared/gatt-server.c
> @@ -389,10 +389,7 @@ static void process_read_by_type(struct async_read_op *op)
>  		return;
>  	}
>  
> -	if (!gatt_db_attribute_get_permissions(attr, &perm)) {
> -		ecode = BT_ATT_ERROR_UNLIKELY;
> -		goto error;
> -	}
> +	perm = gatt_db_attribute_get_permissions(attr);
>  
>  	/*
>  	 * Check for the READ access permission. Encryption,
> @@ -697,10 +694,7 @@ static void write_cb(uint8_t opcode, const void *pdu,
>  				(opcode == BT_ATT_OP_WRITE_REQ) ? "Req" : "Cmd",
>  				handle);
>  
> -	if (!gatt_db_attribute_get_permissions(attr, &perm)) {
> -		ecode = BT_ATT_ERROR_INVALID_HANDLE;
> -		goto error;
> -	}
> +	perm = gatt_db_attribute_get_permissions(attr);
>  
>  	if (!(perm & BT_ATT_PERM_WRITE)) {
>  		ecode = BT_ATT_ERROR_WRITE_NOT_PERMITTED;
> @@ -813,10 +807,7 @@ static void handle_read_req(struct bt_gatt_server *server, uint8_t opcode,
>  			opcode == BT_ATT_OP_READ_BLOB_REQ ? "Blob " : "",
>  			handle);
>  
> -	if (!gatt_db_attribute_get_permissions(attr, &perm)) {
> -		ecode = BT_ATT_ERROR_INVALID_HANDLE;
> -		goto error;
> -	}
> +	perm = gatt_db_attribute_get_permissions(attr);
>  
>  	if (perm && !(perm & BT_ATT_PERM_READ)) {
>  		ecode = BT_ATT_ERROR_READ_NOT_PERMITTED;
> @@ -919,10 +910,7 @@ static void prep_write_cb(uint8_t opcode, const void *pdu,
>  	util_debug(server->debug_callback, server->debug_data,
>  				"Prep Write Req - handle: 0x%04x", handle);
>  
> -	if (!gatt_db_attribute_get_permissions(attr, &perm)) {
> -		ecode = BT_ATT_ERROR_INVALID_HANDLE;
> -		goto error;
> -	}
> +	perm = gatt_db_attribute_get_permissions(attr);
>  
>  	/*
>  	 * TODO: The "Prepare Write" request requires security permission checks
> 

-- 
Best regards, 
Szymon Janc

  reply	other threads:[~2015-01-09 10:10 UTC|newest]

Thread overview: 11+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2014-12-19  9:24 [PATCH] android/gatt: Fix dead code warnings Andrei Emeltchenko
2014-12-19 10:07 ` Szymon Janc
2014-12-19 10:14   ` Andrei Emeltchenko
2014-12-19 10:15     ` Szymon Janc
2014-12-19 10:18       ` [PATCH] android/gatt: Simplify gatt_db_attribute_get_permissions() Andrei Emeltchenko
2015-01-09 10:10         ` Szymon Janc [this message]
2015-01-13 10:09           ` [PATCHv2 1/2] android/gatt: Fix dead code warnings Andrei Emeltchenko
2015-01-13 10:09             ` [PATCHv2 2/2] android/gatt: Refactor gatt_db_attribute_get_permissions() Andrei Emeltchenko
2015-01-20 10:48             ` [PATCHv2 1/2] android/gatt: Fix dead code warnings Szymon Janc
2014-12-19 10:22       ` [PATCH] " Andrei Emeltchenko
2015-01-08 14:19 ` Andrei Emeltchenko

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=2133713.7aeGTCSDGs@uw000953 \
    --to=szymon.janc@tieto.com \
    --cc=Andrei.Emeltchenko.news@gmail.com \
    --cc=linux-bluetooth@vger.kernel.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).