Received: by 2002:a05:6a10:8c0a:0:0:0:0 with SMTP id go10csp498493pxb; Wed, 27 Jan 2021 13:04:45 -0800 (PST) X-Google-Smtp-Source: ABdhPJzLKGaNyz9UZBb6vRKP+uU9B69BWssHycv6A+ozKvbDSyjwEw+mqm1N8eYw1xHbXfKR7uH1 X-Received: by 2002:a05:6402:1549:: with SMTP id p9mr10997505edx.387.1611781484993; Wed, 27 Jan 2021 13:04:44 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1611781484; cv=none; d=google.com; s=arc-20160816; b=dtue2McEnd8fsvWJFL1c+FaX1bjAtPJquYO+YbqmLPa/bX5iZyLsLxhn8WBpSHNtVL PIEucx/ijAH035xF8HE5m4G3VWI/cRQDuOlbMxh2R6E9mnCwtYu9mXb2pQ9AMh1YSjAY yfSlKjyxC9jYODBDeD3xdbbIPFsp7J8lo5kDeAbKJr4ifU3eosRFuvDaWuOqG1pyVc6N s1Jr73nGA3jtBZp3F6njyi0uIQQIIB/5SaaiZDf00G4a2IKgWxcXhK00w1U2YQT0hZ2p OaRIgRnyUthl4qc6j8Etv6MCkYcBmfhMjV5qkHbLMBOeWC/QavhxYEStpb0nIE9kxZKZ sxlg== 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 :user-agent:organization:date:to:from:subject:message-id :ironport-sdr:ironport-sdr; bh=n5cNQ5q9ZfEraxayEkgt8jTTCskL46qF0q/+mjUeoJk=; b=lwiFjWTqqQ9ONhPFkRFKp/7GU+Mvz5AuHmEnSIn9/gF5HiJ6jx4d95jK4dXgNk/VCu R3qJGh28mw2Ue85QN4liksgbeJZdPv4pd1fznapGMuoNek0lvOG9ZHMmzVgINkxoLWBl qslB/rRCaVHFzZw+lL1Prl4WjI90ghM6xz1rZsNssrzRnMT28ygdvIVlS5Nl44U54ou1 B335X031O8vjka3usV5ApCzGXntIZqRDQ196K1AuEZVhOIk2x1sXZNjMOiA3MagLhoDJ I/tBeAORTHWi9lTWTzqz2TlxERZumGQngJ+2sI5WNGgrzQ6r/RxEBH4ZlNU8RuLgN0QJ 98tQ== 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 m19si1555517edv.64.2021.01.27.13.04.18; Wed, 27 Jan 2021 13:04:44 -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; 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 S238674AbhA0E1p (ORCPT + 99 others); Tue, 26 Jan 2021 23:27:45 -0500 Received: from mga03.intel.com ([134.134.136.65]:38304 "EHLO mga03.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2389679AbhA0AG6 (ORCPT ); Tue, 26 Jan 2021 19:06:58 -0500 IronPort-SDR: h5VRoszl5it1STPadwl/mzibzwq/wSMpyWTYbd+buHi/16q7Mush9qJwZENFRGjarV6CdlGP7F WFUzYFZSGkOg== X-IronPort-AV: E=McAfee;i="6000,8403,9876"; a="180071626" X-IronPort-AV: E=Sophos;i="5.79,377,1602572400"; d="scan'208";a="180071626" Received: from orsmga007.jf.intel.com ([10.7.209.58]) by orsmga103.jf.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 26 Jan 2021 16:01:06 -0800 IronPort-SDR: lZa2XQaHGIz1xsSUSc/BOzpUbXar3WQzIBk43IZl0lNttFTW6ciQUtMiwocsc1jAKC4Y0VXBmS rVSipsfNIj2Q== X-IronPort-AV: E=Sophos;i="5.79,377,1602572400"; d="scan'208";a="393897678" Received: from rkfoote-mobl1.amr.corp.intel.com ([10.251.7.251]) by orsmga007-auth.jf.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 26 Jan 2021 16:01:05 -0800 Message-ID: Subject: [PATCH BlueZ] tools/bluemoon: Display FW version of firmware file From: Tedd Ho-Jeong An To: linux-bluetooth@vger.kernel.org Date: Tue, 26 Jan 2021 19:01:05 -0500 Organization: Intel Corporation Content-Type: text/plain; charset="UTF-8" User-Agent: Evolution 3.36.5 (3.36.5-1.fc32) MIME-Version: 1.0 Content-Transfer-Encoding: 7bit Precedence: bulk List-ID: X-Mailing-List: linux-bluetooth@vger.kernel.org From: Tedd Ho-Jeong An This patch displays a FW version after parsing the WRITE_BOOT_PARAMS command in the firmeare file. It also change the display type for Module vendor and Date in the CSS header to hex for easy read. --- tools/bluemoon.c | 24 +++++++++++++++++++++--- 1 file changed, 21 insertions(+), 3 deletions(-) diff --git a/tools/bluemoon.c b/tools/bluemoon.c index 8b62b1e7b..912f4f2a9 100644 --- a/tools/bluemoon.c +++ b/tools/bluemoon.c @@ -805,8 +805,10 @@ static void analyze_firmware(const char *path) le32_to_cpu(css->header_version) >> 16, le32_to_cpu(css->header_version) & 0xffff); printf("Module ID:\t%u\n", le32_to_cpu(css->module_id)); - printf("Module vendor:\t%u\n", le32_to_cpu(css->module_vendor)); - printf("Date:\t\t%u\n", le32_to_cpu(css->date)); + printf("Module vendor:\t0x%x\n", le32_to_cpu(css->module_vendor)); + printf("Date:\t\t%04x-%02x-%02x\n", le32_to_cpu(css->date) >> 16, + le32_to_cpu(css->date) >> 8 & 0xff, + le32_to_cpu(css->date) & 0xff); printf("Size:\t\t%u DWORDs / %u bytes\n", le32_to_cpu(css->size), le32_to_cpu(css->size) * 4); printf("Key size:\t%u DWORDs / %u bytes\n", @@ -840,13 +842,29 @@ static void analyze_firmware(const char *path) while (firmware_offset < firmware_size) { uint16_t opcode; uint8_t dlen; + struct cmd_write_boot_params *params; opcode = get_le16(firmware_data + firmware_offset); dlen = firmware_data[firmware_offset + 2]; switch (opcode) { - case CMD_NO_OPERATION: case CMD_WRITE_BOOT_PARAMS: + params = (void *)&firmware_data[firmware_offset + 3]; + printf("Boot Parameters\n"); + printf("Boot Address:\t0x%08x\n", + le32_to_cpu(params->boot_addr)); + printf("FW Version(yy):\t%d (0x%02X)\n", + params->fw_build_yy + 2000, + params->fw_build_yy); + printf("FW Version(cw):\t%d (0x%02X)\n", + params->fw_build_cw, + params->fw_build_cw); + printf("FW Version(nn):\t%d (0x%02X)\n", + params->fw_build_nn, + params->fw_build_nn); + + printf("\n"); + case CMD_NO_OPERATION: case CMD_MEMORY_WRITE: break; default: -- 2.26.2