Received: by 2002:a05:6a10:f347:0:0:0:0 with SMTP id d7csp5397485pxu; Tue, 22 Dec 2020 16:30:18 -0800 (PST) X-Google-Smtp-Source: ABdhPJyl2McjcHwOzil67nQWZZCdnhFpbwWXcwnKbuzb4ftne0T2Mha6hICFaTLbGsGIWw3ULYIs X-Received: by 2002:a17:906:7687:: with SMTP id o7mr22438088ejm.209.1608683417899; Tue, 22 Dec 2020 16:30:17 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1608683417; cv=none; d=google.com; s=arc-20160816; b=V5TDBXkRB8LmwDi+T0saIl7RbMo9P9qPA4GYe/+MF/ry4nrpPj9ODHf/D13dS4tME2 OV2pQXT/NrDW/UgRGWL3iViAsjdpL1dAmplZrSrHJyo7RxnRA6Otin5rMhXxdaOc3Qi4 BW1XUkRDSieEmWElCp/emNTYUCq0UJG4+J9TCOA5iQy4FyNrHOzURFCOi9bPEybTwVRd vMeuifHMwGFYs6gw6pwbCtjjtORge1GuzlGpNBU8uULE+5vLZZ6prQYH97CD4b1fJmpM EMaFXhcawFoWG4pcIoNloqCGmBbBy5MyF7qOqEv5VIg9o50XtGsoNH0r02iyI+TrFkKK /cCg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=wHkAFeFGdVP0bN+3byL2TsVLZTpr3v8Y3XvQKnnn9Fo=; b=DScAdGLILt7Vmufzo0FeTxNwZFVUfpGBJmHdwkBbVwk8yL+fvmh/bz7aqHc11eg/sZ 9Ip4OmxYyo1YKbpOKGoo0z82cTNFwBQyMwp1GM1qY4T3L1HoZhZhMYa0BrBLEJfXxUWw Y179C4UhosPbccMn/40OH8OPQfgQ/DOtS5+yKb7x+dS2NMSDjl30hnsSLNBtSlOR8C32 /pq0OU/Ni86YHmY4sJjBPvesrx3d+cdlIMZoDcXmn/FgDZDC87O+OkyDFQXMNURHvEgk zwhmPLefrqluprke3K4HxrLC4vxoHwzQWgTz16cobcPCGCqpqBHhOuEECUuGh866XBH7 7sBw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=J8QbsTBg; spf=pass (google.com: domain of linux-bluetooth-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-bluetooth-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id k25si11260112ejz.91.2020.12.22.16.29.38; Tue, 22 Dec 2020 16:30:17 -0800 (PST) Received-SPF: pass (google.com: domain of linux-bluetooth-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=J8QbsTBg; spf=pass (google.com: domain of linux-bluetooth-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-bluetooth-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1725967AbgLWA1b (ORCPT + 99 others); Tue, 22 Dec 2020 19:27:31 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:46912 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725931AbgLWA1b (ORCPT ); Tue, 22 Dec 2020 19:27:31 -0500 Received: from mail-pg1-x52f.google.com (mail-pg1-x52f.google.com [IPv6:2607:f8b0:4864:20::52f]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 1EE9CC0613D6 for ; Tue, 22 Dec 2020 16:26:51 -0800 (PST) Received: by mail-pg1-x52f.google.com with SMTP id e2so9472071pgi.5 for ; Tue, 22 Dec 2020 16:26:51 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=wHkAFeFGdVP0bN+3byL2TsVLZTpr3v8Y3XvQKnnn9Fo=; b=J8QbsTBgbaUeX1aRMZyX9YcjS/yaRckew8+z6zRBRLYyNuOfOPJdNpIZvd/5ERSIBA +6q7lKA+jQzeh1KqvZPPYPJHuCeC4nIRA9SbW/nxe0B8msAZMXzC8O+WdtK0/IWK02w8 HZAfgRjlpY3FbJzGzpr6iDct2n5HjiMahBcWtGZbsKl65aP0DTqXiesyYJOja4hmQ6gW D6rK1rzN0UtLhS/gC78ijx61UgrnpV+3uU5/HO7w/9i+PzAbDi/RrAsMyJGmpx418uvZ MDwBpixL40JfpLvs+EbDI7BFN/ybV4yY/4RLGs5ZSyRJJBZrNoV1bfV+5lUs5FPThjKf Hi/w== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=wHkAFeFGdVP0bN+3byL2TsVLZTpr3v8Y3XvQKnnn9Fo=; b=bYgFXmFHon1NA8LN/C4eoYl2jyDJ8oymV/nQLsLoJHcdAzfjgmVrhUWjo70hliC8nK dR376DGpdOxs5xX8UHzCKn3MJUWWJCwhrG3/Ws8DAsI0qoDn/shbkWzwKpf88PjMW5Lk U4PU2BA2YeJ3d35Zbl23uV8bcSlwBvx7kfNPG1B+Rqxhj1kpnY8LPe48Lahwl3hY/bQc 7anB3agQogh9XEDRmK9R8OSepW6HrE2gfaPY7JOFSvMH9zZ34B2APMl6931LDWIW+Dcb Uh4ZkYDx3od0F+oKsNiCPDJuWXyCmO7LRW/zyRX8k0uK7km0Kmdhnt5ciNzk+lYZjD7y bDYg== X-Gm-Message-State: AOAM531sjIyGGX3wiBtEuT95s+kCa+mx6B8PQUrvlYrTw0v2cSmOvZQl ZCRObeIt9tDpZlgquqei0CGPjCnq6U4= X-Received: by 2002:a65:458e:: with SMTP id o14mr16272005pgq.444.1608683210533; Tue, 22 Dec 2020 16:26:50 -0800 (PST) Received: from localhost.localdomain (c-73-164-224-32.hsd1.or.comcast.net. [73.164.224.32]) by smtp.gmail.com with ESMTPSA id 8sm5505566pfz.93.2020.12.22.16.26.49 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 22 Dec 2020 16:26:50 -0800 (PST) From: Tedd Ho-Jeong An X-Google-Original-From: Tedd Ho-Jeong An To: linux-bluetooth@vger.kernel.org Cc: danielwinkler@google.com, tedd.an@intel.com Subject: [PATCH 2/3] emulator/btdev: Add support LE_READ_TX_POWER command Date: Tue, 22 Dec 2020 16:26:32 -0800 Message-Id: <20201223002633.187612-2-tedd.an@intel.com> X-Mailer: git-send-email 2.25.1 In-Reply-To: <20201223002633.187612-1-tedd.an@intel.com> References: <20201223002633.187612-1-tedd.an@intel.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-bluetooth@vger.kernel.org This patch adds support for LE_READ_TX_POWER command. It uses a random values for min and max tx power since these values is read from the controller. --- emulator/btdev.c | 20 +++++++++++++++++++- 1 file changed, 19 insertions(+), 1 deletion(-) diff --git a/emulator/btdev.c b/emulator/btdev.c index ae382d9b9..17965f9b6 100644 --- a/emulator/btdev.c +++ b/emulator/btdev.c @@ -4170,6 +4170,22 @@ static int cmd_read_per_adv_list_size(struct btdev *dev, const void *data, return -ENOTSUP; } +static int cmd_read_tx_power(struct btdev *dev, const void *data, uint8_t len) +{ + struct bt_hci_rsp_le_read_tx_power rsp; + + memset(&rsp, 0, sizeof(rsp)); + + rsp.status = BT_HCI_ERR_SUCCESS; + /* a random default value */ + rsp.max_tx_power = 0x07; + rsp.min_tx_power = 0xDE; + + cmd_complete(dev, BT_HCI_CMD_LE_READ_TX_POWER, &rsp, sizeof(rsp)); + + return 0; +} + #define CMD_LE_50 \ CMD(BT_HCI_CMD_LE_SET_DEFAULT_PHY, cmd_set_default_phy, NULL), \ CMD(BT_HCI_CMD_LE_SET_ADV_SET_RAND_ADDR, cmd_set_adv_rand_addr, NULL), \ @@ -4205,7 +4221,8 @@ static int cmd_read_per_adv_list_size(struct btdev *dev, const void *data, NULL), \ CMD(BT_HCI_CMD_LE_CLEAR_PERIODIC_ADV_LIST, cmd_per_adv_clear, NULL), \ CMD(BT_HCI_CMD_LE_READ_PERIODIC_ADV_LIST_SIZE, \ - cmd_read_per_adv_list_size, NULL) + cmd_read_per_adv_list_size, NULL), \ + CMD(BT_HCI_CMD_LE_READ_TX_POWER, cmd_read_tx_power, NULL) static const struct btdev_cmd cmd_le_5_0[] = { CMD_COMMON_ALL, @@ -4240,6 +4257,7 @@ static void set_le_50_commands(struct btdev *btdev) btdev->commands[38] |= 0x10; /* LE Remove Periodic Adv List */ btdev->commands[38] |= 0x20; /* LE Clear Periodic Adv List */ btdev->commands[38] |= 0x40; /* LE Read Periodic Adv List Size */ + btdev->commands[38] |= 0x80; /* LE Read Transmit Power */ btdev->cmds = cmd_le_5_0; } -- 2.25.1