Open main menu

Changes

Q100

4,421 bytes added, 14 March
{{GD Template Impl}}
[[File:Q100-IMG-7622-1.jpg|thumb|right|installation guide]]
[[File:Q100-IMG-7641.jpg|thumb|right|]]
[[File:Q100-IMG-7644.jpg|thumb|right|]]
[[File:Q100-XIMG-6870-Packing-List.jpg|thumb|right|Q100 packing list]]
==Overview==
The Q100 is an expansion board similar to [[X1000]]. It has the function of PCIE to NVME ssd and also has an attached a 1.3" 240x240 Color TFT(ST7789 chipset), The TFT can display system and SSD status information, making it ideal for use as an additional display for NAS or media systems.
 
{{PCIe to NVME Sets}}
==Features==
* NVMe Base PCB with M.2 Slot (M-Key NVMe SSD with 2242 sizes)
* With ACT LED Indicator(Flashing: Reading /Writing)
* With 40pin GPIO Header,it can supply power from GPIO,avoiding the problem of insuggicient power supply for ultra-large capactiy SSDs
* 1.3" 240x240 Color TFT (ST7789 chipset),The TFT can display system and SSD status information, making it ideal for use as an additional display for NAS or media systems.
* 'PCIe Pipe' Flat Flex Shielded Cable(50mm length FFC Shielded Cable),shielded cables can provide better PCIE performance, effectively solve the interference problem between PCIE and WIFI, and provide a more stable data link for SSDs.
 
==PIN OUT==
{| class="wikitable"
! PIN !! Raspberry Pi Interface (BCM) !! Description
|-
| SCLK || P11/SCLK || SPI clock line
|-
| MOSI || P10/MOS || SPI data line
|-
| CS || P8/CE0 || Chip selection
|-
| DC || P25 || Data/Command control
|-
| RST || NOT USE || Reset
|-
| BL || P27 || Backlight
|}
 
==LCD and the controller==
The ST7789VW is a single-chip controller/driver for 262K-color, graphic type TFT-LCD. It consists of 240 source line and 320 gate line driving circuits. The resolution of this LCD is 240 (H) RGB x 240(V), it supports horizontal mode and vertical mode, and it doesn't use all the RAM of the controller.
 
This LCD accepts 8-bits/9-bits/16-bits/18-bits parallel interface, that are RGB444, RGB565, RGB666. The color format used in demo codes is RGB565.
 
This LCD use a 4-line SPI interface for reducing GPIO and fast speed.LCD
==LCD Working Protocol==
[[File:Q100-lcd-work-protocol.png]]
 
Note: Different from the traditional SPI protocol, the data line from the slave to the master is hidden since the device only has display requirement.
 
RESX Is the reset pin, it should be low when powering the module and be higher at other times;
 
CSX is slave chip select, when CS is low, the chip is enabled.
 
D/CX is data/command control pin, when DC = 0, write command, when DC = 1, write data
 
SDA is the data pin for transmitting RGB data, it works as the MOSI pin of SPI interface;
SCL worka s the SCLK pins of SPI interface. SPI communication has data transfer timing, which is combined by CPHA and CPOL. CPOL determines the level of the serial synchronous clock at idle state. When CPOL =0, the level is Low. However, CPOL has little effect to the transmission. CPHA determines whether data is collected at the first clock edge or at the second clock edge of serial synchronous clock; when CPHL =Packing List0, data is collected at the first clock edge. There are 4 SPI communication modes. SPI0 is commonly used, in which CPHL =0, CPOL =0.
==User Manual==
Only provides tutorials for running on Raspberry Pi OS as following ==NVMe SSD boot tutorial==Reter to [[NVMe SSD boot with the Raspberry Pi 5]]===LCD display tutorial==='''1. Enable SPI interface'''
Reter to [[How to enable SPI]]
sudo raspi'''2. Install Library''' PS: If you use the bookworm system, you can only use lgpio library, bcm2835 and wiringPi can't be installed and used.  '''BCM2835'''<PRE>#Open the Raspberry Pi terminal and run the following commandwget http://www.airspayce.com/mikem/bcm2835/bcm2835-config1.71.tar.gz Choose Interfacing Options tar zxvf bcm2835-> SPI 1.71.tar.gz cd bcm2835-1.71/sudo ./configure && sudo make && sudo make check && sudo make install# For more, you can refer to the official website at: http://www.airspayce.com/mikem/bcm2835/</PRE> Yes to enable SPI interface
Install lgpio liberery
PS: If you use '''WiringPi'''<pre>#Open the Raspberry Pi terminal and run the bookworm system, you following commandcdsudo apt-get install wiringpi#For Raspberry Pi systems after May 2019 (earlier than that can only use lgpio librarybe executed without), bcm2835 an upgrade may be required:wget https://project-downloads.drogon.net/wiringpi-latest.debsudo dpkg -i wiringpi-latest.debgpio -v# Run gpio -v and wiringPi canversion 2.52 will appear, if it doesn't be installed and usedit means there was an installation error
# Bullseye branch system using the following command:
git clone https://github.com/WiringPi/WiringPi
cd WiringPi
. /build
gpio -v
# Run gpio -v and version 2.70 will appear, if it doesn't it means there was an installation error
</pre>
 
 
'''lgpio'''
<pre>
#Open the Raspberry Pi terminal and run the following command
</pre>
Install '''Python'''
<pre>
sudo apt-get update
sudo apt-get install python3-pil
sudo apt-get install python3-numpy
#sudo pip3 install spidev</pre>  '''Download Examples'''<pre>git clone https://github.com/geekworm-com/Q100.gitcd Q100
</pre>
Download Examples
Open '''3. Run the Raspberry Pi terminal and run the following command:demo'''
<pre>
sudo apt-get install p7zip-full -ywget https://sourceforgepython status.net/projects/u-geek/files/HATs//Raspi_M2_HAT/Raspi_M2_HAT_code.7z7z x Raspi_M2_HAT_code.7z -r -o./Raspi_M2_HAT_codesudo chmod 777 -R Raspi_M2_HAT_codecd Raspi_M2_HAT_codepy
</pre>
The results are as follows:
 
[[File:Q100-lcd-on-2.jpg|800px]]
 
 
'''4. Auto-start when Power on'''
 
Configure the script to run automatically at startup
sudo nano /etc/rc.local
 
and ''python /home/pi/Q100/status.py&'' before '''exit 0''' line
 
[[File:Q100-auto-run-script.png]]
 
'''5. References:'''
* https://www.waveshare.com/wiki/1.3inch_LCD_HAT
Run the demo:
sudo python stats.py
<!--Add review function! -->