Skip to content

Commit

Permalink
fix: ensure HCI send/receive buffers for ATT are large enough for max…
Browse files Browse the repository at this point in the history
…imum MTU length

Signed-off-by: deadprogram <[email protected]>
  • Loading branch information
deadprogram committed Jan 9, 2025
1 parent 62565e6 commit 31e1365
Showing 1 changed file with 10 additions and 5 deletions.
15 changes: 10 additions & 5 deletions att_hci.go
Original file line number Diff line number Diff line change
Expand Up @@ -66,6 +66,11 @@ const (
gattClientCharacteristicConfigUUID = 0x2902
)

const (
maximumMTU = 248
maximumMTUBufferLen = maximumMTU + 8
)

var (
ErrATTTimeout = errors.New("bluetooth: ATT timeout")
ErrATTUnknownEvent = errors.New("bluetooth: ATT unknown event")
Expand Down Expand Up @@ -292,7 +297,7 @@ func newATT(hci *hci) *att {
lastHandle: 0x0001,
attributes: []rawAttribute{},
localServices: []rawService{},
maxMTU: 248,
maxMTU: maximumMTU,
}
}

Expand Down Expand Up @@ -758,7 +763,7 @@ func (a *att) handleData(handle uint16, buf []byte) error {
}

func (a *att) handleReadByGroupReq(handle, start, end uint16, uuid shortUUID) error {
var response [64]byte
var response [maximumMTUBufferLen]byte
response[0] = attOpReadByGroupResponse
response[1] = 0x0 // length per service
pos := 2
Expand Down Expand Up @@ -818,7 +823,7 @@ func (a *att) handleReadByGroupReq(handle, start, end uint16, uuid shortUUID) er
}

func (a *att) handleReadByTypeReq(handle, start, end uint16, uuid shortUUID) error {
var response [64]byte
var response [maximumMTUBufferLen]byte
response[0] = attOpReadByTypeResponse
pos := 0

Expand Down Expand Up @@ -883,7 +888,7 @@ func (a *att) handleReadByTypeReq(handle, start, end uint16, uuid shortUUID) err
}

func (a *att) handleFindInfoReq(handle, start, end uint16) error {
var response [64]byte
var response [maximumMTUBufferLen]byte
response[0] = attOpFindInfoResponse
pos := 0

Expand Down Expand Up @@ -946,7 +951,7 @@ func (a *att) handleReadReq(handle, attrHandle uint16) error {
return a.sendError(handle, attOpReadReq, attrHandle, attErrorAttrNotFound)
}

var response [64]byte
var response [maximumMTUBufferLen]byte
response[0] = attOpReadResponse
pos := 1

Expand Down

0 comments on commit 31e1365

Please sign in to comment.