⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 at91sam9260_devices.c

📁 linux 内核源代码
💻 C
📖 第 1 页 / 共 2 页
字号:
				.coherent_dma_mask	= 0xffffffff,	},	.resource	= spi0_resources,	.num_resources	= ARRAY_SIZE(spi0_resources),};static const unsigned spi0_standard_cs[4] = { AT91_PIN_PA3, AT91_PIN_PC11, AT91_PIN_PC16, AT91_PIN_PC17 };static struct resource spi1_resources[] = {	[0] = {		.start	= AT91SAM9260_BASE_SPI1,		.end	= AT91SAM9260_BASE_SPI1 + SZ_16K - 1,		.flags	= IORESOURCE_MEM,	},	[1] = {		.start	= AT91SAM9260_ID_SPI1,		.end	= AT91SAM9260_ID_SPI1,		.flags	= IORESOURCE_IRQ,	},};static struct platform_device at91sam9260_spi1_device = {	.name		= "atmel_spi",	.id		= 1,	.dev		= {				.dma_mask		= &spi_dmamask,				.coherent_dma_mask	= 0xffffffff,	},	.resource	= spi1_resources,	.num_resources	= ARRAY_SIZE(spi1_resources),};static const unsigned spi1_standard_cs[4] = { AT91_PIN_PB3, AT91_PIN_PC5, AT91_PIN_PC4, AT91_PIN_PC3 };void __init at91_add_device_spi(struct spi_board_info *devices, int nr_devices){	int i;	unsigned long cs_pin;	short enable_spi0 = 0;	short enable_spi1 = 0;	/* Choose SPI chip-selects */	for (i = 0; i < nr_devices; i++) {		if (devices[i].controller_data)			cs_pin = (unsigned long) devices[i].controller_data;		else if (devices[i].bus_num == 0)			cs_pin = spi0_standard_cs[devices[i].chip_select];		else			cs_pin = spi1_standard_cs[devices[i].chip_select];		if (devices[i].bus_num == 0)			enable_spi0 = 1;		else			enable_spi1 = 1;		/* enable chip-select pin */		at91_set_gpio_output(cs_pin, 1);		/* pass chip-select pin to driver */		devices[i].controller_data = (void *) cs_pin;	}	spi_register_board_info(devices, nr_devices);	/* Configure SPI bus(es) */	if (enable_spi0) {		at91_set_A_periph(AT91_PIN_PA0, 0);	/* SPI0_MISO */		at91_set_A_periph(AT91_PIN_PA1, 0);	/* SPI0_MOSI */		at91_set_A_periph(AT91_PIN_PA2, 0);	/* SPI1_SPCK */		at91_clock_associate("spi0_clk", &at91sam9260_spi0_device.dev, "spi_clk");		platform_device_register(&at91sam9260_spi0_device);	}	if (enable_spi1) {		at91_set_A_periph(AT91_PIN_PB0, 0);	/* SPI1_MISO */		at91_set_A_periph(AT91_PIN_PB1, 0);	/* SPI1_MOSI */		at91_set_A_periph(AT91_PIN_PB2, 0);	/* SPI1_SPCK */		at91_clock_associate("spi1_clk", &at91sam9260_spi1_device.dev, "spi_clk");		platform_device_register(&at91sam9260_spi1_device);	}}#elsevoid __init at91_add_device_spi(struct spi_board_info *devices, int nr_devices) {}#endif/* -------------------------------------------------------------------- *  LEDs * -------------------------------------------------------------------- */#if defined(CONFIG_LEDS)u8 at91_leds_cpu;u8 at91_leds_timer;void __init at91_init_leds(u8 cpu_led, u8 timer_led){	/* Enable GPIO to access the LEDs */	at91_set_gpio_output(cpu_led, 1);	at91_set_gpio_output(timer_led, 1);	at91_leds_cpu	= cpu_led;	at91_leds_timer	= timer_led;}#elsevoid __init at91_init_leds(u8 cpu_led, u8 timer_led) {}#endif/* -------------------------------------------------------------------- *  UART * -------------------------------------------------------------------- */#if defined(CONFIG_SERIAL_ATMEL)static struct resource dbgu_resources[] = {	[0] = {		.start	= AT91_VA_BASE_SYS + AT91_DBGU,		.end	= AT91_VA_BASE_SYS + AT91_DBGU + SZ_512 - 1,		.flags	= IORESOURCE_MEM,	},	[1] = {		.start	= AT91_ID_SYS,		.end	= AT91_ID_SYS,		.flags	= IORESOURCE_IRQ,	},};static struct atmel_uart_data dbgu_data = {	.use_dma_tx	= 0,	.use_dma_rx	= 0,		/* DBGU not capable of receive DMA */	.regs		= (void __iomem *)(AT91_VA_BASE_SYS + AT91_DBGU),};static struct platform_device at91sam9260_dbgu_device = {	.name		= "atmel_usart",	.id		= 0,	.dev		= {				.platform_data	= &dbgu_data,				.coherent_dma_mask = 0xffffffff,	},	.resource	= dbgu_resources,	.num_resources	= ARRAY_SIZE(dbgu_resources),};static inline void configure_dbgu_pins(void){	at91_set_A_periph(AT91_PIN_PB14, 0);		/* DRXD */	at91_set_A_periph(AT91_PIN_PB15, 1);		/* DTXD */}static struct resource uart0_resources[] = {	[0] = {		.start	= AT91SAM9260_BASE_US0,		.end	= AT91SAM9260_BASE_US0 + SZ_16K - 1,		.flags	= IORESOURCE_MEM,	},	[1] = {		.start	= AT91SAM9260_ID_US0,		.end	= AT91SAM9260_ID_US0,		.flags	= IORESOURCE_IRQ,	},};static struct atmel_uart_data uart0_data = {	.use_dma_tx	= 1,	.use_dma_rx	= 1,};static struct platform_device at91sam9260_uart0_device = {	.name		= "atmel_usart",	.id		= 1,	.dev		= {				.platform_data	= &uart0_data,				.coherent_dma_mask = 0xffffffff,	},	.resource	= uart0_resources,	.num_resources	= ARRAY_SIZE(uart0_resources),};static inline void configure_usart0_pins(void){	at91_set_A_periph(AT91_PIN_PB4, 1);		/* TXD0 */	at91_set_A_periph(AT91_PIN_PB5, 0);		/* RXD0 */	at91_set_A_periph(AT91_PIN_PB26, 0);		/* RTS0 */	at91_set_A_periph(AT91_PIN_PB27, 0);		/* CTS0 */	at91_set_A_periph(AT91_PIN_PB24, 0);		/* DTR0 */	at91_set_A_periph(AT91_PIN_PB22, 0);		/* DSR0 */	at91_set_A_periph(AT91_PIN_PB23, 0);		/* DCD0 */	at91_set_A_periph(AT91_PIN_PB25, 0);		/* RI0 */}static struct resource uart1_resources[] = {	[0] = {		.start	= AT91SAM9260_BASE_US1,		.end	= AT91SAM9260_BASE_US1 + SZ_16K - 1,		.flags	= IORESOURCE_MEM,	},	[1] = {		.start	= AT91SAM9260_ID_US1,		.end	= AT91SAM9260_ID_US1,		.flags	= IORESOURCE_IRQ,	},};static struct atmel_uart_data uart1_data = {	.use_dma_tx	= 1,	.use_dma_rx	= 1,};static struct platform_device at91sam9260_uart1_device = {	.name		= "atmel_usart",	.id		= 2,	.dev		= {				.platform_data	= &uart1_data,				.coherent_dma_mask = 0xffffffff,	},	.resource	= uart1_resources,	.num_resources	= ARRAY_SIZE(uart1_resources),};static inline void configure_usart1_pins(void){	at91_set_A_periph(AT91_PIN_PB6, 1);		/* TXD1 */	at91_set_A_periph(AT91_PIN_PB7, 0);		/* RXD1 */	at91_set_A_periph(AT91_PIN_PB28, 0);		/* RTS1 */	at91_set_A_periph(AT91_PIN_PB29, 0);		/* CTS1 */}static struct resource uart2_resources[] = {	[0] = {		.start	= AT91SAM9260_BASE_US2,		.end	= AT91SAM9260_BASE_US2 + SZ_16K - 1,		.flags	= IORESOURCE_MEM,	},	[1] = {		.start	= AT91SAM9260_ID_US2,		.end	= AT91SAM9260_ID_US2,		.flags	= IORESOURCE_IRQ,	},};static struct atmel_uart_data uart2_data = {	.use_dma_tx	= 1,	.use_dma_rx	= 1,};static struct platform_device at91sam9260_uart2_device = {	.name		= "atmel_usart",	.id		= 3,	.dev		= {				.platform_data	= &uart2_data,				.coherent_dma_mask = 0xffffffff,	},	.resource	= uart2_resources,	.num_resources	= ARRAY_SIZE(uart2_resources),};static inline void configure_usart2_pins(void){	at91_set_A_periph(AT91_PIN_PB8, 1);		/* TXD2 */	at91_set_A_periph(AT91_PIN_PB9, 0);		/* RXD2 */}static struct resource uart3_resources[] = {	[0] = {		.start	= AT91SAM9260_BASE_US3,		.end	= AT91SAM9260_BASE_US3 + SZ_16K - 1,		.flags	= IORESOURCE_MEM,	},	[1] = {		.start	= AT91SAM9260_ID_US3,		.end	= AT91SAM9260_ID_US3,		.flags	= IORESOURCE_IRQ,	},};static struct atmel_uart_data uart3_data = {	.use_dma_tx	= 1,	.use_dma_rx	= 1,};static struct platform_device at91sam9260_uart3_device = {	.name		= "atmel_usart",	.id		= 4,	.dev		= {				.platform_data	= &uart3_data,				.coherent_dma_mask = 0xffffffff,	},	.resource	= uart3_resources,	.num_resources	= ARRAY_SIZE(uart3_resources),};static inline void configure_usart3_pins(void){	at91_set_A_periph(AT91_PIN_PB10, 1);		/* TXD3 */	at91_set_A_periph(AT91_PIN_PB11, 0);		/* RXD3 */}static struct resource uart4_resources[] = {	[0] = {		.start	= AT91SAM9260_BASE_US4,		.end	= AT91SAM9260_BASE_US4 + SZ_16K - 1,		.flags	= IORESOURCE_MEM,	},	[1] = {		.start	= AT91SAM9260_ID_US4,		.end	= AT91SAM9260_ID_US4,		.flags	= IORESOURCE_IRQ,	},};static struct atmel_uart_data uart4_data = {	.use_dma_tx	= 1,	.use_dma_rx	= 1,};static struct platform_device at91sam9260_uart4_device = {	.name		= "atmel_usart",	.id		= 5,	.dev		= {				.platform_data	= &uart4_data,				.coherent_dma_mask = 0xffffffff,	},	.resource	= uart4_resources,	.num_resources	= ARRAY_SIZE(uart4_resources),};static inline void configure_usart4_pins(void){	at91_set_B_periph(AT91_PIN_PA31, 1);		/* TXD4 */	at91_set_B_periph(AT91_PIN_PA30, 0);		/* RXD4 */}static struct resource uart5_resources[] = {	[0] = {		.start	= AT91SAM9260_BASE_US5,		.end	= AT91SAM9260_BASE_US5 + SZ_16K - 1,		.flags	= IORESOURCE_MEM,	},	[1] = {		.start	= AT91SAM9260_ID_US5,		.end	= AT91SAM9260_ID_US5,		.flags	= IORESOURCE_IRQ,	},};static struct atmel_uart_data uart5_data = {	.use_dma_tx	= 1,	.use_dma_rx	= 1,};static struct platform_device at91sam9260_uart5_device = {	.name		= "atmel_usart",	.id		= 6,	.dev		= {				.platform_data	= &uart5_data,				.coherent_dma_mask = 0xffffffff,	},	.resource	= uart5_resources,	.num_resources	= ARRAY_SIZE(uart5_resources),};static inline void configure_usart5_pins(void){	at91_set_A_periph(AT91_PIN_PB12, 1);		/* TXD5 */	at91_set_A_periph(AT91_PIN_PB13, 0);		/* RXD5 */}struct platform_device *at91_uarts[ATMEL_MAX_UART];	/* the UARTs to use */struct platform_device *atmel_default_console_device;	/* the serial console device */void __init at91_init_serial(struct at91_uart_config *config){	int i;	/* Fill in list of supported UARTs */	for (i = 0; i < config->nr_tty; i++) {		switch (config->tty_map[i]) {			case 0:				configure_usart0_pins();				at91_uarts[i] = &at91sam9260_uart0_device;				at91_clock_associate("usart0_clk", &at91sam9260_uart0_device.dev, "usart");				break;			case 1:				configure_usart1_pins();				at91_uarts[i] = &at91sam9260_uart1_device;				at91_clock_associate("usart1_clk", &at91sam9260_uart1_device.dev, "usart");				break;			case 2:				configure_usart2_pins();				at91_uarts[i] = &at91sam9260_uart2_device;				at91_clock_associate("usart2_clk", &at91sam9260_uart2_device.dev, "usart");				break;			case 3:				configure_usart3_pins();				at91_uarts[i] = &at91sam9260_uart3_device;				at91_clock_associate("usart3_clk", &at91sam9260_uart3_device.dev, "usart");				break;			case 4:				configure_usart4_pins();				at91_uarts[i] = &at91sam9260_uart4_device;				at91_clock_associate("usart4_clk", &at91sam9260_uart4_device.dev, "usart");				break;			case 5:				configure_usart5_pins();				at91_uarts[i] = &at91sam9260_uart5_device;				at91_clock_associate("usart5_clk", &at91sam9260_uart5_device.dev, "usart");				break;			case 6:				configure_dbgu_pins();				at91_uarts[i] = &at91sam9260_dbgu_device;				at91_clock_associate("mck", &at91sam9260_dbgu_device.dev, "usart");				break;			default:				continue;		}		at91_uarts[i]->id = i;		/* update ID number to mapped ID */	}	/* Set serial console device */	if (config->console_tty < ATMEL_MAX_UART)		atmel_default_console_device = at91_uarts[config->console_tty];	if (!atmel_default_console_device)		printk(KERN_INFO "AT91: No default serial console defined.\n");}void __init at91_add_device_serial(void){	int i;	for (i = 0; i < ATMEL_MAX_UART; i++) {		if (at91_uarts[i])			platform_device_register(at91_uarts[i]);	}}#elsevoid __init at91_init_serial(struct at91_uart_config *config) {}void __init at91_add_device_serial(void) {}#endif/* -------------------------------------------------------------------- *//* * These devices are always present and don't need any board-specific * setup. */static int __init at91_add_standard_devices(void){	return 0;}arch_initcall(at91_add_standard_devices);

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -