[PATCH 1/2] sam9g45: add trng clock and platform device

Nicolas Ferre nicolas.ferre at atmel.com
Fri Oct 7 06:09:55 EDT 2011


On 10/06/2011 05:41 PM, Peter Korsgaard :
> For the new hw_random driver.
> 
> Signed-off-by: Peter Korsgaard <jacmet at sunsite.dk>

Signed-off-by: Nicolas Ferre <nicolas.ferre at atmel.com>

I add it to at91-l2 and at91-next branches of:
git://github.com/at91linux/linux-at91.git

Thanks,

> ---
>  arch/arm/mach-at91/at91sam9g45.c         |    7 +++++++
>  arch/arm/mach-at91/at91sam9g45_devices.c |   29 +++++++++++++++++++++++++++++
>  2 files changed, 36 insertions(+), 0 deletions(-)
> 
> diff --git a/arch/arm/mach-at91/at91sam9g45.c b/arch/arm/mach-at91/at91sam9g45.c
> index 6da8ace..6850f1d 100644
> --- a/arch/arm/mach-at91/at91sam9g45.c
> +++ b/arch/arm/mach-at91/at91sam9g45.c
> @@ -54,6 +54,11 @@ static struct clk pioDE_clk = {
>  	.pmc_mask	= 1 << AT91SAM9G45_ID_PIODE,
>  	.type		= CLK_TYPE_PERIPHERAL,
>  };
> +static struct clk trng_clk = {
> +	.name		= "trng_clk",
> +	.pmc_mask	= 1 << AT91SAM9G45_ID_TRNG,
> +	.type		= CLK_TYPE_PERIPHERAL,
> +};
>  static struct clk usart0_clk = {
>  	.name		= "usart0_clk",
>  	.pmc_mask	= 1 << AT91SAM9G45_ID_US0,
> @@ -177,6 +182,7 @@ static struct clk *periph_clocks[] __initdata = {
>  	&pioB_clk,
>  	&pioC_clk,
>  	&pioDE_clk,
> +	&trng_clk,
>  	&usart0_clk,
>  	&usart1_clk,
>  	&usart2_clk,
> @@ -216,6 +222,7 @@ static struct clk_lookup periph_clocks_lookups[] = {
>  	CLKDEV_CON_DEV_ID("t0_clk", "atmel_tcb.1", &tcb0_clk),
>  	CLKDEV_CON_DEV_ID("pclk", "ssc.0", &ssc0_clk),
>  	CLKDEV_CON_DEV_ID("pclk", "ssc.1", &ssc1_clk),
> +	CLKDEV_CON_DEV_ID(NULL, "atmel-trng", &trng_clk),
>  	/* fake hclk clock */
>  	CLKDEV_CON_DEV_ID("hclk", "at91_ohci", &uhphs_clk),
>  };
> diff --git a/arch/arm/mach-at91/at91sam9g45_devices.c b/arch/arm/mach-at91/at91sam9g45_devices.c
> index 2ee20bd..1ca6c62 100644
> --- a/arch/arm/mach-at91/at91sam9g45_devices.c
> +++ b/arch/arm/mach-at91/at91sam9g45_devices.c
> @@ -1101,6 +1101,34 @@ static void __init at91_add_device_rtt(void)
>  
>  
>  /* --------------------------------------------------------------------
> + *  TRNG
> + * -------------------------------------------------------------------- */
> +
> +#if defined(CONFIG_HW_RANDOM_ATMEL) || defined(CONFIG_HW_RANDOM_ATMEL_MODULE)
> +static struct resource trng_resources[] = {
> +	{
> +		.start	= AT91SAM9G45_BASE_TRNG,
> +		.end	= AT91SAM9G45_BASE_TRNG + SZ_16K - 1,
> +		.flags	= IORESOURCE_MEM,
> +	},
> +};
> +
> +static struct platform_device at91sam9g45_trng_device = {
> +	.name		= "atmel-trng",
> +	.id		= -1,
> +	.resource	= trng_resources,
> +	.num_resources	= ARRAY_SIZE(trng_resources),
> +};
> +
> +static void __init at91_add_device_trng(void)
> +{
> +	platform_device_register(&at91sam9g45_trng_device);
> +}
> +#else
> +static void __init at91_add_device_trng(void) {}
> +#endif
> +
> +/* --------------------------------------------------------------------
>   *  Watchdog
>   * -------------------------------------------------------------------- */
>  
> @@ -1589,6 +1617,7 @@ static int __init at91_add_standard_devices(void)
>  	at91_add_device_hdmac();
>  	at91_add_device_rtc();
>  	at91_add_device_rtt();
> +	at91_add_device_trng();
>  	at91_add_device_watchdog();
>  	at91_add_device_tc();
>  	return 0;


-- 
Nicolas Ferre



More information about the linux-arm-kernel mailing list