Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp4378165imu; Sun, 25 Nov 2018 02:22:53 -0800 (PST) X-Google-Smtp-Source: AFSGD/X3NJEzgL24AFatsFQNaysA9RpCXC543foXINfmKxOAr84izhDwgfShbpDEHZlnW+s62E4S X-Received: by 2002:a17:902:7c82:: with SMTP id y2mr22553255pll.33.1543141373556; Sun, 25 Nov 2018 02:22:53 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1543141373; cv=none; d=google.com; s=arc-20160816; b=YoRGJNAUBfZXhxK55+YYxHNikFLIuTAbLCqo0Jqcl9HQfvJuX9g+g1acMstcPpRNxV Iejc86Ir1fTwVQNfkOsk8nDhmtzXWihVGFURUvvGjeIQvPPzmwCknMUJZTKCO9/zAhNg johQtJ3cOUvvJXuDTCwca1OjmPxJ1NpmJPycBczMV9oG3fioHvffVWTReHxu3p5qZI1p XqCC2ZM/RO6tK8rtjRcqLLMs8hRFXNrJpI/r4uIyXQpmLFzTU3jQsDmsVbxeCYEuKzPE X1HrFRwBSWXk2Xd3RbV76513/rtgPFBz45+gi5JaXzX0W4LmS8x36JnERFOqrbHjpDdd IRIQ== 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 :user-agent:message-id:in-reply-to:date:references:organization :subject:cc:to:from:dkim-signature; bh=GQ7JoFg+9gLkKCbYtNyJZSPyRA1X/0rXdvEjJ5dzcs4=; b=kFvny9X3Q7aPdU1Bp+iAefMiePobeUFI5whFkI4TgRrFJmV1kQ8wc5YW/NUZIQJTaK ZfhLbDi8LDcHuSCshkiTVW4i4dOXeGWZs0JKbyhaUO0m+syMPv/pvLD9X22XFAVTaJMc LFNhI3rLXjgsRe4YYHOrtz5uOVxaNRp5VH0TBIiFiLJfpdP4crvC8INYwAlDg35yxg7K tyREoUN/Vg50Hmkjrl2G/7yK5ccipKu5JPybsVtiOxp5eT/YwsnKTXUcViuHXDKP1/46 AZYlNJR2rMI5REc2PIInj7bxgHU/h4DcFv7NCj20potjwaMsIyrf3SSl+T3dEXGlPThh CvGw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@mork.no header.s=b header.b="d62F/ZMM"; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=mork.no Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id t20si54602642pgl.211.2018.11.25.02.22.38; Sun, 25 Nov 2018 02:22:53 -0800 (PST) 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=@mork.no header.s=b header.b="d62F/ZMM"; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=mork.no Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727583AbeKYVMt (ORCPT + 99 others); Sun, 25 Nov 2018 16:12:49 -0500 Received: from canardo.mork.no ([148.122.252.1]:58855 "EHLO canardo.mork.no" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727182AbeKYVMt (ORCPT ); Sun, 25 Nov 2018 16:12:49 -0500 Received: from miraculix.mork.no (miraculix.mork.no [IPv6:2001:4641:0:2:7627:374e:db74:e353]) (authenticated bits=0) by canardo.mork.no (8.15.2/8.15.2) with ESMTPSA id wAPALFfl021379 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NO); Sun, 25 Nov 2018 11:21:16 +0100 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=mork.no; s=b; t=1543141280; bh=GQ7JoFg+9gLkKCbYtNyJZSPyRA1X/0rXdvEjJ5dzcs4=; h=From:To:Cc:Subject:References:Date:Message-ID:From; b=d62F/ZMM1d/JsX+bSWdDAiy6QqGT9NOTlaBfZf12FodDZdUyQH2R6CzSPJHkFqGHN neOKSEvp9AhHP2y59xa8lYZj0m/XOBkmGw5OuuvVEvn3daAonTRydBJsqvzPr+zeFM C5xAmtQImGuYqzwDOWEo+EqyTwuRkSdD58vj7t8I= Received: from bjorn by miraculix.mork.no with local (Exim 4.89) (envelope-from ) id 1gQrXO-00012n-IL; Sun, 25 Nov 2018 11:21:14 +0100 From: =?utf-8?Q?Bj=C3=B8rn_Mork?= To: Eric Wong Cc: Henrique de Moraes Holschuh , Shuduo Sang , Darren Hart , Andy Shevchenko , linux-kernel@vger.kernel.org, ibm-acpi-devel@lists.sourceforge.net, platform-driver-x86@vger.kernel.org Subject: Re: [PATCH] platform/x86: thinkpad_acpi: add adaptive_kbd_modes parameter Organization: m References: <20181115073429.z44czywrf7f65ndb@dcvr> <20181124232327.t3awc6dnjqdtvzwu@dcvr> Date: Sun, 25 Nov 2018 11:21:14 +0100 In-Reply-To: <20181124232327.t3awc6dnjqdtvzwu@dcvr> (Eric Wong's message of "Sat, 24 Nov 2018 23:23:27 +0000") Message-ID: <87in0l31b9.fsf@miraculix.mork.no> User-Agent: Gnus/5.13 (Gnus v5.13) Emacs/25.2 (gnu/linux) MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Transfer-Encoding: quoted-printable X-Virus-Scanned: clamav-milter 0.100.2 at canardo X-Virus-Status: Clean Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Eric Wong writes: > Eric Wong wrote: >> The above setting with this change and the following keymap >> preserves my sanity on the atrocious adaptive keyboard on >> the 2nd-gen X1 Carbon: > > Any comments on this patch? The Esc and F-keys on the keyboard > are still numb and I'll be getting rid of the laptop in a few > days; but maybe my patch can still be useful to others... I've read through and I like it, FWIW. A brilliant idea. I don't have the hardare to test the patch, though.... But I do wonder if you aren't missing an empty mask protection somewhere? If I read this right, then there is nothing preventing you from writing 0 here: > +static ssize_t adaptive_kbd_modes_store(struct device *dev, > + struct device_attribute *attr, > + const char *buf, size_t count) > +{ > + unsigned long t; > + > + if (parse_strtoul(buf, (1 << LAYFLAT_MODE) - 1, &t)) > + return -EINVAL; > + > + adaptive_kbd_modes =3D (unsigned int)t; > + return count; > +} And then I believe you have a busy loop here: > @@ -3815,20 +3838,20 @@ static int adaptive_keyboard_set_mode(int new_mod= e) >=20=20 > static int adaptive_keyboard_get_next_mode(int mode) > { > - size_t i; > - size_t max_mode =3D ARRAY_SIZE(adaptive_keyboard_modes) - 1; > - > - for (i =3D 0; i <=3D max_mode; i++) { > - if (adaptive_keyboard_modes[i] =3D=3D mode) > - break; > - } > + int max_mode =3D fls(adaptive_kbd_modes); > + int new_mode =3D mode >=3D max_mode ? HOME_MODE : mode + 1; >=20=20 > - if (i >=3D max_mode) > - i =3D 0; > - else > - i++; > + /* make sure the new mode is allowed by the user */ > + while (!(adaptive_kbd_modes & (1 << new_mode))) { > + new_mode++; > + if (new_mode > max_mode) > + new_mode =3D HOME_MODE; >=20=20 > - return adaptive_keyboard_modes[i]; > + /* maybe the user disabled all other modes: */ > + if (new_mode =3D=3D mode) > + return mode; > + } > + return new_mode; > } Or am I reading this wrong? Bj=C3=B8rn