Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752131AbbEFQNK (ORCPT ); Wed, 6 May 2015 12:13:10 -0400 Received: from mga02.intel.com ([134.134.136.20]:44222 "EHLO mga02.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751682AbbEFQM7 (ORCPT ); Wed, 6 May 2015 12:12:59 -0400 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.13,380,1427785200"; d="scan'208";a="721681979" Message-ID: <554A3E1F.70908@intel.com> Date: Wed, 06 May 2015 19:15:27 +0300 From: Daniel Baluta User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:31.0) Gecko/20100101 Thunderbird/31.4.0 MIME-Version: 1.0 To: Lars-Peter Clausen , jic23@kernel.org CC: jlbec@evilplan.org, knaack.h@gmx.de, linux-kernel@vger.kernel.org, linux-iio@vger.kernel.org, octavian.purdila@intel.com, pebolle@tiscali.nl, patrick.porlan@intel.com, adriana.reus@intel.com, constantin.musca@intel.com, marten@intuitiveaerial.com Subject: Re: [PATCH v5 2/4] iio: core: Introduce IIO configfs support References: <1430736604-22119-1-git-send-email-daniel.baluta@intel.com> <1430736604-22119-3-git-send-email-daniel.baluta@intel.com> <5547CF8A.9060609@metafoo.de> In-Reply-To: <5547CF8A.9060609@metafoo.de> Content-Type: text/plain; charset=windows-1252; format=flowed Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 2822 Lines: 93 On 05/04/2015 10:59 PM, Lars-Peter Clausen wrote: > On 05/04/2015 12:50 PM, Daniel Baluta wrote: >> This creates an IIO configfs subystem named "iio", with a default >> "triggers" >> group. >> >> Triggers group is used for handling software triggers. To create a new >> software >> trigger one must create a directory inside the trigger directory. >> >> Software trigger name MUST follow the following convention: >> * - >> Where: >> * , specifies the interrupt source (e.g: hrtimer) >> * , specifies the IIO device trigger name >> >> Failing to follow this convention will result in an directory creation >> error. >> >> E.g, assuming that hrtimer trigger type is registered with IIO software >> trigger core: >> >> $ mkdir /config/iio/triggers/hrtimer-instance1 >> > > Nice, short and clean. Looks pretty good. It's a bit of a shame that we > can't have a per type directory, but if that's how configfs works I > guess there is not much choice. > > [...] >> +static struct config_group *trigger_make_group(struct config_group >> *group, >> + const char *name) >> +{ >> + char *type_name; >> + char *trigger_name; >> + char buf[MAX_NAME_LEN]; >> + struct iio_sw_trigger *t; >> + >> + snprintf(buf, MAX_NAME_LEN, "%s", name); >> + >> + /* group name should have the form - */ >> + type_name = buf; >> + trigger_name = strchr(buf, '-'); >> + if (!trigger_name) { >> + pr_err("Unable to locate '-' in %s. Use -.\n", buf); > > Do we want to print this side channel message? Makes it pretty easy to > spam the kernel log with a rouge application. I think this is useful, people can get crazy for random -EINVAL errors :). Also the same is done in drivers/usb/gadget/configfs.c. > >> + return ERR_PTR(-EINVAL); >> + } >> + >> + /* replace - with \0, this nicely separates the two strings */ >> + *trigger_name = '\0'; >> + trigger_name++; >> + >> + t = iio_sw_trigger_create(type_name, trigger_name); >> + if (IS_ERR(t)) >> + return ERR_CAST(t); >> + >> + config_item_set_name(&t->group.cg_item, name); >> + >> + return &t->group; >> +} >> + >> +static void trigger_drop_group(struct config_group *group, >> + struct config_item *item) >> +{ >> + struct iio_sw_trigger *t = to_iio_sw_trigger(item); >> + >> + if (t) > > t will never be NULL. Agree, will fix in v6. > >> + iio_sw_trigger_destroy(t); >> + config_item_put(item); >> +} > -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/