From 323258aebc61d2403a4f61321f85bd73383f998c Mon Sep 17 00:00:00 2001 From: "matthias.ringwald@gmail.com" Date: Sun, 26 Jan 2014 21:52:25 +0000 Subject: [PATCH] execute all pending write queues, cancel all write queues --- example/libusb/ble_peripheral.c | 38 ++++++++++++++++----------------- 1 file changed, 18 insertions(+), 20 deletions(-) diff --git a/example/libusb/ble_peripheral.c b/example/libusb/ble_peripheral.c index 45a4e6bb1..b812a3c8a 100644 --- a/example/libusb/ble_peripheral.c +++ b/example/libusb/ble_peripheral.c @@ -289,13 +289,13 @@ static uint16_t att_read_callback(uint16_t handle, uint16_t offset, uint8_t * bu // write requests static int att_write_callback(uint16_t handle, uint16_t transaction_mode, uint16_t offset, uint8_t *buffer, uint16_t buffer_size, signature_t * signature){ - printf("WRITE Callback, handle %04x\n", handle); + printf("WRITE Callback, handle %04x, mode %u, offset %u\n", handle, transaction_mode, offset); switch(handle){ - case 0x0012: - case 0x0015: - case 0x002a: - case 0x002d: + case 0x0013: + case 0x0018: + case 0x0037: + case 0x003c: client_configuration = buffer[0]; client_configuration_handle = handle; printf("Client Configuration set to %u for handle %04x\n", client_configuration, handle); @@ -317,32 +317,30 @@ static int att_write_callback(uint16_t handle, uint16_t transaction_mode, uint16 } att_attributes[attributes_index].len = buffer_size; memcpy(att_attributes[attributes_index].value, buffer, buffer_size); - printf("Index %u\n", attributes_index); break; case ATT_TRANSACTION_MODE_ACTIVE: writes_index = att_write_queue_for_handle(handle); if (writes_index < 0) return 0; if (buffer_size + offset > ATT_VALUE_MAX_LEN) return 0; att_write_queues[writes_index].len = buffer_size + offset; - memcpy(&att_write_queues[writes_index].value[offset], buffer, buffer_size); + memcpy(&(att_write_queues[writes_index].value[offset]), buffer, buffer_size); break; case ATT_TRANSACTION_MODE_EXECUTE: - writes_index = att_write_queue_for_handle(handle); - if (writes_index < 0) return 0; - attributes_index = att_attribute_for_handle(handle); - if (attributes_index < 0){ - attributes_index = att_attribute_for_handle(0); - if (attributes_index < 0) return 0; // fail - att_attributes[attributes_index].handle = handle; + for (writes_index=0;writes_index