Received: by 2002:a05:6358:1087:b0:cb:c9d3:cd90 with SMTP id j7csp4282872rwi; Sat, 22 Oct 2022 07:45:04 -0700 (PDT) X-Google-Smtp-Source: AMsMyM66QDLAEpzVAEyCEqsYSx6tL7FY+vJxO+DeFCwKgJ8bRjfFFk3p1x3UuBY9rh6YO0pR5VLN X-Received: by 2002:a05:6402:371b:b0:460:ff7d:f511 with SMTP id ek27-20020a056402371b00b00460ff7df511mr12098652edb.148.1666449904383; Sat, 22 Oct 2022 07:45:04 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1666449904; cv=none; d=google.com; s=arc-20160816; b=GXl4AHWmZwRdhH7ZymW01cpy7KAml/oK/3g2R/PidLvUwr1VAlnia1KlroV0taOCFg KQQUXnUzs2AN2PwO3L/SNZz99UyTHZZDHTxWQhEgwGDxJLxzec0Bt56etmCgKNHKP4LE N3ZT9rlT48bdRDEblaqp/oGdiAHUq27uFVzRojDzHLo/ubxHfB+YmZP7iTdGFP7LL0DZ R3CKNz6yLEXEggc54B/M8+r+70Gl9WeMdCrz3ZbGMmXpT1hz4/fnDpP3fD+eDTJeHV++ QnEcFg0g1mhupsTBBXNFg/voJzFF3GOiak/VCpjn9JpWWLs3yXLWcS+c2Ein2/42Nhpl IzmA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:user-agent:organization:in-reply-to :content-transfer-encoding:content-disposition:mime-version :references:mail-followup-to:message-id:subject:cc:to:from:date; bh=uGivLKYtOap0WbKRCsCUVVHgNcGnzi8IhC7rJ4N7vbE=; b=pVpwSb6y8smMR1CBtSGlConsCZ7AeWJuWEatzOVk9skFVjn90MHph/EqAJYYVLytH8 jldFmVsAw4kDK3gngz4hfS7ZoTzYYrwUhs8KZGJ09x2F7wLdCxJXwAxYAuHLAn/MH0Oz 4pMG3mo8esAKUb8xC/HfhcSmKplSp4lEACJ94hh+IkZv8DjahighV2NgXhrGxWlyZn1M teZQYYJdJktvbPR+sWLl8e/AXbg7APCEIvfhJ+oasDz2J44A8aDBB7UtUqzUP6T5kuqa ToIBxR5SAjjZ/KRPDjEbikvqR5jCxfamrMhjHnodseQKa8JOgVQUR8qnkeiFM8zdmaWY iZZQ== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id mp34-20020a1709071b2200b0078c6abf19bfsi20796192ejc.948.2022.10.22.07.44.38; Sat, 22 Oct 2022 07:45:04 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229645AbiJVOax (ORCPT + 99 others); Sat, 22 Oct 2022 10:30:53 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:38052 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229728AbiJVOaq (ORCPT ); Sat, 22 Oct 2022 10:30:46 -0400 Received: from sonata.ens-lyon.org (sonata.ens-lyon.org [140.77.166.138]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id F36311DE3F8 for ; Sat, 22 Oct 2022 07:30:45 -0700 (PDT) Received: from localhost (localhost [127.0.0.1]) by sonata.ens-lyon.org (Postfix) with ESMTP id C7BCF2011C; Sat, 22 Oct 2022 16:30:44 +0200 (CEST) Received: from sonata.ens-lyon.org ([127.0.0.1]) by localhost (sonata.ens-lyon.org [127.0.0.1]) (amavisd-new, port 10024) with ESMTP id bZlmNJtcZlMX; Sat, 22 Oct 2022 16:30:44 +0200 (CEST) Received: from begin (lfbn-bor-1-376-208.w109-215.abo.wanadoo.fr [109.215.91.208]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange ECDHE (P-256) server-signature RSA-PSS (4096 bits) server-digest SHA256) (No client certificate requested) by sonata.ens-lyon.org (Postfix) with ESMTPSA id A2E452011A; Sat, 22 Oct 2022 16:30:44 +0200 (CEST) Received: from samy by begin with local (Exim 4.96) (envelope-from ) id 1omFWO-0001uQ-0t; Sat, 22 Oct 2022 16:30:44 +0200 Date: Sat, 22 Oct 2022 16:30:44 +0200 From: Samuel Thibault To: Osama Muhammad Cc: gregkh@linuxfoundation.org, speakup@linux-speakup.org, linux-kernel@vger.kernel.org Subject: Re: [PATCH] Accessiblity: speakup_audptr: specifying the default driver parameters among the module params Message-ID: <20221022143044.jukm4pvxwkwtmhoi@begin> Mail-Followup-To: Samuel Thibault , Osama Muhammad , gregkh@linuxfoundation.org, speakup@linux-speakup.org, linux-kernel@vger.kernel.org References: <20221021135309.251891-1-osmtendev@gmail.com> MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Disposition: inline Content-Transfer-Encoding: 8bit In-Reply-To: <20221021135309.251891-1-osmtendev@gmail.com> Organization: I am not organized User-Agent: NeoMutt/20170609 (1.8.3) X-Spam-Status: No, score=-4.2 required=5.0 tests=BAYES_00,RCVD_IN_DNSWL_MED, SPF_HELO_PASS,SPF_PASS autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Osama Muhammad, le ven. 21 oct. 2022 18:53:09 +0500, a ecrit: > This is an enhancement which allows to specify the default driver > parameters among the module parameters. > > Adding default variables to the speakup_audptr module > allows to easily set that at boot, rather than > setting the sys variables after boot. > More details can be found here: > https://github.com/linux-speakup/speakup/issues/7 > > Signed-off-by: Osama Muhammad Reviewed-by: Samuel Thibault Thanks! > --- > .../accessibility/speakup/speakup_audptr.c | 42 +++++++++++++++---- > 1 file changed, 33 insertions(+), 9 deletions(-) > > diff --git a/drivers/accessibility/speakup/speakup_audptr.c b/drivers/accessibility/speakup/speakup_audptr.c > index 4d16d60db9b2..55813f3e40ff 100644 > --- a/drivers/accessibility/speakup/speakup_audptr.c > +++ b/drivers/accessibility/speakup/speakup_audptr.c > @@ -19,15 +19,24 @@ > static int synth_probe(struct spk_synth *synth); > static void synth_flush(struct spk_synth *synth); > > -static struct var_t vars[] = { > - { CAPS_START, .u.s = {"\x05[f99]" } }, > - { CAPS_STOP, .u.s = {"\x05[f80]" } }, > - { RATE, .u.n = {"\x05[r%d]", 10, 0, 20, 100, -10, NULL } }, > - { PITCH, .u.n = {"\x05[f%d]", 80, 39, 4500, 0, 0, NULL } }, > - { VOL, .u.n = {"\x05[g%d]", 21, 0, 40, 0, 0, NULL } }, > - { TONE, .u.n = {"\x05[s%d]", 9, 0, 63, 0, 0, NULL } }, > - { PUNCT, .u.n = {"\x05[A%c]", 0, 0, 3, 0, 0, "nmsa" } }, > - { DIRECT, .u.n = {NULL, 0, 0, 1, 0, 0, NULL } }, > + > +enum default_vars_id { > + CAPS_START_ID = 0, CAPS_STOP_ID, > + RATE_ID, PITCH_ID, > + VOL_ID, TONE_ID, PUNCT_ID, > + DIRECT_ID, V_LAST_VAR_ID, > + NB_ID > +}; > + > +static struct var_t vars[NB_ID] = { > + [CAPS_START_ID] = { CAPS_START, .u.s = {"\x05[f99]" } }, > + [CAPS_STOP_ID] = { CAPS_STOP, .u.s = {"\x05[f80]" } }, > + [RATE_ID] = { RATE, .u.n = {"\x05[r%d]", 10, 0, 20, 100, -10, NULL } }, > + [PITCH_ID] = { PITCH, .u.n = {"\x05[f%d]", 80, 39, 4500, 0, 0, NULL } }, > + [VOL_ID] = { VOL, .u.n = {"\x05[g%d]", 21, 0, 40, 0, 0, NULL } }, > + [TONE_ID] = { TONE, .u.n = {"\x05[s%d]", 9, 0, 63, 0, 0, NULL } }, > + [PUNCT_ID] = { PUNCT, .u.n = {"\x05[A%c]", 0, 0, 3, 0, 0, "nmsa" } }, > + [DIRECT_ID] = { DIRECT, .u.n = {NULL, 0, 0, 1, 0, 0, NULL } }, > V_LAST_VAR > }; > > @@ -158,10 +167,25 @@ static int synth_probe(struct spk_synth *synth) > module_param_named(ser, synth_audptr.ser, int, 0444); > module_param_named(dev, synth_audptr.dev_name, charp, 0444); > module_param_named(start, synth_audptr.startup, short, 0444); > +module_param_named(rate, vars[RATE_ID].u.n.default_val, int, 0444); > +module_param_named(pitch, vars[PITCH_ID].u.n.default_val, int, 0444); > +module_param_named(vol, vars[VOL_ID].u.n.default_val, int, 0444); > +module_param_named(tone, vars[TONE_ID].u.n.default_val, int, 0444); > +module_param_named(punct, vars[PUNCT_ID].u.n.default_val, int, 0444); > +module_param_named(direct, vars[DIRECT_ID].u.n.default_val, int, 0444); > + > + > > MODULE_PARM_DESC(ser, "Set the serial port for the synthesizer (0-based)."); > MODULE_PARM_DESC(dev, "Set the device e.g. ttyUSB0, for the synthesizer."); > MODULE_PARM_DESC(start, "Start the synthesizer once it is loaded."); > +MODULE_PARM_DESC(rate, "Set the rate variable on load."); > +MODULE_PARM_DESC(pitch, "Set the pitch variable on load."); > +MODULE_PARM_DESC(vol, "Set the vol variable on load."); > +MODULE_PARM_DESC(tone, "Set the tone variable on load."); > +MODULE_PARM_DESC(punct, "Set the punct variable on load."); > +MODULE_PARM_DESC(direct, "Set the direct variable on load."); > + > > module_spk_synth(synth_audptr); > > -- > 2.25.1 > -- Samuel --- Pour une évaluation indépendante, transparente et rigoureuse ! Je soutiens la Commission d'Évaluation de l'Inria.