summaryrefslogtreecommitdiff
path: root/board
diff options
context:
space:
mode:
authorMichael Jones <michael.jones@matrix-vision.de>2013-02-07 23:53:36 +0000
committerTom Rini <trini@ti.com>2013-02-18 13:51:20 -0500
commit71c4ae3f6db39b888497923573bff215b64a36bd (patch)
tree54174c43617465b1efadd9663a8ad061a4c952a5 /board
parent661bb0f8f49303891b8460149943e32337544e03 (diff)
downloadu-boot-imx-71c4ae3f6db39b888497923573bff215b64a36bd.zip
u-boot-imx-71c4ae3f6db39b888497923573bff215b64a36bd.tar.gz
u-boot-imx-71c4ae3f6db39b888497923573bff215b64a36bd.tar.bz2
omap3: mvblx: select fpgafilename according to orientation
Rather than load the FPGA file from the FAT partition, look at entry in system EEPROM to decide which file to retrieve directly from the EXT3 partition. Signed-off-by: Michael Jones <michael.jones@matrix-vision.de>
Diffstat (limited to 'board')
-rw-r--r--board/matrix_vision/mvblx/sys_eeprom.c24
1 files changed, 24 insertions, 0 deletions
diff --git a/board/matrix_vision/mvblx/sys_eeprom.c b/board/matrix_vision/mvblx/sys_eeprom.c
index 945a36d..15269c6 100644
--- a/board/matrix_vision/mvblx/sys_eeprom.c
+++ b/board/matrix_vision/mvblx/sys_eeprom.c
@@ -326,10 +326,28 @@ int do_mac(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
return 0;
}
+static inline int is_portrait(void)
+{
+ int i;
+ unsigned int orient_index = 0; /* idx of char which determines orientation */
+
+ for (i = sizeof(e.id)/sizeof(*e.id) - 1; i>=0; i--) {
+ if (e.id[i] == '-') {
+ orient_index = i+1;
+ break;
+ }
+ }
+
+ return (orient_index &&
+ (e.id[orient_index] >= '5') && (e.id[orient_index] <= '8'));
+}
+
int mac_read_from_eeprom(void)
{
u32 crc, crc_offset = offsetof(struct eeprom, crc);
u32 *crcp; /* Pointer to the CRC in the data read from the EEPROM */
+#define FILENAME_LANDSCAPE "mvBlueLynx_X.rbf"
+#define FILENAME_PORTRAIT "mvBlueLynx_X_sensor_cd.rbf"
if (read_eeprom()) {
printf("EEPROM Read failed.\n");
@@ -374,6 +392,12 @@ int mac_read_from_eeprom(void)
setenv("serial#", serial_num);
}
+ /* decide which fpga file to load depending on orientation */
+ if (is_portrait())
+ setenv("fpgafilename", FILENAME_PORTRAIT);
+ else
+ setenv("fpgafilename", FILENAME_LANDSCAPE);
+
/* TODO should I calculate CRC here? */
return 0;
}