Received: by 2002:a05:6902:102b:0:0:0:0 with SMTP id x11csp2094212ybt; Fri, 3 Jul 2020 00:12:04 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwZMOPyzmxSZ/D6ZRbVLADTf/jRPh2w+QKpoza544oPvCMYI6nkIFyLcxkJniYcB8270fUE X-Received: by 2002:aa7:c2c5:: with SMTP id m5mr39097155edp.214.1593760324031; Fri, 03 Jul 2020 00:12:04 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1593760324; cv=none; d=google.com; s=arc-20160816; b=YxP6MBHiWpNaNeDbuBsWRk3yiIgIScXY06iBmmQ4m+2cIP1wNfgEj7TIW7ArcRk0J8 WEbR7tmXalQP0ZByx6C4tsMffYFFeibB5KgZem6MPJeUc6Liwn5qaolrk++xpkLkBweF zxB6dUpRxmoLOIXrMO6Gbsq5JgOF5sr58/sDAsfG2gg2i8lgjf+q5W0GEBlLpwELTzJN w1wAP81PPOcf8H6kUynqpoQ8i52TSE7+AvYOxBTgoc4O90iwIFUF/YmPmRHaXRm5Ctai QT6XBCm48aVIiK87eDKELv5k3C9HzxDT3kPmpbA0nnmIhS05NlnY5bTyfupGAaoS9M4v lsZA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from:ironport-sdr:ironport-sdr; bh=jFPW8/pKKYjd96h/8Rqt5WmaLw1HUPzocDlYYi6a0nQ=; b=btTbE1Ch4uqnhocV2g9OsB2m0XH++gEZ3qdCK1/op9JDALRosLnoGGLADMdVid0Hqj PjN6XkPtqqmQQT5LpXMZzlpOpVYTs9TUFVcpL1eXnZ5lpcDqjgaRbdrfjo5kh+5kQKe+ p+0qgBzBRUkvj9zHM1quXqx3vG5NYfcpswutv/57lf21kRmPw83WCZxPU7ksLITkieeu I/A1GVgk3RYFVz742qyGZ67XsAimtZ/p9wQWdV9IgV4/yt6/vdXgm//xFtwLR0nFbvbK HVja84CryHjISj4tG8vuiVsyxIDunQq/idLaY6Hcvb6pIbP9IGrv+hmeuKfTXc6KqRci 0LcA== ARC-Authentication-Results: i=1; mx.google.com; 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=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id o10si6904534ejn.140.2020.07.03.00.11.25; Fri, 03 Jul 2020 00:12:04 -0700 (PDT) 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; 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=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726035AbgGCHLQ (ORCPT + 99 others); Fri, 3 Jul 2020 03:11:16 -0400 Received: from mga07.intel.com ([134.134.136.100]:29061 "EHLO mga07.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725764AbgGCHLQ (ORCPT ); Fri, 3 Jul 2020 03:11:16 -0400 IronPort-SDR: dEFShv6a8V6nWz28gMGq0c08zL7o3XlWBeH0OryM2wf1YBmWrcC+muih9o1zzdpCYmI8uPbXoJ fOBsIQow4eyQ== X-IronPort-AV: E=McAfee;i="6000,8403,9670"; a="212125516" X-IronPort-AV: E=Sophos;i="5.75,307,1589266800"; d="scan'208";a="212125516" X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from orsmga004.jf.intel.com ([10.7.209.38]) by orsmga105.jf.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 03 Jul 2020 00:11:16 -0700 IronPort-SDR: NCoqYr1U0RYdT5zbdhvtWwb/iBVtqUIIdgsKprhhUdewFMap6kzrT7CFG0xstBiTla0ZXJ85Cz BicUhRIJ1efQ== X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.75,307,1589266800"; d="scan'208";a="426212120" Received: from unknown (HELO intel-Lenovo-Legion-Y540-15IRH-PG0.iind.intel.com) ([10.224.186.95]) by orsmga004.jf.intel.com with ESMTP; 03 Jul 2020 00:11:14 -0700 From: Kiran K To: linux-bluetooth@vger.kernel.org Cc: ravishankar.srivatsa@intel.com, chethan.tumkur.narayan@intel.com, kiraank@gmail.com, Kiran K , Amit K Bag , Raghuram Hegde Subject: [PATCH v2 3/5] Bluetooth: btintel: Refactor firmware payload download code Date: Fri, 3 Jul 2020 12:42:10 +0530 Message-Id: <20200703071212.17046-3-kiran.k@intel.com> X-Mailer: git-send-email 2.17.1 In-Reply-To: <20200703071212.17046-1-kiran.k@intel.com> References: <20200703071212.17046-1-kiran.k@intel.com> Sender: linux-bluetooth-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-bluetooth@vger.kernel.org Move firmware payload download code to a separate function to enhance readability and reusability Signed-off-by: Kiran K Signed-off-by: Amit K Bag Signed-off-by: Raghuram Hegde Reviewed-by: Chethan T N Reviewed-by: Sathish Narasimman Reviewed-by: Srivatsa Ravishankar --- Changes in v2: - Avoid exporting new public function for firmware download - Move firmware payload download code to a new function Changes in v1: - Move firmware payload download code to a new function drivers/bluetooth/btintel.c | 22 +++++++++++++++++++--- 1 file changed, 19 insertions(+), 3 deletions(-) diff --git a/drivers/bluetooth/btintel.c b/drivers/bluetooth/btintel.c index ffc888c4e9e3..2cb55a97598c 100644 --- a/drivers/bluetooth/btintel.c +++ b/drivers/bluetooth/btintel.c @@ -19,6 +19,7 @@ #define VERSION "0.1" #define BDADDR_INTEL (&(bdaddr_t) {{0x00, 0x8b, 0x9e, 0x19, 0x03, 0x00}}) +#define RSA_HEADER_LEN 644 int btintel_check_bdaddr(struct hci_dev *hdev) { @@ -682,8 +683,9 @@ static int btintel_sfi_rsa_header_secure_send(struct hci_dev *hdev, return err; } -int btintel_download_firmware(struct hci_dev *hdev, const struct firmware *fw, - u32 *boot_param) +static int btintel_download_firmware_payload(struct hci_dev *hdev, + const struct firmware *fw, + u32 *boot_param, size_t offset) { int err; const u8 *fw_ptr; @@ -693,8 +695,9 @@ int btintel_download_firmware(struct hci_dev *hdev, const struct firmware *fw, if (err) goto done; - fw_ptr = fw->data + 644; + fw_ptr = fw->data + offset; frag_len = 0; + err = -EINVAL; while (fw_ptr - fw->data < fw->size) { struct hci_command_hdr *cmd = (void *)(fw_ptr + frag_len); @@ -740,6 +743,19 @@ int btintel_download_firmware(struct hci_dev *hdev, const struct firmware *fw, done: return err; } + +int btintel_download_firmware(struct hci_dev *hdev, + const struct firmware *fw, + u32 *boot_param) +{ + int err; + + err = btintel_sfi_rsa_header_secure_send(hdev, fw); + if (err) + return err; + + return btintel_download_firmware_payload(hdev, fw, boot_param, RSA_HEADER_LEN); +} EXPORT_SYMBOL_GPL(btintel_download_firmware); void btintel_reset_to_bootloader(struct hci_dev *hdev) -- 2.17.1