Received: by 2002:a05:6a10:6d10:0:0:0:0 with SMTP id gq16csp1587776pxb; Thu, 14 Apr 2022 09:15:22 -0700 (PDT) X-Google-Smtp-Source: ABdhPJykVQhySVVW9pFxEe0+cmreHR1FSI34aujODf0Vctmq47i5V1QTxylhxJBhZyY70eCufkCp X-Received: by 2002:a17:907:3e8f:b0:6e8:94ef:32e1 with SMTP id hs15-20020a1709073e8f00b006e894ef32e1mr3007586ejc.454.1649952917788; Thu, 14 Apr 2022 09:15:17 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1649952917; cv=none; d=google.com; s=arc-20160816; b=hKx+KuL1mIhDpf1v23I4EX+5uRB0y4jlwzfKIm0mlwYsJL8IcaquFNhZzOq4a8fp18 L6FSxJWr61XKT75HSe1rDE5PYgavGSDDsFhIJUjj04w2ZnggjzPdLDIcxaTOYpyEUYiM B7M+GRlB7BIhQTT+lVGpnA725cIZIvX1wDG5wT1TWFYPlT+Ptwdn7RB9M0m6V1aN9WTC IHr3Qex3Wd2Yv2ZApi16zYUNYCPcG5MQJxjoh+IHXf63XV+TQcSkATR0X46h2tK9VnrC w42SMcRH1yp7/kY/11tHBYIGpcY+Su1Lpcflcxs86jP0xZVjderf/lGOvF1xAOsPiZXn lnGQ== 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=WFWSbvyg+22b/MTXpAJu7hFpGo/4sj3aFOsTXUdx0xU=; b=NA/AKo8zsGdqSViKpsrsFNJarXmUe99TZcUWBc9yARRHjMvPtNLKsXa5pFO53Jc1/M 2jHqksV1y5jRwD61yV4P1JnQkM4a5Ajom9q6zVgYWQVLlyG/f0UlNk+hUqljKACstnkY aQ3vy7Wcse8I4B40EJdS6Z3UWGphiPN9rVhJn33i6CGi+LpXNlK3TZB6KxbXkWBsKeR5 km2nRE9HPD/ct/bK2Nj+AlhqPVPiuQ/t5ErGTR7y9hPYftT2ZhDrtavap4nzM7HOqcAz XYL1+mnQEuk1wCPk2bVEKhydwQt98vRzzL3jCOycEPOH+YkGV/9+3lwmJ21TqZRe5eIf 3Riw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20210112 header.b=ZLXMAdvZ; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id cf21-20020a170906b2d500b006e6ed377f42si2105092ejb.754.2022.04.14.09.14.45; Thu, 14 Apr 2022 09:15:17 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@gmail.com header.s=20210112 header.b=ZLXMAdvZ; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-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 S241004AbiDNIli (ORCPT + 99 others); Thu, 14 Apr 2022 04:41:38 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:45322 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S240982AbiDNIle (ORCPT ); Thu, 14 Apr 2022 04:41:34 -0400 Received: from mail-ej1-x633.google.com (mail-ej1-x633.google.com [IPv6:2a00:1450:4864:20::633]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 52ECB64BDB for ; Thu, 14 Apr 2022 01:39:10 -0700 (PDT) Received: by mail-ej1-x633.google.com with SMTP id s18so8762388ejr.0 for ; Thu, 14 Apr 2022 01:39:10 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20210112; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=WFWSbvyg+22b/MTXpAJu7hFpGo/4sj3aFOsTXUdx0xU=; b=ZLXMAdvZA5nPgsMZXpuI68jXLnxG3WeCvhyC2GDAFZqh8PUfxRByOo0E+6+BwchGz3 HTTKg17xUiBhRy2Iholc/Q5lS9y50YhJNeLFwNlbThEUvFcPwdV4kUuBI0CmHDUK0Bj8 +mkh8MPxDBGs3giiND6xjptxk3Zq8m+fRt4texdNoDHTGorpNztfSl62is27kC9QwWyz +AuaNtBJ6fJhIjmTeTuC9QW+NQkq9c86lD7N9eSiUglPxC/AO9YFlPSg2E617BkWrwz8 p4x9OYw7oO3d79QD0yQsM8QmwPEuWS9kyHk4EJQLPevorLOAIyAs7I/ikEbo0X0FdI1V TQ9w== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=WFWSbvyg+22b/MTXpAJu7hFpGo/4sj3aFOsTXUdx0xU=; b=EudGxRlub161WhKmCTcp+3zgFIStC+G8Mvt/0oT4jOF9+Eaemqb1iX3wywgUjbCf35 64FafMRFBm2TzvJeSraYZyC6/1gzj8OJipPuvtR6ZtjkrW00Um5tiEWX8QLZ7lXlzYyJ jywFKRLowSfHsk/u9hrwn7Q9Gk5jh2JZV/TYw6eqGZRbEdXGx7N9V38qqtavDV3jZzSk GWA9IeYGpi9yDSJcGKGm1mmu7L1i97yXWwBVFckQhVkt3AR+z5yRfxOm+T3OTot2m49N 42ZKsajrksgdhMeX4Yaxk3N7QqTnfV5ioXlQgKjERJL1kXZgJ/Jh6t31kICWoRt6nwzQ JIYw== X-Gm-Message-State: AOAM533N4vd7JP76V61lGqb15bW0aP/4Oi2lQzYOS+J6c2h2+1lnDoIh qceBoTqj0goHAWnQlL9jih0= X-Received: by 2002:a17:907:d16:b0:6d6:e3b6:9cd8 with SMTP id gn22-20020a1709070d1600b006d6e3b69cd8mr1380050ejc.94.1649925548940; Thu, 14 Apr 2022 01:39:08 -0700 (PDT) Received: from localhost.localdomain (ip5f5abb6b.dynamic.kabel-deutschland.de. [95.90.187.107]) by smtp.gmail.com with ESMTPSA id ah13-20020a1709069acd00b006e8a0b3e071sm418138ejc.110.2022.04.14.01.39.08 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 14 Apr 2022 01:39:08 -0700 (PDT) From: Michael Straube To: gregkh@linuxfoundation.org Cc: Larry.Finger@lwfinger.net, phil@philpotter.co.uk, linux-staging@lists.linux.dev, linux-kernel@vger.kernel.org, Michael Straube Subject: [PATCH 1/7] staging: r8188eu: fix struct rt_firmware_hdr Date: Thu, 14 Apr 2022 10:38:47 +0200 Message-Id: <20220414083853.3422-2-straube.linux@gmail.com> X-Mailer: git-send-email 2.35.1 In-Reply-To: <20220414083853.3422-1-straube.linux@gmail.com> References: <20220414083853.3422-1-straube.linux@gmail.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-2.1 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,FREEMAIL_FROM, RCVD_IN_DNSWL_NONE,SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org The structure rt_firmware_hdr is wrong, there are two issues. The first issue is that the size of struct rt_firmware_hdr is 33 bytes but the header in the firmware file is 32 bytes long. The hexdump of rtl8188eufw.bin shows that the field Rsvd1 of struct rt_firmware_hdr should be u8 instead of __le16. OFFSET rtl8188eufw.bin ----------------------------------------------------------- 0x00000000 E1 88 10 00 0B 00 01 00 01 21 11 27 30 36 00 00 0x00000010 2D 07 00 00 00 00 00 00 00 00 00 00 00 00 00 00 0x00000020 02 45 4E 00 00 00 00 00 00 00 00 00 00 00 00 00 0x00000000 E1 88 10 00 0B 00 01 00 01 21 11 27 30 36 00 00 ^ ^ ^ ^ ^ ^ Subversion Rsvd1 Month Date Hour Minute This was figured out by looking at struct rtlwifi_firmware_header in drivers/net/wireless/rtlwifi/wifi.h and the firmware file that the rtlwifi/rtl8188ee driver uses. The second issue is that the u16 and u32 fields sould be __le16 and __le32. Change the field Rsvd1 to u8 and the u16, u32 fileds to __le16, __le32. Both issues had no effect because the header size is actually hardcoded to 32 where it is used in the code. Also the fields after Subversion are not used and the bytes of the u16 and u32 fields are all zero. Fixes: 7884fc0a1473 ("staging: r8188eu: introduce new include dir for RTL8188eu driver") Signed-off-by: Michael Straube --- drivers/staging/r8188eu/core/rtw_fw.c | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/drivers/staging/r8188eu/core/rtw_fw.c b/drivers/staging/r8188eu/core/rtw_fw.c index 8620f3c92b52..7cd08268f3b9 100644 --- a/drivers/staging/r8188eu/core/rtw_fw.c +++ b/drivers/staging/r8188eu/core/rtw_fw.c @@ -29,7 +29,7 @@ struct rt_firmware_hdr { * FW for different conditions */ __le16 Version; /* FW Version */ u8 Subversion; /* FW Subversion, default 0x00 */ - u16 Rsvd1; + u8 Rsvd1; /* LONG WORD 1 ---- */ u8 Month; /* Release time Month field */ @@ -42,11 +42,11 @@ struct rt_firmware_hdr { /* LONG WORD 2 ---- */ __le32 SvnIdx; /* The SVN entry index */ - u32 Rsvd3; + __le32 Rsvd3; /* LONG WORD 3 ---- */ - u32 Rsvd4; - u32 Rsvd5; + __le32 Rsvd4; + __le32 Rsvd5; }; static void fw_download_enable(struct adapter *padapter, bool enable) -- 2.35.1