]> git.kernelconcepts.de Git - karo-tx-uboot.git/blobdiff - common/splash.c
JFFS2: Speed up and fix comparison functions
[karo-tx-uboot.git] / common / splash.c
index 5cf52723a565980c19b744299c1e84ab58d635c0..561d35b4e41f9072d84e430d028e92ec8aecd8c3 100644 (file)
  *
  */
 
+#include <common.h>
 #include <splash.h>
-#include <config.h>
+#include <lcd.h>
 
-#ifdef CONFIG_SPLASH_SCREEN_PREPARE
-int splash_screen_prepare(void)
+__weak int splash_screen_prepare(void)
 {
-       return board_splash_screen_prepare();
+       return 0;
 }
-#else
-int splash_screen_prepare(void)
+
+#ifdef CONFIG_SPLASH_SCREEN_ALIGN
+void splash_get_pos(int *x, int *y)
 {
-       return 0;
+       char *s = getenv("splashpos");
+
+       if (!s)
+               return;
+
+       if (s[0] == 'm')
+               *x = BMP_ALIGN_CENTER;
+       else
+               *x = simple_strtol(s, NULL, 0);
+
+       s = strchr(s + 1, ',');
+       if (s != NULL) {
+               if (s[1] == 'm')
+                       *y = BMP_ALIGN_CENTER;
+               else
+                       *y = simple_strtol(s + 1, NULL, 0);
+       }
+}
+#endif /* CONFIG_SPLASH_SCREEN_ALIGN */
+
+#if defined(CONFIG_SPLASH_SCREEN) && defined(CONFIG_LCD)
+int lcd_splash(ulong addr)
+{
+       int x = 0, y = 0, ret;
+
+       ret = splash_screen_prepare();
+       if (ret)
+               return ret;
+
+       splash_get_pos(&x, &y);
+
+       return bmp_display(addr, x, y);
 }
 #endif