Add font_data_size() and update consoles to use it.

Signed-off-by: Thomas Zimmermann <[email protected]>
---
 drivers/video/console/newport_con.c |  2 +-
 drivers/video/fbdev/core/fbcon.c    | 14 +++++++-------
 include/linux/font.h                |  2 ++
 lib/fonts/fonts.c                   | 21 +++++++++++++++++++++
 4 files changed, 31 insertions(+), 8 deletions(-)

diff --git a/drivers/video/console/newport_con.c 
b/drivers/video/console/newport_con.c
index fcf76f65b06e..eee9695c3eb5 100644
--- a/drivers/video/console/newport_con.c
+++ b/drivers/video/console/newport_con.c
@@ -530,7 +530,7 @@ static int newport_set_font(int unit, const struct 
console_font *op,
        /* check if font is already used by other console */
        for (i = 0; i < MAX_NR_CONSOLES; i++) {
                if (font_data[i] != FONT_DATA
-                   && FNTSIZE(font_data[i]) == size
+                   && font_data_size(font_data[i]) == size
                    && !memcmp(font_data[i], new_data, size)) {
                        kfree(new_data - FONT_EXTRA_WORDS * sizeof(int));
                        /* current font is the same as the new one */
diff --git a/drivers/video/fbdev/core/fbcon.c b/drivers/video/fbdev/core/fbcon.c
index 73f2757155e6..ebb9c5c1b247 100644
--- a/drivers/video/fbdev/core/fbcon.c
+++ b/drivers/video/fbdev/core/fbcon.c
@@ -2058,7 +2058,7 @@ static int fbcon_resize(struct vc_data *vc, unsigned int 
width,
        struct fb_var_screeninfo var = info->var;
        int x_diff, y_diff, virt_w, virt_h, virt_fw, virt_fh;
 
-       if (p->userfont && FNTSIZE(p->fontdata)) {
+       if (p->userfont && font_data_size(p->fontdata)) {
                unsigned int size = vc_font_size(&vc->vc_font);
 
                /*
@@ -2068,7 +2068,7 @@ static int fbcon_resize(struct vc_data *vc, unsigned int 
width,
                 * charcount can change and cannot be used to determine the
                 * font data allocated size.
                 */
-               if (!size || size > FNTSIZE(p->fontdata))
+               if (!size || size > font_data_size(p->fontdata))
                        return -EINVAL;
        }
 
@@ -2307,7 +2307,7 @@ static int fbcon_get_font(struct vc_data *vc, struct 
console_font *font, unsigne
 
        if (font->width <= 8) {
                j = vc->vc_font.height;
-               if (font->charcount * j > FNTSIZE(fontdata))
+               if (font->charcount * j > font_data_size(fontdata))
                        return -EINVAL;
 
                for (i = 0; i < font->charcount; i++) {
@@ -2318,7 +2318,7 @@ static int fbcon_get_font(struct vc_data *vc, struct 
console_font *font, unsigne
                }
        } else if (font->width <= 16) {
                j = vc->vc_font.height * 2;
-               if (font->charcount * j > FNTSIZE(fontdata))
+               if (font->charcount * j > font_data_size(fontdata))
                        return -EINVAL;
 
                for (i = 0; i < font->charcount; i++) {
@@ -2328,7 +2328,7 @@ static int fbcon_get_font(struct vc_data *vc, struct 
console_font *font, unsigne
                        fontdata += j;
                }
        } else if (font->width <= 24) {
-               if (font->charcount * (vc->vc_font.height * sizeof(u32)) > 
FNTSIZE(fontdata))
+               if (font->charcount * (vc->vc_font.height * sizeof(u32)) > 
font_data_size(fontdata))
                        return -EINVAL;
 
                for (i = 0; i < font->charcount; i++) {
@@ -2343,7 +2343,7 @@ static int fbcon_get_font(struct vc_data *vc, struct 
console_font *font, unsigne
                }
        } else {
                j = vc->vc_font.height * 4;
-               if (font->charcount * j > FNTSIZE(fontdata))
+               if (font->charcount * j > font_data_size(fontdata))
                        return -EINVAL;
 
                for (i = 0; i < font->charcount; i++) {
@@ -2558,7 +2558,7 @@ static int fbcon_set_font(struct vc_data *vc, const 
struct console_font *font,
                if (fb_display[i].userfont &&
                    fb_display[i].fontdata &&
                    FNTSUM(fb_display[i].fontdata) == csum &&
-                   FNTSIZE(fb_display[i].fontdata) == size &&
+                   font_data_size(fb_display[i].fontdata) == size &&
                    tmp->vc_font.width == w &&
                    !memcmp(fb_display[i].fontdata, new_data, size)) {
                        kfree(new_data - FONT_EXTRA_WORDS * sizeof(int));
diff --git a/include/linux/font.h b/include/linux/font.h
index 4ff8d52e59c3..3afb32b625d3 100644
--- a/include/linux/font.h
+++ b/include/linux/font.h
@@ -54,6 +54,8 @@ static inline const unsigned char *font_data_buf(font_data_t 
*fd)
        return (const unsigned char *)fd;
 }
 
+unsigned int font_data_size(font_data_t *fd);
+
 /*
  * Font lookup
  */
diff --git a/lib/fonts/fonts.c b/lib/fonts/fonts.c
index a7f118b30171..8c9a6762061c 100644
--- a/lib/fonts/fonts.c
+++ b/lib/fonts/fonts.c
@@ -20,6 +20,27 @@
 #endif
 #include <linux/font.h>
 
+/*
+ * Helpers for font_data_t
+ */
+
+/**
+ * font_data_size - Return size of the font data in bytes
+ * @fd: Font data
+ *
+ * Returns:
+ * The number of bytes in the given font data.
+ */
+unsigned int font_data_size(font_data_t *fd)
+{
+       return FNTSIZE(fd);
+}
+EXPORT_SYMBOL_GPL(font_data_size);
+
+/*
+ * Font lookup
+ */
+
 static const struct font_desc *fonts[] = {
 #ifdef CONFIG_FONT_8x8
        &font_vga_8x8,
-- 
2.52.0

Reply via email to