From patchwork Sat Sep 26 22:04:06 2015 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Viresh Kumar X-Patchwork-Id: 7272171 X-Patchwork-Delegate: kvalo@adurom.com Return-Path: X-Original-To: patchwork-linux-wireless@patchwork.kernel.org Delivered-To: patchwork-parsemail@patchwork2.web.kernel.org Received: from mail.kernel.org (mail.kernel.org [198.145.29.136]) by patchwork2.web.kernel.org (Postfix) with ESMTP id 5DF18BF036 for ; Sat, 26 Sep 2015 22:04:53 +0000 (UTC) Received: from mail.kernel.org (localhost [127.0.0.1]) by mail.kernel.org (Postfix) with ESMTP id 7E0B3207BE for ; Sat, 26 Sep 2015 22:04:52 +0000 (UTC) Received: from vger.kernel.org (vger.kernel.org [209.132.180.67]) by mail.kernel.org (Postfix) with ESMTP id 80C9E207DF for ; Sat, 26 Sep 2015 22:04:51 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S932608AbbIZWEq (ORCPT ); Sat, 26 Sep 2015 18:04:46 -0400 Received: from mail-pa0-f52.google.com ([209.85.220.52]:33610 "EHLO mail-pa0-f52.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S932377AbbIZWEm (ORCPT ); Sat, 26 Sep 2015 18:04:42 -0400 Received: by pacex6 with SMTP id ex6so137743249pac.0 for ; Sat, 26 Sep 2015 15:04:41 -0700 (PDT) X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20130820; h=x-gm-message-state:from:to:cc:subject:date:message-id; bh=/sTlcjx3ySMkTaTD76qmlRxei1MjlYLKzO3orLUeRVI=; b=ApMKCqAO+D+q/TFkX2+CjX2jg4K/a7urlY/IdwkRKDb1J2H0RSR/JA8VsWISXBloA7 BR22mXtc4QinOVIqb759XZltFn9SuLk5u4txiwf35bkdhIjtdIhBOUZc+e8zwxPM0V80 Gs7NZtWWZ58iS83NzQ4rf28+wPLK4DGT+JryMk3m3kCU4kyVwg9MEXvkV7k5CktajGG8 tYGl+2W1psLxHnNl5HSzxGymcRjrMnrzfLQ9IbQEODs3/MMDCZDAa3v0EL/wrTJ9d+aF 0mXmf51PIB+9mSM7NCKp0a41qMuwMi5PfUHlOh44sAOAZ6dFYAqRPbiaCKoGqy/at3ue PuVA== X-Gm-Message-State: ALoCoQnLzLRRZzN30J6xxvF6+BpfXVJ4K/StyBOyOeeuUYe72/KZ/zWoytCvXiisdfdojCIIdPDa X-Received: by 10.68.191.200 with SMTP id ha8mr16768041pbc.72.1443305081197; Sat, 26 Sep 2015 15:04:41 -0700 (PDT) Received: from localhost (c-67-169-81-235.hsd1.ca.comcast.net. [67.169.81.235]) by smtp.gmail.com with ESMTPSA id qy5sm10933604pbb.16.2015.09.26.15.04.40 (version=TLSv1.2 cipher=RC4-SHA bits=128/128); Sat, 26 Sep 2015 15:04:40 -0700 (PDT) From: Viresh Kumar To: Greg Kroah-Hartman Cc: linaro-kernel@lists.linaro.org, QCA ath9k Development , Intel Linux Wireless , Viresh Kumar , linux-doc@vger.kernel.org, linux-kernel@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-acpi@vger.kernel.org, linux-bluetooth@vger.kernel.org, iommu@lists.linux-foundation.org, netdev@vger.kernel.org, linux-wireless@vger.kernel.org, linux-scsi@vger.kernel.org, linux-usb@vger.kernel.org, linux-edac@vger.kernel.org, linux-mm@kvack.org, alsa-devel@alsa-project.org Subject: [PATCH V5 1/2] ACPI / EC: Fix broken 64bit big-endian users of 'global_lock' Date: Sat, 26 Sep 2015 15:04:06 -0700 Message-Id: <8d3d3428c3a36f821e4c3d8563d094ca4b4763fd.1443304934.git.viresh.kumar@linaro.org> X-Mailer: git-send-email 2.4.0 Sender: linux-wireless-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-wireless@vger.kernel.org X-Spam-Status: No, score=-7.9 required=5.0 tests=BAYES_00, RCVD_IN_DNSWL_HI, RP_MATCHES_RCVD, UNPARSEABLE_RELAY autolearn=ham version=3.3.1 X-Spam-Checker-Version: SpamAssassin 3.3.1 (2010-03-16) on mail.kernel.org X-Virus-Scanned: ClamAV using ClamSMTP global_lock is defined as an unsigned long and accessing only its lower 32 bits from sysfs is incorrect, as we need to consider other 32 bits for big endian 64-bit systems. There are no such platforms yet, but the code needs to be robust for such a case. Fix that by changing type of 'global_lock' to u32. Signed-off-by: Viresh Kumar Acked-by: Rafael J. Wysocki --- BCC'd a lot of people (rather than cc'ing them) to make sure - the series reaches them - mailing lists do not block the patchset due to long cc list - and we don't spam the BCC'd people for every reply V4->V5: - Switch back to the original solution of making global_lock u32. --- drivers/acpi/ec_sys.c | 2 +- drivers/acpi/internal.h | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/drivers/acpi/ec_sys.c b/drivers/acpi/ec_sys.c index b4c216bab22b..bea8e425a8de 100644 --- a/drivers/acpi/ec_sys.c +++ b/drivers/acpi/ec_sys.c @@ -128,7 +128,7 @@ static int acpi_ec_add_debugfs(struct acpi_ec *ec, unsigned int ec_device_count) if (!debugfs_create_x32("gpe", 0444, dev_dir, (u32 *)&first_ec->gpe)) goto error; if (!debugfs_create_bool("use_global_lock", 0444, dev_dir, - (u32 *)&first_ec->global_lock)) + &first_ec->global_lock)) goto error; if (write_support) diff --git a/drivers/acpi/internal.h b/drivers/acpi/internal.h index 9e426210c2a8..9db196de003c 100644 --- a/drivers/acpi/internal.h +++ b/drivers/acpi/internal.h @@ -138,7 +138,7 @@ struct acpi_ec { unsigned long gpe; unsigned long command_addr; unsigned long data_addr; - unsigned long global_lock; + u32 global_lock; unsigned long flags; unsigned long reference_count; struct mutex mutex;