public inbox for u-boot@lists.denx.de
 help / color / mirror / Atom feed
From: Minkyu Kang <mk7.kang@samsung.com>
To: u-boot@lists.denx.de
Subject: [U-Boot] [PATCH V7 08/10] SMDK5250: Enable EMMC booting
Date: Thu, 28 Mar 2013 17:23:45 +0900	[thread overview]
Message-ID: <5153FE11.4050109@samsung.com> (raw)
In-Reply-To: <1362489090-7745-9-git-send-email-amarendra.xt@samsung.com>

Dear Amar,

On 05/03/13 22:11, Amar wrote:
> This patch adds support for EMMC booting on SMDK5250.
> 
> Signed-off-by: Amar <amarendra.xt@samsung.com>
> Acked-by: Simon Glass <sjg@chromium.org>
> ---
> Changes since V1:
> 	1)Updated spl_boot.c file to maintain irom pointer table
> 	instead of using the #define values defined in header file.
> 
> Changes since V2:
> 	1)Updation of commit message and resubmition of proper patch set.
> 
> Changes since V3:
> 	No change.
> 
> Changes since V4:
> 	1)The function get_irom_func(int index) has been added to avoid
> 	type casting at many places.
> 	2)The changes to file arch/arm/include/asm/arch-exynos/clk.h are
> 	included in this patch file.
> 
> Changes since V5:
> 	No change.
> 
> Changes since V6:
> 	No change.
> 
>  arch/arm/include/asm/arch-exynos/clk.h |  3 ++
>  board/samsung/smdk5250/clock_init.c    | 15 ++++++++++
>  board/samsung/smdk5250/clock_init.h    |  5 ++++
>  board/samsung/smdk5250/spl_boot.c      | 52 ++++++++++++++++++++++++++++++----
>  4 files changed, 69 insertions(+), 6 deletions(-)
> 
> diff --git a/arch/arm/include/asm/arch-exynos/clk.h b/arch/arm/include/asm/arch-exynos/clk.h
> index 1935b0b..a4d5b4e 100644
> --- a/arch/arm/include/asm/arch-exynos/clk.h
> +++ b/arch/arm/include/asm/arch-exynos/clk.h
> @@ -29,6 +29,9 @@
>  #define VPLL	4
>  #define BPLL	5
>  
> +#define FSYS1_MMC0_DIV_MASK	0xff0f
> +#define FSYS1_MMC0_DIV_VAL	0x0701

I think, these values are not generic.
please keep these values locally.

