Received: by 10.213.65.68 with SMTP id h4csp910924imn; Tue, 27 Mar 2018 11:02:38 -0700 (PDT) X-Google-Smtp-Source: AIpwx4/szXUr5dE4aK8fyJeBtPcvp4TlkfNyB/yBBLbUga4+TZCYXqqn0Uv7dBf1X2ueBkcEZDAM X-Received: by 10.98.201.194 with SMTP id l63mr266895pfk.126.1522173758526; Tue, 27 Mar 2018 11:02:38 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1522173758; cv=none; d=google.com; s=arc-20160816; b=drfS/It5f7JD4lbXQi9lKfXAXOlp2BmM09a3HKWzvhRWO30uEBrjXeVUeB11EoJLjB HUGddMsgE1AZsmbfusBWELPmza0sgKWWY0cMwtxH62V9a47wwgwikMrcJ2HfyASsY1UF /DlI9IEmD6dWok7K9IR09MLB9xEDzT1Hyrfyz29L8I0x55ebgI46mCHsgeIxF2V4JA31 66gC4SjpEeVRybs363KbyWshRdaApRlNvjALBdNvfWM9e8WVNydllXoGifbKyUABk/J/ 9YUjX7yN5tqzI9W1PBgnMGxK2bIR33EqyNbIqW2jFmo6mcAlTBCOBw+c9yoMdBjwEvuX /GIQ== 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:mime-version :message-id:date:subject:cc:to:from:dkim-signature :arc-authentication-results; bh=7Jud7JAckR+CezwQUOUPXwAZnN8Ennxh+w0WQzMykBw=; b=qeLEz+yCxf5oeKmFwePf136g4Lg1I+YJ5zBEFeXE53INVTipyxm3jjRc5QfdU1S++B f8zUrzaxDD9vnEtx44aLF37wM4KZdn9oS3jq8AZLhKzjFeBloG6P0o1WboD2CGCEwIn/ qVDbFx13udZU0D8p/uXJykP9shTen5vt4R7At9bNxaY5W35MVHG3kq6Ia5ORaP1ng4zh 078HvOf6xqtZ6HG0WjooiMVwmeqztaDhEr98vNH/3qrznqVjIApNKl25iYA4/+IZXHJ/ H5KsoXui+DXQlcGUAPIFrighj6bXep7BHmcD4gU9j+HIL2+BHCHbjKr/tvix0AzM4R+m pfPA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@lightnvm-io.20150623.gappssmtp.com header.s=20150623 header.b=jRpTuHhA; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id 204si1137822pgf.771.2018.03.27.11.02.24; Tue, 27 Mar 2018 11:02:38 -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=@lightnvm-io.20150623.gappssmtp.com header.s=20150623 header.b=jRpTuHhA; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1753390AbeC0SAq (ORCPT + 99 others); Tue, 27 Mar 2018 14:00:46 -0400 Received: from mail-lf0-f65.google.com ([209.85.215.65]:40894 "EHLO mail-lf0-f65.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1753106AbeC0SAn (ORCPT ); Tue, 27 Mar 2018 14:00:43 -0400 Received: by mail-lf0-f65.google.com with SMTP id e5-v6so34619233lfb.7 for ; Tue, 27 Mar 2018 11:00:42 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=lightnvm-io.20150623.gappssmtp.com; s=20150623; h=from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=7Jud7JAckR+CezwQUOUPXwAZnN8Ennxh+w0WQzMykBw=; b=jRpTuHhAeasC0fMHojkpsqdrWa9G5rO2LWuad7kxcEwJDUQ/2ta4F9okXnwQmHlIw5 1AyKJRF4LUmdup7lvqrcpKOHV/fBCMAkQ1Bp0309gCOqg6SdZyh4DYaERIhZnnPdq6bc Azu5Jkn9mxqrMYBjpI8F/HWL6Zv+KpitVJ5SCA0liId21zbbHzE8IgNHOcO5WYBBzz+d CI9+ijiAe12VuakhWcg8hx8vJNHGG3MdqCJw4+hMJYDPOYoVoQ+FCDpVDSxy8hoBk0HL 4du0AgEe6h8q+/V9GFFo4aqnxNtoSu9NE7znSvhjZ8MeIUknO9sZPAxj3N4aN/rxIUPx 0kiw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=7Jud7JAckR+CezwQUOUPXwAZnN8Ennxh+w0WQzMykBw=; b=FlAWZZHnUo59rBTz66sVtSfH4t61SkSKrBLWZ+xL8yiZa1GivkwHBc8ZonECTSF7Vv gh9pzIQCYH12YOZywK9iNb8D6UAiaKIP4UsyJfNatOTr8aUbcaeTMJExmdoGKiKvbpgS 2mN6WfWihj/9B/aDQwwltonSdcCIdVvapxIUs/rZk48J9qfRsdG3lTLFhhpZsBAyrHox gQR8E2ypE2/8q8qtsEhsDQlBgx/gaRyhvY/LrhwLG9cWvQgWiqYbg+Z290HJ2Scal8k2 Kf9EyqXkPJz8c7KyqPiiFdeCemswCP29I6pihnhN4BZWcHM0yVefske0Q0r8astHeB3i iEug== X-Gm-Message-State: AElRT7GlVnmIWxLpfMo9HgScOPnVuLnH4WHLkDUGbA/05APlYl2JlKCW DP4nabY5PY5m82eKNyd0YFuXhw== X-Received: by 10.46.128.90 with SMTP id p26mr206481ljg.141.1522173641491; Tue, 27 Mar 2018 11:00:41 -0700 (PDT) Received: from Macroninja.cnexlabs.com (x1-6-a4-08-f5-18-3c-3a.cpe.webspeed.dk. [188.176.29.198]) by smtp.gmail.com with ESMTPSA id f6sm302888ljc.73.2018.03.27.11.00.40 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Tue, 27 Mar 2018 11:00:40 -0700 (PDT) From: =?UTF-8?q?Matias=20Bj=C3=B8rling?= To: keith.busch@intel.com Cc: linux-kernel@vger.kernel.org, linux-nvme@lists.infradead.org, =?UTF-8?q?Matias=20Bj=C3=B8rling?= Subject: [PATCH] nvme: enforce 64bit offset for nvme_get_log_ext fn Date: Tue, 27 Mar 2018 20:00:33 +0200 Message-Id: <20180327180033.28316-1-mb@lightnvm.io> X-Mailer: git-send-email 2.11.0 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Compiling on 32 bits system produces a warning for the shift width when shifting 32 bit integer with 64bit integer. Make sure that offset always is 64bit, and use macros for retrieving lower and upper bits of the offset. Signed-off-by: Matias Bjørling --- drivers/nvme/host/core.c | 6 +++--- drivers/nvme/host/nvme.h | 2 +- 2 files changed, 4 insertions(+), 4 deletions(-) diff --git a/drivers/nvme/host/core.c b/drivers/nvme/host/core.c index f81e3b323366..a22fc5304cd7 100644 --- a/drivers/nvme/host/core.c +++ b/drivers/nvme/host/core.c @@ -2220,7 +2220,7 @@ static int nvme_init_subsystem(struct nvme_ctrl *ctrl, struct nvme_id_ctrl *id) int nvme_get_log_ext(struct nvme_ctrl *ctrl, struct nvme_ns *ns, u8 log_page, void *log, - size_t size, size_t offset) + size_t size, u64 offset) { struct nvme_command c = { }; unsigned long dwlen = size / 4 - 1; @@ -2235,8 +2235,8 @@ int nvme_get_log_ext(struct nvme_ctrl *ctrl, struct nvme_ns *ns, c.get_log_page.lid = log_page; c.get_log_page.numdl = cpu_to_le16(dwlen & ((1 << 16) - 1)); c.get_log_page.numdu = cpu_to_le16(dwlen >> 16); - c.get_log_page.lpol = cpu_to_le32(offset & ((1ULL << 32) - 1)); - c.get_log_page.lpou = cpu_to_le32(offset >> 32ULL); + c.get_log_page.lpol = cpu_to_le32(lower_32_bits(offset)); + c.get_log_page.lpou = cpu_to_le32(upper_32_bits(offset)); return nvme_submit_sync_cmd(ctrl->admin_q, &c, log, size); } diff --git a/drivers/nvme/host/nvme.h b/drivers/nvme/host/nvme.h index aa10842a6709..e9cca9c59a68 100644 --- a/drivers/nvme/host/nvme.h +++ b/drivers/nvme/host/nvme.h @@ -430,7 +430,7 @@ int nvme_delete_ctrl(struct nvme_ctrl *ctrl); int nvme_delete_ctrl_sync(struct nvme_ctrl *ctrl); int nvme_get_log_ext(struct nvme_ctrl *ctrl, struct nvme_ns *ns, - u8 log_page, void *log, size_t size, size_t offset); + u8 log_page, void *log, size_t size, u64 offset); extern const struct attribute_group nvme_ns_id_attr_group; extern const struct block_device_operations nvme_ns_head_ops; -- 2.11.0