Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1753190AbaAXVTW (ORCPT ); Fri, 24 Jan 2014 16:19:22 -0500 Received: from mga02.intel.com ([134.134.136.20]:25328 "EHLO mga02.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752786AbaAXVTS (ORCPT ); Fri, 24 Jan 2014 16:19:18 -0500 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="4.95,715,1384329600"; d="scan'208";a="444259684" From: Andi Kleen To: x86@kernel.org Cc: linux-kernel@vger.kernel.org, Andi Kleen Subject: [PATCH 2/2] x86, microcode: Add option to allow downgrading of microcode Date: Fri, 24 Jan 2014 13:18:59 -0800 Message-Id: <1390598339-18740-2-git-send-email-andi@firstfloor.org> X-Mailer: git-send-email 1.8.3.1 In-Reply-To: <1390598339-18740-1-git-send-email-andi@firstfloor.org> References: <1390598339-18740-1-git-send-email-andi@firstfloor.org> Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Andi Kleen For testing purposes it can be useful to downgrade microcode. Normally the driver only allows upgrading. Add a module_param (default off) that allows downgrading. Note the module_param can currently not be set for early ucode update, only for late. Signed-off-by: Andi Kleen --- arch/x86/kernel/microcode_intel_lib.c | 7 +++++++ 1 file changed, 7 insertions(+) diff --git a/arch/x86/kernel/microcode_intel_lib.c b/arch/x86/kernel/microcode_intel_lib.c index ce69320..18d5325 100644 --- a/arch/x86/kernel/microcode_intel_lib.c +++ b/arch/x86/kernel/microcode_intel_lib.c @@ -26,11 +26,16 @@ #include #include #include +#include #include #include #include +static bool allow_downgrade; +module_param(allow_downgrade, bool, 0644); +MODULE_PARM_DESC(allow_downgrade, "Allow downgrading microcode"); + static inline int update_match_cpu(unsigned int csig, unsigned int cpf, unsigned int sig, unsigned int pf) @@ -41,6 +46,8 @@ update_match_cpu(unsigned int csig, unsigned int cpf, int update_match_revision(struct microcode_header_intel *mc_header, int rev) { + if (allow_downgrade) + return 1; return (mc_header->rev <= rev) ? 0 : 1; } -- 1.8.3.1 -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/