> +
>  unsigned long get_pll_clk(int pllreg);
>  unsigned long get_arm_clk(void);
>  unsigned long get_i2c_clk(void);
> diff --git a/board/samsung/smdk5250/clock_init.c b/board/samsung/smdk5250/clock_init.c
> index c009ae5..154993c 100644
> --- a/board/samsung/smdk5250/clock_init.c
> +++ b/board/samsung/smdk5250/clock_init.c
> @@ -28,6 +28,7 @@
>  #include <asm/arch/clk.h>
>  #include <asm/arch/clock.h>
>  #include <asm/arch/spl.h>
> +#include <asm/arch/dwmmc.h>
>  
>  #include "clock_init.h"
>  #include "setup.h"
> @@ -664,3 +665,17 @@ void clock_init_dp_clock(void)
>  	/* We run DP at 267 Mhz */
>  	setbits_le32(&clk->div_disp1_0, CLK_DIV_DISP1_0_FIMD1);
>  }
> +
> +/*
> + * Set clock divisor value for booting from EMMC.
> + * Set DWMMC channel-0 clk div to operate mmc0 device at 50MHz.
> + */
> +void emmc_boot_clk_div_set(void)
> +{
> +	struct exynos5_clock *clk = (struct exynos5_clock *)EXYNOS5_CLOCK_BASE;
> +	unsigned int div_mmc;
> +
> +	div_mmc = readl((unsigned int) &clk->div_fsys1) & ~FSYS1_MMC0_DIV_MASK;
> +	div_mmc |= FSYS1_MMC0_DIV_VAL;
> +	writel(div_mmc, (unsigned int) &clk->div_fsys1);
> +}
> diff --git a/board/samsung/smdk5250/clock_init.h b/board/samsung/smdk5250/clock_init.h
> index f751bcb..20a1d47 100644
> --- a/board/samsung/smdk5250/clock_init.h
> +++ b/board/samsung/smdk5250/clock_init.h
> @@ -146,4 +146,9 @@ struct mem_timings *clock_get_mem_timings(void);
>   * Initialize clock for the device
>   */
>  void system_clock_init(void);
> +
> +/*
> + * Set clock divisor value for booting from EMMC.
> + */
> +void emmc_boot_clk_div_set(void);
>  #endif
> diff --git a/board/samsung/smdk5250/spl_boot.c b/board/samsung/smdk5250/spl_boot.c
> index d8f3c1e..4ddbd4a 100644
> --- a/board/samsung/smdk5250/spl_boot.c
> +++ b/board/samsung/smdk5250/spl_boot.c
> @@ -23,15 +23,42 @@
>  #include<common.h>
>  #include<config.h>
>  
> +#include <asm/arch-exynos/dmc.h>
> +#include <asm/arch/clock.h>
> +#include <asm/arch/clk.h>
> +
> +#include "clock_init.h"
> +
> +/* Index into irom ptr table */
> +enum index {
> +	MMC_INDEX,
> +	EMMC44_INDEX,
> +	EMMC44_END_INDEX,
> +	SPI_INDEX,
> +};
> +
> +/* IROM Function Pointers Table */
> +u32 irom_ptr_table[] = {
> +	[MMC_INDEX] = 0x02020030,	/* iROM Function Pointer-SDMMC boot */
> +	[EMMC44_INDEX] = 0x02020044,	/* iROM Function Pointer-EMMC4.4 boot*/
> +	[EMMC44_END_INDEX] = 0x02020048,/* iROM Function Pointer
> +						-EMMC4.4 end boot operation */
> +	[SPI_INDEX] = 0x02020058,	/* iROM Function Pointer-SPI boot */
> +	};
> +
>  enum boot_mode {
>  	BOOT_MODE_MMC = 4,
>  	BOOT_MODE_SERIAL = 20,
> +	BOOT_MODE_EMMC = 8,	/* EMMC4.4 */
>  	/* Boot based on Operating Mode pin settings */
>  	BOOT_MODE_OM = 32,
>  	BOOT_MODE_USB,	/* Boot using USB download */
>  };
>  
> -	typedef u32 (*spi_copy_func_t)(u32 offset, u32 nblock, u32 dst);
> +void *get_irom_func(int index)
> +{
> +	return (void *) *(u32 *)irom_ptr_table[index];
> +}
>  
>  /*
>  * Copy U-boot from mmc to RAM:
> @@ -40,23 +67,36 @@ enum boot_mode {
>  */
>  void copy_uboot_to_ram(void)
>  {
> -	spi_copy_func_t spi_copy;
>  	enum boot_mode bootmode;
> -	u32 (*copy_bl2)(u32, u32, u32);
> -
> +	u32 (*spi_copy)(u32 offset, u32 nblock, u32 dst);
> +	u32 (*copy_bl2)(u32 offset, u32 nblock, u32 dst);
> +	u32 (*copy_bl2_from_emmc)(u32 nblock, u32 dst);
> +	void (*end_bootop_from_emmc)(void);
> +	/* read Operation Mode ststus register to find the bootmode */
>  	bootmode = readl(EXYNOS5_POWER_BASE) & OM_STAT;
>  
>  	switch (bootmode) {
>  	case BOOT_MODE_SERIAL:
> -		spi_copy = *(spi_copy_func_t *)EXYNOS_COPY_SPI_FNPTR_ADDR;
> +		spi_copy = get_irom_func(SPI_INDEX);
>  		spi_copy(SPI_FLASH_UBOOT_POS, CONFIG_BL2_SIZE,
>  						CONFIG_SYS_TEXT_BASE);
>  		break;
>  	case BOOT_MODE_MMC:
> -		copy_bl2 = (void *) *(u32 *)COPY_BL2_FNPTR_ADDR;
> +		copy_bl2 = get_irom_func(MMC_INDEX);
>  		copy_bl2(BL2_START_OFFSET, BL2_SIZE_BLOC_COUNT,
>  						CONFIG_SYS_TEXT_BASE);
>  		break;
> +	case BOOT_MODE_EMMC:
> +		/* Set the FSYS1 clock divisor value for EMMC boot */
> +		emmc_boot_clk_div_set();
> +
> +		copy_bl2_from_emmc = get_irom_func(EMMC44_INDEX);
> +		end_bootop_from_emmc = get_irom_func(EMMC44_END_INDEX);
> +
> +		copy_bl2_from_emmc(BL2_SIZE_BLOC_COUNT, CONFIG_SYS_TEXT_BASE);
> +		end_bootop_from_emmc();
> +		break;
> +
>  	default:
>  		break;
>  	}
> 

Thanks,
Minkyu Kang.

  reply	other threads:[~2013-03-28  8:23 UTC|newest]

Thread overview: 26+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2013-03-05 13:11 [U-Boot] [PATCH V7 00/10] EXYNOS5: Enable DWMMC, add FDT support for DWMMC and enable EMMC boot Amar
2013-03-05 13:11 ` [U-Boot] [PATCH V7 01/10] FDT: Add compatible string for DWMMC Amar
2013-03-11 16:34   ` Simon Glass
2013-03-12  6:16     ` Amarendra Reddy
2013-03-05 13:11 ` [U-Boot] [PATCH V7 02/10] EXYNOS5: FDT: Add DWMMC device node data Amar
2013-03-05 13:11 ` [U-Boot] [PATCH V7 03/10] DWMMC: Initialise dwmci and resolve EMMC read write issues Amar
2013-03-05 13:11 ` [U-Boot] [PATCH V7 04/10] EXYNOS5: DWMMC: Added FDT support for DWMMC Amar
2013-03-05 13:11 ` [U-Boot] [PATCH V7 05/10] EXYNOS5: DWMMC: Initialise the local variable to avoid unwanted results Amar
2013-03-05 13:11 ` [U-Boot] [PATCH V7 06/10] SMDK5250: Initialise and Enable DWMMC, support FDT and non-FDT Amar
2013-03-05 13:11 ` [U-Boot] [PATCH V7 07/10] MMC: APIs to support resize of EMMC boot partition Amar
2013-03-05 20:43   ` Wolfgang Denk
2013-03-07  9:26     ` Amarendra Reddy
2013-03-28  8:18       ` Minkyu Kang
2013-03-28  9:10         ` Amarendra Reddy
2013-03-29  2:02           ` Minkyu Kang
2013-03-05 13:11 ` [U-Boot] [PATCH V7 08/10] SMDK5250: Enable EMMC booting Amar
2013-03-28  8:23   ` Minkyu Kang [this message]
2013-04-01 11:21     ` Amarendra Reddy
2013-03-05 13:11 ` [U-Boot] [PATCH V7 09/10] COMMON: MMC: Command to support EMMC booting and to resize EMMC boot partition Amar
2013-03-05 20:42   ` Wolfgang Denk
2013-03-07  9:25     ` Amarendra Reddy
2013-03-05 13:11 ` [U-Boot] [PATCH V7 10/10] EXYNOS5: I2C: Added FDT and non-FDT support for I2C Amar
2013-03-06 10:21   ` Hung-ying Tyan
2013-03-28  8:29   ` Minkyu Kang
2013-04-01 11:37     ` Amarendra Reddy
2013-04-01 11:46       ` Minkyu Kang

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=5153FE11.4050109@samsung.com \
    --to=mk7.kang@samsung.com \
    --cc=u-boot@lists.denx.de \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox