Received: by 2002:a05:6a10:9848:0:0:0:0 with SMTP id x8csp121783pxf; Wed, 24 Mar 2021 00:24:12 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxtoUO7WrjPa9R2CwpTXEI7sUzECUd5htqdq8LEjlKrHVs8+npzoz5be+G5n9hlnCL4dph1 X-Received: by 2002:a05:6402:6ca:: with SMTP id n10mr1936271edy.312.1616570652608; Wed, 24 Mar 2021 00:24:12 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1616570652; cv=none; d=google.com; s=arc-20160816; b=n2h9bVCzLNbusUUd/jLdVOsm1GHw5+s4CVrgg8jlLU2vCwIXBM6hNojXTAuOnZ2/VX 6irC7s1LDRHDHCByCTuYKvA+p2HSrw8jr4i0kNVgk0zi9lQ2NGwVlNtVvdmwYBC6Hb+M 1VE6HPoTqIv96DqRzGG+mAOeZz08OeQ8tLN4NX4QalBXHVvjGxRbzxPKs7S/HllRL/vS 38VYZeMS6ecny4l9TaDPvSl1ScVx4ADeMwUWCOmpP+S2QTvFczUbEZ/d+Eu2TcEl5uDh E0+3oA49A5jZx61LhwyP7IwruEsWf0MnETNr0LZGWWCrCSWvjivGbPEYyp/Izd7/SBzW 620g== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:cc:to:from:subject:mime-version:message-id:date :dkim-signature; bh=56VTN0FUBRnVBARbqzGdkyXYNoI8u6ilkqebe9VyH9c=; b=mOMNW+b1Sc25Bko3qHOT3NH7xCK2Q7mUhop9e7ivarT1bK7fx0qDhcrz+5/SwrdJ+6 sUQoluYyDCYYS5Iqq0DyBbkbc5DuNjB/diOBG3cCeY8gZVeXPDX9kLwt1kxTg2x8Qe7f CUv7gpKXKed0HL1WL0v47gOXEy/We4OOA9CTDGsUA7O4/i2b5X6HUl/Gq57uEeD+ES0W hopm9SATDiPl77E5zetqoRKyfizzJ07hlJQWjKIKzUWPH4CKjXsuxPIizbpTub2ihOga KnfwMnchv+rs6Fv+VbdSpUoog0vMUj1RK3sv2PEIBf6IyDZyBHUp/6c0j73cHGBUyBru WFFg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@google.com header.s=20161025 header.b=GUS+CWBc; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=REJECT sp=REJECT dis=NONE) header.from=google.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id ga5si1197185ejb.592.2021.03.24.00.23.50; Wed, 24 Mar 2021 00:24:12 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-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=@google.com header.s=20161025 header.b=GUS+CWBc; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=REJECT sp=REJECT dis=NONE) header.from=google.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S230084AbhCWTge (ORCPT + 99 others); Tue, 23 Mar 2021 15:36:34 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:59450 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230138AbhCWTg0 (ORCPT ); Tue, 23 Mar 2021 15:36:26 -0400 Received: from mail-qv1-xf4a.google.com (mail-qv1-xf4a.google.com [IPv6:2607:f8b0:4864:20::f4a]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 79731C061764 for ; Tue, 23 Mar 2021 12:36:25 -0700 (PDT) Received: by mail-qv1-xf4a.google.com with SMTP id k4so2304673qvf.8 for ; Tue, 23 Mar 2021 12:36:25 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=20161025; h=date:message-id:mime-version:subject:from:to:cc; bh=56VTN0FUBRnVBARbqzGdkyXYNoI8u6ilkqebe9VyH9c=; b=GUS+CWBcIQkh8I8fr5OKzOYFk+tloF8Q/GWf18p53CrTIht/js1LArNJNrcQ8JkxA2 F+Fp58EZl/Ce+EnQwG3oOgP1Wz6JuJyY/qt3LEQFqR2aBelPMOimhS4d6QVSmTM75gyw +DSaAdwFwC8ec4GdBytwn1uygKvHoienPD4LcEnCF6AJ9YqeLQgWncKkLBuEbATBBfDq nXIu73guCAynLC74XYx5iVB6y5nDoU6GIEaQqU9Gvw253sFgMdFnMeg+Jk9XD5srh1Gm qV9si7k0wDds3Z/qnypWd2FFbj1rNb0ok+kK/JWkW0zgm0c207YF8MRhCbTViJJ3nLaP MRgQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:date:message-id:mime-version:subject:from:to:cc; bh=56VTN0FUBRnVBARbqzGdkyXYNoI8u6ilkqebe9VyH9c=; b=lhTUZr4LM4mTZksvVYc8EfJo6cnka3RaSDQzPad/8W0aQNbIAADaCFj7tktew+D5zt eY+lg9ZNm6hXCVR0jalFderiv0YpAJkQ5RzXsugWPz/JLPvDCltYsYKx3S9m2NvwzMY7 Zc40C2TMgzrNQGo5zqHMgnrZlj1un+HMVx5R0ibjQtWWS1ipA968d3IuLgWCrZG4ulDp VdmGhs9H7CnQDp5YXZXIx4MISCUP4sEr1hpEi7j3MXHw2G5GVUZq/WTpBFAzzmCJDsDa nBQn1sEoQsQYpXzoHX/JsIVFtNUySaJ4zAeX0bYpat68Vo1C9mW5abRebmtckmdzZZgG TuHg== X-Gm-Message-State: AOAM533vFBuFcE8EChFs++3Lsqhdq/V6G7i1mONZ7YHfeKLkg4ib5MKb GjWQAdiFGxUxUgyQWMNwdXkZ35V0GujU X-Received: from coin.lon.corp.google.com ([2a00:79e0:d:204:cd66:be0a:5c1f:e5d4]) (user=pterjan job=sendgmr) by 2002:a0c:f505:: with SMTP id j5mr6352108qvm.61.1616528184501; Tue, 23 Mar 2021 12:36:24 -0700 (PDT) Date: Tue, 23 Mar 2021 19:36:17 +0000 Message-Id: <20210323193617.3748164-1-pterjan@google.com> Mime-Version: 1.0 X-Mailer: git-send-email 2.31.0.291.g576ba9dcdaf-goog Subject: [PATCH] rtl8xxxu: Fix device info for RTL8192EU devices From: Pascal Terjan To: Jes Sorensen , linux-wireless@vger.kernel.org, linux-kernel@vger.kernel.org Cc: Pascal Terjan Content-Type: text/plain; charset="UTF-8" Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Based on 2001:3319 and 2357:0109 which I used to test the fix and 0bda:818b and 2357:0108 for which I found efuse dumps online. == 2357:0109 == === Before === Vendor: Realtek Product: \x03802.11n NI Serial: === After === Vendor: Realtek Product: 802.11n NIC Serial not available. == 2001:3319 == === Before === Vendor: Realtek Product: Wireless N Serial: no USB Adap === After === Vendor: Realtek Product: Wireless N Nano USB Adapter Serial not available. Signed-off-by: Pascal Terjan --- .../net/wireless/realtek/rtl8xxxu/rtl8xxxu.h | 11 ++-- .../realtek/rtl8xxxu/rtl8xxxu_8192e.c | 53 ++++++++++++++++--- 2 files changed, 50 insertions(+), 14 deletions(-) diff --git a/drivers/net/wireless/realtek/rtl8xxxu/rtl8xxxu.h b/drivers/net/wireless/realtek/rtl8xxxu/rtl8xxxu.h index d6d1be4169e5..acb6b0cd3667 100644 --- a/drivers/net/wireless/realtek/rtl8xxxu/rtl8xxxu.h +++ b/drivers/net/wireless/realtek/rtl8xxxu/rtl8xxxu.h @@ -853,15 +853,10 @@ struct rtl8192eu_efuse { u8 usb_optional_function; u8 res9[2]; u8 mac_addr[ETH_ALEN]; /* 0xd7 */ - u8 res10[2]; - u8 vendor_name[7]; - u8 res11[2]; - u8 device_name[0x0b]; /* 0xe8 */ - u8 res12[2]; - u8 serial[0x0b]; /* 0xf5 */ - u8 res13[0x30]; + u8 device_info[80]; + u8 res11[3]; u8 unknown[0x0d]; /* 0x130 */ - u8 res14[0xc3]; + u8 res12[0xc3]; }; struct rtl8xxxu_reg8val { diff --git a/drivers/net/wireless/realtek/rtl8xxxu/rtl8xxxu_8192e.c b/drivers/net/wireless/realtek/rtl8xxxu/rtl8xxxu_8192e.c index cfe2dfdae928..9c5fad49ed2a 100644 --- a/drivers/net/wireless/realtek/rtl8xxxu/rtl8xxxu_8192e.c +++ b/drivers/net/wireless/realtek/rtl8xxxu/rtl8xxxu_8192e.c @@ -554,9 +554,39 @@ rtl8192e_set_tx_power(struct rtl8xxxu_priv *priv, int channel, bool ht40) } } +static void rtl8192eu_log_device_info(struct rtl8xxxu_priv *priv, + char *record_name, + char **record) +{ + /* A record is [ total length | 0x03 | value ] */ + unsigned char l = (*record)[0]; + + /* The whole section seems to be 80 characters so a record should not + * be able to be that large. + */ + if (l > 80) { + dev_warn(&priv->udev->dev, + "invalid record length %d while parsing \"%s\".\n", + l, record_name); + return; + } + + if (l >= 2) { + char value[80]; + + memcpy(value, &(*record)[2], l - 2); + value[l - 2] = '\0'; + dev_info(&priv->udev->dev, "%s: %s\n", record_name, value); + *record = *record + l; + } else { + dev_info(&priv->udev->dev, "%s not available.\n", record_name); + } +} + static int rtl8192eu_parse_efuse(struct rtl8xxxu_priv *priv) { struct rtl8192eu_efuse *efuse = &priv->efuse_wifi.efuse8192eu; + char *record = efuse->device_info; int i; if (efuse->rtl_id != cpu_to_le16(0x8129)) @@ -604,12 +634,23 @@ static int rtl8192eu_parse_efuse(struct rtl8xxxu_priv *priv) priv->has_xtalk = 1; priv->xtalk = priv->efuse_wifi.efuse8192eu.xtal_k & 0x3f; - dev_info(&priv->udev->dev, "Vendor: %.7s\n", efuse->vendor_name); - dev_info(&priv->udev->dev, "Product: %.11s\n", efuse->device_name); - if (memchr_inv(efuse->serial, 0xff, 11)) - dev_info(&priv->udev->dev, "Serial: %.11s\n", efuse->serial); - else - dev_info(&priv->udev->dev, "Serial not available.\n"); + /* device_info section seems to be laid out as records + * [ total length | 0x03 | value ] so: + * - vendor length + 2 + * - 0x03 + * - vendor string (not null terminated) + * - product length + 2 + * - 0x03 + * - product string (not null terminated) + * Then there is one or 2 0x00 on all the 4 devices I own or found + * dumped online. + * As previous version of the code handled an optional serial + * string, I now assume there may be a third record if the + * length is not 0. + */ + rtl8192eu_log_device_info(priv, "Vendor", &record); + rtl8192eu_log_device_info(priv, "Product", &record); + rtl8192eu_log_device_info(priv, "Serial", &record); if (rtl8xxxu_debug & RTL8XXXU_DEBUG_EFUSE) { unsigned char *raw = priv->efuse_wifi.raw; -- 2.30.2