Received: by 2002:ac0:950c:0:0:0:0:0 with SMTP id f12csp3868639imc; Thu, 14 Mar 2019 07:08:08 -0700 (PDT) X-Google-Smtp-Source: APXvYqygDeeEauLkD/otLtsVClYV+CIfFb2aqXAuvs188rFEQ+I8Q8I14TO8ailoKg+jB5TpaRLn X-Received: by 2002:a17:902:822:: with SMTP id 31mr51571920plk.290.1552572488857; Thu, 14 Mar 2019 07:08:08 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1552572488; cv=none; d=google.com; s=arc-20160816; b=qyUlYG82RleX3WnPWq4S6MWRD1Gyjn1wdpNQMuSVA42JNghfVYQZX9Dl6PSf3BG48k MolQEE0AlS/sPltUIxxBVjF+qZnI8MiNkj9TQ08zqXOAUWcELehcfL+icS2vk2lm6DhS 8mrsut+iPKAdql07gAmYHNl42nrR0E36eGoh63YBaChYL01UPokW2vyC/BfuL1TyZjQK Qmh2r5jpLKwt31zbmMaSNjdK4+dNDlSd7KjJgGDA5mJnwN+Je6ceZrrnx5+W2jz6byak QQVA7Rz+iTCIPlkP0SSOo4sbqa2zrpF8XqBNcUONlzff3WKY3VSUbggS8xeyXocC88gs pd1w== 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 :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=p8EpCtqjAm4J2CBGC1CDK0h+QRPUremQspzB4HLzQkM=; b=cjWk+mvIOQf1fzAmxsVsMri/zyWapJ34364Ww3AMDilhl08qZWnhh2GXFhG4Yertco Ns/d4yrJxPf2SUiFdc7ZarferUtef1sC0hLPr2aV+zoQ+fDn586snKVqneTW6sIfm6Xu yjZVg67WebizLU1BuQLjKfKsusMzfj1eHzAnSwZBvJoyhlCC3f1v9/HYD89H6RMaXbCG FcthI6rjfbGIH62FrwvwEYzntke1rmQwwhaOZnF2Q8vll9X7S9qzqhi0OkIvKOzVNSDp wnWOgbNbUzqBG12uIJnH/CD5+DBGIcfuD1AldlIUPsn/sL5YjL3gOMlKWPLuRArCh7ix qJsw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@rasmusvillemoes.dk header.s=google header.b=iiyYDh0h; 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 f5si12428677pgo.394.2019.03.14.07.07.52; Thu, 14 Mar 2019 07:08:08 -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=@rasmusvillemoes.dk header.s=google header.b=iiyYDh0h; 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 S1727711AbfCNOGp (ORCPT + 99 others); Thu, 14 Mar 2019 10:06:45 -0400 Received: from mail-lf1-f65.google.com ([209.85.167.65]:37791 "EHLO mail-lf1-f65.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727595AbfCNOGa (ORCPT ); Thu, 14 Mar 2019 10:06:30 -0400 Received: by mail-lf1-f65.google.com with SMTP id u2so4302103lfd.4 for ; Thu, 14 Mar 2019 07:06:29 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=rasmusvillemoes.dk; s=google; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=p8EpCtqjAm4J2CBGC1CDK0h+QRPUremQspzB4HLzQkM=; b=iiyYDh0hQqtDSOIY3ADO4E2t/q8s7H2qCJ/oyrbHGCDuy6vRE8qrSHTXgjOmLEegOP IAiloUMw7Ke5+3IjG3KwtFyvr34bq9MQT9Q/g4cdppRoZxBzhnXEl25Rtr0mZ3+ZJX1N DDzkFRpA3uftSDnDot9ocPU/iJoyMj7MVlcWs= 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:in-reply-to :references:mime-version:content-transfer-encoding; bh=p8EpCtqjAm4J2CBGC1CDK0h+QRPUremQspzB4HLzQkM=; b=iN9QhKugSF5pgsoPnTrDnskJUORtIHQAYVEhRMhAWKfOumD0CT02tkAhKuITINYY3m bG0ExsmY5R8kM/xJHFWMDIKeKSpOyntsUWmY+6aeimtJ/2IS0bYjUE/Q1zeB+kqXWZIV qYJRnFeSKvsPGOaxYxTIFMbBzjeoOWKQnsT6vzRXjChWjsrDhf3lwnrPnpBCJ6PdUQp8 Q6sAOMysAGzyTSndBW+fFRyYN/8KncVh28TLuAkKYyI1N4kgG9x4410ycoO3c3hV91bN q440qMBkBfD7IEOjYEo6UnfwKyuVVCnD4amsB8fULWYMxTB802OJErqe+PIExlakGGYo Y4/A== X-Gm-Message-State: APjAAAXa7Gz973RjRY0feB1C7yb+3cmmrU35lFtI2uImRYa9HHO+L1Ew ID4eBRwNTKWqBBEDuWvMVbxNdkk9nODtttNE X-Received: by 2002:ac2:4310:: with SMTP id l16mr25782184lfh.58.1552572388394; Thu, 14 Mar 2019 07:06:28 -0700 (PDT) Received: from prevas-ravi.prevas.se ([81.216.59.226]) by smtp.gmail.com with ESMTPSA id t14sm2733709lfe.51.2019.03.14.07.06.27 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Thu, 14 Mar 2019 07:06:28 -0700 (PDT) From: Rasmus Villemoes To: Pavel Machek , =?UTF-8?q?Uwe=20Kleine-K=C3=B6nig?= , Jacek Anaszewski Cc: LKML , Rasmus Villemoes , linux-leds@vger.kernel.org Subject: [PATCH v2 4/6] leds: netdev trigger: move name length checking to netdev_trig_set_device Date: Thu, 14 Mar 2019 15:06:17 +0100 Message-Id: <20190314140619.3309-5-linux@rasmusvillemoes.dk> X-Mailer: git-send-email 2.20.1 In-Reply-To: <20190314140619.3309-1-linux@rasmusvillemoes.dk> References: <20190313202615.22883-1-linux@rasmusvillemoes.dk> <20190314140619.3309-1-linux@rasmusvillemoes.dk> 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 It's better to check that size is sane in the function that does the memcpy'ing and 0-termination to the IFNAMSIZ-sized buffer instead of relying on callers getting it right. Not rejecting size upfront does mean we would do the cancel_delayed_work_sync(), but that gets fixed up by the set_baseline_state() call. Signed-off-by: Rasmus Villemoes --- drivers/leds/trigger/ledtrig-netdev.c | 15 +++++++++------ 1 file changed, 9 insertions(+), 6 deletions(-) diff --git a/drivers/leds/trigger/ledtrig-netdev.c b/drivers/leds/trigger/ledtrig-netdev.c index c35439291424..e4a76ce4e4c7 100644 --- a/drivers/leds/trigger/ledtrig-netdev.c +++ b/drivers/leds/trigger/ledtrig-netdev.c @@ -104,9 +104,12 @@ static ssize_t device_name_show(struct device *dev, return len; } -static void netdev_trig_set_device(struct led_netdev_data *trigger_data, - const char *buf, size_t size) +static ssize_t netdev_trig_set_device(struct led_netdev_data *trigger_data, + const char *buf, size_t size) { + if (size >= IFNAMSIZ) + return -EINVAL; + if (trigger_data->net_dev) { dev_put(trigger_data->net_dev); trigger_data->net_dev = NULL; @@ -125,6 +128,7 @@ static void netdev_trig_set_device(struct led_netdev_data *trigger_data, set_bit(NETDEV_LED_MODE_LINKUP, &trigger_data->mode); trigger_data->last_activity = 0; + return 0; } static ssize_t device_name_store(struct device *dev, @@ -133,23 +137,22 @@ static ssize_t device_name_store(struct device *dev, { struct led_netdev_data *trigger_data = led_trigger_get_drvdata(dev); size_t orig_size = size; + ssize_t ret; /* Ignore trailing newline */ if (size > 0 && buf[size - 1] == '\n') size--; - if (size >= IFNAMSIZ) - return -EINVAL; cancel_delayed_work_sync(&trigger_data->work); spin_lock_bh(&trigger_data->lock); - netdev_trig_set_device(trigger_data, buf, size); + ret = netdev_trig_set_device(trigger_data, buf, size); set_baseline_state(trigger_data); spin_unlock_bh(&trigger_data->lock); - return orig_size; + return ret ? ret : orig_size; } static DEVICE_ATTR_RW(device_name); -- 2.20.1