|  | @@ -1193,3 +1193,187 @@ static struct resource adc_resources[] = {
 | 
											
												
													
														|  |  	},
 |  |  	},
 | 
											
												
													
														|  |  	[1] = {
 |  |  	[1] = {
 | 
											
												
													
														|  |  		.start	= NR_IRQS_LEGACY + AT91SAM9G45_ID_TSC,
 |  |  		.start	= NR_IRQS_LEGACY + AT91SAM9G45_ID_TSC,
 | 
											
												
													
														|  | 
 |  | +		.end	= NR_IRQS_LEGACY + AT91SAM9G45_ID_TSC,
 | 
											
												
													
														|  | 
 |  | +		.flags	= IORESOURCE_IRQ,
 | 
											
												
													
														|  | 
 |  | +	}
 | 
											
												
													
														|  | 
 |  | +};
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +static struct platform_device at91_adc_device = {
 | 
											
												
													
														|  | 
 |  | +	.name		= "at91_adc",
 | 
											
												
													
														|  | 
 |  | +	.id		= -1,
 | 
											
												
													
														|  | 
 |  | +	.dev		= {
 | 
											
												
													
														|  | 
 |  | +				.platform_data	= &adc_data,
 | 
											
												
													
														|  | 
 |  | +	},
 | 
											
												
													
														|  | 
 |  | +	.resource	= adc_resources,
 | 
											
												
													
														|  | 
 |  | +	.num_resources	= ARRAY_SIZE(adc_resources),
 | 
											
												
													
														|  | 
 |  | +};
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +static struct at91_adc_trigger at91_adc_triggers[] = {
 | 
											
												
													
														|  | 
 |  | +	[0] = {
 | 
											
												
													
														|  | 
 |  | +		.name = "external-rising",
 | 
											
												
													
														|  | 
 |  | +		.value = 1,
 | 
											
												
													
														|  | 
 |  | +		.is_external = true,
 | 
											
												
													
														|  | 
 |  | +	},
 | 
											
												
													
														|  | 
 |  | +	[1] = {
 | 
											
												
													
														|  | 
 |  | +		.name = "external-falling",
 | 
											
												
													
														|  | 
 |  | +		.value = 2,
 | 
											
												
													
														|  | 
 |  | +		.is_external = true,
 | 
											
												
													
														|  | 
 |  | +	},
 | 
											
												
													
														|  | 
 |  | +	[2] = {
 | 
											
												
													
														|  | 
 |  | +		.name = "external-any",
 | 
											
												
													
														|  | 
 |  | +		.value = 3,
 | 
											
												
													
														|  | 
 |  | +		.is_external = true,
 | 
											
												
													
														|  | 
 |  | +	},
 | 
											
												
													
														|  | 
 |  | +	[3] = {
 | 
											
												
													
														|  | 
 |  | +		.name = "continuous",
 | 
											
												
													
														|  | 
 |  | +		.value = 6,
 | 
											
												
													
														|  | 
 |  | +		.is_external = false,
 | 
											
												
													
														|  | 
 |  | +	},
 | 
											
												
													
														|  | 
 |  | +};
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +static struct at91_adc_reg_desc at91_adc_register_g45 = {
 | 
											
												
													
														|  | 
 |  | +	.channel_base = AT91_ADC_CHR(0),
 | 
											
												
													
														|  | 
 |  | +	.drdy_mask = AT91_ADC_DRDY,
 | 
											
												
													
														|  | 
 |  | +	.status_register = AT91_ADC_SR,
 | 
											
												
													
														|  | 
 |  | +	.trigger_register = 0x08,
 | 
											
												
													
														|  | 
 |  | +};
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +void __init at91_add_device_adc(struct at91_adc_data *data)
 | 
											
												
													
														|  | 
 |  | +{
 | 
											
												
													
														|  | 
 |  | +	if (!data)
 | 
											
												
													
														|  | 
 |  | +		return;
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +	if (test_bit(0, &data->channels_used))
 | 
											
												
													
														|  | 
 |  | +		at91_set_gpio_input(AT91_PIN_PD20, 0);
 | 
											
												
													
														|  | 
 |  | +	if (test_bit(1, &data->channels_used))
 | 
											
												
													
														|  | 
 |  | +		at91_set_gpio_input(AT91_PIN_PD21, 0);
 | 
											
												
													
														|  | 
 |  | +	if (test_bit(2, &data->channels_used))
 | 
											
												
													
														|  | 
 |  | +		at91_set_gpio_input(AT91_PIN_PD22, 0);
 | 
											
												
													
														|  | 
 |  | +	if (test_bit(3, &data->channels_used))
 | 
											
												
													
														|  | 
 |  | +		at91_set_gpio_input(AT91_PIN_PD23, 0);
 | 
											
												
													
														|  | 
 |  | +	if (test_bit(4, &data->channels_used))
 | 
											
												
													
														|  | 
 |  | +		at91_set_gpio_input(AT91_PIN_PD24, 0);
 | 
											
												
													
														|  | 
 |  | +	if (test_bit(5, &data->channels_used))
 | 
											
												
													
														|  | 
 |  | +		at91_set_gpio_input(AT91_PIN_PD25, 0);
 | 
											
												
													
														|  | 
 |  | +	if (test_bit(6, &data->channels_used))
 | 
											
												
													
														|  | 
 |  | +		at91_set_gpio_input(AT91_PIN_PD26, 0);
 | 
											
												
													
														|  | 
 |  | +	if (test_bit(7, &data->channels_used))
 | 
											
												
													
														|  | 
 |  | +		at91_set_gpio_input(AT91_PIN_PD27, 0);
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +	if (data->use_external_triggers)
 | 
											
												
													
														|  | 
 |  | +		at91_set_A_periph(AT91_PIN_PD28, 0);
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +	data->num_channels = 8;
 | 
											
												
													
														|  | 
 |  | +	data->startup_time = 40;
 | 
											
												
													
														|  | 
 |  | +	data->registers = &at91_adc_register_g45;
 | 
											
												
													
														|  | 
 |  | +	data->trigger_number = 4;
 | 
											
												
													
														|  | 
 |  | +	data->trigger_list = at91_adc_triggers;
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +	adc_data = *data;
 | 
											
												
													
														|  | 
 |  | +	platform_device_register(&at91_adc_device);
 | 
											
												
													
														|  | 
 |  | +}
 | 
											
												
													
														|  | 
 |  | +#else
 | 
											
												
													
														|  | 
 |  | +void __init at91_add_device_adc(struct at91_adc_data *data) {}
 | 
											
												
													
														|  | 
 |  | +#endif
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +/* --------------------------------------------------------------------
 | 
											
												
													
														|  | 
 |  | + *  RTT
 | 
											
												
													
														|  | 
 |  | + * -------------------------------------------------------------------- */
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +static struct resource rtt_resources[] = {
 | 
											
												
													
														|  | 
 |  | +	{
 | 
											
												
													
														|  | 
 |  | +		.start	= AT91SAM9G45_BASE_RTT,
 | 
											
												
													
														|  | 
 |  | +		.end	= AT91SAM9G45_BASE_RTT + SZ_16 - 1,
 | 
											
												
													
														|  | 
 |  | +		.flags	= IORESOURCE_MEM,
 | 
											
												
													
														|  | 
 |  | +	}, {
 | 
											
												
													
														|  | 
 |  | +		.flags	= IORESOURCE_MEM,
 | 
											
												
													
														|  | 
 |  | +	}, {
 | 
											
												
													
														|  | 
 |  | +		.flags  = IORESOURCE_IRQ,
 | 
											
												
													
														|  | 
 |  | +	}
 | 
											
												
													
														|  | 
 |  | +};
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +static struct platform_device at91sam9g45_rtt_device = {
 | 
											
												
													
														|  | 
 |  | +	.name		= "at91_rtt",
 | 
											
												
													
														|  | 
 |  | +	.id		= 0,
 | 
											
												
													
														|  | 
 |  | +	.resource	= rtt_resources,
 | 
											
												
													
														|  | 
 |  | +};
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +#if IS_ENABLED(CONFIG_RTC_DRV_AT91SAM9)
 | 
											
												
													
														|  | 
 |  | +static void __init at91_add_device_rtt_rtc(void)
 | 
											
												
													
														|  | 
 |  | +{
 | 
											
												
													
														|  | 
 |  | +	at91sam9g45_rtt_device.name = "rtc-at91sam9";
 | 
											
												
													
														|  | 
 |  | +	/*
 | 
											
												
													
														|  | 
 |  | +	 * The second resource is needed:
 | 
											
												
													
														|  | 
 |  | +	 * GPBR will serve as the storage for RTC time offset
 | 
											
												
													
														|  | 
 |  | +	 */
 | 
											
												
													
														|  | 
 |  | +	at91sam9g45_rtt_device.num_resources = 3;
 | 
											
												
													
														|  | 
 |  | +	rtt_resources[1].start = AT91SAM9G45_BASE_GPBR +
 | 
											
												
													
														|  | 
 |  | +				 4 * CONFIG_RTC_DRV_AT91SAM9_GPBR;
 | 
											
												
													
														|  | 
 |  | +	rtt_resources[1].end = rtt_resources[1].start + 3;
 | 
											
												
													
														|  | 
 |  | +	rtt_resources[2].start = NR_IRQS_LEGACY + AT91_ID_SYS;
 | 
											
												
													
														|  | 
 |  | +	rtt_resources[2].end = NR_IRQS_LEGACY + AT91_ID_SYS;
 | 
											
												
													
														|  | 
 |  | +}
 | 
											
												
													
														|  | 
 |  | +#else
 | 
											
												
													
														|  | 
 |  | +static void __init at91_add_device_rtt_rtc(void)
 | 
											
												
													
														|  | 
 |  | +{
 | 
											
												
													
														|  | 
 |  | +	/* Only one resource is needed: RTT not used as RTC */
 | 
											
												
													
														|  | 
 |  | +	at91sam9g45_rtt_device.num_resources = 1;
 | 
											
												
													
														|  | 
 |  | +}
 | 
											
												
													
														|  | 
 |  | +#endif
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +static void __init at91_add_device_rtt(void)
 | 
											
												
													
														|  | 
 |  | +{
 | 
											
												
													
														|  | 
 |  | +	at91_add_device_rtt_rtc();
 | 
											
												
													
														|  | 
 |  | +	platform_device_register(&at91sam9g45_rtt_device);
 | 
											
												
													
														|  | 
 |  | +}
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +/* --------------------------------------------------------------------
 | 
											
												
													
														|  | 
 |  | + *  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
 | 
											
												
													
														|  | 
 |  | + * -------------------------------------------------------------------- */
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +#if defined(CONFIG_AT91SAM9X_WATCHDOG) || defined(CONFIG_AT91SAM9X_WATCHDOG_MODULE)
 | 
											
												
													
														|  | 
 |  | +static struct resource wdt_resources[] = {
 | 
											
												
													
														|  | 
 |  | +	{
 | 
											
												
													
														|  | 
 |  | +		.start	= AT91SAM9G45_BASE_WDT,
 | 
											
												
													
														|  | 
 |  | +		.end	= AT91SAM9G45_BASE_WDT + SZ_16 - 1,
 | 
											
												
													
														|  | 
 |  | +		.flags	= IORESOURCE_MEM,
 | 
											
												
													
														|  | 
 |  | +	}
 | 
											
												
													
														|  | 
 |  | +};
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +static struct platform_device at91sam9g45_wdt_device = {
 | 
											
												
													
														|  | 
 |  | +	.name		= "at91_wdt",
 | 
											
												
													
														|  | 
 |  | +	.id		= -1,
 | 
											
												
													
														|  | 
 |  | +	.resource	= wdt_resources,
 | 
											
												
													
														|  | 
 |  | +	.num_resources	= ARRAY_SIZE(wdt_resources),
 | 
											
												
													
														|  | 
 |  | +};
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +static void __init at91_add_device_watchdog(void)
 |