Difference between revisions of "Matrix - Compact Kit"
(→介绍) |
(→Applications) |
||
(50 intermediate revisions by 3 users not shown) | |||
Line 3: | Line 3: | ||
==Introduction== | ==Introduction== | ||
[[File:Matrix-Compact_Kit.png|thumb|]] | [[File:Matrix-Compact_Kit.png|thumb|]] | ||
− | *The Matrix-Compact Kit is a compact board with various hardware resources, interfaces and ports | + | *The Matrix-Compact Kit is a compact board with various hardware resources, interfaces and ports. It includes user keys, LED, buzzer, ADC, compass, temperature sensor, IR receiver, TFT port and etc. This board can be connected to the NanoPi, NanoPi 2 and Raspberry Pi via its 40 pin header. In addition you can connect other external modules to its GPIOs. |
− | == | + | ==Features== |
− | Matrix - Compact | + | * PCB Dimension(mm): |
+ | [[File:Matrix-Compact_Kit_PCB.png|frameless|400px|]] | ||
+ | [[File:Matrix-Compact_Kit.png |thumb|300px|Matrix-Compact_Kit Layout]] | ||
+ | * '''40pin female connector's GPIO Pin Spec''' | ||
+ | ::{| class="wikitable" | ||
+ | |- | ||
+ | |Pin# || Name ||Pin# || Name | ||
+ | |- | ||
+ | |1 || VDD_SYS_3.3V ||2 || VDD_5V | ||
+ | |- | ||
+ | |3 || I2C0_SDA ||4 || VDD_5V | ||
+ | |- | ||
+ | |5 || I2C0_SCL ||6 || DGND | ||
+ | |- | ||
+ | |7 || GPIOB28 ||8 || UART3_TXD | ||
+ | |- | ||
+ | |9 || DGND ||10 || UART3_RXD | ||
+ | |- | ||
+ | |11 || GPIOB29 ||12 || GPIOB26 | ||
+ | |- | ||
+ | |13 || GPIOB30 ||14 || DGND | ||
+ | |- | ||
+ | |15 || GPIOB31 ||16 || PWM2 | ||
+ | |- | ||
+ | |17 || VDD_SYS_3.3V ||18 || GPIOB27 | ||
+ | |- | ||
+ | |19 || SPI0_MOSI ||20 || DGND | ||
+ | |- | ||
+ | |21 || SPI0_MISO ||22 || PWM0 | ||
+ | |- | ||
+ | |23 || SPI0_CLK ||24 || SPI0_CS | ||
+ | |- | ||
+ | |25 || DGND ||26 || PWM1 | ||
+ | |- | ||
+ | |27 || I2C1_SDA ||28 || I2C1_SCL | ||
+ | |- | ||
+ | |29 || GPIOC8 ||30 || DGND | ||
+ | |- | ||
+ | |31 || SPI2_CLK ||32 || GPIOC28 | ||
+ | |- | ||
+ | |33 || SPI2_CS ||34 || DGND | ||
+ | |- | ||
+ | |35 || SPI2_MOSI ||36 || GPIOC7 | ||
+ | |- | ||
+ | |37 || SPI2_MISO ||38 || ALIVEGPIO2 | ||
+ | |- | ||
+ | |39 || DGND ||40 || ALIVEGPIO3 | ||
+ | |} | ||
+ | |||
+ | [[File:Matrix-Compact_Kit3*10.png |thumb|300px|Matrix-Compact_Kit Layout]] | ||
+ | * '''30pin Pin Spec''' | ||
+ | ::{| class="wikitable" | ||
+ | |- | ||
+ | |Pin# || Name ||Pin# || Name ||Pin# || Name | ||
+ | |- | ||
+ | |1 || GND ||2 || VDD_5V ||3 ||A1_PCF | ||
+ | |- | ||
+ | |4 || GND ||5 || VDD_5V ||6 ||A2_PCF | ||
+ | |- | ||
+ | |7 || GND ||8 || VDD_5V ||9 ||A3_PCF | ||
+ | |- | ||
+ | |10 || GND ||11 || VDD_5V ||12 ||D1_Pi11 | ||
+ | |- | ||
+ | |13 || GND ||14 || VDD_5V ||15 ||D2_Pi26 | ||
+ | |- | ||
+ | |16 || GND ||17 || VDD_5V ||18 ||D3_Pi16 | ||
+ | |- | ||
+ | |19 || GND ||20 || VDD_5V ||21 ||D4_Pi19 | ||
+ | |- | ||
+ | |22 || GND ||23 || VDD_5V ||24 ||D5_Pi21 | ||
+ | |- | ||
+ | |25 || GND ||26 || VDD_5V ||27 ||D6_Pi23 | ||
+ | |- | ||
+ | |28 || GND ||29 || VDD_5V ||30 ||D7_Pi24 | ||
+ | |- | ||
+ | |} | ||
+ | |||
+ | [[File:18B20 and IRR.png |thumb|300px|18B20 & IR Receiver Layout]] | ||
+ | * '''18B20 & IR Receiver Pin Spec''' | ||
+ | ::{| class="wikitable" | ||
+ | |- | ||
+ | |Module ||Pin# || Name ||Pin# || Name ||Pin# || Name | ||
+ | |- | ||
+ | |18B20 ||1 || VDD_5V ||2 || DATA ||3 || GND | ||
+ | |- | ||
+ | |IR Receiver ||1 || DATA ||2 || GND ||3 || VDD_5V | ||
+ | |- | ||
+ | |} | ||
+ | |||
+ | ==Applications== | ||
+ | ===Connect to NanoPi 2=== | ||
+ | Refer to the following connection diagram to connect the module to the NanoPi 2:<br> | ||
+ | [[File:Matrix-Compact_Kit_nanopi2.jpg|frameless|600px|Matrix-Compact_Kit_nanopi2]] | ||
+ | |||
+ | ==Compile & Run Test Program== | ||
+ | Boot your ARM board with Debian and copy the matrix code: | ||
+ | <syntaxhighlight lang="bash"> | ||
+ | $ apt-get update && apt-get install git | ||
+ | $ git clone https://github.com/friendlyarm/matrix.git | ||
+ | </syntaxhighlight> | ||
+ | If your cloning is done successfully a "matrix" directory will be generated. | ||
+ | |||
+ | Compile and install Matrix: | ||
+ | <syntaxhighlight lang="bash"> | ||
+ | $ cd matrix | ||
+ | $ make && make install | ||
+ | </syntaxhighlight> | ||
+ | |||
+ | Run test program: | ||
+ | <syntaxhighlight lang="bash"> | ||
+ | $ matrix-compact_kit | ||
+ | </syntaxhighlight> | ||
+ | Note: this module is not plug and play therefore before running the module please make sure it is connected to an ARM board.<br> | ||
+ | Here is what you should observe:<br> | ||
+ | <syntaxhighlight lang="bash"> | ||
+ | LED blinking 1 | ||
+ | LED blinking 2 | ||
+ | Button: 1 1 1 | ||
+ | ADC channel0: 550 | ||
+ | Compass angle: 328.5 | ||
+ | Pwm start | ||
+ | Pwm stop | ||
+ | </syntaxhighlight> | ||
+ | |||
+ | Run Qt program to test the TFT LCD: | ||
+ | <syntaxhighlight lang="bash"> | ||
+ | cd matrix/demo/nanopi-status | ||
+ | ./build.sh | ||
+ | ./run.sh /dev/fb-st7735s | ||
+ | </syntaxhighlight> | ||
+ | The program will present the system's basic information:<br> | ||
+ | [[File:st7735s-status.pnc|frameless|600px|st7735s-status]] | ||
+ | |||
+ | ==Code Sample== | ||
+ | This Matrix code sample can work with all the ARM boards mentioned in this module's wiki. The name of this code sample is "matrix-compact_kit". Here is its source code: | ||
+ | <syntaxhighlight lang="c"> | ||
+ | int main(int argc, char ** argv) | ||
+ | { | ||
+ | int board; | ||
+ | |||
+ | if ((board = boardInit()) < 0) { | ||
+ | printf("Fail to init board\n"); | ||
+ | return -1; | ||
+ | } | ||
+ | testLED(board); | ||
+ | readButton(); | ||
+ | readADC(); | ||
+ | readCompass(); | ||
+ | testPWM(board); | ||
+ | // readTemp(); | ||
+ | // testIR(); | ||
+ | |||
+ | return 0; | ||
+ | } | ||
+ | </syntaxhighlight> | ||
+ | For more details about this APIs called in this code sample refer to [[Matrix API reference manual]] <br> | ||
+ | |||
+ | ==Code Samples in Python== | ||
+ | The Python version is 2.7.9 in the following samples<br> | ||
+ | Install the Python libraries and modules: | ||
+ | <syntaxhighlight lang="bash"> | ||
+ | $ apt-get install Python-dev libi2c-dev | ||
+ | </syntaxhighlight> | ||
+ | |||
+ | The python code is in our github: | ||
+ | <syntaxhighlight lang="bash"> | ||
+ | $ git clone https://github.com/friendlyarm/matrix-python.git | ||
+ | </syntaxhighlight> | ||
+ | After it is done a matrix-python directory will be generated. | ||
+ | |||
+ | Access LED: | ||
+ | <syntaxhighlight lang="bash"> | ||
+ | $ cd matrix-python/Matrix.GPIO | ||
+ | $ python setup.py install | ||
+ | $ python test/matrix_output.py 33 | ||
+ | </syntaxhighlight> | ||
+ | The red LED will be flashing. | ||
+ | |||
+ | Read KEY1: | ||
+ | <syntaxhighlight lang="bash"> | ||
+ | $ cd matrix-python/Matrix.GPIO | ||
+ | $ python setup.py install | ||
+ | $ python test/matrix_input.py 36 | ||
+ | </syntaxhighlight> | ||
+ | When you press KEY1 "value" will be set to 0. When you release KEY1 "value" will be set to 1. | ||
+ | |||
+ | Test AD: | ||
+ | <syntaxhighlight lang="bash"> | ||
+ | $ cd matrix-python/modules | ||
+ | $ modprobe pcf8591 | ||
+ | $ cd ../Matrix.pcf8591 | ||
+ | $ python setup.py install | ||
+ | $ python test/matrix_adc.py | ||
+ | </syntaxhighlight> | ||
+ | When you change the resistor AD value will be changed accordingly. | ||
+ | |||
+ | Test Compass: | ||
+ | <syntaxhighlight lang="bash"> | ||
+ | $ cd matrix-python/Matrix.I2C | ||
+ | $ python setup.py install | ||
+ | $ python test/matrix_compass.py | ||
+ | </syntaxhighlight> | ||
+ | When you rotate the compass you will get changing direction values. | ||
+ | |||
+ | <!--- | ||
+ | ==Features== | ||
+ | Matrix - Compact Kit has the following onboard resources:<br> | ||
* 0.9 TFT LCD | * 0.9 TFT LCD | ||
− | * | + | * 3 x tact switch |
− | * 5mm | + | * 4 x 5mm LED |
− | * | + | * Buzzer |
* ADC | * ADC | ||
− | * | + | * Potentiometer |
− | * | + | * 40 pin female connector |
− | * | + | * 4 pin header - I2C interface |
− | * | + | * 4 pin header - UART interface |
− | * | + | * 3 pin double row pin-header - 3.3V and GND |
− | * | + | * DS18B20 temperature sensor |
− | * | + | * IR receiver |
− | * | + | * 10 x 3 pin header - 3 x AIO, 7 x DIO (two of them can be configured to PWM and four of them can be configured to SPI) |
− | * | + | * Compass |
− | == | + | ==Dimensional Diagram and Pin Description== |
− | * | + | * PCB Dimension (mm): |
[[File:Matrix-Compact_Kit_PCB.png|frameless|400px|]] | [[File:Matrix-Compact_Kit_PCB.png|frameless|400px|]] | ||
− | [[File:Matrix- | + | [[File:Matrix-Compact_Kit01.png |thumb|300px|Matrix-Compact_Kit Interface]] |
− | * ''' | + | * '''40 pin female connector's pin description''' |
::{| class="wikitable" | ::{| class="wikitable" | ||
|- | |- | ||
Line 85: | Line 291: | ||
|} | |} | ||
− | [[File:Matrix-Compact_Kit3*10.png |thumb|300px|Matrix- | + | [[File:Matrix-Compact_Kit3*10.png |thumb|300px|Matrix-Compact_Kit Interface]] |
− | * ''' | + | * '''30 pin header's pin description''' |
::{| class="wikitable" | ::{| class="wikitable" | ||
|- | |- | ||
− | | | + | |Ch# || G ||Ch# || V ||Ch# || S |
|- | |- | ||
|1 || GND ||2 || VDD_5V ||3 ||A1_PCF | |1 || GND ||2 || VDD_5V ||3 ||A1_PCF | ||
Line 113: | Line 319: | ||
|} | |} | ||
− | [[File:18B20 and IRR.png |thumb|300px| | + | [[File:18B20 and IRR.png |thumb|300px|DS18B20 and IR receiver's interface]] |
− | * ''' | + | * '''DS18B20 and IR receiver's pin description''' |
::{| class="wikitable" | ::{| class="wikitable" | ||
|- | |- | ||
Line 125: | Line 331: | ||
|} | |} | ||
− | == | + | ==Download Matrix Source Code== |
− | + | All the matrix modules' code samples are open source. They are maintained on GitHub: https://github.com/friendlyarm/matrix.git <br> | |
− | + | Each branch in this hub contains the matrix modules' code samples for a board that the matrix modules can work with<br> | |
− | * | + | * The matrix-nanopi branch contains the matrix modules' code samples for the NanoPi |
− | * | + | * The matrix-nanopi2 branch contains the matrix modules' code samples for the NanoPi 2 |
− | * | + | * The matrix-tiny4412 branch contains the matrix modules' code samples for the Tiny4412; |
− | * | + | * The matrix-raspberrypi branch contains the matrix modules' code samples for the RaspberryPi; |
− | + | Follow the steps below to get the source code:<br> | |
+ | Install the git utility on a PC running Ubuntu14.04 | ||
<syntaxhighlight lang="bash"> | <syntaxhighlight lang="bash"> | ||
$ sudo apt-get install git | $ sudo apt-get install git | ||
</syntaxhighlight> | </syntaxhighlight> | ||
− | + | Clone the matrix code from GitHub | |
<syntaxhighlight lang="bash"> | <syntaxhighlight lang="bash"> | ||
$ git clone https://github.com/friendlyarm/matrix.git | $ git clone https://github.com/friendlyarm/matrix.git | ||
</syntaxhighlight> | </syntaxhighlight> | ||
− | + | If this is successful a "matrix" directory will be generated, which will contain all the matrix modules' code samples. | |
− | == | + | ==Connect to NanoPi 2== |
− | === | + | ===Hardware Connection=== |
− | + | Refer to the following connection diagram to connect the Matrix-Compact_Kit to the NanoPi 2:<br> | |
[[File:Matrix-Compact_Kit_nanopi2.jpg|frameless|600px|Matrix-Compact_Kit_nanopi2]] | [[File:Matrix-Compact_Kit_nanopi2.jpg|frameless|600px|Matrix-Compact_Kit_nanopi2]] | ||
− | === | + | ===Compile Test Program=== |
− | + | Login to the matrix hub and enter the nanopi2 branch | |
<syntaxhighlight lang="bash"> | <syntaxhighlight lang="bash"> | ||
$ cd matrix | $ cd matrix | ||
Line 156: | Line 363: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
− | + | Compile the Matrix code | |
<syntaxhighlight lang="bash"> | <syntaxhighlight lang="bash"> | ||
$ make CROSS_COMPILE=arm-linux- clean | $ make CROSS_COMPILE=arm-linux- clean | ||
Line 162: | Line 369: | ||
$ make CROSS_COMPILE=arm-linux- install | $ make CROSS_COMPILE=arm-linux- install | ||
</syntaxhighlight> | </syntaxhighlight> | ||
− | + | Note: make sure to install the cross compiler "arm-linux-gcc-4.9.3" on your PC, which is used to compile files for the NanoPi 2.<br> | |
− | + | Generated library files are under the "install/lib" directory. The test program is under the "install/usr/bin" directory.<br> | |
+ | The modules are under the "modules" directory. The driver's source code is in github: https://github.com/friendlyarm/linux-3.4.y.git <br> | ||
− | === | + | ===Copy Test Program=== |
− | + | Insert a TF card which is flashed with Debian into a Linux host and mount its boot and rootfs sections.<br> | |
− | + | We assume the rootfs is mounted to /media/rootfs then run the following commands to copy the module, library and test program to the card<br> | |
<syntaxhighlight lang="bash"> | <syntaxhighlight lang="bash"> | ||
$ cp modules /media/rootfs/ -r | $ cp modules /media/rootfs/ -r | ||
Line 174: | Line 382: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
− | === | + | ===Test LCD=== |
− | + | Insert this TF card to your NanoPi 2, power on and run the following commands.<br> | |
<syntaxhighlight lang="bash"> | <syntaxhighlight lang="bash"> | ||
$ cd /modules | $ cd /modules | ||
Line 181: | Line 389: | ||
$ sudo FRAMEBUFFER=/dev/fb-st7735s startx & | $ sudo FRAMEBUFFER=/dev/fb-st7735s startx & | ||
</syntaxhighlight> | </syntaxhighlight> | ||
− | + | "fbtft_device" is the LCD's driver.After it is loaded the LCD will be initialized.<br> | |
− | + | "startx" sets the LCD to the output device. Here is what you should expect:<br> | |
[[File:matrix-cpt_kit_result1.png|frameless|600px|matrix-cpt_kit_result_lcd]] | [[File:matrix-cpt_kit_result1.png|frameless|600px|matrix-cpt_kit_result_lcd]] | ||
− | === | + | ===Access LED=== |
− | + | {| class="wikitable" | |
+ | |- | ||
+ | |LED || CPU GPIO || linux ID | ||
+ | |- | ||
+ | |LED1 || GPIOC10 || 74 | ||
+ | |- | ||
+ | |LED2 || GPIOC9 || 73 | ||
+ | |- | ||
+ | |LED3 || GPIOC11 || 75 | ||
+ | |- | ||
+ | |LED4 || GPIOC12 || 76 | ||
+ | |} | ||
+ | We used LED1 as an example. Run the following commands to access LED1: | ||
<syntaxhighlight lang="bash"> | <syntaxhighlight lang="bash"> | ||
− | $ | + | $ cd /sys/class/gpio/ |
+ | $ echo 74 > export | ||
+ | $ echo out > gpio74/direction | ||
+ | $ echo 1 > gpio74/value | ||
</syntaxhighlight> | </syntaxhighlight> | ||
− | + | 1 indicates LED on and 0 indicates LED1 off. | |
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | === | + | ===Test Key=== |
{| class="wikitable" | {| class="wikitable" | ||
|- | |- | ||
− | | | + | |Key || CPU GPIO || linux ID |
|- | |- | ||
|KEY1 || GPIOC7 || 71 | |KEY1 || GPIOC7 || 71 | ||
Line 212: | Line 426: | ||
|KEY3 || ALIVEGPIO3 || 163 | |KEY3 || ALIVEGPIO3 || 163 | ||
|} | |} | ||
− | + | We used KEY1 as an example. Running the following commands reads its value: | |
<syntaxhighlight lang="bash"> | <syntaxhighlight lang="bash"> | ||
$ cd /sys/class/gpio/ | $ cd /sys/class/gpio/ | ||
Line 219: | Line 433: | ||
$ cat gpio71/value | $ cat gpio71/value | ||
</syntaxhighlight> | </syntaxhighlight> | ||
− | + | After you press KEY1 the value will be 0. After it is released the value will be 1. | |
− | === | + | ===Test AD=== |
− | + | Run the following command to get Channel 0's value: | |
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
<syntaxhighlight lang="bash"> | <syntaxhighlight lang="bash"> | ||
− | $ | + | $ matrix-adc |
− | + | ||
− | + | ||
− | + | ||
</syntaxhighlight> | </syntaxhighlight> | ||
− | + | When you turn the resistor the AD value will change. Here is what you should expect:<br> | |
+ | [[File:matrix-cpt_kit_result2.png|frameless|600px|matrix-cpt_kit_result_ad]] | ||
+ | |||
+ | ===Test Compass=== | ||
+ | Run the following command to activate the compass: | ||
+ | <syntaxhighlight lang="bash"> | ||
+ | $ matrix-compass | ||
+ | </syntaxhighlight> | ||
+ | When you change the module's direction you will get a changing value. Here is what you should expect:<br> | ||
+ | [[File:matrix-cpt_kit_result3.png|frameless|600px|matrix-cpt_kit_result_cps]] | ||
+ | |||
+ | ===Test Temperature Sensor=== | ||
+ | Refer to the following connection diagram to connect the Matrix-Compact_Kit to the DS18B20 temperature sensor:<br> | ||
+ | [[File:Matrix-Compact_Kit_ds18b20.jpg|frameless|600px|Matrix-Compact_Kit_ds18b20]] | ||
+ | |||
+ | Run the following commands: | ||
+ | <syntaxhighlight lang="bash"> | ||
+ | $ cd /modules | ||
+ | $ insmod w1-gpio.ko | ||
+ | $ insmod w1-gpio-board gpio=72 | ||
+ | $ matrix-temp_sensor | ||
+ | </syntaxhighlight> | ||
+ | gpio=72 means pin GPIOC8 is used. 72 is the index number in Linux.<br> | ||
+ | Here is what you should expect:<br> | ||
+ | [[File:matrix-temperature_sensor_result.png|frameless|600px|matrix-temperature_sensor_result]] | ||
+ | |||
+ | ===Test IR Receiver=== | ||
+ | Refer to the following connection diagram to connect the Matrix-Compact_Kit to the VS1833B IR receiver:<br> | ||
+ | [[File:Matrix-Compact_Kit_vs1833b.jpg|frameless|600px|Matrix-Compact_Kit_vs1833b]] | ||
+ | |||
+ | Run the following commands: | ||
+ | <syntaxhighlight lang="bash"> | ||
+ | $ cd /modules | ||
+ | $ insmod matrix_ir_recv.ko gpio=92 | ||
+ | </syntaxhighlight> | ||
+ | gpio=92 means pin GPIOC28 is used. 92 is the index number in Linux.<br> | ||
+ | After the driver is successfully loaded a device node will be generated under /dev/input/. We assume it is event1 in our example.<br> | ||
+ | |||
+ | An open source utility "input-utils" can be used to read a device's data. Here is how to do it:<br> | ||
+ | <syntaxhighlight lang="bash"> | ||
+ | $ apt-get install input-utils | ||
+ | $ input-events 1 | ||
+ | </syntaxhighlight> | ||
+ | 1 stands for device node event1。<br> | ||
+ | |||
+ | If you send data to the IR receiver with a remote control you will be able to see this:<br> | ||
+ | [[File:matrix-ir_receiver_result.png|frameless|600px|matrix-ir_receiver_result]] | ||
+ | |||
+ | ===Code Samples in Python=== | ||
+ | The Python version is 2.7.9 in the following samples<br> | ||
+ | Install the Python libraries and modules: | ||
+ | <syntaxhighlight lang="bash"> | ||
+ | $ apt-get install Python-dev | ||
+ | $ apt-get install libi2c-dev | ||
+ | </syntaxhighlight> | ||
+ | The python code is in our github: | ||
+ | <syntaxhighlight lang="bash"> | ||
+ | $ git clone https://github.com/friendlyarm/matrix-python.git | ||
+ | </syntaxhighlight> | ||
+ | After it is done a matrix-python directory will be generated. | ||
+ | |||
+ | |||
+ | Access LED: | ||
+ | <syntaxhighlight lang="bash"> | ||
+ | $ cd matrix-python/Matrix.GPIO | ||
+ | $ python setup.py install | ||
+ | $ python test/matrix_output.py 33 | ||
+ | </syntaxhighlight> | ||
+ | The red LED will be flashing. | ||
+ | |||
+ | Read KEY1: | ||
+ | <syntaxhighlight lang="bash"> | ||
+ | $ cd matrix-python/Matrix.GPIO | ||
+ | $ python setup.py install | ||
+ | $ python test/matrix_input.py 36 | ||
+ | </syntaxhighlight> | ||
+ | When you press KEY1 "value" will be set to 0. When you release KEY1 "value" will be set to 1. | ||
+ | |||
+ | Test AD: | ||
+ | <syntaxhighlight lang="bash"> | ||
+ | $ cd matrix-python/modules | ||
+ | $ insmod pcf8591.ko | ||
+ | $ cd ../Matrix.pcf8591 | ||
+ | $ python setup.py install | ||
+ | $ python test/matrix_adc.py | ||
+ | </syntaxhighlight> | ||
+ | When you change the resistor AD value will be changed accordingly. | ||
+ | |||
+ | Test Compass: | ||
+ | <syntaxhighlight lang="bash"> | ||
+ | $ cd matrix-python/Matrix.I2C | ||
+ | $ python setup.py install | ||
+ | $ python test/matrix_compass.py | ||
+ | </syntaxhighlight> | ||
+ | When you rotate the compass you will get changing direction values | ||
+ | |||
+ | ==Connect to NanoPi== | ||
+ | |||
+ | ==Connect to Tiny4412== | ||
+ | |||
+ | ==Connect to RaspberryPi== | ||
+ | |||
+ | ==Connect to Arduino== | ||
+ | ---> | ||
+ | |||
+ | ==Resources== | ||
+ | *[Schematic]([http://wiki.friendlyarm.com/wiki/images/9/94/Schematic-Martix_Compact_Kit.pdf Matrix - Compact Kit-Schematic.pdf]) | ||
+ | *[Schematic]([http://pan.baidu.com/s/1pJQ29Az?qq-pf-to=pcqq.temporaryc2c Matrix - Compact Kit-Schematic.pdf]) | ||
+ | *[0.9'LCD datasheet]([http://wiki.friendlyarm.com/wiki/images/3/3b/0.9inch_TFT_ST7735S.pdf Matrix - Compact Kit-0.9'LCD datasheet.pdf]) | ||
− | == | + | ==Update Log== |
+ | ===Feb-17-2016=== | ||
+ | * Added 5.9, 5.10 and 5.11 | ||
− | == | + | ===Feb-24-2016=== |
+ | * Added the driver's source code location in Section 5.2 | ||
− | == | + | ===Mar-21-2016=== |
+ | * Corrected typo in Section 5.9 | ||
+ | * Added lib installation steps in Section 5.11 | ||
− | == | + | ===Mar-29-2016=== |
+ | * Corrected expression errors | ||
− | == | + | ===June-19-2016=== |
− | * | + | * Re-organized and simplified wiki |
Latest revision as of 10:32, 19 June 2016
Contents
1 Introduction
- The Matrix-Compact Kit is a compact board with various hardware resources, interfaces and ports. It includes user keys, LED, buzzer, ADC, compass, temperature sensor, IR receiver, TFT port and etc. This board can be connected to the NanoPi, NanoPi 2 and Raspberry Pi via its 40 pin header. In addition you can connect other external modules to its GPIOs.
2 Features
- PCB Dimension(mm):
- 40pin female connector's GPIO Pin Spec
Pin# Name Pin# Name 1 VDD_SYS_3.3V 2 VDD_5V 3 I2C0_SDA 4 VDD_5V 5 I2C0_SCL 6 DGND 7 GPIOB28 8 UART3_TXD 9 DGND 10 UART3_RXD 11 GPIOB29 12 GPIOB26 13 GPIOB30 14 DGND 15 GPIOB31 16 PWM2 17 VDD_SYS_3.3V 18 GPIOB27 19 SPI0_MOSI 20 DGND 21 SPI0_MISO 22 PWM0 23 SPI0_CLK 24 SPI0_CS 25 DGND 26 PWM1 27 I2C1_SDA 28 I2C1_SCL 29 GPIOC8 30 DGND 31 SPI2_CLK 32 GPIOC28 33 SPI2_CS 34 DGND 35 SPI2_MOSI 36 GPIOC7 37 SPI2_MISO 38 ALIVEGPIO2 39 DGND 40 ALIVEGPIO3
- 30pin Pin Spec
Pin# Name Pin# Name Pin# Name 1 GND 2 VDD_5V 3 A1_PCF 4 GND 5 VDD_5V 6 A2_PCF 7 GND 8 VDD_5V 9 A3_PCF 10 GND 11 VDD_5V 12 D1_Pi11 13 GND 14 VDD_5V 15 D2_Pi26 16 GND 17 VDD_5V 18 D3_Pi16 19 GND 20 VDD_5V 21 D4_Pi19 22 GND 23 VDD_5V 24 D5_Pi21 25 GND 26 VDD_5V 27 D6_Pi23 28 GND 29 VDD_5V 30 D7_Pi24
- 18B20 & IR Receiver Pin Spec
Module Pin# Name Pin# Name Pin# Name 18B20 1 VDD_5V 2 DATA 3 GND IR Receiver 1 DATA 2 GND 3 VDD_5V
3 Applications
3.1 Connect to NanoPi 2
Refer to the following connection diagram to connect the module to the NanoPi 2:
4 Compile & Run Test Program
Boot your ARM board with Debian and copy the matrix code:
$ apt-get update && apt-get install git $ git clone https://github.com/friendlyarm/matrix.git
If your cloning is done successfully a "matrix" directory will be generated.
Compile and install Matrix:
$ cd matrix $ make && make install
Run test program:
$ matrix-compact_kit
Note: this module is not plug and play therefore before running the module please make sure it is connected to an ARM board.
Here is what you should observe:
LED blinking 1 LED blinking 2 Button: 1 1 1 ADC channel0: 550 Compass angle: 328.5 Pwm start Pwm stop
Run Qt program to test the TFT LCD:
cd matrix/demo/nanopi-status ./build.sh ./run.sh /dev/fb-st7735s
The program will present the system's basic information:
5 Code Sample
This Matrix code sample can work with all the ARM boards mentioned in this module's wiki. The name of this code sample is "matrix-compact_kit". Here is its source code:
int main(int argc, char ** argv) { int board; if ((board = boardInit()) < 0) { printf("Fail to init board\n"); return -1; } testLED(board); readButton(); readADC(); readCompass(); testPWM(board); // readTemp(); // testIR(); return 0; }
For more details about this APIs called in this code sample refer to Matrix API reference manual
6 Code Samples in Python
The Python version is 2.7.9 in the following samples
Install the Python libraries and modules:
$ apt-get install Python-dev libi2c-dev
The python code is in our github:
$ git clone https://github.com/friendlyarm/matrix-python.git
After it is done a matrix-python directory will be generated.
Access LED:
$ cd matrix-python/Matrix.GPIO $ python setup.py install $ python test/matrix_output.py 33
The red LED will be flashing.
Read KEY1:
$ cd matrix-python/Matrix.GPIO $ python setup.py install $ python test/matrix_input.py 36
When you press KEY1 "value" will be set to 0. When you release KEY1 "value" will be set to 1.
Test AD:
$ cd matrix-python/modules $ modprobe pcf8591 $ cd ../Matrix.pcf8591 $ python setup.py install $ python test/matrix_adc.py
When you change the resistor AD value will be changed accordingly.
Test Compass:
$ cd matrix-python/Matrix.I2C $ python setup.py install $ python test/matrix_compass.py
When you rotate the compass you will get changing direction values.
7 Resources
- [Schematic](Matrix - Compact Kit-Schematic.pdf)
- [Schematic](Matrix - Compact Kit-Schematic.pdf)
- [0.9'LCD datasheet](Matrix - Compact Kit-0.9'LCD datasheet.pdf)
8 Update Log
8.1 Feb-17-2016
- Added 5.9, 5.10 and 5.11
8.2 Feb-24-2016
- Added the driver's source code location in Section 5.2
8.3 Mar-21-2016
- Corrected typo in Section 5.9
- Added lib installation steps in Section 5.11
8.4 Mar-29-2016
- Corrected expression errors
8.5 June-19-2016
- Re-organized and simplified wiki