rearranging nand Partitions sizes in uboot unable to boot in imx6ul

cancel
Showing results for 
Show  only  | Search instead for 
Did you mean: 

rearranging nand Partitions sizes in uboot unable to boot in imx6ul

1,141 Views
chandraevolute
Contributor V

Hi,

I have changed the nand partition sizs in uboot mx6ul_14*14_evk.h, attached is my uboot header file

I am able to succesfully run mfg tool and program all the files uboot, kernel, device tree and rootfs to nand.

/*
 * Copyright (C) 2015 Freescale Semiconductor, Inc.
 *
 * Configuration settings for the Freescale i.MX6UL 14x14 EVK board.
 *
 * SPDX-License-Identifier:    GPL-2.0+
 */
#ifndef __MX6UL_14X14_EVK_CONFIG_H
#define __MX6UL_14X14_EVK_CONFIG_H

 


#include <asm/arch/imx-regs.h>
#include <linux/sizes.h>
#include "mx6_common.h"
#include <asm/imx-common/gpio.h>

 

#define CONFIG_MX6
#define CONFIG_ROM_UNIFIED_SECTIONS
#define CONFIG_SYS_GENERIC_BOARD
#define CONFIG_DISPLAY_CPUINFO
#define CONFIG_DISPLAY_BOARDINFO

 

/* DCDC used on EVK, no PMIC */
#undef CONFIG_LDO_BYPASS_CHECK

 

/* uncomment for PLUGIN mode support */
/* #define CONFIG_USE_PLUGIN */

 

/* uncomment for SECURE mode support */
/* #define CONFIG_SECURE_BOOT */

 

#ifdef CONFIG_SECURE_BOOT
#ifndef CONFIG_CSF_SIZE
#define CONFIG_CSF_SIZE 0x4000
#endif
#endif

 

#define CONFIG_CMDLINE_TAG
#define CONFIG_SETUP_MEMORY_TAGS
#define CONFIG_INITRD_TAG
#define CONFIG_REVISION_TAG

 

/* Size of malloc() pool */
#define CONFIG_SYS_MALLOC_LEN        (16 * SZ_1M)

 

#define CONFIG_BOARD_EARLY_INIT_F
#define CONFIG_BOARD_LATE_INIT
#define CONFIG_MXC_GPIO

 

#define CONFIG_MXC_UART
#define CONFIG_MXC_UART_BASE        UART1_BASE

 

/* allow to overwrite serial and ethaddr */
#define CONFIG_ENV_OVERWRITE
#define CONFIG_CONS_INDEX        1
#define CONFIG_BAUDRATE            115200

 

#define CONFIG_CMD_FUSE
#ifdef CONFIG_CMD_FUSE
#define CONFIG_MXC_OCOTP
#endif

 

 

 

#ifdef CONFIG_SYS_USE_NAND
#define CONFIG_SYS_FSL_USDHC_NUM    1
#else
#define CONFIG_SYS_FSL_USDHC_NUM    2
#endif

 


#undef CONFIG_BOOTM_NETBSD
#undef CONFIG_BOOTM_PLAN9
#undef CONFIG_BOOTM_RTEMS

 

#undef CONFIG_CMD_EXPORTENV
#undef CONFIG_CMD_IMPORTENV

 


/* allow to overwrite serial and ethaddr */
#define CONFIG_ENV_OVERWRITE
#define CONFIG_CONS_INDEX        1

 

/* I2C configs */
#define CONFIG_CMD_I2C
#ifdef CONFIG_CMD_I2C
#define CONFIG_SYS_I2C
#define CONFIG_SYS_I2C_MXC
#define CONFIG_SYS_I2C_SPEED        100000
#endif

 

#define PHYS_SDRAM_SIZE            SZ_128M

 

#undef CONFIG_VIDEO

 

/* Command definition */
#include <config_cmd_default.h>

 

#undef CONFIG_CMD_IMLS

 

#define CONFIG_BOOTDELAY        3

 

#define CONFIG_LOADADDR            0x80800000
#define CONFIG_SYS_TEXT_BASE        0x87800000

 


#ifdef CONFIG_SYS_BOOT_NAND
#define CONFIG_MFG_NAND_PARTITION "mtdparts=gpmi-nand:2m(boot),5m(kernel),1m(dtb),-(rootfs) "
#else
#define CONFIG_MFG_NAND_PARTITION ""
#endif

 

 

 


#define CONFIG_MFG_ENV_SETTINGS \
    "mfgtool_args=setenv bootargs console=${console},${baudrate} " \
        "rdinit=/linuxrc " \
        "g_mass_storage.stall=0 g_mass_storage.removable=1 " \
        "g_mass_storage.idVendor=0x066F g_mass_storage.idProduct=0x37FF "\
        "g_mass_storage.iSerialNumber=\"\" "\
        CONFIG_MFG_NAND_PARTITION \
        "clk_ignore_unused "\
        "\0" \
    "initrd_addr=0x83800000\0" \
    "initrd_high=0xffffffff\0" \
    "bootcmd_mfg=run mfgtool_args;bootz ${loadaddr} ${initrd_addr} ${fdt_addr};\0" \

 

#if defined(CONFIG_SYS_BOOT_NAND)
#define CONFIG_EXTRA_ENV_SETTINGS \
    CONFIG_MFG_ENV_SETTINGS \
    "fdt_addr=0x83000000\0" \
    "fdt_high=0xffffffff\0"      \
    "console=ttymxc0\0" \
    "bootargs=console=ttymxc0,115200 ubi.mtd=4 "  \
        "root=ubi0:rootfs rw rootfstype=ubifs "             \
        "mtdparts=gpmi-nand:2m(boot),5m(kernel),1m(dtb),-(rootfs)\0"\
    "bootcmd=nand read ${loadaddr} 0x4000000 0x500000;"\
        "nand read ${fdt_addr} 0x5000000 0x100000;"\
        "bootz ${loadaddr} - ${fdt_addr}\0"

 

