Exynos4412 SPI驱动配置

Exynos4412 SPI配置
Linux内核层就不说了,可以参考资料:
http://www.embedu.org/Column/Column367.htm
要说的时关于4412特别的部分,在4412板级文件mach-**4412.c中,需要配置的相关内容:
1. CS管脚信息结构体:
static struct s3c64xx_spi_csinfo spi0_csi[] = {
[0] = {
.line = EXYNOS4_GPB(1),
.set_level = gpio_set_value,
.fb_delay = 0x2,
},
};
2. 定义板级信息结构体:
static struct spi_board_info spi0_board_info[] __initdata = {
{
.modalias = “spidev”,
.platform_data = NULL,
.max_speed_hz = 10*1000*1000,
.bus_num = 0,
.chip_select = 0,
.mode = SPI_MODE_0,
.controller_data = &spi0_csi[0],
}
};
3. 配置GPIO功能:
if (!gpio_request(EXYNOS4_GPB(1), “SPI_CS0”)) {
gpio_direction_output(EXYNOS4_GPB(1), 1);
s3c_gpio_cfgpin(EXYNOS4_GPB(1), S3C_GPIO_SFN(1));
s3c_gpio_setpull(EXYNOS4_GPB(1), S3C_GPIO_PULL_UP);
exynos_spi_set_info(0, EXYNOS_SPI_SRCCLK_SCLK,
ARRAY_SIZE(spi0_csi));
}
gpio_direction_output(EXYNOS4_GPB(1),1);//配置CS(GPB(1))为输出,才能正确输出波形
void *gpio_base;
unsigned int *cs_cfg;
gpio_base = ioremap(0x1392000c,4);
cs_cfg = (unsigned int *)gpio_base;
*cs_cfg |= 0x10;//配置cs为自动模式,参照4412Datasheet1439页
4. 注册板级信息:
spi_register_board_info(spi0_board_info, ARRAY_SIZE(spi0_board_info));

OK,完成。本次写的不好,但是都是自己看了很多源代码之后的成果,如有疑问,欢迎讨论。guq@microarray.com.cn

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值