summaryrefslogtreecommitdiffstats
path: root/lib/fonts/fonts.c
diff options
context:
space:
mode:
authorTakashi Iwai <tiwai@suse.de>2019-06-18 22:34:25 +0200
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>2019-06-20 10:11:24 +0200
commitdfd19a5004eff03755967086aa04254c3d91b8ec (patch)
tree569cd8274cc79defebd8bfb1474279990e4dd3e1 /lib/fonts/fonts.c
parentfonts: Use BUILD_BUG_ON() for checking empty font table (diff)
downloadlinux-dfd19a5004eff03755967086aa04254c3d91b8ec.tar.xz
linux-dfd19a5004eff03755967086aa04254c3d91b8ec.zip
fonts: Prefer a bigger font for high resolution screens
Although we may have multiple fonts in kernel, the small 8x16 font is chosen as default usually unless user specify the boot option. This is suboptimal for monitors with high resolutions. This patch tries to assign a bigger font for such a high resolution by calculating some penalty value. This won't change anything for a standard monitor like Full HD (1920x1080), but for a high res monitor like UHD 4K, a bigger font like TER16x32 will be chosen once when enabled in Kconfig. Signed-off-by: Takashi Iwai <tiwai@suse.de> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Diffstat (limited to 'lib/fonts/fonts.c')
-rw-r--r--lib/fonts/fonts.c7
1 files changed, 6 insertions, 1 deletions
diff --git a/lib/fonts/fonts.c b/lib/fonts/fonts.c
index a8e31e9d6fc5..e7258d8c252b 100644
--- a/lib/fonts/fonts.c
+++ b/lib/fonts/fonts.c
@@ -106,7 +106,7 @@ EXPORT_SYMBOL(find_font);
const struct font_desc *get_default_font(int xres, int yres, u32 font_w,
u32 font_h)
{
- int i, c, cc;
+ int i, c, cc, res;
const struct font_desc *f, *g;
g = NULL;
@@ -127,6 +127,11 @@ const struct font_desc *get_default_font(int xres, int yres, u32 font_w,
if ((yres < 400) == (f->height <= 8))
c += 1000;
+ /* prefer a bigger font for high resolution */
+ res = (xres / f->width) * (yres / f->height) / 1000;
+ if (res > 20)
+ c += 20 - res;
+
if ((font_w & (1 << (f->width - 1))) &&
(font_h & (1 << (f->height - 1))))
c += 1000;