Received: by 2002:a05:6a10:a0d1:0:0:0:0 with SMTP id j17csp331086pxa; Wed, 12 Aug 2020 03:13:24 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwi07ddyc9ap6W9FAFUdjjZT9mkjNBp48t+dhZn19y81ldt6epVCidX7nSpUAlhoWGPXezJ X-Received: by 2002:a17:906:43c9:: with SMTP id j9mr30145482ejn.542.1597227204048; Wed, 12 Aug 2020 03:13:24 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1597227204; cv=none; d=google.com; s=arc-20160816; b=HC9F3ZcAlhltlBrYuMdRwcDTI0TWUgEodDPsWphbI4EURMTj2f/+hJyivRby7E3slq MeqYIFPU/rVBGWq9FPAjRSIcC64hJ2NGYkK1juN+a39jp8BA+hW9+UzXxMWxO0AXRqLl cP2+MqzoF65p3IgUGiAntaVAYF8TsD2fDZ+t9GGRPyp03qgztq9OHnSc5YK1KjNzwMux zHwJkXXM75f6gsmBV1VhzwvoYo3DIdD3i36qILoxgLHlqH6ln8oQzfS1nFBUCw7qb1BI j+1Kcv4PRislaiErc5XnNRdfI1CTqMm4LWm3qscj3Ax5HffbgWaeODSCHSQcLi4He/Rs 8ifA== 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 :content-language:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject:ironport-sdr:ironport-sdr; bh=9W27Kzie6Gci+UJJIpNTxEYi2g7ojMrsXQ8nJlolrpY=; b=AIHNLd4vApfUNzRYGF+NifuS4HlM9yXpk8g2mTDgl9zyK6e+PRH0p/9WLIyw9GqSbY iIiIZkftzs5wFJWD0JFk+s1yFqUoTCEQ2GZNB5eRmCdA0tBpKmDR7zV4L3O9ATcCPmPz WDDoMGDFiTiWfpGkic3kvF4VmeMPLYxlZytBNiVo7auJ6F+j/R/ZLbgigcsCrEeG98Jm 3L8MuZ7A7egVrqAyaq9CpiAykTJETzBfBRUN7zMsBoMkrvjP/RGngkit7SmVT3kD/PMX Kp9tVDbktU4V10pyNQiiuxzNSw7zEEPDFdFhrEECOG+UBFgbwtQxuSRz/eK0ZO0VQ8m8 Xfdg== ARC-Authentication-Results: i=1; mx.google.com; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id ot7si868678ejb.747.2020.08.12.03.13.00; Wed, 12 Aug 2020 03:13:24 -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; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727858AbgHLKLl (ORCPT + 99 others); Wed, 12 Aug 2020 06:11:41 -0400 Received: from esa1.mentor.iphmx.com ([68.232.129.153]:41936 "EHLO esa1.mentor.iphmx.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726453AbgHLKLl (ORCPT ); Wed, 12 Aug 2020 06:11:41 -0400 IronPort-SDR: /Na1TFej3rwiPwoC1wHSsVWyqg8mBfRNNKikqZtVeJbnGno3FTf6RS9/91eSmLsOUdqXqGfkrZ xklOvFu4aTCGiHTYnDrC/M1/loka+fxD+kz8Ux5P5k5fAkPRJmYjaWVTu9b9c4mjVypj+Jqpgv tCW9gmUB1dCHiYDrpgXvpWpCkBFPXocPpUkS0/3M8uW56mLbZHiSvQN4usOHNk5svcYqYBWM2s 9/oGABz5EiVBXIqkjetY5cjzEBggPK7u/cAyEn5VEwHSf4yMZPkBSH3ZsiF+dUg8M38vUTkaQ/ 54M= X-IronPort-AV: E=Sophos;i="5.76,303,1592899200"; d="scan'208";a="54015934" Received: from orw-gwy-02-in.mentorg.com ([192.94.38.167]) by esa1.mentor.iphmx.com with ESMTP; 12 Aug 2020 02:11:39 -0800 IronPort-SDR: mejU22uvxz4tPtEmuQVl+kgGTP6+w3XIrqzSRUEJ3wk6N9HFD8BTMKhpOGk4heBQ6DFlmQK5Pl CU1sQayIa9Lj/pywUGTwoXtJ3yH+Y6uXQFhhhmsCvMpe8S8kekB2yux3VQhswVS/I08P0Jz8XP gHpGWyzwhdgnYSBufiBuqyq2xp87MKjk7xSiJ5IoHu2uBeXzNWGXkILD9CGSTl/cu+c2Xu7m3Q 2NjQvK+qlxaRDcVHWDJuSZrGqXLxo1U8G5tsOZVrKzu1xAku7+NNW5Ohi2cDzjvzADA73g8Ik8 WmM= Subject: Re: [PATCH 1/1] Input: atmel_mxt_ts - allow specification of firmware file name To: Dmitry Osipenko , "nick@shmanahar.org" , "dmitry.torokhov@gmail.com" CC: "linux-input@vger.kernel.org" , "linux-kernel@vger.kernel.org" , "erosca@de.adit-jv.com" , "Gabbasov, Andrew" References: <20200731075714.10608-1-jiada_wang@mentor.com> From: "Wang, Jiada" Message-ID: Date: Wed, 12 Aug 2020 19:11:34 +0900 User-Agent: Mozilla/5.0 (Windows NT 10.0; WOW64; rv:68.0) Gecko/20100101 Thunderbird/68.11.0 MIME-Version: 1.0 In-Reply-To: Content-Type: text/plain; charset="utf-8"; format=flowed Content-Language: en-US Content-Transfer-Encoding: 8bit X-ClientProxiedBy: SVR-ORW-MBX-06.mgc.mentorg.com (147.34.90.206) To svr-orw-mbx-01.mgc.mentorg.com (147.34.90.201) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Dmitry On 2020/08/10 5:11, Dmitry Osipenko wrote: > 31.07.2020 10:57, Jiada Wang пишет: >> From: Nick Dyer >> >> On platforms which have multiple device instances using this driver, the >> firmware may be different on each device. This patch makes the user give >> the name of the firmware file when flashing. >> >> This also prevents accidental triggering of the firmware load process. >> >> Signed-off-by: Nick Dyer >> Acked-by: Benson Leung >> Acked-by: Yufeng Shen >> (cherry picked from ndyer/linux/for-upstream commit 76ebb7cee971cb42dfb0a3a9224403b8b09abcf1) >> [gdavis: Forward port and fix conflicts.] >> Signed-off-by: George G. Davis >> Signed-off-by: Jiada Wang >> --- >> drivers/input/touchscreen/atmel_mxt_ts.c | 42 ++++++++++++++++++++---- >> 1 file changed, 36 insertions(+), 6 deletions(-) >> >> diff --git a/drivers/input/touchscreen/atmel_mxt_ts.c b/drivers/input/touchscreen/atmel_mxt_ts.c >> index a2189739e30f..024dee7a3571 100644 >> --- a/drivers/input/touchscreen/atmel_mxt_ts.c >> +++ b/drivers/input/touchscreen/atmel_mxt_ts.c >> @@ -30,8 +30,6 @@ >> #include >> #include >> >> -/* Firmware files */ >> -#define MXT_FW_NAME "maxtouch.fw" >> #define MXT_CFG_NAME "maxtouch.cfg" >> #define MXT_CFG_MAGIC "OBP_RAW V1" >> >> @@ -308,6 +306,7 @@ struct mxt_data { >> struct t7_config t7_cfg; >> struct mxt_dbg dbg; >> struct gpio_desc *reset_gpio; >> + char *fw_name; > > Hello, Jiada! > > Have you decided to abandon the patch which allowed to specify firmware > name in a device tree? > In v11 patch-set, there is a patch allows user to specify config file name via device-tree and sysfs, I will drop device-tree part, since Dmitry Torokhov commented he would like to change the behavior of firmware loading during boot time, but I will keep sysfs interface part, which is similar to this patch but for configuration file. >> /* Cached parameters from object table */ >> u16 T5_address; >> @@ -2766,7 +2765,7 @@ static int mxt_check_firmware_format(struct device *dev, >> return -EINVAL; >> } >> >> -static int mxt_load_fw(struct device *dev, const char *fn) >> +static int mxt_load_fw(struct device *dev) >> { >> struct mxt_data *data = dev_get_drvdata(dev); >> const struct firmware *fw = NULL; >> @@ -2776,9 +2775,9 @@ static int mxt_load_fw(struct device *dev, const char *fn) >> unsigned int frame = 0; >> int ret; >> >> - ret = request_firmware(&fw, fn, dev); >> + ret = request_firmware(&fw, data->fw_name, dev); >> if (ret) { >> - dev_err(dev, "Unable to open firmware %s\n", fn); >> + dev_err(dev, "Unable to open firmware %s\n", data->fw_name); >> return ret; >> } >> >> @@ -2887,6 +2886,33 @@ static int mxt_load_fw(struct device *dev, const char *fn) >> return ret; >> } >> >> +static int mxt_update_file_name(struct device *dev, char **file_name, >> + const char *buf, size_t count) >> +{ >> + char *file_name_tmp; >> + >> + /* Simple sanity check */ >> + if (count > 64) { >> + dev_warn(dev, "File name too long\n"); >> + return -EINVAL; >> + } >> + >> + file_name_tmp = krealloc(*file_name, count + 1, GFP_KERNEL); >> + if (!file_name_tmp) >> + return -ENOMEM; > > The allocated string is never release, this is not good. > > Wouldn't it be nicer to make data->fw_name a fixed-size string? OK, I will change to a fixed-size string > >> + *file_name = file_name_tmp; >> + memcpy(*file_name, buf, count); >> + >> + /* Echo into the sysfs entry may append newline at the end of buf */ >> + if (buf[count - 1] == '\n') >> + (*file_name)[count - 1] = '\0'; >> + else >> + (*file_name)[count] = '\0'; > > What about to use strscpy? > Thanks for the advice, I will replace with strscpy >> + return 0; >> +} >> + >> static ssize_t mxt_update_fw_store(struct device *dev, >> struct device_attribute *attr, >> const char *buf, size_t count) >> @@ -2894,7 +2920,11 @@ static ssize_t mxt_update_fw_store(struct device *dev, >> struct mxt_data *data = dev_get_drvdata(dev); >> int error; >> >> - error = mxt_load_fw(dev, MXT_FW_NAME); >> + error = mxt_update_file_name(dev, &data->fw_name, buf, count); >> + if (error) >> + return error; > > This change breaks old behavior, I'm not sure that it's acceptable. The > default name should remain to be "maxtouch.fw", IMO. it makes sense, I will update to write default "maxtouch.fw", in case user doesn't specify a file name in sysfs write operation Thanks, Jiada > >> + error = mxt_load_fw(dev); >> if (error) { >> dev_err(dev, "The firmware update failed(%d)\n", error); >> count = error; >> >