189f95492SHeungJun, Kim /* 289f95492SHeungJun, Kim * Copyright (C) 2011 Samsung Electronics 389f95492SHeungJun, Kim * Heungjun Kim <riverful.kim@samsung.com> 489f95492SHeungJun, Kim * 589f95492SHeungJun, Kim * Configuation settings for the SAMSUNG TRATS (EXYNOS4210) board. 689f95492SHeungJun, Kim * 71a459660SWolfgang Denk * SPDX-License-Identifier: GPL-2.0+ 889f95492SHeungJun, Kim */ 989f95492SHeungJun, Kim 10fe601647SPiotr Wilczek #ifndef __CONFIG_TRATS_H 11fe601647SPiotr Wilczek #define __CONFIG_TRATS_H 1289f95492SHeungJun, Kim 13fe601647SPiotr Wilczek #include <configs/exynos4-dt.h> 14fe601647SPiotr Wilczek 15fe601647SPiotr Wilczek #define CONFIG_SYS_PROMPT "Trats # " /* Monitor Command Prompt */ 16fe601647SPiotr Wilczek 17fe601647SPiotr Wilczek #define CONFIG_TRATS 18fe601647SPiotr Wilczek 19fe601647SPiotr Wilczek #undef CONFIG_DEFAULT_DEVICE_TREE 20fe601647SPiotr Wilczek #define CONFIG_DEFAULT_DEVICE_TREE exynos4210-trats 21fe601647SPiotr Wilczek 2290464971SDonghwa Lee #define CONFIG_TIZEN /* TIZEN lib */ 2389f95492SHeungJun, Kim 24c4e96dbfSŁukasz Majewski #define CONFIG_SYS_L2CACHE_OFF 25d0460b01SŁukasz Majewski #ifndef CONFIG_SYS_L2CACHE_OFF 26d0460b01SŁukasz Majewski #define CONFIG_SYS_L2_PL310 27d0460b01SŁukasz Majewski #define CONFIG_SYS_PL310_BASE 0x10502000 28d0460b01SŁukasz Majewski #endif 2989f95492SHeungJun, Kim 30fe601647SPiotr Wilczek /* TRATS has 4 banks of DRAM */ 31fe601647SPiotr Wilczek #define CONFIG_NR_DRAM_BANKS 4 3289f95492SHeungJun, Kim #define CONFIG_SYS_SDRAM_BASE 0x40000000 33fe601647SPiotr Wilczek #define PHYS_SDRAM_1 CONFIG_SYS_SDRAM_BASE 3489f95492SHeungJun, Kim #define CONFIG_SYS_TEXT_BASE 0x63300000 35fe601647SPiotr Wilczek #define SDRAM_BANK_SIZE (256 << 20) /* 256 MB */ 3689f95492SHeungJun, Kim 37fe601647SPiotr Wilczek /* memtest works on */ 38fe601647SPiotr Wilczek #define CONFIG_SYS_MEMTEST_START CONFIG_SYS_SDRAM_BASE 39fe601647SPiotr Wilczek #define CONFIG_SYS_MEMTEST_END (CONFIG_SYS_SDRAM_BASE + 0x5000000) 40fe601647SPiotr Wilczek #define CONFIG_SYS_LOAD_ADDR (CONFIG_SYS_SDRAM_BASE + 0x4800000) 4189f95492SHeungJun, Kim 42fe601647SPiotr Wilczek #define CONFIG_SYS_TEXT_BASE 0x63300000 4389f95492SHeungJun, Kim 441ace4022SAlexey Brodkin #include <linux/sizes.h> 4589f95492SHeungJun, Kim /* Size of malloc() pool */ 46e96751daSLukasz Majewski #define CONFIG_SYS_MALLOC_LEN (CONFIG_ENV_SIZE + (80 * SZ_1M)) 4789f95492SHeungJun, Kim 4889f95492SHeungJun, Kim /* select serial console configuration */ 49fe601647SPiotr Wilczek #define CONFIG_SERIAL2 5089f95492SHeungJun, Kim #define CONFIG_BAUDRATE 115200 5189f95492SHeungJun, Kim 52fe601647SPiotr Wilczek /* Console configuration */ 53fe601647SPiotr Wilczek #define CONFIG_SYS_CONSOLE_INFO_QUIET 54fe601647SPiotr Wilczek #define CONFIG_SYS_CONSOLE_IS_IN_ENV 5589f95492SHeungJun, Kim 56fe601647SPiotr Wilczek /* MACH_TYPE_TRATS macro will be removed once added to mach-types */ 57fe601647SPiotr Wilczek #define MACH_TYPE_TRATS 3928 58fe601647SPiotr Wilczek #define CONFIG_MACH_TYPE MACH_TYPE_TRATS 5989f95492SHeungJun, Kim 6089f95492SHeungJun, Kim #define CONFIG_BOOTARGS "Please use defined boot" 6189f95492SHeungJun, Kim #define CONFIG_BOOTCOMMAND "run mmcboot" 62fe601647SPiotr Wilczek #define CONFIG_DEFAULT_CONSOLE "console=ttySAC1,115200n8\0" 6389f95492SHeungJun, Kim 64fe601647SPiotr Wilczek #define CONFIG_SYS_INIT_SP_ADDR (CONFIG_SYS_LOAD_ADDR \ 65fe601647SPiotr Wilczek - GENERATED_GBL_DATA_SIZE) 66fe601647SPiotr Wilczek 67fe601647SPiotr Wilczek #define CONFIG_SYS_MEM_TOP_HIDE (1 << 20) /* ram console */ 68fe601647SPiotr Wilczek 69fe601647SPiotr Wilczek #define CONFIG_SYS_MONITOR_BASE 0x00000000 70fe601647SPiotr Wilczek 7189f95492SHeungJun, Kim #define CONFIG_BOOTBLOCK "10" 7289f95492SHeungJun, Kim #define CONFIG_ENV_COMMON_BOOT "${console} ${meminfo}" 7389f95492SHeungJun, Kim 74fe601647SPiotr Wilczek #define CONFIG_ENV_IS_IN_MMC 75fe601647SPiotr Wilczek #define CONFIG_SYS_MMC_ENV_DEV CONFIG_MMC_DEFAULT_DEV 76fe601647SPiotr Wilczek #define CONFIG_ENV_SIZE 4096 77fe601647SPiotr Wilczek #define CONFIG_ENV_OFFSET ((32 - 4) << 10) /* 32KiB - 4KiB */ 78fe601647SPiotr Wilczek 79fe601647SPiotr Wilczek #define CONFIG_ENV_OVERWRITE 80fe601647SPiotr Wilczek 81fe601647SPiotr Wilczek #define CONFIG_ENV_VARS_UBOOT_CONFIG 82fe601647SPiotr Wilczek #define CONFIG_ENV_VARS_UBOOT_RUNTIME_CONFIG 83fe601647SPiotr Wilczek 849960d9a8SLukasz Majewski /* Tizen - partitions definitions */ 859960d9a8SLukasz Majewski #define PARTS_CSA "csa-mmc" 869960d9a8SLukasz Majewski #define PARTS_BOOT "boot" 87*18f3e0ebSPrzemyslaw Marczak #define PARTS_QBOOT "qboot" 88*18f3e0ebSPrzemyslaw Marczak #define PARTS_CSC "csc" 899960d9a8SLukasz Majewski #define PARTS_ROOT "platform" 909960d9a8SLukasz Majewski #define PARTS_DATA "data" 919960d9a8SLukasz Majewski #define PARTS_UMS "ums" 929960d9a8SLukasz Majewski 939960d9a8SLukasz Majewski #define PARTS_DEFAULT \ 949960d9a8SLukasz Majewski "uuid_disk=${uuid_gpt_disk};" \ 95*18f3e0ebSPrzemyslaw Marczak "name="PARTS_CSA",start=5MiB,size=8MiB,uuid=${uuid_gpt_"PARTS_CSA"};" \ 96*18f3e0ebSPrzemyslaw Marczak "name="PARTS_BOOT",size=60MiB,uuid=${uuid_gpt_"PARTS_BOOT"};" \ 97*18f3e0ebSPrzemyslaw Marczak "name="PARTS_QBOOT",size=100MiB,uuid=${uuid_gpt_"PARTS_QBOOT"};" \ 989960d9a8SLukasz Majewski "name="PARTS_CSC",size=150MiB,uuid=${uuid_gpt_"PARTS_CSC"};" \ 99*18f3e0ebSPrzemyslaw Marczak "name="PARTS_ROOT",size=1536MiB,uuid=${uuid_gpt_"PARTS_ROOT"};" \ 100*18f3e0ebSPrzemyslaw Marczak "name="PARTS_DATA",size=3000MiB,uuid=${uuid_gpt_"PARTS_DATA"};" \ 1019960d9a8SLukasz Majewski "name="PARTS_UMS",size=-,uuid=${uuid_gpt_"PARTS_UMS"}\0" \ 1029960d9a8SLukasz Majewski 10393a1ab57SLukasz Majewski #define CONFIG_DFU_ALT \ 10493a1ab57SLukasz Majewski "u-boot mmc 80 400;" \ 105ba223bb2SArkadiusz Wlodarczyk "uImage ext4 0 2;" \ 106*18f3e0ebSPrzemyslaw Marczak "modem.bin ext4 0 2;" \ 107e96751daSLukasz Majewski "exynos4210-trats.dtb ext4 0 2;" \ 108*18f3e0ebSPrzemyslaw Marczak ""PARTS_CSA" part 0 1;" \ 109cdd15bceSŁukasz Majewski ""PARTS_BOOT" part 0 2;" \ 110*18f3e0ebSPrzemyslaw Marczak ""PARTS_QBOOT" part 0 3;" \ 111*18f3e0ebSPrzemyslaw Marczak ""PARTS_CSC" part 0 4;" \ 112cdd15bceSŁukasz Majewski ""PARTS_ROOT" part 0 5;" \ 113cdd15bceSŁukasz Majewski ""PARTS_DATA" part 0 6;" \ 114a0afc6f3SPrzemyslaw Marczak ""PARTS_UMS" part 0 7;" \ 115a0afc6f3SPrzemyslaw Marczak "params.bin mmc 0x38 0x8\0" 11693a1ab57SLukasz Majewski 11789f95492SHeungJun, Kim #define CONFIG_EXTRA_ENV_SETTINGS \ 11889f95492SHeungJun, Kim "bootk=" \ 119425e26deSPiotr Wilczek "run loaduimage;" \ 120425e26deSPiotr Wilczek "if run loaddtb; then " \ 121425e26deSPiotr Wilczek "bootm 0x40007FC0 - ${fdtaddr};" \ 122425e26deSPiotr Wilczek "fi;" \ 123425e26deSPiotr Wilczek "bootm 0x40007FC0;\0" \ 12489f95492SHeungJun, Kim "updatemmc=" \ 12589f95492SHeungJun, Kim "mmc boot 0 1 1 1; mmc write 0 0x42008000 0 0x200;" \ 12689f95492SHeungJun, Kim "mmc boot 0 1 1 0\0" \ 12789f95492SHeungJun, Kim "updatebackup=" \ 12889f95492SHeungJun, Kim "mmc boot 0 1 1 2; mmc write 0 0x42100000 0 0x200;" \ 12989f95492SHeungJun, Kim "mmc boot 0 1 1 0\0" \ 13089f95492SHeungJun, Kim "updatebootb=" \ 13189f95492SHeungJun, Kim "mmc read 0 0x42100000 0x80 0x200; run updatebackup\0" \ 13289f95492SHeungJun, Kim "lpj=lpj=3981312\0" \ 13389f95492SHeungJun, Kim "nfsboot=" \ 13435777e22SŁukasz Majewski "setenv bootargs root=/dev/nfs rw " \ 13589f95492SHeungJun, Kim "nfsroot=${nfsroot},nolock,tcp " \ 13689f95492SHeungJun, Kim "ip=${ipaddr}:${serverip}:${gatewayip}:" \ 13789f95492SHeungJun, Kim "${netmask}:generic:usb0:off " CONFIG_ENV_COMMON_BOOT \ 13889f95492SHeungJun, Kim "; run bootk\0" \ 13989f95492SHeungJun, Kim "ramfsboot=" \ 14035777e22SŁukasz Majewski "setenv bootargs root=/dev/ram0 rw rootfstype=ext2 " \ 14189f95492SHeungJun, Kim "${console} ${meminfo} " \ 14289f95492SHeungJun, Kim "initrd=0x43000000,8M ramdisk=8192\0" \ 14389f95492SHeungJun, Kim "mmcboot=" \ 14435777e22SŁukasz Majewski "setenv bootargs root=/dev/mmcblk${mmcdev}p${mmcrootpart} " \ 14589f95492SHeungJun, Kim "${lpj} rootwait ${console} ${meminfo} ${opts} ${lcdinfo}; " \ 146425e26deSPiotr Wilczek "run bootk\0" \ 14735777e22SŁukasz Majewski "bootchart=setenv opts init=/sbin/bootchartd; run bootcmd\0" \ 14889f95492SHeungJun, Kim "boottrace=setenv opts initcall_debug; run bootcmd\0" \ 14989f95492SHeungJun, Kim "mmcoops=mmc read 0 0x40000000 0x40 8; md 0x40000000 0x400\0" \ 15089f95492SHeungJun, Kim "verify=n\0" \ 15189f95492SHeungJun, Kim "rootfstype=ext4\0" \ 15289f95492SHeungJun, Kim "console=" CONFIG_DEFAULT_CONSOLE \ 15389f95492SHeungJun, Kim "meminfo=crashkernel=32M@0x50000000\0" \ 15489f95492SHeungJun, Kim "nfsroot=/nfsroot/arm\0" \ 15589f95492SHeungJun, Kim "bootblock=" CONFIG_BOOTBLOCK "\0" \ 15635777e22SŁukasz Majewski "loaduimage=ext4load mmc ${mmcdev}:${mmcbootpart} 0x40007FC0 uImage\0" \ 157ba223bb2SArkadiusz Wlodarczyk "loaddtb=ext4load mmc ${mmcdev}:${mmcbootpart} ${fdtaddr} " \ 158ba223bb2SArkadiusz Wlodarczyk "${fdtfile}\0" \ 15989f95492SHeungJun, Kim "mmcdev=0\0" \ 16089f95492SHeungJun, Kim "mmcbootpart=2\0" \ 16135777e22SŁukasz Majewski "mmcrootpart=5\0" \ 16293a1ab57SLukasz Majewski "opts=always_resume=1\0" \ 1639960d9a8SLukasz Majewski "partitions=" PARTS_DEFAULT \ 16435777e22SŁukasz Majewski "dfu_alt_info=" CONFIG_DFU_ALT \ 16535777e22SŁukasz Majewski "spladdr=0x40000100\0" \ 16635777e22SŁukasz Majewski "splsize=0x200\0" \ 16735777e22SŁukasz Majewski "splfile=falcon.bin\0" \ 16835777e22SŁukasz Majewski "spl_export=" \ 16935777e22SŁukasz Majewski "setexpr spl_imgsize ${splsize} + 8 ;" \ 170dc993a65SPrzemyslaw Marczak "setenv spl_imgsize 0x${spl_imgsize};" \ 17135777e22SŁukasz Majewski "setexpr spl_imgaddr ${spladdr} - 8 ;" \ 17235777e22SŁukasz Majewski "setexpr spl_addr_tmp ${spladdr} - 4 ;" \ 17335777e22SŁukasz Majewski "mw.b ${spl_imgaddr} 0x00 ${spl_imgsize};run loaduimage;" \ 17435777e22SŁukasz Majewski "setenv bootargs root=/dev/mmcblk${mmcdev}p${mmcrootpart} " \ 17535777e22SŁukasz Majewski "${lpj} rootwait ${console} ${meminfo} ${opts} ${lcdinfo};" \ 17635777e22SŁukasz Majewski "spl export atags 0x40007FC0;" \ 17735777e22SŁukasz Majewski "crc32 ${spladdr} ${splsize} ${spl_imgaddr};" \ 17835777e22SŁukasz Majewski "mw.l ${spl_addr_tmp} ${splsize};" \ 17935777e22SŁukasz Majewski "ext4write mmc ${mmcdev}:${mmcbootpart}" \ 18035777e22SŁukasz Majewski " /${splfile} ${spl_imgaddr} ${spl_imgsize};" \ 18135777e22SŁukasz Majewski "setenv spl_imgsize;" \ 18235777e22SŁukasz Majewski "setenv spl_imgaddr;" \ 183ba223bb2SArkadiusz Wlodarczyk "setenv spl_addr_tmp;\0" \ 184ba223bb2SArkadiusz Wlodarczyk "fdtaddr=40800000\0" \ 185ba223bb2SArkadiusz Wlodarczyk 18635777e22SŁukasz Majewski /* Falcon mode definitions */ 18735777e22SŁukasz Majewski #define CONFIG_CMD_SPL 188fe601647SPiotr Wilczek #define CONFIG_SYS_SPL_ARGS_ADDR CONFIG_SYS_SDRAM_BASE + 0x100 18989f95492SHeungJun, Kim 190fe601647SPiotr Wilczek /* I2C */ 191fe601647SPiotr Wilczek #include <asm/arch/gpio.h> 1929960d9a8SLukasz Majewski 193fe601647SPiotr Wilczek #define CONFIG_CMD_I2C 19489f95492SHeungJun, Kim 195ea818dbbSHeiko Schocher #define CONFIG_SYS_I2C 1962d8f1e27SPiotr Wilczek #define CONFIG_SYS_I2C_S3C24X0 1972d8f1e27SPiotr Wilczek #define CONFIG_SYS_I2C_S3C24X0_SPEED 100000 1982d8f1e27SPiotr Wilczek #define CONFIG_SYS_I2C_S3C24X0_SLAVE 0xFE 1992d8f1e27SPiotr Wilczek #define CONFIG_MAX_I2C_NUM 8 200ea818dbbSHeiko Schocher #define CONFIG_SYS_I2C_SOFT /* I2C bit-banged */ 201ea818dbbSHeiko Schocher #define CONFIG_SYS_I2C_SOFT_SPEED 50000 2022d8f1e27SPiotr Wilczek #define CONFIG_SYS_I2C_SOFT_SLAVE 0x7F 20389f95492SHeungJun, Kim #define CONFIG_SOFT_I2C_READ_REPEATED_START 204fd8dca83SŁukasz Majewski #define CONFIG_SYS_I2C_INIT_BOARD 205fd8dca83SŁukasz Majewski 206fd8dca83SŁukasz Majewski /* I2C FG */ 2078475c869SPrzemyslaw Marczak #define CONFIG_SOFT_I2C_GPIO_SCL exynos4_gpio_get(2, y4, 1) 2088475c869SPrzemyslaw Marczak #define CONFIG_SOFT_I2C_GPIO_SDA exynos4_gpio_get(2, y4, 0) 20989f95492SHeungJun, Kim 210fe601647SPiotr Wilczek /* POWER */ 211be3b51aaSŁukasz Majewski #define CONFIG_POWER 212be3b51aaSŁukasz Majewski #define CONFIG_POWER_I2C 213be3b51aaSŁukasz Majewski #define CONFIG_POWER_MAX8997 21489f95492SHeungJun, Kim 2155a77358cSŁukasz Majewski #define CONFIG_POWER_FG 2165a77358cSŁukasz Majewski #define CONFIG_POWER_FG_MAX17042 2177dcda99dSŁukasz Majewski #define CONFIG_POWER_MUIC 2187dcda99dSŁukasz Majewski #define CONFIG_POWER_MUIC_MAX8997 21961365ffcSŁukasz Majewski #define CONFIG_POWER_BATTERY 22061365ffcSŁukasz Majewski #define CONFIG_POWER_BATTERY_TRATS 22189f95492SHeungJun, Kim 222679549d1SPrzemyslaw Marczak /* Common misc for Samsung */ 223679549d1SPrzemyslaw Marczak #define CONFIG_MISC_COMMON 224679549d1SPrzemyslaw Marczak 225679549d1SPrzemyslaw Marczak #define CONFIG_MISC_INIT_R 226679549d1SPrzemyslaw Marczak 22700e64ab6SPrzemyslaw Marczak /* Download menu - Samsung common */ 22800e64ab6SPrzemyslaw Marczak #define CONFIG_LCD_MENU 22900e64ab6SPrzemyslaw Marczak #define CONFIG_LCD_MENU_BOARD 23000e64ab6SPrzemyslaw Marczak 23100e64ab6SPrzemyslaw Marczak /* Download menu - definitions for check keys */ 23200e64ab6SPrzemyslaw Marczak #ifndef __ASSEMBLY__ 23300e64ab6SPrzemyslaw Marczak #include <power/max8997_pmic.h> 23400e64ab6SPrzemyslaw Marczak 23500e64ab6SPrzemyslaw Marczak #define KEY_PWR_PMIC_NAME "MAX8997_PMIC" 23600e64ab6SPrzemyslaw Marczak #define KEY_PWR_STATUS_REG MAX8997_REG_STATUS1 23700e64ab6SPrzemyslaw Marczak #define KEY_PWR_STATUS_MASK (1 << 0) 23800e64ab6SPrzemyslaw Marczak #define KEY_PWR_INTERRUPT_REG MAX8997_REG_INT1 23900e64ab6SPrzemyslaw Marczak #define KEY_PWR_INTERRUPT_MASK (1 << 0) 24000e64ab6SPrzemyslaw Marczak 24100e64ab6SPrzemyslaw Marczak #define KEY_VOL_UP_GPIO exynos4_gpio_get(2, x2, 0) 24200e64ab6SPrzemyslaw Marczak #define KEY_VOL_DOWN_GPIO exynos4_gpio_get(2, x2, 1) 24300e64ab6SPrzemyslaw Marczak #endif /* __ASSEMBLY__ */ 24400e64ab6SPrzemyslaw Marczak 24500e64ab6SPrzemyslaw Marczak /* LCD console */ 24600e64ab6SPrzemyslaw Marczak #define LCD_BPP LCD_COLOR16 24700e64ab6SPrzemyslaw Marczak #define CONFIG_SYS_WHITE_ON_BLACK 24800e64ab6SPrzemyslaw Marczak 24951b1cd6dSDonghwa Lee /* LCD */ 25051b1cd6dSDonghwa Lee #define CONFIG_EXYNOS_FB 25151b1cd6dSDonghwa Lee #define CONFIG_LCD 25290464971SDonghwa Lee #define CONFIG_CMD_BMP 2532df21cb3SPrzemyslaw Marczak #define CONFIG_BMP_16BPP 25451b1cd6dSDonghwa Lee #define CONFIG_FB_ADDR 0x52504000 25551b1cd6dSDonghwa Lee #define CONFIG_S6E8AX0 25651b1cd6dSDonghwa Lee #define CONFIG_EXYNOS_MIPI_DSIM 25790464971SDonghwa Lee #define CONFIG_VIDEO_BMP_GZIP 258903afe18SPrzemyslaw Marczak #define CONFIG_SYS_VIDEO_LOGO_MAX_SIZE ((500 * 160 * 4) + 54) 25951b1cd6dSDonghwa Lee 260fe601647SPiotr Wilczek #define LCD_XRES 720 261fe601647SPiotr Wilczek #define LCD_YRES 1280 262ba223bb2SArkadiusz Wlodarczyk 26389f95492SHeungJun, Kim #endif /* __CONFIG_H */ 264