Skip to content

Commit

Permalink
softdevice: fix writing to a characteristic
Browse files Browse the repository at this point in the history
This seems to have been broken since
#192, I suspect it's a
problem with the struct calling convention (which most certainly is a
TinyGo CGo bug, but at least this works around the problem).
  • Loading branch information
aykevl authored and deadprogram committed Dec 25, 2023
1 parent 0124318 commit b5d4e3f
Showing 1 changed file with 7 additions and 5 deletions.
12 changes: 7 additions & 5 deletions gatts_sd.go
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,12 @@ static inline uint32_t sd_ble_gatts_hvx_noescape(uint16_t conn_handle, uint16_t
return sd_ble_gatts_hvx(conn_handle, &p_hvx_params);
}
static inline uint32_t sd_ble_gatts_value_set_noescape(uint16_t conn_handle, uint16_t handle, ble_gatts_value_t p_value) {
static inline uint32_t sd_ble_gatts_value_set_noescape(uint16_t conn_handle, uint16_t handle, uint16_t len, uint8_t *value) {
ble_gatts_value_t p_value = {
.len = len,
.offset = 0,
.p_value = value,
};
return sd_ble_gatts_value_set(conn_handle, handle, &p_value);
}
*/
Expand Down Expand Up @@ -145,10 +150,7 @@ func (c *Characteristic) Write(p []byte) (n int, err error) {
}
}

errCode := C.sd_ble_gatts_value_set_noescape(C.BLE_CONN_HANDLE_INVALID, c.handle, C.ble_gatts_value_t{
len: C.uint16_t(len(p)),
p_value: (*C.uint8_t)(unsafe.Pointer(&p[0])),
})
errCode := C.sd_ble_gatts_value_set_noescape(C.BLE_CONN_HANDLE_INVALID, c.handle, C.uint16_t(len(p)), unsafe.SliceData(p))
if errCode != 0 {
return 0, Error(errCode)
}
Expand Down

0 comments on commit b5d4e3f

Please sign in to comment.