Received: by 2002:a05:6358:e9c4:b0:b2:91dc:71ab with SMTP id hc4csp2683309rwb; Sat, 6 Aug 2022 04:17:09 -0700 (PDT) X-Google-Smtp-Source: AA6agR4PXc/35E44x0W8ZCw49gVViCfeSJaaXI7j3sMPYaG8CZ5qB7s+NmjNMCA1LIEbdNfJXzQn X-Received: by 2002:a05:6402:34c7:b0:43e:4237:e57c with SMTP id w7-20020a05640234c700b0043e4237e57cmr10341817edc.171.1659784628912; Sat, 06 Aug 2022 04:17:08 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1659784628; cv=none; d=google.com; s=arc-20160816; b=sMjWURvgSeb6IJXYGSc6TiAxPnKgzsc8SXsJykbxYztsaX+vXPLbrZL/LGh8JJ9EPV NoW8uL31CGi/O/zgwMLZ+nFk+Xg85kmwKVrs/yPds0asDk4O9Y/wSdJ+By3HIb3e7we2 iq3Dxz9zEbovxtiBjiBsx/+h2K8q2WXFylhvs9rj/gSeRGOwZVkPlTktUHXVZd5dBE7y OwmZT12rboYIiYQ7UkrMVLhTrtkxRHhl9kaDDf32ifxljdlRTmYoJudDZdfovLHXshJj unlFDs9sa9fP2mS+xaGBRPY2iR2RYM7xhHtyH5YQ1ZxtiHCxlFcO5qgS4RZ7x1b2l9Ra 7rMQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:cc:to:subject:message-id:date:from:in-reply-to :references:mime-version:dkim-signature; bh=I3uXfOIh0HQkXTbkdEdipML9h3bJHEvJCiPVtZoJAxE=; b=S1SoNt0zTGRb8Xt220kCEbN1tMFsgtqjKWJQaj6/B10CdrN/jgs2Rj7S4nW2myqLrC 1GxytliPyEeQaWP25NV4vPNfc5RRk7jlHKAPFagrMvOisTahyZ+3kdFNAcyY/1ksX1vg XGes3SNVHtSx5ZldCYzD6n0mHdOMChUkF0PcR6rC80XYnnUWZecUtcBGEJuMe+eLA+go B1B5yBtcLr+R5KtIPa+me2phDNT7GF/LmX5gVsZ30ty9O2XlE0b7ced3BJQKiVwpGhyA MtwL+tD3wGNjCqHPJAiCXOf5VpXhvkHhmonON4w2640Z/YTWDlXVEB9lrGNhNl9tvrIw CQow== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20210112 header.b=bMf5AdAU; 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; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id sd31-20020a1709076e1f00b00730d9f7aec8si5287486ejc.151.2022.08.06.04.16.41; Sat, 06 Aug 2022 04:17:08 -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; dkim=pass header.i=@gmail.com header.s=20210112 header.b=bMf5AdAU; 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; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231220AbiHFLNH (ORCPT + 99 others); Sat, 6 Aug 2022 07:13:07 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:35104 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229695AbiHFLNE (ORCPT ); Sat, 6 Aug 2022 07:13:04 -0400 Received: from mail-qk1-x732.google.com (mail-qk1-x732.google.com [IPv6:2607:f8b0:4864:20::732]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 599EE11802; Sat, 6 Aug 2022 04:13:03 -0700 (PDT) Received: by mail-qk1-x732.google.com with SMTP id o3so2206691qkk.5; Sat, 06 Aug 2022 04:13:03 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20210112; h=cc:to:subject:message-id:date:from:in-reply-to:references :mime-version:from:to:cc; bh=I3uXfOIh0HQkXTbkdEdipML9h3bJHEvJCiPVtZoJAxE=; b=bMf5AdAUe63EHMZe1gF1GIKSeeV1hL+NGemf4kNorRiMZPJA4EuWlFEPg9AqfPrcKF fjCN0X+ObNCek24R4wD9uGBdoffu/vatpfBOscBwY09OkXmmNXJ52rSBd26a/zut9wv+ jZSs4DynzWiynB/SyroaEb9IlLyAtpx5YzTrgq7GlAHRZY7sFEXbwFOj61EfTwv784Az m93LJvQxCG9aPvkczjdA4TfBp5iNTlOZq6Lnw4vzWSIKm841MjP+cq9diruYevNYDWdz DKNMGS3ldJ6UPhMcgbYC945jLYDxGHGeS1iRBszg1MjMw1FaRT+hfcQw6zOXFdv/WUJy FGAg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=cc:to:subject:message-id:date:from:in-reply-to:references :mime-version:x-gm-message-state:from:to:cc; bh=I3uXfOIh0HQkXTbkdEdipML9h3bJHEvJCiPVtZoJAxE=; b=Ph073nU+uFjtAGa1nYxJS1MKoDhn16ozyUfwwVvKim5FYn0eyEnQAADIoPpd0mcFm1 T1reBsdKEeWtoMM1CpvCEEouONNbn9bwUwW529gXiKDJK3AunTOhlvAxHOjstSmtEmyC Tkm1FCz2x4ZBARWnmy3DUbnZ1Fh2MSjTF0Bu7Z2Da8jfvP5seIM760d0alZachFVLM2j HRjyFcgh+tkS5V/GpF9b+xbldj6ZC4pFs2y34Du+L6S8027DuLJAwa7ZUlMbnsNppT2u mKFKpZB2UTicpN4UlGswjRMLJht3wEfGLTZxy1+OizK3i8cu+I83ORGtzNBOHBYyEj+b Xlgw== X-Gm-Message-State: ACgBeo2EXh4HQRHWSvEBAtIRZdyJyHJfgJUdtqJBI4u6vg07iWeIe1hg t66ZH4dNp3PGF6Jpo/MF3ofZpucGCCxU1Lz71r+F1+uQ33I= X-Received: by 2002:a05:620a:8018:b0:6b6:5df:977 with SMTP id ee24-20020a05620a801800b006b605df0977mr7992311qkb.320.1659784382338; Sat, 06 Aug 2022 04:13:02 -0700 (PDT) MIME-Version: 1.0 References: <20220805081909.10962-1-luke@ljones.dev> <20220805081909.10962-3-luke@ljones.dev> <90W6GR.9Z5CYBT7NOHJ1@ljones.dev> In-Reply-To: <90W6GR.9Z5CYBT7NOHJ1@ljones.dev> From: Andy Shevchenko Date: Sat, 6 Aug 2022 13:12:25 +0200 Message-ID: Subject: Re: [PATCH 2/5] asus-wmi: Add support for TUF laptop keyboard RGB mode control To: Luke Jones Cc: Hans de Goede , Mark Gross , Platform Driver , Linux Kernel Mailing List Content-Type: text/plain; charset="UTF-8" X-Spam-Status: No, score=-2.1 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,FREEMAIL_FROM, RCVD_IN_DNSWL_NONE,SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE 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 On Sat, Aug 6, 2022 at 12:34 PM Luke Jones wrote: > On Sat, Aug 6 2022 at 11:56:58 +0200, Andy Shevchenko > wrote: > > On Fri, Aug 5, 2022 at 10:20 AM Luke D. Jones wrote: ... > >> + if (sscanf(buf, "%hhd %hhd %hhd", &save, &mode, &speed) != > >> 3) > >> + return -EINVAL; > > > > Usually we have three separate nodes for that, but they are kinda > > hidden in one driver, so I don't care much. > > I don't really understand what you mean sorry. Each value is in a separate sysfs "file" (we call it "sysfs node"), but it seems Pavel proposed a better solution so LED framework has something to offer you. ... > >> + /* These are the known usable modes across all TUF/ROG */ > >> + asus->keyboard_rgb_mode.mode = mode < 12 && mode != 9 ? > >> mode : 0x0a; This also can be improved if (mode >= 12 || mode == 9) ...mode = 10; else ...mode = mode; Or, if it's important, switch all above to be hexadecimal constants. ... > >> + err = tuf_rgb_brightness_set(cdev, cdev->brightness); > >> + if (err) > >> + return err; > >> + return 0; > > > > return tuf_rgb_brightness_set(...); > > This causes a hang (waiting for return somewhere?) if I don't return > count. Especially true if the return is 0. I didn't get this, because what I suggested is an equivalent to the above 4 lines. -- With Best Regards, Andy Shevchenko