Skip to content

Commit

Permalink
Merge tag 'fbdev-for-6.2-rc7' of git://git.kernel.org/pub/scm/linux/k…
Browse files Browse the repository at this point in the history
…ernel/git/deller/linux-fbdev

Pull fbdev fixes from Helge Deller:

 - fix fbcon to prevent fonts bigger than 32x32 pixels to avoid
   overflows reported by syzbot

 - switch omapfb to use kstrtobool()

 - switch some fbdev drivers to use the backlight helpers

* tag 'fbdev-for-6.2-rc7' of git://git.kernel.org/pub/scm/linux/kernel/git/deller/linux-fbdev:
  fbcon: Check font dimension limits
  fbdev: omapfb: Use kstrtobool() instead of strtobool()
  fbdev: fbmon: fix function name in kernel-doc
  fbdev: atmel_lcdfb: Rework backlight status updates
  fbdev: riva: Use backlight helper
  fbdev: omapfb: panel-dsi-cm: Use backlight helper
  fbdev: nvidia: Use backlight helper
  fbdev: mx3fb: Use backlight helper
  fbdev: radeon: Use backlight helper
  fbdev: atyfb: Use backlight helper
  fbdev: aty128fb: Use backlight helper
  • Loading branch information
torvalds committed Feb 5, 2023
2 parents 9e48260 + 2b09d5d commit 870c3a9
Show file tree
Hide file tree
Showing 14 changed files with 27 additions and 75 deletions.
22 changes: 1 addition & 21 deletions drivers/video/fbdev/atmel_lcdfb.c
Original file line number Diff line number Diff line change
Expand Up @@ -49,7 +49,6 @@ struct atmel_lcdfb_info {
struct clk *lcdc_clk;

struct backlight_device *backlight;
u8 bl_power;
u8 saved_lcdcon;

u32 pseudo_palette[16];
Expand Down Expand Up @@ -109,22 +108,7 @@ static u32 contrast_ctr = ATMEL_LCDC_PS_DIV8
static int atmel_bl_update_status(struct backlight_device *bl)
{
struct atmel_lcdfb_info *sinfo = bl_get_data(bl);
int power = sinfo->bl_power;
int brightness = bl->props.brightness;

/* REVISIT there may be a meaningful difference between
* fb_blank and power ... there seem to be some cases
* this doesn't handle correctly.
*/
if (bl->props.fb_blank != sinfo->bl_power)
power = bl->props.fb_blank;
else if (bl->props.power != sinfo->bl_power)
power = bl->props.power;

if (brightness < 0 && power == FB_BLANK_UNBLANK)
brightness = lcdc_readl(sinfo, ATMEL_LCDC_CONTRAST_VAL);
else if (power != FB_BLANK_UNBLANK)
brightness = 0;
int brightness = backlight_get_brightness(bl);

lcdc_writel(sinfo, ATMEL_LCDC_CONTRAST_VAL, brightness);
if (contrast_ctr & ATMEL_LCDC_POL_POSITIVE)
Expand All @@ -133,8 +117,6 @@ static int atmel_bl_update_status(struct backlight_device *bl)
else
lcdc_writel(sinfo, ATMEL_LCDC_CONTRAST_CTR, contrast_ctr);

bl->props.fb_blank = bl->props.power = sinfo->bl_power = power;

return 0;
}

Expand All @@ -155,8 +137,6 @@ static void init_backlight(struct atmel_lcdfb_info *sinfo)
struct backlight_properties props;
struct backlight_device *bl;

sinfo->bl_power = FB_BLANK_UNBLANK;

if (sinfo->backlight)
return;

Expand Down
6 changes: 2 additions & 4 deletions drivers/video/fbdev/aty/aty128fb.c
Original file line number Diff line number Diff line change
Expand Up @@ -1766,12 +1766,10 @@ static int aty128_bl_update_status(struct backlight_device *bd)
unsigned int reg = aty_ld_le32(LVDS_GEN_CNTL);
int level;

if (bd->props.power != FB_BLANK_UNBLANK ||
bd->props.fb_blank != FB_BLANK_UNBLANK ||
!par->lcd_on)
if (!par->lcd_on)
level = 0;
else
level = bd->props.brightness;
level = backlight_get_brightness(bd);

reg |= LVDS_BL_MOD_EN | LVDS_BLON;
if (level > 0) {
Expand Down
8 changes: 1 addition & 7 deletions drivers/video/fbdev/aty/atyfb_base.c
Original file line number Diff line number Diff line change
Expand Up @@ -2219,13 +2219,7 @@ static int aty_bl_update_status(struct backlight_device *bd)
{
struct atyfb_par *par = bl_get_data(bd);
unsigned int reg = aty_ld_lcd(LCD_MISC_CNTL, par);
int level;

if (bd->props.power != FB_BLANK_UNBLANK ||
bd->props.fb_blank != FB_BLANK_UNBLANK)
level = 0;
else
level = bd->props.brightness;
int level = backlight_get_brightness(bd);

reg |= (BLMOD_EN | BIASMOD_EN);
if (level > 0) {
Expand Down
6 changes: 1 addition & 5 deletions drivers/video/fbdev/aty/radeon_backlight.c
Original file line number Diff line number Diff line change
Expand Up @@ -57,11 +57,7 @@ static int radeon_bl_update_status(struct backlight_device *bd)
* backlight. This provides some greater power saving and the display
* is useless without backlight anyway.
*/
if (bd->props.power != FB_BLANK_UNBLANK ||
bd->props.fb_blank != FB_BLANK_UNBLANK)
level = 0;
else
level = bd->props.brightness;
level = backlight_get_brightness(bd);

del_timer_sync(&rinfo->lvds_timer);
radeon_engine_idle();
Expand Down
7 changes: 5 additions & 2 deletions drivers/video/fbdev/core/fbcon.c
Original file line number Diff line number Diff line change
Expand Up @@ -2495,9 +2495,12 @@ static int fbcon_set_font(struct vc_data *vc, struct console_font *font,
h > FBCON_SWAP(info->var.rotate, info->var.yres, info->var.xres))
return -EINVAL;

if (font->width > 32 || font->height > 32)
return -EINVAL;

/* Make sure drawing engine can handle the font */
if (!(info->pixmap.blit_x & (1 << (font->width - 1))) ||
!(info->pixmap.blit_y & (1 << (font->height - 1))))
if (!(info->pixmap.blit_x & BIT(font->width - 1)) ||
!(info->pixmap.blit_y & BIT(font->height - 1)))
return -EINVAL;

/* Make sure driver can handle the font length */
Expand Down
2 changes: 1 addition & 1 deletion drivers/video/fbdev/core/fbmon.c
Original file line number Diff line number Diff line change
Expand Up @@ -1050,7 +1050,7 @@ static u32 fb_get_vblank(u32 hfreq)
}

/**
* fb_get_hblank_by_freq - get horizontal blank time given hfreq
* fb_get_hblank_by_hfreq - get horizontal blank time given hfreq
* @hfreq: horizontal freq
* @xres: horizontal resolution in pixels
*
Expand Down
7 changes: 1 addition & 6 deletions drivers/video/fbdev/mx3fb.c
Original file line number Diff line number Diff line change
Expand Up @@ -283,12 +283,7 @@ static int mx3fb_bl_get_brightness(struct backlight_device *bl)
static int mx3fb_bl_update_status(struct backlight_device *bl)
{
struct mx3fb_data *fbd = bl_get_data(bl);
int brightness = bl->props.brightness;

if (bl->props.power != FB_BLANK_UNBLANK)
brightness = 0;
if (bl->props.fb_blank != FB_BLANK_UNBLANK)
brightness = 0;
int brightness = backlight_get_brightness(bl);

fbd->backlight_level = (fbd->backlight_level & ~0xFF) | brightness;

Expand Down
8 changes: 1 addition & 7 deletions drivers/video/fbdev/nvidia/nv_backlight.c
Original file line number Diff line number Diff line change
Expand Up @@ -49,17 +49,11 @@ static int nvidia_bl_update_status(struct backlight_device *bd)
{
struct nvidia_par *par = bl_get_data(bd);
u32 tmp_pcrt, tmp_pmc, fpcontrol;
int level;
int level = backlight_get_brightness(bd);

if (!par->FlatPanel)
return 0;

if (bd->props.power != FB_BLANK_UNBLANK ||
bd->props.fb_blank != FB_BLANK_UNBLANK)
level = 0;
else
level = bd->props.brightness;

tmp_pmc = NV_RD32(par->PMC, 0x10F0) & 0x0000FFFF;
tmp_pcrt = NV_RD32(par->PCRTC0, 0x081C) & 0xFFFFFFFC;
fpcontrol = NV_RD32(par->PRAMDAC, 0x0848) & 0xCFFFFFCC;
Expand Down
8 changes: 1 addition & 7 deletions drivers/video/fbdev/omap2/omapfb/displays/panel-dsi-cm.c
Original file line number Diff line number Diff line change
Expand Up @@ -331,13 +331,7 @@ static int dsicm_bl_update_status(struct backlight_device *dev)
struct panel_drv_data *ddata = dev_get_drvdata(&dev->dev);
struct omap_dss_device *in = ddata->in;
int r;
int level;

if (dev->props.fb_blank == FB_BLANK_UNBLANK &&
dev->props.power == FB_BLANK_UNBLANK)
level = dev->props.brightness;
else
level = 0;
int level = backlight_get_brightness(dev);

dev_dbg(&ddata->pdev->dev, "update brightness to %d\n", level);

Expand Down
7 changes: 4 additions & 3 deletions drivers/video/fbdev/omap2/omapfb/dss/display-sysfs.c
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@
#define DSS_SUBSYS_NAME "DISPLAY"

#include <linux/kernel.h>
#include <linux/kstrtox.h>
#include <linux/module.h>
#include <linux/platform_device.h>
#include <linux/sysfs.h>
Expand All @@ -36,7 +37,7 @@ static ssize_t display_enabled_store(struct omap_dss_device *dssdev,
int r;
bool enable;

r = strtobool(buf, &enable);
r = kstrtobool(buf, &enable);
if (r)
return r;

Expand Down Expand Up @@ -73,7 +74,7 @@ static ssize_t display_tear_store(struct omap_dss_device *dssdev,
if (!dssdev->driver->enable_te || !dssdev->driver->get_te)
return -ENOENT;

r = strtobool(buf, &te);
r = kstrtobool(buf, &te);
if (r)
return r;

Expand Down Expand Up @@ -183,7 +184,7 @@ static ssize_t display_mirror_store(struct omap_dss_device *dssdev,
if (!dssdev->driver->set_mirror || !dssdev->driver->get_mirror)
return -ENOENT;

r = strtobool(buf, &mirror);
r = kstrtobool(buf, &mirror);
if (r)
return r;

Expand Down
7 changes: 4 additions & 3 deletions drivers/video/fbdev/omap2/omapfb/dss/manager-sysfs.c
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@
#define DSS_SUBSYS_NAME "MANAGER"

#include <linux/kernel.h>
#include <linux/kstrtox.h>
#include <linux/slab.h>
#include <linux/module.h>
#include <linux/platform_device.h>
Expand Down Expand Up @@ -246,7 +247,7 @@ static ssize_t manager_trans_key_enabled_store(struct omap_overlay_manager *mgr,
bool enable;
int r;

r = strtobool(buf, &enable);
r = kstrtobool(buf, &enable);
if (r)
return r;

Expand Down Expand Up @@ -290,7 +291,7 @@ static ssize_t manager_alpha_blending_enabled_store(
if(!dss_has_feature(FEAT_ALPHA_FIXED_ZORDER))
return -ENODEV;

r = strtobool(buf, &enable);
r = kstrtobool(buf, &enable);
if (r)
return r;

Expand Down Expand Up @@ -329,7 +330,7 @@ static ssize_t manager_cpr_enable_store(struct omap_overlay_manager *mgr,
if (!dss_has_feature(FEAT_CPR))
return -ENODEV;

r = strtobool(buf, &enable);
r = kstrtobool(buf, &enable);
if (r)
return r;

Expand Down
3 changes: 2 additions & 1 deletion drivers/video/fbdev/omap2/omapfb/dss/overlay-sysfs.c
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,7 @@
#include <linux/err.h>
#include <linux/sysfs.h>
#include <linux/kobject.h>
#include <linux/kstrtox.h>
#include <linux/platform_device.h>

#include <video/omapfb_dss.h>
Expand Down Expand Up @@ -210,7 +211,7 @@ static ssize_t overlay_enabled_store(struct omap_overlay *ovl, const char *buf,
int r;
bool enable;

r = strtobool(buf, &enable);
r = kstrtobool(buf, &enable);
if (r)
return r;

Expand Down
3 changes: 2 additions & 1 deletion drivers/video/fbdev/omap2/omapfb/omapfb-sysfs.c
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@
#include <linux/uaccess.h>
#include <linux/platform_device.h>
#include <linux/kernel.h>
#include <linux/kstrtox.h>
#include <linux/mm.h>
#include <linux/omapfb.h>

Expand Down Expand Up @@ -96,7 +97,7 @@ static ssize_t store_mirror(struct device *dev,
int r;
struct fb_var_screeninfo new_var;

r = strtobool(buf, &mirror);
r = kstrtobool(buf, &mirror);
if (r)
return r;

Expand Down
8 changes: 1 addition & 7 deletions drivers/video/fbdev/riva/fbdev.c
Original file line number Diff line number Diff line change
Expand Up @@ -293,13 +293,7 @@ static int riva_bl_update_status(struct backlight_device *bd)
{
struct riva_par *par = bl_get_data(bd);
U032 tmp_pcrt, tmp_pmc;
int level;

if (bd->props.power != FB_BLANK_UNBLANK ||
bd->props.fb_blank != FB_BLANK_UNBLANK)
level = 0;
else
level = bd->props.brightness;
int level = backlight_get_brightness(bd);

tmp_pmc = NV_RD32(par->riva.PMC, 0x10F0) & 0x0000FFFF;
tmp_pcrt = NV_RD32(par->riva.PCRTC0, 0x081C) & 0xFFFFFFFC;
Expand Down

0 comments on commit 870c3a9

Please sign in to comment.