summaryrefslogtreecommitdiff
path: root/emulator
diff options
context:
space:
mode:
authorLuiz Augusto von Dentz <luiz.von.dentz@intel.com>2022-08-05 14:48:37 -0700
committerLuiz Augusto von Dentz <luiz.von.dentz@intel.com>2022-08-05 15:50:56 -0700
commitbbbd0512c92d5b9a629a41b6e1afaef94f63a8b4 (patch)
treeefb07d7cc6b6603a1d464bf17c7ffdceaa4cea0f /emulator
parentf07b88abfb89dbd951d65b782076383768bbc8be (diff)
downloadbluez-bbbd0512c92d5b9a629a41b6e1afaef94f63a8b4.tar.gz
bthost: Add qos support to bthost_set_cig_params
This enables setting QoS other then the mandatory 16_2_1.
Diffstat (limited to 'emulator')
-rw-r--r--emulator/bthost.c26
-rw-r--r--emulator/bthost.h4
2 files changed, 18 insertions, 12 deletions
diff --git a/emulator/bthost.c b/emulator/bthost.c
index 75fa625b1..f067d39a0 100644
--- a/emulator/bthost.c
+++ b/emulator/bthost.c
@@ -3131,25 +3131,29 @@ bool bthost_search_ext_adv_addr(struct bthost *bthost, const uint8_t *addr)
}
void bthost_set_cig_params(struct bthost *bthost, uint8_t cig_id,
- uint8_t cis_id)
+ uint8_t cis_id, const struct bt_iso_qos *qos)
{
struct bt_hci_cmd_le_set_cig_params *cp;
cp = malloc(sizeof(*cp) + sizeof(*cp->cis));
memset(cp, 0, sizeof(*cp) + sizeof(*cp->cis));
cp->cig_id = cig_id;
- put_le24(10000, cp->c_interval);
- put_le24(10000, cp->p_interval);
- cp->c_latency = cpu_to_le16(10);
- cp->p_latency = cpu_to_le16(10);
+ put_le24(qos->in.interval ? qos->in.interval : qos->out.interval,
+ cp->c_interval);
+ put_le24(qos->out.interval ? qos->out.interval : qos->in.interval,
+ cp->p_interval);
+ cp->c_latency = cpu_to_le16(qos->in.latency ? qos->in.latency :
+ qos->out.latency);
+ cp->p_latency = cpu_to_le16(qos->out.latency ? qos->out.latency :
+ qos->in.latency);
cp->num_cis = 0x01;
cp->cis[0].cis_id = cis_id;
- cp->cis[0].c_sdu = 40;
- cp->cis[0].p_sdu = 40;
- cp->cis[0].c_phy = 0x02;
- cp->cis[0].p_phy = 0x02;
- cp->cis[0].c_rtn = 2;
- cp->cis[0].p_rtn = 2;
+ cp->cis[0].c_sdu = qos->in.sdu;
+ cp->cis[0].p_sdu = qos->out.sdu;
+ cp->cis[0].c_phy = qos->in.phy ? qos->in.phy : qos->out.phy;
+ cp->cis[0].p_phy = qos->out.phy ? qos->out.phy : qos->in.phy;
+ cp->cis[0].c_rtn = qos->in.rtn;
+ cp->cis[0].p_rtn = qos->out.rtn;
send_command(bthost, BT_HCI_CMD_LE_SET_CIG_PARAMS, cp,
sizeof(*cp) + sizeof(*cp->cis));
diff --git a/emulator/bthost.h b/emulator/bthost.h
index fd177ac29..3d7a124f0 100644
--- a/emulator/bthost.h
+++ b/emulator/bthost.h
@@ -12,6 +12,8 @@
#include <stdint.h>
#include <sys/uio.h>
+#include "lib/bluetooth.h"
+
typedef void (*bthost_send_func) (const struct iovec *iov, int iovlen,
void *user_data);
@@ -101,7 +103,7 @@ void bthost_create_big(struct bthost *bthost, uint8_t num_bis);
bool bthost_search_ext_adv_addr(struct bthost *bthost, const uint8_t *addr);
void bthost_set_cig_params(struct bthost *bthost, uint8_t cig_id,
- uint8_t cis_id);
+ uint8_t cis_id, const struct bt_iso_qos *qos);
void bthost_create_cis(struct bthost *bthost, uint16_t cis_handle,
uint16_t acl_handle);