Received: by 2002:a25:ef43:0:0:0:0:0 with SMTP id w3csp90922ybm; Thu, 28 May 2020 16:57:58 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwEfDR0swIpBZ4W7zColDJ0h6ITvOQd5QAvLX8annO6UXHJNGOvb3fgORGBtWKoOmxcsFqC X-Received: by 2002:a50:ace4:: with SMTP id x91mr5697641edc.361.1590710278659; Thu, 28 May 2020 16:57:58 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1590710278; cv=none; d=google.com; s=arc-20160816; b=uDlnAtUAs7yTRY7gJxQlyv/AAW5ZdYXjgrEOW4+CVLaZjgFj3Ivbmc4hJOZ5NgmnKG IFE/373heiIp/fxm6mq/I6bjsEcPvmnu0gg8XrUlF1m0G47sl51bBmF46V9dUhYirInr L0J+ejzYgUikUG5+fqLa9zT1uAvh3zlSHDjam9Dq/4pa1p5jrKSDeJUb6x0o/1ViQDqe MiavO1v1ZBmOvb23kbyfhtPBq3rGLXulKgo/WEwzKVj6z00L3/VASnbNg3eV4mKNjBnU Q8duOWNO8vdRsW5u1VHXuolpTNVUENCLL+GL11OsWXwRkrpTH6fvqFwTO9O5k3cee+AG xO3g== 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; bh=MsZSmU61OLe136r//qttOvmTDf94o4Xes23hd9beBhc=; b=shywr7QMEkxNOpMuvvsSSQXAn2UV0vHxp4cfkXKIIcLE4aAMwOW7oQbCFSIHBwPvCv +MUyzSUzG3K9O8NISAcMnZrIIbOPMczGW2hVxpLd3p5PRGkY9AUEw1lGQQgWqSU3J9u4 vrdn10IOAjlhhW4vmx6P2XIkqUhkDdgpFb0Pk8o8qbordiJ63LoMyT7vqvt22I5zrPRK dM+5jvGQ5xQTDiI7vjLOvwcFKMVmD6EYpC2020TuaapgnHkAy/c5ATv/Nh3KicGF6oJW CQqe26kGqRRZPQ5baM95fqN85P5TzXwSDvVqiLssDjtS6MyliXb5AfC0jk1FBUsPA2f2 9W5A== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@chromium.org header.s=google header.b=nYn3psEF; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=chromium.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id s24si4837082ejx.153.2020.05.28.16.57.35; Thu, 28 May 2020 16:57:58 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@chromium.org header.s=google header.b=nYn3psEF; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=chromium.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2437802AbgE1Xxq (ORCPT + 99 others); Thu, 28 May 2020 19:53:46 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:45536 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2437677AbgE1Xxo (ORCPT ); Thu, 28 May 2020 19:53:44 -0400 Received: from mail-pl1-x641.google.com (mail-pl1-x641.google.com [IPv6:2607:f8b0:4864:20::641]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id E9411C08C5C8 for ; Thu, 28 May 2020 16:53:43 -0700 (PDT) Received: by mail-pl1-x641.google.com with SMTP id a13so247169pls.8 for ; Thu, 28 May 2020 16:53:43 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=chromium.org; s=google; h=from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=MsZSmU61OLe136r//qttOvmTDf94o4Xes23hd9beBhc=; b=nYn3psEFlsAo+l4qjLcV/PPFHdSi/yh4Ak7xlfTqvsuuGV0fmcl5epZboPlP0qPDie bhpqMExiCSK+2twDheP4//o41BF4oowsaXRpQkFp89iHqzAeQnbdErfzkyrXmnb7BSZz uiSrLz3eYN7fipm8yg74y/x/sJD3WeduEtkEA= 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=MsZSmU61OLe136r//qttOvmTDf94o4Xes23hd9beBhc=; b=devPpLRZ7L7ycUMQc59RI9oPyKIN/OpGDxvwW6LV1fQvIE7sOkh3dYsZXGEG86U7NO sKeV3LO3iCQ79BOSEWuRbYeRK4r8pWkfiDxOzjSTkYP2moQd79LoopcED8f0gj8aNb2s pe/Od3VHjgd604/3qApJZ1n3qTiUIqMZvIC0KUzVTxXVuIOgsd9/kCYjn2Dcxt/08r4t PoCc2Ix665EjgJcYKfS8jOqDt2CWLRXZwBJZWtZ3aMv/r1gbJgZGEulXJr2OwgLVcHvV RVaVp3Wi/2ACbqAniWF+FovfuyRcy5hthtNSq3yCZp/MEanYx/NmHoy3t2eG9qyftmLN sXRA== X-Gm-Message-State: AOAM531CgVI1kZ+K8wMORaAWls4LNInLNZZejbInhtWIoFbKiQ4bfH2c RqHjvT6K91WJULJTAaHOl1x/iw== X-Received: by 2002:a17:90a:ad87:: with SMTP id s7mr749166pjq.225.1590710023485; Thu, 28 May 2020 16:53:43 -0700 (PDT) Received: from tictac2.mtv.corp.google.com ([2620:15c:202:1:24fa:e766:52c9:e3b2]) by smtp.gmail.com with ESMTPSA id i197sm5735574pfe.30.2020.05.28.16.53.42 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 28 May 2020 16:53:43 -0700 (PDT) From: Douglas Anderson To: Srinivas Kandagatla Cc: evgreen@chromium.org, Ravi Kumar Bokka , Douglas Anderson , linux-kernel@vger.kernel.org Subject: [PATCH] nvmem: Enforce nvmem stride in the sysfs interface Date: Thu, 28 May 2020 16:53:02 -0700 Message-Id: <20200528165250.1.Iad7dec5afecba175c816773a0088be805476453f@changeid> X-Mailer: git-send-email 2.27.0.rc0.183.gde8f92d652-goog MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org The 'struct nvmem_config' has a stride attribute that specifies the needed alignment for accesses into the nvmem. This is used in nvmem_cell_info_to_nvmem_cell() but not in the sysfs read/write functions. If the alignment is important in one place it's important everywhere, so let's add enforcement. For now we'll consider it totally invalid to access with the wrong alignment. We could relax this in the read case where we could just read some extra bytes and throw them away. Relaxing it in the write case seems harder (and less safe?) since we'd have to read some data first and then write it back. To keep it symmetric we'll just disallow it in both cases. Reported-by: Ravi Kumar Bokka Signed-off-by: Douglas Anderson --- drivers/nvmem/core.c | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/drivers/nvmem/core.c b/drivers/nvmem/core.c index 05c6ae4b0b97..1c0e7953f90d 100644 --- a/drivers/nvmem/core.c +++ b/drivers/nvmem/core.c @@ -111,6 +111,9 @@ static ssize_t bin_attr_nvmem_read(struct file *filp, struct kobject *kobj, if (pos >= nvmem->size) return 0; + if (!IS_ALIGNED(pos, nvmem->stride)) + return -EINVAL; + if (count < nvmem->word_size) return -EINVAL; @@ -148,6 +151,9 @@ static ssize_t bin_attr_nvmem_write(struct file *filp, struct kobject *kobj, if (pos >= nvmem->size) return -EFBIG; + if (!IS_ALIGNED(pos, nvmem->stride)) + return -EINVAL; + if (count < nvmem->word_size) return -EINVAL; -- 2.27.0.rc0.183.gde8f92d652-goog