#endif

 

/* Miscellaneous configurable options */
#define CONFIG_SYS_LONGHELP
#define CONFIG_SYS_HUSH_PARSER
#define CONFIG_SYS_PROMPT        "=> "
#define CONFIG_AUTO_COMPLETE
#define CONFIG_SYS_CBSIZE        1024

 

/* Print Buffer Size */
#define CONFIG_SYS_PBSIZE (CONFIG_SYS_CBSIZE + sizeof(CONFIG_SYS_PROMPT) + 16)
#define CONFIG_SYS_MAXARGS        256
#define CONFIG_SYS_BARGSIZE CONFIG_SYS_CBSIZE

 

#define CONFIG_CMD_MEMTEST
#define CONFIG_SYS_MEMTEST_START    0x80000000
#define CONFIG_SYS_MEMTEST_END        (CONFIG_SYS_MEMTEST_START + 0x10000000)

 

#define CONFIG_SYS_LOAD_ADDR        CONFIG_LOADADDR
#define CONFIG_SYS_HZ            1000

 

#define CONFIG_CMDLINE_EDITING
#define CONFIG_STACKSIZE        SZ_128K

 

/* Physical Memory Map */
#define CONFIG_NR_DRAM_BANKS        1
#define PHYS_SDRAM            MMDC0_ARB_BASE_ADDR

 

#define CONFIG_SYS_SDRAM_BASE        PHYS_SDRAM
#define CONFIG_SYS_INIT_RAM_ADDR    IRAM_BASE_ADDR
#define CONFIG_SYS_INIT_RAM_SIZE    IRAM_SIZE

 

#define CONFIG_SYS_INIT_SP_OFFSET \
    (CONFIG_SYS_INIT_RAM_SIZE - GENERATED_GBL_DATA_SIZE)
#define CONFIG_SYS_INIT_SP_ADDR \
    (CONFIG_SYS_INIT_RAM_ADDR + CONFIG_SYS_INIT_SP_OFFSET)

 

/* FLASH and environment organization */
#define CONFIG_SYS_NO_FLASH

 

 

 


#define CONFIG_SYS_USE_NAND
#define CONFIG_ENV_IS_IN_NAND
#define CONFIG_CMD_NAND
#define CONFIG_CMD_NAND_TRIMFFS

 

/* NAND stuff */
#define CONFIG_NAND_MXS
#define CONFIG_SYS_MAX_NAND_DEVICE    1
#define CONFIG_SYS_NAND_BASE        0x40000000
#define CONFIG_SYS_NAND_5_ADDR_CYCLE
#define CONFIG_SYS_NAND_ONFI_DETECTION

 

/* DMA stuff, needed for GPMI/MXS NAND support */
#define CONFIG_APBH_DMA
#define CONFIG_APBH_DMA_BURST
#define CONFIG_APBH_DMA_BURST8

 

 

 


#define CONFIG_ENV_OFFSET        (8 << 20)
#define CONFIG_ENV_SECT_SIZE        (128 << 10)
#define CONFIG_ENV_SIZE            CONFIG_ENV_SECT_SIZE

 


#define CONFIG_SYS_MMC_ENV_DEV        1   /* USDHC2 */
#define CONFIG_SYS_MMC_ENV_PART        0    /* user area */
#define CONFIG_MMCROOT            "/dev/mmcblk1p2"  /* USDHC2 */

 

#define CONFIG_OF_LIBFDT
#define CONFIG_CMD_BOOTZ

 

#define CONFIG_CMD_BMODE

 

#ifndef CONFIG_SYS_DCACHE_OFF
#define CONFIG_CMD_CACHE
#endif

 


/* USB Configs */
#define CONFIG_CMD_USB
#ifdef CONFIG_CMD_USB
#define CONFIG_USB_EHCI
#define CONFIG_USB_EHCI_MX6
#define CONFIG_USB_STORAGE
#define CONFIG_EHCI_HCD_INIT_AFTER_RESET
#define CONFIG_USB_HOST_ETHER
#define CONFIG_USB_ETHER_ASIX
#define CONFIG_MXC_USB_PORTSC  (PORT_PTS_UTMI | PORT_PTS_PTW)
#define CONFIG_MXC_USB_FLAGS   0
#define CONFIG_USB_MAX_CONTROLLER_COUNT 2
#endif

 

#if defined(CONFIG_ANDROID_SUPPORT)
#include "mx6ul_14x14_evk_android.h"
#endif

 

#endif

 

 

After changing the mode to internal boot mode it gives error saying wrong zImage magic number. Can anyone suggest what changes need to be done

With the default partition sizes i am able to boot completely. Right now we added some packages to the rootfs and out rootfs increased from 17MB to 62MB. 

Original Attachment has been moved to: mx6ul_14x14_evk.h.zip

Labels (3)
0 Kudos
1 Reply

566 Views
igorpadykov
NXP Employee
NXP Employee

Hi chandra

#define CONFIG_MFG_NAND_PARTITION means that mfg tools

would use this change, so seems its firmware should be rebuilt, please refer

to attached Yocto Guide sect.6.2 Manufacturing Tool, MFGTool

Best regards
igor
-----------------------------------------------------------------------------------------------------------------------
Note: If this post answers your question, please click the Correct Answer button. Thank you!
-----------------------------------------------------------------------------------------------------------------------

0 Kudos