From: Tyszkowski Jakub <jakub.tyszkowski@tieto.com>
To: Luiz Augusto von Dentz <luiz.dentz@gmail.com>
Cc: "linux-bluetooth@vger.kernel.org" <linux-bluetooth@vger.kernel.org>
Subject: Re: [PATCH 3/5] android/gatt: Fix write commands being not handled
Date: Mon, 08 Dec 2014 11:17:23 +0100 [thread overview]
Message-ID: <54857AB3.4090309@tieto.com> (raw)
In-Reply-To: <54856FE3.7030808@tieto.com>
Hi,
On 12/08/2014 10:31 AM, Tyszkowski Jakub wrote:
> Hi Luiz,
>
> On 12/08/2014 10:22 AM, Luiz Augusto von Dentz wrote:
>> Hi Jakub,
>>
>> On Mon, Dec 8, 2014 at 10:55 AM, Luiz Augusto von Dentz
>> <luiz.dentz@gmail.com> wrote:
>>> Hi Jakub,
>>>
>>> On Mon, Dec 8, 2014 at 10:22 AM, Jakub Tyszkowski
>>> <jakub.tyszkowski@tieto.com> wrote:
>>>> Registering for GATTRIB_ALL_REQS now means only requests and not
>>>> commands
>>>> or other type of att operations. Those needs their own handlers to be
>>>> registered.
>>>
>>> Is this something we break while with the internal changes to use
>>> bt_gatt* internally? Maybe we should have it fixed there instead since
>>> it perhaps breaks the core daemon as well. Going forward this code
>>> will transition to use bt_gatt* directly.
>>
>> Looks like this code is to blame:
>>
>> opcode_match:
>>
>> if (opcode == BT_ATT_ALL_REQUESTS &&
>> get_op_type(test_opcode) == ATT_OP_TYPE_REQ)
>> return true;
>>
>> Id say this turn BT_ATT_ALL_REQUESTS not that convenient for server
>> since, and looking at gatt-server.c you can clearly see how many
>> handlers we end up doing, perhaps we could something like this:
>>
>> diff --git a/src/shared/att.c b/src/shared/att.c
>> index bc01827..3b52607 100644
>> --- a/src/shared/att.c
>> +++ b/src/shared/att.c
>> @@ -661,7 +661,7 @@ struct notify_data {
>> static bool opcode_match(uint8_t opcode, uint8_t test_opcode)
>> {
>> if (opcode == BT_ATT_ALL_REQUESTS &&
>> - get_op_type(test_opcode) ==
>> ATT_OP_TYPE_REQ)
>> + get_op_type(test_opcode) !=
>> ATT_OP_TYPE_RSP)
>> return true;
If we do that, we are still left with other stuff like indications or
even confirmations which would still be quite quirky for using
*ALL_REQESTS in name.
>>
>> return opcode == test_opcode;
>>
> Yeap, that's the line. I assumed that this change was intended and we
> should make the daemon compatible with this new semantic.
> I've looked through the code where ALL_REQUESTS is used and I think
> there is no other place affected by this.
>
> Regards
Regards
next prev parent reply other threads:[~2014-12-08 10:17 UTC|newest]
Thread overview: 14+ messages / expand[flat|nested] mbox.gz Atom feed top
2014-12-08 8:22 [PATCH 1/5] android/gatt: Fix write confirm callback being not set Jakub Tyszkowski
2014-12-08 8:22 ` [PATCH 2/5] android/gatt: Fix not confirming write commands in database Jakub Tyszkowski
2014-12-08 8:22 ` [PATCH 3/5] android/gatt: Fix write commands being not handled Jakub Tyszkowski
2014-12-08 8:55 ` Luiz Augusto von Dentz
2014-12-08 9:22 ` Luiz Augusto von Dentz
2014-12-08 9:31 ` Tyszkowski Jakub
2014-12-08 10:17 ` Tyszkowski Jakub [this message]
2014-12-08 11:02 ` Luiz Augusto von Dentz
2014-12-08 19:50 ` Arman Uguray
2014-12-08 22:08 ` Luiz Augusto von Dentz
2014-12-08 22:20 ` Arman Uguray
2014-12-09 7:53 ` Tyszkowski Jakub
2014-12-08 8:22 ` [PATCH 4/5] android/gatt: Extract indication support from att_req_handler Jakub Tyszkowski
2014-12-08 8:22 ` [PATCH 5/5] android/gatt: Remove not handled att ops in request handler Jakub Tyszkowski
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=54857AB3.4090309@tieto.com \
--to=jakub.tyszkowski@tieto.com \
--cc=linux-bluetooth@vger.kernel.org \
--cc=luiz.dentz@gmail.com \
/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).