drivers/lcd: ssd1306: separate lcd_dev_s setup to separate object. g_oleddev takes 1 KiB because framebuffer and was allocated to .data section because of lcd_dev_s function pointer setup. Move lcd_dev_s setup out, so that g_oleddev goes to .bss and avoid wasting ROM.

This commit is contained in:
Jussi Kivilinna 2017-08-22 08:46:00 -06:00 committed by Gregory Nutt
parent 89cc4741ac
commit a099506b1b

View File

@ -221,12 +221,10 @@ static const struct lcd_planeinfo_s g_planeinfo =
.bpp = SSD1306_DEV_BPP, /* Bits-per-pixel */
};
/* This is the OLED driver instance (only a single device is supported for now) */
/* This is the outside visible interface for the OLED driver */
static struct ssd1306_dev_s g_oleddev =
static const struct lcd_dev_s g_oleddev_dev =
{
.dev =
{
/* LCD Configuration */
.getvideoinfo = ssd1306_getvideoinfo,
@ -241,9 +239,12 @@ static struct ssd1306_dev_s g_oleddev =
.setpower = ssd1306_setpower,
.getcontrast = ssd1306_getcontrast,
.setcontrast = ssd1306_setcontrast,
},
};
/* This is the OLED driver instance (only a single device is supported for now) */
static struct ssd1306_dev_s g_oleddev;
/**************************************************************************************
* Private Functions
**************************************************************************************/
@ -1035,6 +1036,8 @@ FAR struct lcd_dev_s *ssd1306_initialize(FAR struct i2c_master_s *dev,
{
FAR struct ssd1306_dev_s *priv = &g_oleddev;
priv->dev = g_oleddev_dev;
DEBUGASSERT(dev && devno == 0);
priv->on = false;