Re: [PATCH] android/gatt: Set attrib MTU correctly

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

 



Hi Marcin,

On Wednesday 04 of June 2014 20:31:56 Marcin Kraglak wrote:
> Hi Szymon,
> 
> On 4 June 2014 19:38, Szymon Janc <szymon.janc@xxxxxxxxx> wrote:
> > Hi Marcin,
> > 
> > On Wednesday 04 of June 2014 14:54:08 Marcin Kraglak wrote:
> >> We should set g_attrib mtu with MIN of two values: Remote Rx MTU
> >> and local Tx MTU. In previous solution once we set g_attrib mtu, we
> >> could only reduce MTU (because we took previously set g_attrib MTU
> >> and Remote Rx MTU). It affected cases when remote wanted to increase
> >> MTU
> > 
> > According to spec:
> > section 3.4.2.1: "This [Exchange MTU] request shall only be sent once
> > during a connection by the client."
> > section 3.4.2.2: "A device's Exchange MTU Request shall contain the same
> > MTU as the device's Exchange MTU Response (i.e. the MTU shall be
> > symmetric)."
> > 
> > So if I get the spec correctly it is illegal to increase (or decrease) MTU
> > after it was exchanged (we should probably respond with error if client is
> > sending request more than one).
> > 
> > Please correct me if I'm wrong.
> 
> That is not the case. We set g_attrib MTU when g_attrib_new() is called,
> and then it is set to default value - 23 (gattrib.c:499). While
> exchanging MTU we
> get MIN value of g_attrib MTU, which was previously set to 23 and remote
> MTU. So it was set to 23 again. (It means that we always used default MTU).
> Now we get remote MTU and local output MTU.

Fair enough. This patch is now applied, thanks.

> 
> Increasing or decreasing MTU even if it was previously exchanged can be a
> point of discussion, however PTS exchange it two times in test case
> TP/GAC/SR/BV-01-C. We can create an issue for this case.

I guess PTS errata should be filled to clear this up.

> 
> >> .
> >> ---
> >> 
> >>  android/gatt.c | 9 +++++----
> >>  1 file changed, 5 insertions(+), 4 deletions(-)
> >> 
> >> diff --git a/android/gatt.c b/android/gatt.c
> >> index 429181f..5bf7694 100644
> >> --- a/android/gatt.c
> >> +++ b/android/gatt.c
> >> @@ -4857,8 +4857,8 @@ static uint8_t read_request(const uint8_t *cmd,
> >> uint16_t cmd_len, static uint8_t mtu_att_handle(const uint8_t *cmd,
> >> uint16_t cmd_len, struct gatt_device *dev)
> >> 
> >>  {
> >> 
> >> -     uint16_t mtu, imtu;
> >> -     size_t omtu;
> >> +     uint16_t mtu, imtu, omtu;
> >> +     size_t length;
> >> 
> >>       GIOChannel *io;
> >>       GError *gerr = NULL;
> >>       uint16_t len;
> >> 
> >> @@ -4877,6 +4877,7 @@ static uint8_t mtu_att_handle(const uint8_t *cmd,
> >> uint16_t cmd_len,
> >> 
> >>       bt_io_get(io, &gerr,
> >>       
> >>                       BT_IO_OPT_IMTU, &imtu,
> >> 
> >> +                     BT_IO_OPT_OMTU, &omtu,
> >> 
> >>                       BT_IO_OPT_INVALID);
> >>       
> >>       if (gerr) {
> >>       
> >>               error("bt_io_get: %s", gerr->message);
> >> 
> >> @@ -4884,10 +4885,10 @@ static uint8_t mtu_att_handle(const uint8_t *cmd,
> >> uint16_t cmd_len, return ATT_ECODE_UNLIKELY;
> >> 
> >>       }
> >> 
> >> -     rsp = g_attrib_get_buffer(dev->attrib, &omtu);
> >> +     rsp = g_attrib_get_buffer(dev->attrib, &length);
> >> 
> >>       /* Respond with our IMTU */
> >> 
> >> -     len = enc_mtu_resp(imtu, rsp, omtu);
> >> +     len = enc_mtu_resp(imtu, rsp, length);
> >> 
> >>       if (!len)
> >>       
> >>               return ATT_ECODE_UNLIKELY;
> > 
> > --
> > BR
> > Szymon Janc
> 
> BR
> Marcin

-- 
BR
Szymon Janc
--
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