Received: by 2002:a05:7208:3003:b0:81:def:69cd with SMTP id f3csp4233004rba; Tue, 2 Apr 2024 10:52:39 -0700 (PDT) X-Forwarded-Encrypted: i=3; AJvYcCVbMSDYp7Vy6xgOm6/mCMyeO83J2q6B4jdXFPv9o9gKB2JFKcxG4x9u3SrAzT07Vd7fjjseyBUrCGrCSrt6YIPLXrrQArDvthR2gLXfOg== X-Google-Smtp-Source: AGHT+IFUlRezepGOm2KbiQC5Ql91grGwU8BZtn8wso/Tbewjh3lB7atl0VtK9wjJDUJX0Qtg47Yy X-Received: by 2002:a05:6a20:9e4c:b0:1a3:ca3c:c62b with SMTP id mt12-20020a056a209e4c00b001a3ca3cc62bmr15423857pzb.19.1712080359530; Tue, 02 Apr 2024 10:52:39 -0700 (PDT) ARC-Seal: i=2; a=rsa-sha256; t=1712080359; cv=pass; d=google.com; s=arc-20160816; b=Bu7VxwEAx7YXbzvWrKOgy8dA1txZbO/ufry9HTCYAxnHJSbfM1hlc3bY1n9Zp4d9tL lvAw/Kvu5p8oBtBRxO0MwPy3TaSa3d0YKjdhwgGdmdZDh+dGfzE5evuNaUNJMQdGRyYZ FsOFvcn8TwJ9SGjg1VTGN6iIjQkP1qjbZoclzcd386sqWkEEBycXmnDl9OOcGBwDLXmM lxQxbkPnfTo1+3+bgHLDnbaFize4vlAdW8/MVPVnPWR0zR2GzUYcbPC5LPhRHzKG8cDJ kTp2TXUZAJIknL+Cx1i6XDt1ZPRmyMpn9Y021l52704U05RR8ZZAfEMiS87HeN0jh5Rx aKfg== ARC-Message-Signature: i=2; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=content-transfer-encoding:mime-version:list-unsubscribe :list-subscribe:list-id:precedence:references:in-reply-to:message-id :date:subject:cc:to:from:dkim-signature; bh=c1GxYkp1TjjnIR9rK17S+CcUyT2nTt0S09WXsEkFxfM=; fh=01vijPOZ+gCavAsyrdEz9K9/AEOpllkWHTsZFq7mUHU=; b=ATfV4dfewOAaec/c5UMcQb/rtWdCOZKEu3PS6afVXopOuZ8K6xPA4yC83dz5psJ6Kj /Wv1AIzhoy1uralU2frTlRapXkLH/ysTaavmJCOf1xWpawYf5tHKnE6sRaP3xq4ICAX6 tbLc9bAvBIVwU0xFs8DWf8GuuDartJ6T95is6Hvckb2W4Ft+XFczsGaRKvrmeOjcXr9v Zkyhd93LtCfWz9uvt+TlZAzXZUe6UWSnaXx0KJp3MEc24rF3qjQTgKUms2u+NyaHymps 16P6g0kf4teKBs5vroMXhMz3Efuv0PmT7nVj669D+Hkv5sQQ4gBT4nzWO9OZQGhIrcjj 9ioQ==; dara=google.com ARC-Authentication-Results: i=2; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=OCJcD0IB; arc=pass (i=1 dkim=pass dkdomain=kernel.org); spf=pass (google.com: domain of linux-kernel+bounces-128462-linux.lists.archive=gmail.com@vger.kernel.org designates 139.178.88.99 as permitted sender) smtp.mailfrom="linux-kernel+bounces-128462-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from sv.mirrors.kernel.org (sv.mirrors.kernel.org. [139.178.88.99]) by mx.google.com with ESMTPS id k15-20020a17090a39cf00b002a03ae4c1e7si11759149pjf.21.2024.04.02.10.52.39 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 02 Apr 2024 10:52:39 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel+bounces-128462-linux.lists.archive=gmail.com@vger.kernel.org designates 139.178.88.99 as permitted sender) client-ip=139.178.88.99; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=OCJcD0IB; arc=pass (i=1 dkim=pass dkdomain=kernel.org); spf=pass (google.com: domain of linux-kernel+bounces-128462-linux.lists.archive=gmail.com@vger.kernel.org designates 139.178.88.99 as permitted sender) smtp.mailfrom="linux-kernel+bounces-128462-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: from smtp.subspace.kernel.org (wormhole.subspace.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by sv.mirrors.kernel.org (Postfix) with ESMTPS id 79791284303 for ; Tue, 2 Apr 2024 17:52:03 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id D916B15B0FD; Tue, 2 Apr 2024 17:51:25 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=kernel.org header.i=@kernel.org header.b="OCJcD0IB" Received: from smtp.kernel.org (aws-us-west-2-korg-mail-1.web.codeaurora.org [10.30.226.201]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id DA71215B0E2; Tue, 2 Apr 2024 17:51:24 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=10.30.226.201 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1712080285; cv=none; b=C7Xj1xsHNzkJ1mluMXE9vvslziQSSwn1X8OmH6s/geOts7kZchb9dyYPgpyJL1nUlVlDQaBBTqISyuVB4DwyJe2d8wYQRP4K3aQoLWDkyd52XFFP0ZQQ65dyc1JTKTEOuurM51fc47F9eLE97u9eUE3l4uail/hxvzrPX82FuJ8= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1712080285; c=relaxed/simple; bh=mcZpMvFtZwhSB7YYS+YmnPDFhAZDnH/C5k4Mpq9FzcY=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: MIME-Version; b=daAgC5pStZc6TMuD5ZmoGKqGNs4Lopt2v92e+aFUmc+3C7SMkEub/r1fbeDQvahKRypiU0tvbieQYRN6oItDxv0yZS6Rtj5IIPUrJUkI2sUgxlJpylGUi0hyID79NgzSO95Uo/5n7ifreYWIqZkGcSRyiFPVAdJfmCrh2hecX1s= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=kernel.org header.i=@kernel.org header.b=OCJcD0IB; arc=none smtp.client-ip=10.30.226.201 Received: by smtp.kernel.org (Postfix) with ESMTPSA id 9A6ECC433C7; Tue, 2 Apr 2024 17:51:22 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1712080284; bh=mcZpMvFtZwhSB7YYS+YmnPDFhAZDnH/C5k4Mpq9FzcY=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=OCJcD0IBXDGg1DbWi/wLw28dQ4aN7qSRFaUDY8HSPDJOJY45G89fBV8qK9ZbAj8U8 Juw1UUlJzRQGV2mZoijgalpdR9rgltpjtig2vHX6OeKEz4f1aLInqtCSVvOEcPSp2V TNVXZIF0GvBHHadHGDqq7AoX0K5ayf+2FPKbZFPNrVlnVFb8WiUbyUt2Wzt1JaI8iC mws7qRNrGMrQUOGIWdAQTiN80lCIpmuKnpQDWz6aaSG29DRgvajIqBN6OimsPWbbZz 9Ag4t2nlkQ9QjMo3BdsNMCK2Oxd2vIzsIl2Lkl5QPrdt8Nt5TXx2kcZMxKPC5yif5c DzERlwbUwX/mA== From: Alexey Gladkov To: Greg Kroah-Hartman , Jiri Slaby Cc: LKML , kbd@lists.linux.dev, linux-api@vger.kernel.org, linux-fbdev@vger.kernel.org, linux-serial@vger.kernel.org, Helge Deller Subject: [PATCH v4 2/3] VT: Add KDFONTINFO ioctl Date: Tue, 2 Apr 2024 19:50:45 +0200 Message-ID: <7cd32f988a147d7617742c9e074c753de0c6bc1f.1712080158.git.legion@kernel.org> X-Mailer: git-send-email 2.44.0 In-Reply-To: References: <74ca50e0-61b1-4d4c-85dd-a5d920548c04@kernel.org> Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Each driver has its own restrictions on font size. There is currently no way to understand what the requirements are. The new ioctl allows userspace to get the minimum and maximum font size values. Acked-by: Helge Deller Signed-off-by: Alexey Gladkov --- drivers/tty/vt/vt.c | 24 ++++++++++++++++++++++++ drivers/tty/vt/vt_ioctl.c | 11 +++++++++++ include/linux/console.h | 3 +++ include/linux/vt_kern.h | 1 + include/uapi/linux/kd.h | 13 ++++++++++++- 5 files changed, 51 insertions(+), 1 deletion(-) diff --git a/drivers/tty/vt/vt.c b/drivers/tty/vt/vt.c index 9b5b98dfc8b4..e8db0e9ea674 100644 --- a/drivers/tty/vt/vt.c +++ b/drivers/tty/vt/vt.c @@ -4851,6 +4851,30 @@ int con_font_op(struct vc_data *vc, struct console_font_op *op) return -ENOSYS; } +int con_font_info(struct vc_data *vc, struct console_font_info *info) +{ + int rc; + + info->min_height = 0; + info->max_height = max_font_height; + + info->min_width = 0; + info->max_width = max_font_width; + + info->flags = KD_FONT_INFO_FLAG_LOW_SIZE | KD_FONT_INFO_FLAG_HIGH_SIZE; + + console_lock(); + if (vc->vc_mode != KD_TEXT) + rc = -EINVAL; + else if (vc->vc_sw->con_font_info) + rc = vc->vc_sw->con_font_info(vc, info); + else + rc = -ENOSYS; + console_unlock(); + + return rc; +} + /* * Interface exported to selection and vcs. */ diff --git a/drivers/tty/vt/vt_ioctl.c b/drivers/tty/vt/vt_ioctl.c index 4b91072f3a4e..40f9467f503d 100644 --- a/drivers/tty/vt/vt_ioctl.c +++ b/drivers/tty/vt/vt_ioctl.c @@ -479,6 +479,17 @@ static int vt_k_ioctl(struct tty_struct *tty, unsigned int cmd, break; } + case KDFONTINFO: { + struct console_font_info fnt_info; + + ret = con_font_info(vc, &fnt_info); + if (ret) + return ret; + if (copy_to_user(up, &fnt_info, sizeof(fnt_info))) + return -EFAULT; + break; + } + default: return -ENOIOCTLCMD; } diff --git a/include/linux/console.h b/include/linux/console.h index 31a8f5b85f5d..4b798322aa01 100644 --- a/include/linux/console.h +++ b/include/linux/console.h @@ -21,6 +21,7 @@ #include struct vc_data; +struct console_font_info; struct console_font_op; struct console_font; struct module; @@ -102,6 +103,8 @@ struct consw { bool (*con_switch)(struct vc_data *vc); bool (*con_blank)(struct vc_data *vc, enum vesa_blank_mode blank, bool mode_switch); + int (*con_font_info)(struct vc_data *vc, + struct console_font_info *info); int (*con_font_set)(struct vc_data *vc, const struct console_font *font, unsigned int vpitch, unsigned int flags); diff --git a/include/linux/vt_kern.h b/include/linux/vt_kern.h index d008c3d0a9bb..383b3a4f6113 100644 --- a/include/linux/vt_kern.h +++ b/include/linux/vt_kern.h @@ -33,6 +33,7 @@ void do_blank_screen(int entering_gfx); void do_unblank_screen(int leaving_gfx); void poke_blanked_console(void); int con_font_op(struct vc_data *vc, struct console_font_op *op); +int con_font_info(struct vc_data *vc, struct console_font_info *info); int con_set_cmap(unsigned char __user *cmap); int con_get_cmap(unsigned char __user *cmap); void scrollback(struct vc_data *vc); diff --git a/include/uapi/linux/kd.h b/include/uapi/linux/kd.h index 8ddb2219a84b..abaf4dd6bb93 100644 --- a/include/uapi/linux/kd.h +++ b/include/uapi/linux/kd.h @@ -185,8 +185,19 @@ struct console_font { #define KD_FONT_FLAG_DONT_RECALC 1 /* Don't recalculate hw charcell size [compat] */ +#define KDFONTINFO _IO(KD_IOCTL_BASE, 0x73) /* font information */ + +#define KD_FONT_INFO_FLAG_LOW_SIZE _BITUL(0) /* 256 */ +#define KD_FONT_INFO_FLAG_HIGH_SIZE _BITUL(1) /* 512 */ + +struct console_font_info { + unsigned int min_width, min_height; /* minimal font size */ + unsigned int max_width, max_height; /* maximum font size */ + unsigned int flags; /* KD_FONT_INFO_FLAG_* */ +}; + /* note: 0x4B00-0x4B4E all have had a value at some time; don't reuse for the time being */ -/* note: 0x4B60-0x4B6D, 0x4B70-0x4B72 used above */ +/* note: 0x4B60-0x4B6D, 0x4B70-0x4B73 used above */ #endif /* _UAPI_LINUX_KD_H */ -- 2.44.0