blob: aba99b5f2bd4967434eaf8004559b6e6a6e4fec0 [file] [log] [blame]
/*
* Copyright (c) 2009, Google Inc.
* All rights reserved.
* Copyright (c) 2009-2010, Code Aurora Forum. All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
* * Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* * Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in
* the documentation and/or other materials provided with the
* distribution.
* * Neither the name of Google, Inc. nor the names of its contributors
* may be used to endorse or promote products derived from this
* software without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
* OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
* AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
* OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
* OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
* SUCH DAMAGE.
*/
#include <debug.h>
#include <dev/keys.h>
#include <dev/gpio_keypad.h>
#include <lib/ptable.h>
#include <dev/flash.h>
#include <smem.h>
#include <platform/iomap.h>
#include <reg.h>
#define LINUX_MACHTYPE_8660_SURF 1009002
#define LINUX_MACHTYPE_8660_FFA 1009003
void keypad_init(void);
static int emmc_boot = -1; /* set to uninitialized */
int target_is_emmc_boot(void);
void debug_led_write(char);
char debug_led_read();
void target_init(void)
{
dprintf(INFO, "target_init()\n");
setup_fpga();
#if (!ENABLE_NANDWRITE)
keys_init();
keypad_init();
#endif
if(mmc_boot_main())
{
dprintf(CRITICAL, "mmc init failed!");
ASSERT(0);
}
}
unsigned board_machtype(void)
{
/* Writing to Debug LED register and reading back to auto detect
SURF and FFA. If we read back, it is SURF */
debug_led_write(0xA5);
if((debug_led_read() & 0xFF) == 0xA5)
{
debug_led_write(0);
return LINUX_MACHTYPE_8660_SURF;
}
else
return LINUX_MACHTYPE_8660_FFA;
}
void reboot_device(unsigned reboot_reason)
{
return;
}
unsigned check_reboot_mode(void)
{
return 0;
}
void target_battery_charging_enable(unsigned enable, unsigned disconnect)
{
}
void setup_fpga()
{
writel(0x147, GPIO_CFG133_ADDR);
writel(0x144, GPIO_CFG135_ADDR);
writel(0x144, GPIO_CFG136_ADDR);
writel(0x144, GPIO_CFG137_ADDR);
writel(0x144, GPIO_CFG138_ADDR);
writel(0x144, GPIO_CFG139_ADDR);
writel(0x144, GPIO_CFG140_ADDR);
writel(0x144, GPIO_CFG141_ADDR);
writel(0x144, GPIO_CFG142_ADDR);
writel(0x144, GPIO_CFG143_ADDR);
writel(0x144, GPIO_CFG144_ADDR);
writel(0x144, GPIO_CFG145_ADDR);
writel(0x144, GPIO_CFG146_ADDR);
writel(0x144, GPIO_CFG147_ADDR);
writel(0x144, GPIO_CFG148_ADDR);
writel(0x144, GPIO_CFG149_ADDR);
writel(0x144, GPIO_CFG150_ADDR);
writel(0x147, GPIO_CFG151_ADDR);
writel(0x147, GPIO_CFG152_ADDR);
writel(0x147, GPIO_CFG153_ADDR);
writel(0x3, GPIO_CFG154_ADDR);
writel(0x147, GPIO_CFG155_ADDR);
writel(0x147, GPIO_CFG156_ADDR);
writel(0x147, GPIO_CFG157_ADDR);
writel(0x3, GPIO_CFG158_ADDR);
writel(0x00000B31, EBI2_CHIP_SELECT_CFG0);
writel(0xA3030020, EBI2_XMEM_CS3_CFG1);
}
void debug_led_write(char val)
{
writeb(val,SURF_DEBUG_LED_ADDR);
}
char debug_led_read()
{
return readb(SURF_DEBUG_LED_ADDR);
}