1
0
mirror of https://xff.cz/git/u-boot/ synced 2025-09-01 16:52:14 +02:00

lcd: Add support for flushing LCD fb from dcache after update

This provides an option for the LCD to flush the dcache after each update
(puts, scroll or clear).

Signed-off-by: Simon Glass <sjg@chromium.org>
Signed-off-by: Tom Warren <twarren@nvidia.com>
This commit is contained in:
Simon Glass
2012-10-30 13:40:18 +00:00
committed by Tom Warren
parent 676d319ef5
commit 9a8efc4604
3 changed files with 57 additions and 9 deletions

View File

@@ -94,6 +94,9 @@ static void lcd_setbgcolor(int color);
char lcd_is_enabled = 0; char lcd_is_enabled = 0;
static char lcd_flush_dcache; /* 1 to flush dcache after each lcd update */
#ifdef NOT_USED_SO_FAR #ifdef NOT_USED_SO_FAR
static void lcd_getcolreg(ushort regno, static void lcd_getcolreg(ushort regno,
ushort *red, ushort *green, ushort *blue); ushort *red, ushort *green, ushort *blue);
@@ -102,6 +105,28 @@ static int lcd_getfgcolor(void);
/************************************************************************/ /************************************************************************/
/* Flush LCD activity to the caches */
void lcd_sync(void)
{
/*
* flush_dcache_range() is declared in common.h but it seems that some
* architectures do not actually implement it. Is there a way to find
* out whether it exists? For now, ARM is safe.
*/
#if defined(CONFIG_ARM) && !defined(CONFIG_SYS_DCACHE_OFF)
int line_length;
if (lcd_flush_dcache)
flush_dcache_range((u32)lcd_base,
(u32)(lcd_base + lcd_get_size(&line_length)));
#endif
}
void lcd_set_flush_dcache(int flush)
{
lcd_flush_dcache = (flush != 0);
}
/*----------------------------------------------------------------------*/ /*----------------------------------------------------------------------*/
static void console_scrollup(void) static void console_scrollup(void)
@@ -111,6 +136,7 @@ static void console_scrollup(void)
/* Clear the last one */ /* Clear the last one */
memset(CONSOLE_ROW_LAST, COLOR_MASK(lcd_color_bg), CONSOLE_ROW_SIZE); memset(CONSOLE_ROW_LAST, COLOR_MASK(lcd_color_bg), CONSOLE_ROW_SIZE);
lcd_sync();
} }
/*----------------------------------------------------------------------*/ /*----------------------------------------------------------------------*/
@@ -140,6 +166,8 @@ static inline void console_newline(void)
/* Scroll everything up */ /* Scroll everything up */
console_scrollup(); console_scrollup();
--console_row; --console_row;
} else {
lcd_sync();
} }
} }
@@ -195,6 +223,7 @@ void lcd_puts(const char *s)
while (*s) { while (*s) {
lcd_putc(*s++); lcd_putc(*s++);
} }
lcd_sync();
} }
/*----------------------------------------------------------------------*/ /*----------------------------------------------------------------------*/
@@ -362,13 +391,6 @@ int drv_lcd_init (void)
} }
/*----------------------------------------------------------------------*/ /*----------------------------------------------------------------------*/
static
int do_lcd_clear(cmd_tbl_t *cmdtp, int flag, int argc, char *const argv[])
{
lcd_clear();
return 0;
}
void lcd_clear(void) void lcd_clear(void)
{ {
#if LCD_BPP == LCD_MONOCHROME #if LCD_BPP == LCD_MONOCHROME
@@ -410,6 +432,14 @@ void lcd_clear(void)
console_col = 0; console_col = 0;
console_row = 0; console_row = 0;
lcd_sync();
}
static int do_lcd_clear(cmd_tbl_t *cmdtp, int flag, int argc,
char *const argv[])
{
lcd_clear();
return 0;
} }
U_BOOT_CMD( U_BOOT_CMD(
@@ -621,6 +651,7 @@ void bitmap_plot(int x, int y)
} }
WATCHDOG_RESET(); WATCHDOG_RESET();
lcd_sync();
} }
#else #else
static inline void bitmap_plot(int x, int y) {} static inline void bitmap_plot(int x, int y) {}
@@ -842,6 +873,7 @@ int lcd_display_bitmap(ulong bmp_image, int x, int y)
break; break;
}; };
lcd_sync();
return 0; return 0;
} }
#endif #endif

View File

@@ -1041,8 +1041,16 @@ int readline_into_buffer(const char *const prompt, char *buffer, int timeout)
puts (tab_seq+(col&07)); puts (tab_seq+(col&07));
col += 8 - (col&07); col += 8 - (col&07);
} else { } else {
++col; /* echo input */ char buf[2];
putc (c);
/*
* Echo input using puts() to force am
* LCD flush if we are using an LCD
*/
++col;
buf[0] = c;
buf[1] = '\0';
puts(buf);
} }
*p++ = c; *p++ = c;
++n; ++n;

View File

@@ -57,6 +57,14 @@ extern void lcd_initcolregs (void);
extern struct bmp_image *gunzip_bmp(unsigned long addr, unsigned long *lenp); extern struct bmp_image *gunzip_bmp(unsigned long addr, unsigned long *lenp);
extern int bmp_display(ulong addr, int x, int y); extern int bmp_display(ulong addr, int x, int y);
/**
* Set whether we need to flush the dcache when changing the LCD image. This
* defaults to off.
*
* @param flush non-zero to flush cache after update, 0 to skip
*/
void lcd_set_flush_dcache(int flush);
#if defined CONFIG_MPC823 #if defined CONFIG_MPC823
/* /*
* LCD controller stucture for MPC823 CPU * LCD controller stucture for MPC823 CPU