Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp4655089imu; Sun, 25 Nov 2018 07:42:44 -0800 (PST) X-Google-Smtp-Source: AFSGD/U751auJxbxXLJOD6uhC8VD0JA6+66h0G9HQHtWZLM/PWdbcemF5+SFDFrKr9TWe59NDRqs X-Received: by 2002:a17:902:bd92:: with SMTP id q18mr23988509pls.167.1543160564432; Sun, 25 Nov 2018 07:42:44 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1543160564; cv=none; d=google.com; s=arc-20160816; b=JyONjGGArX3t1jFy5/eSd1F6sKMZyBv2WYSJwrnZuUewg9tOZN+mtUc+WH56LpsCkb x3feA+bevqVxX4rZfsmjujGcgkJZNjMdiMgctidhyHofd6P1SDneGtnW/s+eCoPvVe1v 7bNT7PKJ4iivysfaAGvZfv35kOyR6Io7RVcKzuq3dmIs+TE5whLORwLHUmZXbiKPGYG4 E0yeG/V8TksO/UwNLudL0Wx1JOAaimQwqCEYDMvC49yE82m93u6pTfOtEyTR549uOo46 nu9CD79J1Zm693fZ5hsu4m8VCgPh17sJbJ+yew46WOrgOkSqk0ceiQR8MPYyECmsTGpI 8vDA== 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=2KAkplTJhGzzvyoPKCDSLroA5gHvmKhAYlkFOqKCpWk=; b=cmZ61YY0zh+Tj/rU49pFKCKpkjE4f3TC4xXZ1QeR30kHZTWiEUpDFqkGDJsEtA+3z4 8Ix1HBCd4dJ4G9UNPIu2T5T2nr7Pr1B9reAba2fzOF+c8udEZzELBF64Br09Gl94V7WL a9WqYk9qV5wmiABEVvFXafG5FLcfUPlv7EDZprotdU1fK1yx5NdiJVzN9wAJvJN6c8Ei e02+T9PDC1hWOhkxD1S/lkhLWY9pEojFlpjz61TsiJrZ9YwQzm8DvgyX1VQxAJp5S6qh Is4Ei3sleDsh0TM2juR1QDNynCOJayVy1JuCTwhnNNX7dmImiLpgCsPLzh4R9u1//Rlu ohyg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@mork.no header.s=b header.b=Am0S+l0v; 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 z188si21617528pgb.330.2018.11.25.07.42.27; Sun, 25 Nov 2018 07:42:44 -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=Am0S+l0v; 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 S1726460AbeKZCdL (ORCPT + 99 others); Sun, 25 Nov 2018 21:33:11 -0500 Received: from canardo.mork.no ([148.122.252.1]:42755 "EHLO canardo.mork.no" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726226AbeKZCdL (ORCPT ); Sun, 25 Nov 2018 21:33:11 -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 wAPFfG7N010168 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NO); Sun, 25 Nov 2018 16:41:16 +0100 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=mork.no; s=b; t=1543160478; bh=2KAkplTJhGzzvyoPKCDSLroA5gHvmKhAYlkFOqKCpWk=; h=From:To:Cc:Subject:References:Date:Message-ID:From; b=Am0S+l0vYCmOLrFi3IMRBWwJaJLTmcztdJIdTr3VPPrYwc0x7wjC8wERgXajK6Y+0 Yui4jEzJOZxyeziKGVQx0S3WdffI8FtQUXx/227Ert5ajUugni6td1CcL2b88tCVyF n/56jZCocZ1mncBuLas/AfSAH/mZfhB1pAQnmP+U= Received: from bjorn by miraculix.mork.no with local (Exim 4.89) (envelope-from ) id 1gQwX5-0003Ie-TH; Sun, 25 Nov 2018 16:41:15 +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> <87in0l31b9.fsf@miraculix.mork.no> <20181125144441.xpwuov2i7lab3agh@dcvr> Date: Sun, 25 Nov 2018 16:41:15 +0100 In-Reply-To: <20181125144441.xpwuov2i7lab3agh@dcvr> (Eric Wong's message of "Sun, 25 Nov 2018 14:44:41 +0000") Message-ID: <87zhtx17xg.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: > Bj=C3=B8rn Mork wrote: > >> And then I believe you have a busy loop here: >>=20 >> > @@ -3815,20 +3838,20 @@ static int adaptive_keyboard_set_mode(int new_= mode) >> >=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; >> > } > > Not a busy loop, since new_mode will reset at HOME_MODE (0) > and then it'll hit "new_mode =3D=3D mode" and remain locked in > to the current mode. Right. I see it now. Thanks for explaining. I guess I was expecting a complete loop bypass ala if (!max_mode) return mode: but your solution will of course work just as fine. Bj=C3=B8rn