Received: by 2002:a25:1985:0:0:0:0:0 with SMTP id 127csp1627416ybz; Sun, 26 Apr 2020 00:34:31 -0700 (PDT) X-Google-Smtp-Source: APiQypI4TS+QafGaSclhQoOwiH5JEauahpoX7GMwwn0/PM2U+CzkyRgpL+EPJbl6eaKaReGtZ87F X-Received: by 2002:a17:906:1199:: with SMTP id n25mr15135213eja.30.1587886471543; Sun, 26 Apr 2020 00:34:31 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1587886471; cv=none; d=google.com; s=arc-20160816; b=s2v5HVMOp+klpXRqbpLaUBbvD2aO/2RfvWYSQQu5xsg4K7g2l7Eeh0rxrENLu9sA2s pfdRvWI3EmLiH3umaBvzX0zdWrhpEuIAcZQbAwGoJ5bj/DIOEf/6yq96sTMyhqXpble9 5e/igs1S50GG+Fg2oxiNH80a6jsFBKsQqadJYqS+kFaJ6h57dT2IXMuy0FvVW53H3qeC kATtCsFtNqdQM/JQdFpV5ClBuHJgFmrlwbpaXBm+qOOJCnkohJfKqxkIaBOI922X/tw5 FblUvdp/T0ZhzpdyF6s4k43IJRVZLrx5JAP2YaD6XLg3us2saNAlNLX0NZ+xveUEs3E4 yMZw== 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 :content-language:in-reply-to:mime-version:user-agent:date :message-id:autocrypt:from:references:cc:to:subject; bh=4YPj4b4MHcxfTgC1QhBKELJwv0oh8+rDYcb1k9qmVo4=; b=h3KZgii4WnsAikbF+cxMIjDz++dzS24/MceTjnUz4BIDvrMNzoNW6NqH0eax1NIf2B x+Xw1/2HiP9YwA4xCHxBTm+La3hIMxAZRrhqeMR8VJQXUvpCATGsOitvHVOCR8sxP8vB QgmZdiUBagykc76ZHNDLh4jfR49ZTbZrBqmSto1EEkqpZs0t5OUs1Lsctw5PMCFTFhHv YQCtxIb1KpoPsrUuFKA2IyT7PehtX/K9lYUgeP1FvLO7Xjs2sPEUxmvAOv6p3nJGBE4r bb9NSpwjlOx2VmdauQzoKtvDLwjuMDdBWI0YdQeRZg6UDroOG24VK9QTAAgezq6SkZ0k 8hqw== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id p4si6396019ejd.3.2020.04.26.00.34.08; Sun, 26 Apr 2020 00:34:31 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726159AbgDZHIi (ORCPT + 99 others); Sun, 26 Apr 2020 03:08:38 -0400 Received: from mx2.suse.de ([195.135.220.15]:49444 "EHLO mx2.suse.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725864AbgDZHIh (ORCPT ); Sun, 26 Apr 2020 03:08:37 -0400 X-Virus-Scanned: by amavisd-new at test-mx.suse.de Received: from relay2.suse.de (unknown [195.135.220.254]) by mx2.suse.de (Postfix) with ESMTP id C4D0DABAD; Sun, 26 Apr 2020 07:08:34 +0000 (UTC) Subject: Re: [PATCH] vt: vt_ioctl: Add new ioctl to read vt switch lock state To: Johannes Hostert Cc: Greg Kroah-Hartman , Eric Biggers , Eric Dumazet , linux-kernel@vger.kernel.org References: <20200425231436.535671-1-jojohostert@gmail.com> From: Jiri Slaby Autocrypt: addr=jslaby@suse.com; prefer-encrypt=mutual; keydata= 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 Message-ID: Date: Sun, 26 Apr 2020 09:08:33 +0200 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:68.0) Gecko/20100101 Thunderbird/68.6.0 MIME-Version: 1.0 In-Reply-To: <20200425231436.535671-1-jojohostert@gmail.com> Content-Type: text/plain; charset=iso-8859-2 Content-Language: en-US Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 26. 04. 20, 1:14, Johannes Hostert wrote: > The existing ioctls VT_LOCKSWITCH and VT_UNLOCKSWITCH can be used to > allow/disallow switching the virtual terminal. However, no mechanism > exists that allows software to read this lock state. > > Userspace programs that try to switch to another virtual terminal > like chvt have no mechanism to figure out whether they will be able > to actually switch the terminal. When eg. chvt is run while terminal > switching is disabled, it simply sleeps forever waiting for the target > terminal to become active. > > This commit introduces a new ioctl VT_GETLOCKSWITCH that allows > reading the current state of the switch lock flag. Userspace > software can then use that flag and handle not being able to switch > virtual terminals. > > Example program using this: > > #include > #include > #include > #include > #include > #include > #include > const char* console_device = "/dev/tty0"; > int main(int argc, char* argv[]) { > int fd; > while ((fd = open(console_device, O_RDWR)) == -1 && errno == EINTR); > if (fd < 0) > error(1, errno, "Opening %s", console_device); > int ret; > while ((ret = ioctl(fd, VT_GETLOCKSWITCH, 1)) == -1 && errno == EINTR); > if (ret == -1) > error(1, errno, "%s: VT_GETLOCKSWITCH", console_device); And now if you do VT_LOCKSWITCH even when VT_GETLOCKSWITCH returns 0, vt_dont_switch can be 1 already. So NACK. Please don't add another racy ioctl. Introduce VT_LOCKSWITCH_NONBLOCK or something like that instead (like respecting O_NONBLOCK). thanks, -- js suse labs