高通APQ8074 spi 接口配置

8074 平台含有两个BLSP(BAM Low-Speed Peripheral) , 每一个BLSP含有两个QUP, 每一个QUP可以被配置为I2C, SPI, UART, UIM接口, BLSP是高通对于低速接口的一种管理方式。

每个QUP是和特定的引脚相关的, 如下图所示,比如下面的引脚是属于BLSP8的, 也就是第二个BLSP的第二个QUP,

注意这些引脚只能被配置到第二个BLSP的第2个QUP上,可以通过继续查看高通相关资料

QUP的中断相关信息

得到这些信息后,如果只是要将SPI配置成FIFO模式,而不是BAM模式,需要修改如下文件

diff --git a/arch/arm/boot/dts/msm8974.dtsi b/arch/arm/boot/dts/msm8974.dtsi
index 4178acf..649aa87 100644
--- a/arch/arm/boot/dts/msm8974.dtsi
+++ b/arch/arm/boot/dts/msm8974.dtsi
@@ -20,6 +20,7 @@
        aliases {
                spi0 = &spi_0;
                spi7 = &spi_7;
+               spi8 = &spi_8;
                sdhc1 = &sdhc_1; /* SDC1 eMMC slot */
                sdhc2 = &sdhc_2; /* SDC2 SD card slot */
                sdhc3 = &sdhc_3; /* SDC3 SDIO slot */
@@ -888,6 +889,27 @@
                qcom,master-id = <86>;
        };
 
+       spi_8: spi@f9964000 {
+               compatible = "qcom,spi-qup-v2";
+               reg = <0xf9964000 0x1000>;
+               interrupts = <0 102 0>;
+               spi-max-frequency = <19200000>;
+               #address-cells = <1>;
+               #size-cells = <0>;
+               qcom,gpio-clk  = <&msmgpio 48 0>; /* CLK */
+               qcom,gpio-miso = <&msmgpio 46 0>; /* MISO */
+               qcom,gpio-mosi = <&msmgpio 45 0>; /* MOSI */
+               qcom,gpio-cs0 = <&msmgpio 47 0>;
+
+               qcom,master-id = <84>;
+
+               spidev@0 { //Slave driver and CS ID
+                       compatible = "qcom,spi_name"; //Manufacture, and Mode
+                       reg = <0>; //Same as CS ID
+                       spi-max-frequency = <3200000>; //Max Frequency for Device
+               };
+       };
+
        qcom,clock-krait@f9016000 {
                compatible = "qcom,clock-krait-8974";
                reg = <0xf9016000 0x20>,

/*使能 spi驱动, 可以修改spidev.c的 compatible 把名字修改为device tree相同的名字,之后kernel会挂在这个设备到spi总线,dev目录下将会出现spidev8.0的设备节点*/

diff --git a/arch/arm/configs/msm8974_defconfig b/arch/arm/configs/msm8974_defconfig
index a12538a..74c51e6 100755
--- a/arch/arm/configs/msm8974_defconfig
+++ b/arch/arm/configs/msm8974_defconfig
@@ -315,7 +315,7 @@ CONFIG_I2C_CHARDEV=y
 CONFIG_I2C_QUP=y
 CONFIG_SPI=y
 CONFIG_SPI_QUP=y
-CONFIG_SPI_SPIDEV=m
+CONFIG_SPI_SPIDEV=y
 CONFIG_SPMI=y
 CONFIG_SPMI_MSM_PMIC_ARB=y
 CONFIG_MSM_QPNP_INT=y

修改gpio SPI属性,注意GPIO的function不要和已经注册的function 冲突

diff --git a/arch/arm/mach-msm/board-8974-gpiomux.c b/arch/arm/mach-msm/board-8974-gpiomux.c
index cec1a8f..6d67f18 100755
--- a/arch/arm/mach-msm/board-8974-gpiomux.c
+++ b/arch/arm/mach-msm/board-8974-gpiomux.c
@@ -683,6 +683,35 @@ static struct msm_gpiomux_config msm_blsp_configs[] __initdata = {
                        [GPIOMUX_SUSPENDED] = &gpio_suspend_config[0],
                },
        },
