Received: by 10.213.65.68 with SMTP id h4csp1499438imn; Mon, 26 Mar 2018 08:41:55 -0700 (PDT) X-Google-Smtp-Source: AG47ELuoA6rmvtoj3ir2gqcLcN3t530d7i1Nlc+iQAaJhnTDY9gRfKvLB7USbIeBq9yHn2YNRsFk X-Received: by 10.101.77.67 with SMTP id j3mr29403513pgt.210.1522078915008; Mon, 26 Mar 2018 08:41:55 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1522078914; cv=none; d=google.com; s=arc-20160816; b=Z8nnVs2w7yM5tD9Z2MeHJbaPN0CIviIZGnRF5vcV/h/h4f2AFELnSgg6oWFrlQe9TR tOhHpp5aJv7Kq3biVhi+eksleYRdmbhI4xfJcSdj8mzmUjvN9VNEYIQKEraH9R28ppUg DaZxPD3Dw4TG2WPFWJHnh0Hxe/OiR4ijiVeBRT4DqTFmZzBDZcHT35SQUVV4a2zmjlYU k7s2kBX7kKes+y6q3JTt25xEpUznXFPRgc310dedM71YZLlANNbLEL9An0DXlQjIEXjA k0fiwuCJlZKjuk8+sxwzrUpUSiKnt1yqauFWl1vlQU8sul+AodWkxQSuSMLm77MlYjrg KU5Q== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding :content-language:mime-version:user-agent:date:message-id:to:subject :from:dkim-signature:arc-authentication-results; bh=4R3mh8N8JndAvB5GILOG5ZeMGPiVGnAAULNA16g5ryk=; b=fJu4CtinnMAkdehjlPSKFhSKJbgrKpx3XXoPpKmov1yAOAsqSYlhVwvIC/RKm52dTP vwol6GwsGgpaaOFrUo737x6kuydflDjRNHsaVfKZx5RcFunH9GU120SFMI/8Sb6jIp5Z s0okHu25lpfkYqqZm+V4fLaYQUosTwVYuc8CoyUih6N45iabuhIW/IweLD9W+sxGe3XM Mw+UNZD7eN/UcqfFFLI9yQD5bVEL1WhK3xwCzHfXcA9/jAwhkz8KZDnfwq5ZWcqZu/q7 fi/gAgNAma1qee4AElibQBdY0FayToNYZX2re50FEWWeXlbP7GLMwQ5w0QKh6ovdvgbP xxYA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=FOvNiKud; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 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 vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id w16-v6si8600023plp.165.2018.03.26.08.41.39; Mon, 26 Mar 2018 08:41:54 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=FOvNiKud; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 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 S1752458AbeCZPkD (ORCPT + 99 others); Mon, 26 Mar 2018 11:40:03 -0400 Received: from mail-oi0-f67.google.com ([209.85.218.67]:35285 "EHLO mail-oi0-f67.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751868AbeCZPkB (ORCPT ); Mon, 26 Mar 2018 11:40:01 -0400 Received: by mail-oi0-f67.google.com with SMTP id x20-v6so16189708oie.2 for ; Mon, 26 Mar 2018 08:40:01 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=from:subject:to:message-id:date:user-agent:mime-version :content-language:content-transfer-encoding; bh=4R3mh8N8JndAvB5GILOG5ZeMGPiVGnAAULNA16g5ryk=; b=FOvNiKudFOOJPYr7knk3c9NDwN8MfFRUdl38x67v8FqFSHc7NSCn73mhdazNKFW5gn wLyF6yV/Zmn2yW2smQOgz+xZQRff2it/YWbxhfU1Mttu+YJhj6FrQO85RkB1eO5O50EO 8eaqKQzZceQ8g9RyAJit53H3ciaU9z18bhEPbVK1EHhnSYOgmjmRNI8MsF20tLWypyTo 6Us0q5OpiTgdST4WuR3BnC1Z+Z0TIh3QDtH+0A3bLlDbLlueQZRe+K25HXHNDMUMiUtF 4k7LWA1ILIusSoVEzZ/cTItU0yxCO+ivDynF3lsbgAphWtEp744li4YvX5y8cI8XcSc9 oEyg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:subject:to:message-id:date:user-agent :mime-version:content-language:content-transfer-encoding; bh=4R3mh8N8JndAvB5GILOG5ZeMGPiVGnAAULNA16g5ryk=; b=qChZ/WdUDBnT+mmmBnEZQxADJuahKvZJsbuIfK7ZtjEnzkpSvjzDH0M3aLDLx2E6xP z23vzhru8yfcIZEiqenzW0Gt4pvAqPCYCF19y1TKKCNwDQJn1KH+CietZWXEidbXKb0H RsL+6RaMJWsIJo+1OUtwD5lXbM/7fkOnipKNNrztZcG3RyaM5YwQBV8Du97H7I6qyvAb DsDS1OZPvh5vFETwbf0lImw4lZx0gmaPUWUL3EdLC/xWB9BfMmKRE78ADbxH2uGuHX8G 6JXwfj26tjXd7Aw96KnE6p0UnjDx6nffzKWdqzHEOrBsBUD7ldKQEcImcVuZKpRS1mTH +uBA== X-Gm-Message-State: AElRT7H7hiqg8EMWazNpVJp53MTwMhBSPr7cqwU2b9P8H3iQqBhOHN7P +8N1c75u/TjN4EU7Zb0fMxy4so3Q X-Received: by 10.202.205.66 with SMTP id d63mr5907505oig.213.1522078800402; Mon, 26 Mar 2018 08:40:00 -0700 (PDT) Received: from [192.168.0.2] (cpe-24-27-59-32.austin.res.rr.com. [24.27.59.32]) by smtp.gmail.com with ESMTPSA id h88-v6sm2343657oth.59.2018.03.26.08.39.59 for (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Mon, 26 Mar 2018 08:39:59 -0700 (PDT) From: Stuart Hayes Subject: [PATCH v2] dell_rbu: make firmware payload memory uncachable To: linux-kernel@vger.kernel.org Message-ID: <8c18af18-17cf-57c5-5d57-ed3878d8a004@gmail.com> Date: Mon, 26 Mar 2018 10:39:57 -0500 User-Agent: Mozilla/5.0 (Windows NT 10.0; WOW64; rv:52.0) Gecko/20100101 Thunderbird/52.6.0 MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Language: en-US Content-Transfer-Encoding: 7bit X-Antivirus: Avast (VPS 180326-0, 03/26/2018), Outbound message X-Antivirus-Status: Clean Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org The dell_rbu driver takes firmware update payloads and puts them in memory so the system BIOS can find them after a reboot. This sometimes fails (though rarely), because the memory containing the payload is in the CPU cache but never gets written back to main memory before the system is rebooted (CPU cache contents are lost on reboot). With this patch, the payload memory will be changed to uncachable to ensure that the payload is actually in main memory before the system is rebooted. Signed-off-by: Stuart Hayes --- v2 Added include, removed extra parentheses This patch has no maintainer. diff --git a/drivers/firmware/dell_rbu.c b/drivers/firmware/dell_rbu.c index 2f452f1f7c8a..640a88c3418d 100644 --- a/drivers/firmware/dell_rbu.c +++ b/drivers/firmware/dell_rbu.c @@ -45,6 +45,7 @@ #include #include #include +#include MODULE_AUTHOR("Abhay Salunke "); MODULE_DESCRIPTION("Driver for updating BIOS image on DELL systems"); @@ -180,6 +181,11 @@ static int create_packet(void *data, size_t length) invalid_addr_packet_array[idx++] = packet_data_temp_buf; packet_data_temp_buf = NULL; } + /* + * set to uncachable or it may never get written back before + * reboot + */ + set_memory_uc(packet_data_temp_buf, 1 << ordernum); } spin_lock(&rbu_data.lock); @@ -349,6 +355,7 @@ static void packet_empty_list(void) * to make sure there are no stale RBU packets left in memory */ memset(newpacket->data, 0, rbu_data.packetsize); + set_memory_wb(newpacket->data, 1 << newpacket->ordernum); free_pages((unsigned long) newpacket->data, newpacket->ordernum); kfree(newpacket);