Lichee Pi zero SPI LCD使用指南
===================
在閱讀本文之前,首先要保證你能夠成功的編譯linux內核,并構建一個完整的根文件系統。關于這部分的知識,之后還會單獨寫一個文檔討論。
其實lichee pi zero使用的4.10內核已經包含了市面上常見的SPI液晶屏的驅動(fbtft),我們所要做的僅僅是在設備樹中添加節點。說起這個fbtft,它之前獨立于內核存在過一段時間,作為單獨的代碼文件發布,如果你需要它,可以手動把這部分文件復制到內核源碼中(參考[fbtft的 github倉庫](https://github.com/notro/fbtft))。后來被并入內核,具體是在哪一個版本的被并入內核的,這個也不必深究了。不過目前為止fbtft并未轉正,依然存放在drivers/staging目錄中。
## 1 配置內核添加fbtft驅動
使用make menuconfig配置內核,加入ili9341驅動。fbtft還支持更多型號的SPI總線的液晶屏。關于支持列表這里就不一一列出,可以進入menuconfig中查看。
```
Device Drivers --->
[*] Staging drivers --->
<*> Support for small TFT LCD display modules --->
<*> FB driver for the ILI9341 LCD Controller
<*> Generic FB driver for TFT LCD displays
```
編譯內核:
make -j4
## 2 修改設備樹注冊ili9341
lichee pi zero默認注冊40Pin RGB液晶屏,并且在啟動參數中設置console為tty0 。為了盡可能減少改動,我們在設備樹中刪除了默認的40Pin液晶屏,這樣新添加的ili9341也就順利成章的成了唯一的太子,啟動時的信息會通過他顯示。
下面是使用git對比改動前后的細節:
```
diff --git a/arch/arm/boot/dts/sun8i-v3s-licheepi-zero.dts b/arch/arm/boot/dts/sun8i-v3s-licheepi-zero.dts
index 929a79e..9c91f75 100644
--- a/arch/arm/boot/dts/sun8i-v3s-licheepi-zero.dts
+++ b/arch/arm/boot/dts/sun8i-v3s-licheepi-zero.dts
@@ -90,3 +90,21 @@
usb0_id_det-gpio = <&pio 5 6 GPIO_ACTIVE_HIGH>;
status = "okay";
};
+
+&spi0 {
+ status = "okay";
+
+ ili9341@0 {
+ compatible = "ilitek,ili9341";
+ reg = <0>;
+
+ spi-max-frequency = <15000000>;
+ rotate = <270>;
+ bgr;
+ fps = <10>;
+ buswidth = <8>;
+ reset-gpios = <&pio 1 7 GPIO_ACTIVE_LOW>;
+ dc-gpios = <&pio 1 5 GPIO_ACTIVE_LOW>;
+ debug = <0>;
+ };
+};
diff --git a/arch/arm/boot/dts/sun8i-v3s.dtsi b/arch/arm/boot/dts/sun8i-v3s.dtsi
index 50b8788..b0eb22e 100644
--- a/arch/arm/boot/dts/sun8i-v3s.dtsi
+++ b/arch/arm/boot/dts/sun8i-v3s.dtsi
@@ -54,15 +54,6 @@
#address-cells = <1>;
#size-cells = <1>;
ranges;
-
- simplefb_lcd: framebuffer@0 {
- compatible = "allwinner,simple-framebuffer",
- "simple-framebuffer";
- allwinner,pipeline = "de0-lcd0";
- clocks = <&ccu CLK_BUS_TCON0>, <&ccu CLK_BUS_DE>,
- <&ccu CLK_DE>, <&ccu CLK_TCON0>;
- status = "disabled";
- };
```
注:
+ dc-gpios = <&pio 1 5 GPIO_ACTIVE_LOW>;
在設備樹中,PA對應&pio 0, PB對應&pio 1, 以此類推。因此dc-gpios實際表示的是PB5,也就是zero絲印上的PWM1。
+ reset-gpios = <&pio 1 7 GPIO_ACTIVE_LOW>;
如果我的屏幕的RESET引腳連接了高電平,或者接了一個RC回路作為上電復位的信號,那么這里的復位引腳是不是可以不指定呢?
這樣也是不可以的。因為在程序中,首先讀取reset-gpios,若reset-gpios在設備樹中不存在,那么直接忽略其余的信號。這樣導致無法控制最關鍵的dc-gpios引腳。因此至少在不更改程序的前提下,這條信號是一定要寫上的。
```
static int fbtft_request_gpios_dt(struct fbtft_par *par)
{
int i;
int ret;
if (!par->info->device->of_node)
return -EINVAL;
ret = fbtft_request_one_gpio(par, "reset-gpios", 0, &par->gpio.reset);
if (ret)
return ret;
ret = fbtft_request_one_gpio(par, "dc-gpios", 0, &par->gpio.dc);
if (ret)
return ret;
```
## 3 更新SD卡中的程序
假設你之前已經創建好了一張可以正確啟動的SD卡,那么你要做的很簡單:
將arch/arm/boot/zImage和arch/arm/boot/dts/sun8i-v3s-licheepi-zero.dtb拷貝到SD卡中的vfat分區,覆蓋之前的程序即可。
## 4 硬件連接
| SPI屏 | zero |
| ------ | -------- |
| 3v3 | 3v3 |
| GND | GND |
| DC | PWM1 |
| RST | 3v3 |
| CS | CS |
| CLK | CLK |
| MISO | MISO |
| MOSI | MOSI |
## 5 上電啟動
linux內核啟動時會加載fbtft驅動,注冊framebuffer設備,打印如下信息:
```
[ 0.860671] fbtft_of_value: buswidth = 8
[ 0.864653] fbtft_of_value: debug = 0
[ 0.868325] fbtft_of_value: rotate = 270
[ 0.872252] fbtft_of_value: fps = 10
[ 1.244063] graphics fb0: fb_ili9341 frame buffer, 320x240, 150 KiB video memory, 16 KiB DMA buffer memory, fps=10, spi32766.0 at 15 MHz
```
顯示效果如下圖:

- 前言
- 荔枝派TODO任務領取
- linux使用小貼士
- 入門篇
- 板卡介紹
- 開箱指南
- 燒錄啟動系統
- 聯網方法
- 鏡像使用
- 鏡像說明
- buildroot系統使用
- debian系統使用
- 外設操作
- 外設操作概覽
- 低速外設
- GPIO
- GPIO模擬低速接口
- UART
- PWM
- I2C
- SPI
- 高速接口
- SDIO
- USB
- EtherNet
- DVP CSI
- MIPI CSI
- 模擬外設
- CODEC
- LRADC
- 常見設備驅動
- USB攝像頭
- USB 3G/4G 網卡
- 舵機
- 開發篇
- UBOOT適配
- UBOOT編譯
- UBOOT配置
- UBOOT配置屏幕分辨率
- UBOOT配置SPI啟動
- Linux內核開發
- Linux內核編譯
- BSP Linux內核編譯.md
- Linux內核選項
- 外設驅動與設備樹
- RTL8723BS驅動
- 根文件系統定制
- buildroot定制系統
- buildroot添加軟件包
- openwrt定制系統
- emdebian定制系統
- camdriod開發
- camdriod編譯
- 主線Uboot引導Camdriod
- 系統鏡像打包
- XBOOT適配
- 荔枝運行XBOOT
- 應用篇
- 游戲機-基于EmulationStation
- 游戲機-gnuboy
- 語音識別-科大訊飛云
- GUI-QT5
- 語音識別-離線關鍵詞識別
- 路由器-Lichee Zero
- 投稿文章
- 荔枝派Zero開箱指南
- Zero i2c oled使用指南
- zero SPI LCD使用指南
- Zero u-boot編譯和使用指南
- TF WiFi使用方法
- Zero Ethernet使用指南
- Zero 移植Qt5.4.1
- ZeroSpiNorFlash啟動系統制作指南
- Visio-uboot-sunxi流程
- lichee 編譯踩坑記錄(ilichee ZERO)
- lichee_zero_外設GPIO接口
- TF WIFI 小白編
- 從零開始LicheePi Zero的開發
- 認識Zero的硬件
- 搭建Zero的開發環境
- 主線Uboot
- 主線kernel
- BSP kernel
- BSP內核啟動
- bsp內核的攝像頭使用
- BSP內核中的保留內存
- uboot啟動BSP內核常見錯誤
- BSP內核 FBTFT移植
- BSP內核啟動錯誤及警告解決
- buildroot 根文件系統
- emdebian 根文件系統
- SPI Flash 系統編譯
- sunxi-fel增加對16M 以上flash的支持
- overlayfs的使用
- jffs2系統掛載不上的常見原因
- JFFS2 文件系統簡介
- uboot對spi flash的識別
- bsp內核的SPI flash啟動
- Docker開發環境
- Docker 命令速查
- 基礎ubuntu系統配置
- docker離線鏡像
- Zero系統燒錄
- dd鏡像燒錄
- 分區鏡像燒錄
- SPI Flash系統燒錄
- 一鍵鏡像燒錄
- Zero外設把玩
- I2C操作
- PWM輸出
- CODEC的使用
- 以太網使用指南
- GPIO操作
- 文件IO方式
- C語言接口(mmap)
- Python操作GPIO
- pinctrl-sunxi介紹
- UART操作
- 點屏
- 點屏之RGB屏
- 點屏之SPI屏 ili9341
- 點屏之SPI OLED
- 點屏之I2C OLED
- 點屏之SPI屏 ili9488
- 點屏之MCU屏
- 點屏之觸摸屏驅動
- 點屏之simple-framebuffer
- 點屏之屏幕時序
- 時鐘控制器CCM
- 攝像頭
- BSP DVP攝像頭
- BSP MIPI 攝像頭
- 主線DVP攝像頭
- 主線 MIPI攝像頭
- SPI 操作
- 應用層開發
- 開機自啟動
- Segment Fault調試
- Zero通過OTG共享PC網絡
- USB攝像頭使用
- 基于QT的GUI開發
- 移植tslib
- 移植QT5.9.1
- 移植QT4.8.7
- QtCreator使用
- Qt5.x移植到Qt4.8
- Qt字體相關
- Qt移植總結
- Qt裁剪
- Qt去除鼠標指針顯示
- zero_imager使用
- 驅動開發
- 設備樹簡介
- GPU/DRM 顯示驅動
- sys下設備樹查看
- atmel觸摸屏驅動分析
- atmel觸摸屏中斷改輪詢
- uboot下gpio操作
- helloworld驅動編譯演示
- FBTFT分析
- 內核模塊靜態加載的順序
- SPI驅動分析
- SPI 驅動編寫
- Uboot開發
- 開機logo
- 看門狗的使用
- 關于系統reboot
- 內核printk等級設置