+
+       {
+               .gpio = 45,      /* BLSP2 QUP1 SPI_DATA_MOSI */
+               .settings = {
+                       [GPIOMUX_ACTIVE] = &gpio_spi_config,
+                       [GPIOMUX_SUSPENDED] = &gpio_suspend_config[1],
+               },
+       },
+       {
+               .gpio = 46,      /* BLSP2 QUP1 SPI_DATA_MISO */
+               .settings = {
+                       [GPIOMUX_ACTIVE] = &gpio_spi_config,
+                       [GPIOMUX_SUSPENDED] = &gpio_suspend_config[1],
+               },
+       },
+       {
+               .gpio = 48,      /* BLSP2 QUP1 SPI_CLK */
+               .settings = {
+                       [GPIOMUX_ACTIVE] = &gpio_spi_config,
+                       [GPIOMUX_SUSPENDED] = &gpio_suspend_config[0],
+               },
+       },
+       {
+               .gpio = 47,      /* BLSP2 QUP1 SPI_CS0_N */
+               .settings = {
+                       [GPIOMUX_ACTIVE] = &gpio_spi_config,
+                       [GPIOMUX_SUSPENDED] = &gpio_suspend_config[0],
+               },
+       },
 };

diff --git a/arch/arm/mach-msm/clock-8974.c b/arch/arm/mach-msm/clock-8974.c
index 128a363..adff33a 100755
--- a/arch/arm/mach-msm/clock-8974.c
+++ b/arch/arm/mach-msm/clock-8974.c
@@ -4967,7 +4967,8 @@ static struct clk_lookup msm_clocks_8974_common[] __initdata = {
        CLK_LOOKUP("core_clk", gcc_blsp2_qup1_i2c_apps_clk.c, ""),
        CLK_LOOKUP("core_clk", gcc_blsp2_qup1_spi_apps_clk.c, ""),
        CLK_LOOKUP("core_clk", gcc_blsp2_qup2_i2c_apps_clk.c, ""),
-       CLK_LOOKUP("core_clk", gcc_blsp2_qup2_spi_apps_clk.c, ""),
+       CLK_LOOKUP("iface_clk", gcc_blsp2_ahb_clk.c, "f9964000.spi"),
+       CLK_LOOKUP("core_clk", gcc_blsp2_qup2_spi_apps_clk.c, "f9964000.spi"),
        CLK_LOOKUP("core_clk", gcc_blsp2_qup3_i2c_apps_clk.c, ""),
        CLK_LOOKUP("core_clk", gcc_blsp2_qup3_spi_apps_clk.c, ""),
        CLK_LOOKUP("core_clk", gcc_blsp2_qup4_i2c_apps_clk.c, ""),

最后注意下使能的spidev.c设备驱动,这个驱动也需要修改spi_qsd.c 保存实际传输数据长度的actual_lenght字段不会被赋值,需要对spidev.c文件进行少许的修改

diff --git a/drivers/spi/spidev.c b/drivers/spi/spidev.c
index aaf0265..efb7d07 100644
--- a/drivers/spi/spidev.c
+++ b/drivers/spi/spidev.c

@@ -198,14 +204,14 @@ spidev_read(struct file *filp, char __user *buf, size_t count, loff_t *f_pos)
 
        mutex_lock(&spidev->buf_lock);
        status = spidev_sync_read(spidev, count);
-       if (status > 0) {
+       if (status >= 0) {
                unsigned long   missing;
 
-               missing = copy_to_user(buf, spidev->buffer, status);
-               if (missing == status)
+               missing = copy_to_user(buf, spidev->buffer, count);
+               if (missing == count)
                        status = -EFAULT;
                else
-                       status = status - missing;
+                       status = count - missing;
        }
        mutex_unlock(&spidev->buf_lock);

之后可以通过打开dev/spidev8.0文件进行SPI设备的读写测试,需要注意的是,如果你用dragonboard, 需要注意一下电平转换芯片的电压,一定要在PMIC中时能对应的电压。

高通APQ8074 spi 接口配置的更多相关文章

  1. 【转】高通平台android 环境配置编译及开发经验总结

    原文网址:http://blog.csdn.net/dongwuming/article/details/12784535 1.高通平台android开发总结 1.1 搭建高通平台环境开发环境 在高通 ...

  2. 高通调试 SPI 屏的 bug

    1. spi调试问题: 问题描述: spi屏幕lk启动的时候正常出现小企鹅,到kernel启动的过程黑屏并且花屏才到开机动画: 2. 黑屏的三个阶段: 参照:黑屏分析 分析开机过程黑屏,首先需要定位黑 ...

  3. 高通spi 屏幕 -lk代码分析

    lk SPI驱动 1. 初始化时钟 在lk中,我们是从kmain开始执行下来的,而执行顺序则是先初始化时钟,也就是在platform_early_init函数中开始执行的: 在这里我们需要修改这个函数 ...

  4. 最新内核3.4)Linux 设备树加载I2C client adapter 的流程(内核3.4 高通)【转】

    转自:https://blog.csdn.net/lsn946803746/article/details/52515225 版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转 ...

  5. STC8A8K64S4A12通过SPI接口操作基于ST7920的LCD12864液晶模块

    文章地址:https://www.cnblogs.com/jqdy/p/12665430.html 1. 硬件连接 1.1 64引脚的STC8A8K64S4A12 使用的是最小核心板,所以引脚皆引出可 ...

  6. [转帖]高通推出八核笔电处理器骁龙8cx 能超英特尔吗?

    高通推出八核笔电处理器骁龙8cx 能超英特尔吗? https://baijiahao.baidu.com/s?id=1619154699684981202&wfr=spider&for ...

  7. 嵌入式物联网之SPI接口原理与配置

    本实验采用W25Q64芯片 W25Q64是华邦公司推出的大容量SPI FLASH产品,其容量为64Mb.该25Q系列的器件在灵活性和性能方面远远超过普通的串行闪存器件.W25Q64将8M字节的容量分为 ...

  8. 高通平台 lcd driver 调试小结

    一.概述 1.1 简介 本文档主要包括LCD模块的驱动流程分析.Framebuffer相关知识.Gralloc等相关内容,以及LCD调试的一些经验和相关bug的分析和讲解. 1.2  开发环境 And ...

  9. Linux加载DTS设备节点的过程(以高通8974平台为例)

    DTS是Device Tree Source的缩写,用来描述设备的硬件细节.在过去的ARM Linux中,arch/arm/plat-xxx和arch/arm/mach-xxx中充斥着大量的垃圾代码, ...

随机推荐

  1. 供应商 银行 SQL (转自ITPUB)

    在此记录一下自己学习过程.新手,请多多指教,谢谢. 最近客户有需求,找出供应商对应的银行信息,查看了下网上帖子,发现都是从供应商及供应商地点层发起,去查找对应的银行信息,但是,供应商维护银行界面共有四 ...

  2. JSP-05- JSP总结

    1   客户端请求新页面 <%@ page language="java" contentType="text/html; charset=UTF-8" ...

  3. android初体验——HelloWord

    一.新建项目: 打开 eclipse ,选择File – New – Android Application Project 输入项目名称,程序名称,包名. 包名不能重复,它是项目的唯一标示,我理解为 ...

  4. ipseccmd命令解析

    IPSec 首先需要指出的是,IPSec和TCP/IP筛选是不同的东西,大家不要混淆了.TCP/IP筛选的功能十分有限,远不如IPSec灵活和强大.下面就说说如何在命令行下控制IPSec. XP系统用 ...

  5. OpenStack 的防火墙规则流程

    Contents [hide] 1 发现的问题 2 解决过程 3 删除临时错误数据 4 其实前面的解决办法是错的 发现的问题 3台虚拟机在同一宿主机,防火墙配置都一样,但是他们的网络表现不一致,有的能 ...

  6. WCF技术的不同应用场景及其实现分析

    这一篇文章,是总结一下WCF技术,以及基于这个技术发展出来的几个典型应用场景,并且我将尝试对这些不同的WCF实现的原理进行一些比较分析. 关于WCF这个技术的基本概念,如果你不是很清楚,可以参考一下有 ...

  7. android 学习随笔十七(服务 )

    1.Service 四大组件之一 运行于后台,没有前台界面的组件,用于运行需要在后台运行的代码 可以理解为没有前台的Activity 定义方式:创建java类继承Service,清单文件中注册该类 p ...

  8. mysql grant用户权限设置

    MySQL 赋予用户权限命令的简单格式可概括为: grant 权限 on 数据库对象 to 用户 一.grant 普通数据用户,查询.插入.更新.删除 数据库中所有表数据的权利. grant sele ...

  9. Sqoop安装及操作

    一.集群环境: Hostname IP Hadoop版本 Hadoop 功能 系统 node1 192.168.1.151 0.20.0 namenode hive+sqoop rhel5.4X86 ...

  10. 怎么使用Docker搭建PHP开发环境呢?

    在Docker流行之前,要搭建开发环境通常有两种选择:一种是使用wamp.xampp.mamp等集成开发环境安装包,另外一种就是使用普通虚拟机来安装linux服务器,然后通过下载一键安装包(如:lnm ...