Hi, Here are the updates I have recently worked on: - migration to KODI stable 14.0 - Raspbian OS from 24 december 2013 - linux kernel 3.18.1 with touchscreen drivers - updates to Radio and Navigation addons
You can install the build using the tutorial link on the right side of the blog. Please don't forget about the forum for any comments.
After installing the image on an sd card, you have to configure the system for your needs.
Calibrate the touch screen The touch screen calibration involves two steps and you need a keyboard connected: 1. Calibrating the touch screen for X11 applications(like Navit). Open the terminal from Desktop and type xinput_calibrator and follow the indications. After the calibration is completed you have to put the output in a file to make this permanent: sudo nano /usr/share/X11/xorg.conf.d/01-input.conf Put here the output of xinput_calibrator. It will be something like: Section "InputClass" Identifier "calibration" MatchProduct "eGalax Inc. USB TouchController" Option "Calibration" "121 1917 317 1741" Option "SwapAxes" "1" EndSection 2. Calibrating the touch screen for XBMC. In XBMC use the keyboard to go to Programs/Touch Screen Calibration and follow the informations on screen. Note, that in order to make a better calibration you can move the finger on screen towards the point, before pressing enter(as can be seen on minute 0:52 in the video). Touch each point and then press enter to go to the next one. At the end, you have to unplug the touch from usb and then plug it back(works on XBMC Gotham). After this, he calibration is stored permanently in the file /home/pi/touchscreen_axes_calib. You can edit this file to fine tune the position of the cursor if the calibration isn't perfect. calib_x_d and calib_y_d - control the cursor displacement up/down/left/right calib_x_fact and calib_y_fact - some factors obtained in the calibration process(don't edit them) click_confines - defines the area that will be used for click(if the touch moves outside of this area then a drag action will occur) - this area is measured from the first touched point touch_mouse - if you want to use a mouse you have to set this to 0, but some touch screens behave as mouses and you have to set this to 1 in order for them to work(with single click). For the most of the touches this can be 0 if you want to also use a mouse, but if you don't want to use a mouse it doesn't mater, let it be 1.
Change the resolution [XBMC] Using ssh you have to edit the file /home/pi/.xbmc/userdata/advancedsettings.xml and set your resolution. After this restart the whole system and XBMC should run with your new resolution. [LXDE] Connect with ssh and type tvservice -mDMT && tvservice -mCEA and get the desired resolution mode Edit /boot/config.txt and modify according to your preference, for example: hdmi_group=2 hdmi_mode=27 CEA group is 1 and DMT 2.
Add a new map for Navit 1. Go to Navit Planet Extractor and download a .bin file for your area. 2. Copy the .bin file in your RPI card in /home/pi/.navit/ folder 3. Edit the file /home/pi/navit_src/build/navit/navit.xml and search for the entry: <mapset enabled="yes"> <map type="binfile" enabled="yes" data="/home/pi/.navit/Romania.bin"/> </mapset> 4. Add your map name here like this: <mapset enabled="yes"> <map type="binfile" enabled="yes" data="/home/pi/.navit/Romania.bin"/> <map type="binfile" enabled="yes" data="/home/pi/.navit/new_map.bin"/> </mapset>
Setup the GPS receiver 1. For USB devices. After plugging the device into the usb port type dmesg and you should see somewhere that a new device was mapped on /dev/tty... Most probably the file name would be /dev/ttyACM0. 2. For Serial(UART) modules. The device will have the file name as /dev/ttyAMA0. You can test that the device is connected to a file name by calling cat/dev/ttyAMA0, for example and you should see some NMEA output. Now, copy this file name and put it in the file /home/pi/StartCarPC in the section: # Start gpsd # /dev/ttyAMA0 - RPI serial port # /dev/ttyACM0 - usb port sudo killall gpsd gpsd /dev/ttyAMA0
Voice configuration for Navit Each time a road indication has to be made, Navit will execute the file /home/pi/.navit/speech.sh with the indication text. This file will play a sound and the speak the indication, through speakers. aplay -r 44100 /home/pi/.navit/notification3.wav & sleep 0.7 && espeak -ven+f4 -s150 -a 150 -p 50 "$1" --stdout | aplay /home/pi/.navit/notification3.wav - the sound that will be played each time before an indication -ven+f4 - female voice number 4 -s150 - speed 150 words per minute -a150 - amplitude -p50 - pitch You can find more settings in the espeak manual If you don't want the voice guidance you can press the speaker button in Navit and it will be turned off.
Configure the Controller The controller can be easily used with Steering wheel controls or other physical controls in your car. To enable this controller, you have to edit the file /home/pi/StartCarPC and search for the entry: # Start the GPIO Remote #sudo opencarpc-controller /home/pi/gpio_description & You have to change it to: # Start the GPIO Remote sudo opencarpc-controller /home/pi/gpio_description & Now, you can set the configuration file like in this post
Change the car logo in the Home screen If you want to put another car logo you have to edit the file /home/pi/.xmc/addons/skin.CarPC-touch/16x9/Home.xml and find the entry: <posx>580</posx> <posy>205</posy> <width>550</width> <height>550</height> <texture>bmw_logo.png</texture> Here, you can set your new image instead of bmw_logo.png you can put a complete path of the new image.
Set up a WIFI connection If you want to have internet connection, or airplay or control the whole system using the XBMC remotes, you have to setup a wifi hotspot with your phone and then use an USB WIFI dongle(I am using EDIMAX EW-7811UN dongle). The system is configured to automatically connect to a wifi hotspot with the following settings: wpa-ssid "opencarpc" wpa-psk "opencarpc123" You can find these settings in the file /etc/network/interfaces.
I have worked on some new features for my CarPC. Here are the changes: First, some videos:
The latest image can be downloaded from the Downloads link on the right of this blog(username:pi, password:a). Note! If you do not have any rotary encoder connected or any buttons with a resistor you need to disable the carpc-controller application. You can do this by editing the file /home/pi/StartCarPC and commenting the line which contains carpc-controller.
Hardware updates: - added ViewHd HDMI to HDMI+audio board - added SI4703 FM Radio module - created an expansion board with fm radio module and three connectors(one for GPS receiver and two for rotary encoders) - added a very cheap board to mix two output channels(RPI and radio) into a single output(which goes to the amplifier, in my case AUX input of the car player)
Software updates: - added loading movie(created by Doru Ignat) - added a python server responsible for controlling the radio module via i2c - added new XBMC plugin for controlling the FM Radio(including storing up to 5 radio stations in a file) - improved carpc-controller to support sending multiple commands for a single button press or encoder turn(e.g. turning right one rotary encoder can increase the volume in XBMC and the volume of radio at the same time) - improved the speed in Navit clicking - improved the Navit OSD for both day and night setup(Navit switches automatically teh setup based on the time of the system). - added time synchronization mechanism based on GPS readings(RPI does not have a real time clock)
The expansion board.
RE1 and RE2 are rotary encoders.
The FM Radio driver and Python server. The FM Radio module is connected using i2c communication interface(GPIO0-SDA and GPIO1-SCL of the PI). The radio driver is contained in the si4703 python class. The Radio server is implemented in the file radio_server.py(which is automatically started at boot time). This server simply opens a socket and waits for data. After any data is received, a couple of if-else statements different radio functions are called base on the incoming data. The available commands are:
seek_right - search for a new station in the right of the current frequency seek_left - search for a new station in the left of the current frequency tune_xx.x - set the current frequency to xx.x MHz volume_xx - set the volume of the radio module to xx. xx should be between 0 and 15 toggle_mute - toggle mute get_frequency - get the current frequency
The server reply with the current frequency for each command.
Simple test. To understand how this radio server-client works you can make the folowing experiment: 1. Plug the gpio expansion board(or wire the radio module to the PI as in the above schematic) 2. [Server] Connect using one ssh window(I use Putty) to the PI and enter the folowing commands: cd radio sudo python radio_server.py The radio server should initialize the radio module and start the server. 3. [Client] go to the radio folder and use radio_client.py to send commands o the radio server, like in the folowing picture:
The file radio_client.py simply opens an UDP socket, puts an '_' character between arguments and send the obtained string to the server socket.
The radioFM XBMC plugin. In order to simplify user interaction I have created a new XBMC plugin(radioFM). Its purpose is to allow interacting with the Radio Server(and with the Radio Module) using the touch screen. In order to be able to use this plugin you need to have the radio_server.py started and the FM module plugged in.
Features:
The current frequency is displayed at the top.
The left and right arrow buttons are for seeking to the next channel(left or right).
The bottom 5 buttons are preset channels(these are kept in a file so they are available after reboot).
The Set/Tune Channels button is used for changing the mode in which the bottom buttons are operating. By default they are in the 'Tune' mode, so if you presss them the radio will tune to that frequency. If you press the Set/Tune Channels button once you will enter the Set mode, which will allow you to store the current channel in which preset button you like(or in all of them... if you want) by pressing it once. You will see that the frequency will be changed.
Connecting two audio sources(RPI and Radio) to one amplifier. In order to correctly hook up two audio sources together(putting them in parallel) for a single output you have to use one schematic from this document. I have used the last schematic. Don't forget to use at least 1% tolerance for the resistors. The new GPIO controller. The GPIO controller is now using the official XBMC client code from xbmcclient.h. Now, you can call a lot more XBMC functions for any button pressed or encoder movement.
TODO List: - update to the latest Raspberry PI firmware(today it is possible but then Navit won't be visible) - remove the calibration file for XBMC(/usr/share/eGalax/touchscreen_axes_calib) and use the values from the Debian calibration file(/usr/share/X11/xorg.conf.d/01-input.conf) - create an XBMC addon to allow calibrating the touch screen for both XBMC and X11 windows and also for calibrating the external encoders and button - create a configuration page(XBMC addon) for the carpc-controller settings - create a better audio mixer unit - create a new page for launching different X11 applications
I have recently worked on adding external controls for my Raspberry PI CarPC project because while driving it is better to have some physical controls to rely on, rather than looking at the touch screen to find the buttons. This post provide information on how to set up buttons or rotary encoders to control XBMC from Raspberry PI.
Rotary encoder
Rotary encoders are very cheap and very nice controls(eBay link). You can find them in car stereos for volume control. You can also use them to browse through menu items or to skip to next song etc. They are looking very similar to a potentiometer, but there are major differences: they can be turned in both directions with infinite steps(you know just the direction of the spin), they provide digital output, a full rotation have a number of steps and they have push button also. Connections for Raspberry PI should be done as follows: + pin to 3.3V GND pin to Raspberry PI GND SW to one GPIO CLK and DT to two GPIOs When the push button is pressed the pin labelled SW is connected to GND. This can be set up as any push button(see below).
Push button
A push button can have two states on or off. There are two ways to hook up a button to a logical circuit(e.g Raspberry PI GPIO's):
We have to use the first setup(with pull up resistor) for the tool to work properly. So, for the push button of the rotary encoder above, we have to cable it like this:
The tool I have created a tool to allow you interface rotary encoders(and also push buttons) with Raspberry PI GPIO's. Also you can set an XBMC command to be executed for click, left rotation and right rotation. The tool can be otbained from my Google Code project(link to page). It is very easy to use it. You just have to accomplish two steps: - copy rpi-xbmc-remote in a place where it can be accessed from anywhere(e.g. /usr/bin) - call it using sudo rpi-xbmc-remote /path/to/configuration/file
The configuration file Example:
ip:localhost
button:7:KB:return
encoder:clk:23:KB:up:dt:24:KB:down
The configuration file can reside anywhere on the disk. It provides a way to define two kind of inputs for XBMC: regular button and rotary encoder.Lines should be less than 100 characters in length. Lines starting with # are comments and are not being processed.
Example of regular button definition:
button:7:KB:return
- 'button' means it is a regular button
- '7' means use GPIO7 for this button
- 'KB' means XBMC device map
"KB" - Standard keyboard map
"XG" - Xbox Gamepad
"R1" - Xbox Remote
"R2" - Xbox Universal Remote
"LI:devicename" - valid LIRC device map where 'devicename' is the actual
name of the LIRC device
- 'return' means XBMC button name to be called(see XBMC keymaps)
Example of rotary encoder definition:
encoder:clk:23:KB:up:dt:24:KB:down
- 'encoder' means it is a rotary encoder
- '23' means use GPIO23 for rotary encoder CLK
- 'KB' means XBMC device map for rotary encoder left turn(same as above)
- 'up' means XBMC button name to be sent for left turn of the rotary encoder
- '24' means use GPIO24 for rotary encoder DT
- 'KB' means XBMC device map for rotary encoder right turn(same as above)
- 'return' means XBMC button name to be called(see XBMC keymaps)
Keep in mind!
You have to put a pull up resistor for every push button you define in the configuration file. If you don't do this then the state of the button will be variable when not pressed(it will oscillate between 0 and 1) and it will behave like it is pressed randomly.
A big problem for a CarPC is that you need a real time clock to synchronize your system with. For my CarPC, I don't have any RTC module on Raspberry PI, but I do have a gps always connected, which provide accurate date and UTC time. I have found some tutorials on how I can set up ntp to update the system clock based on gpsd but they didn't worked with any of my gps devices: ST22 SkyTraq GPS receiver Columbus V-800 I have followed some links with no luck. I got: "gpsd:WARN: can't use GGA time until after ZDA or RMC has supplied a year." or "gps data is no good" or "unrecognized ... sentence"
I have decided to make my own time synchronization based on parsing raw gps data. You can download an archive containing the scripts from here.
How does it work? First connect your gps module: gpsd /dev/ttyAMA0 Then, to get the raw data I used: gpspipe -R -n10 This command will get the first 10 lines from gps raw data. I got this:
The Shell part. To set UTC time for our unix system we have to issue a command like this:
date -u -s "2013/10/05 12:48:00"
From the raw gps output, we see that GPRMC gives all the needed information about the date and time(see here what the fields mean). My idea was to capture just GPRMC data from this output and send it as a parameter to a C program which will parse the string and create a new string as needed to set time. To get the GPRMC string from the raw gps output I have did the following bash command:
gpspipe -R -n10 | sed -n "/GPRMC/,/*/p"
Decomposition of the command: gpspipe -R -n10 - this outputs the first 10 lines from the gps raw output. sed -n "/GPRMC/,/*/p" - extracts the line starting with the string GPRMC I have used unix pipes(| character) to pass the output from gpspipe -R -n10 to the sed command. The output from this command will be like this:
Now, to pass this as program arguments(assuming the program's name is set_date) we have to do the following:
./set_date 21 $(gpspipe -R -n10 | sed -n "/GPRMC/,/*/p")
The C program part. In this example, argc will be 4 and argv will be as follows: argv[0] - "./set_date" argv[1] - "21" argv[2] - "$GPRMC,100201.786,A,4425.1179,N,02602.8192,E,000.0,191.5,061013,,,A*61" argv[3] - "$GPVTG,191.5,T,,M,000.0,N,000.0,K,A*01"
The GPRMC output gives 100201 for time and 061013 for date. This means: UTC time is 10:02:01 and date is 06 October 2013. GPRMC does not provide the full year, so we have to provide the century as an argument to the C program to compute the correct date. We are only interested in argv[1] and argv[2], so, in the C program we will convert argv[1] to int using atoi(argv[1]) and we will have the century and after this we have to parse argv[2] using sscanf to get the two numbers for time: 100201 and for date 061013. Let's assume we got these numbers in two uint32_t variables: rawDate = 61013 rawTime = 100201 To get useful data from here we have to do this:
Lately I have tested OpenElec for Raspberry PI and found out that it is very very fast, very very small and also it has some great addons(wifi, bluetooth and more). Speed/size features on an 512MB RaspberryPI: - a complete boot is less than 25 seconds - cpu is around 30% load - memory used is 32% - total system size is less than 300MB
Edit. You can download my build from here(contains eGalax module and XBMC patches). Username is root and password is openelec. The touch screen calibration file should be put in /storage/touchscreen_axes_calib.
Next, I will guide you through the instructions for building(cross compile) latest OpenElec for Raspberry PI with touch screen support. For this tutorial let's assume that you have a Linux machine where you will work.
1. Get the latest OpenElec. git clone git://github.com/OpenELEC/OpenELEC.tv.git
2. Add kernel touch screen module support. Open the file OpenELEC.tv/projects/RPI/linux/linux.arm.conf and search for "CONFIG_INPUT_TOUCHSCREEN". Replace the whole text line with the following lines: CONFIG_INPUT_TOUCHSCREEN=y CONFIG_TOUCHSCREEN_USB_COMPOSITE=y CONFIG_TOUCHSCREEN_USB_EGALAX=y 3. Fix ppl version in OpenElec. Open the file OpenELEC.tv/packages/toolchain/math/ppl/meta and change PKG_VERSION from "1.1pre9" to "1.1pre10"
4. Put touch screen calibration file into the system. Navigate to folder OpenELEC.tv/projects/RPI/ and create the file usr/share/eGalaxCalibration/touchscreen_axes_calib. This file should have the following contents: calib_x_d=-21;calib_x_fact=0.658097686;calib_y_d=-50;calib_y_fact=0.408626561;swap_axes=0;click_confines=8 To set up these values please visit this post(at section 4). This step is not needed any more, because you can use the calibration addon to calibrate your screen. Get the calibration addon from my Downloads folder and put it in /storage/.xbmc/addons/
5. Put XBMC 12.3 patch. Get my latest patches from here and put them in the folder OpenELEC.tv/packages/mediacenter/xbmc/patches/
6. Build OpenElec. Navigate to OpenElec folder and type: PROJECT=RPi ARCH=arm make -j3 -j3 option is to use parallel build(if you have more than one cpu's set this number as nb_cpus+1). This option will speed up the build process. The build process will take couple of hours, but you have to come back once(in the first 10 minutes) and press ENTER for the kernel touch screen modifications to be approved.
This is an update for my CarPC project. You can download the latest image from the link on the top right corner of this blog(username:'pi', password:'a'). The main features are: Hardware:
[Media Center] - omxplayer - XBMC 12.2 Frodo - media formats supported: listed here - sources with objects build on 27.July.2013 - skin: CarPC-touch(download current version) - system shutdown button(safely stop xbmc and safely halt) - reload skin button - switch to camera view button - modified spectrum analyzer(OpenGL with no rotation) - eGalax touch screen calibrated - eGalax touch screen click&drag fix - black rectangle behind XBMC removed - patch to add getMousePosition feature to xbmcgui module(used to redirect clicks from the Navigation skin page to X11 using xdotool)
[Navigation] - Navit build from source - Zoom In, Zoom Out buttons - Click sent from XBMC to X11 (Navit Window)
GPS Setup 1. Connect GPS module to UART TX, UART RX, GND and 3.3V or on a usb port. 2. If you are using an UART GPS module, as I did, use this tutorial or any other to setup UART communication. 3. Connect GPS to gpsd: sudo apt-get install gpsd gpsd /dev/ttyAMA0 Adding maps to Navit In order to add new maps to Navit, there is a simple process. First, go to Navit Planet Extractor and download your desired area file(this will be a .bin file). After this, transfer the file to your Raspberry PI in the folder /home/pi/navit_export/build/navit/maps/. Here, you should also update the existing .xml file and add another entry for your new map. My .xml file is looking like this:
Safety: - The wires are 2mm in diameter with good insulation, resistant at temperature variations - I have added fuses(1.5A for the radio, 1A for Raspberry PI, 1A for display, 0.1A for reverse camera trigger, 0.1A for reverse camera video signal)
Bugs: - sound pops(will soon disappear by using this hdmi to hdmi and audio splitter) - Navigation is behind Video Player -> Navigation isn't visible while playing videos(this isn't a big issue)
After working a lot at my CarPC project I have decided to take a break and post about it.
A short preview is here:
You can download the latest image from my Downloads page in the top right corner of this blog. If you want to build it by yourself please follow my previous tutorials but replace the three patches with the single patch from here, which is for XBMC12.2. Also read my previous post to find how to calibrate the screen axes.
Features:
auto start XBMC
eGalax touch screen support with configurable greater area for touch event(8 pixels)
improved skin with larger buttons and smooth transitions(link for the skin)
System Power OFF button
usbmount enabled(so usb MSD's are plug and play)
The new calibration file contains one more entry: click_confines which defines the area for XBMC to distinguish between click and drag actions(touch moves less than 8 pixels before release than action is click, else the action is drag).
I have spent some time lately trying to find a solution to get my 7 inch eGalax touchscreen to work with Raspbian(Debian Wheezy) in XBMC 12 Frodo and finally got it working as I wanted.
My Setup
Raspberry PI model B: ~30$
7 inch display with touchscreen for car rear view camera, from eBay(touchscreen is connected to one USB port): 80$
HDMI male to HDMI male connector(from eBay): <2$
4GB SDHC class 4 card
12V(500mA) AC to DC adapter for powering the display
5V(1A) microUSB AC to DC converter for powering the PI
USB keyboard
Edit: Download the latest image from the top right corner of this blog(username: pi, password: a).
Here is what you need to do in order to have a system with Raspberry PI, Raspbian OS and XBMC 12 Frodo stable with eGalax touchscreen working correctly(which means axes calibrated and click working with just one tap&release action):
1. Get latest Raspbian image from here and flash it to an SD card.
2. Build your own kernel with eGalax touchscreen support, like in this post(you will only need to replace kernel.img file and /lib/modules and /lib/firmware folders on the SD card).
3. Build XBMC 12 on Raspberry PI using this tutorial. Note: After downloading XBMC archive, get this archive and unpack it anywhere. Apply patches to xbmc files:
4. Touchscreen calibration. Create a new file /home/pi/touchscreen_axes_calib on Raspberry PI. It will contain four values for the axes calibration and one value for swapping axes. The simplest way to swap axes is to switch the four wires cable plug's orientation which comes from the touchscreen to the touch controller.
Here is how the calibration was done.
the original behavior(no calibration)
In the picture above, we see that "touch panel values frame" differs from "touch panel physical size frame". When we are pressing the touch we are moving in the "touch panel physical size frame" but when the touch screen is not calibrated the arrow from XBMC is in another place.
"touch panel physical size frame" is the screen starting from (0,0) on the left top corner and going to (width, height) in the right bottom corner.
"touch panel values frame" is the frame which contains all the number the touch controller is giving.
We see that these frames differs a lot. Our main scope is to overlap the "touch panel values frame" to the "touch panel physical size frame".
In order to do this we need to do three steps(the third one is done in software): a. Scale the value read from the touch driver x and y) in order to fit 0->width range and respectively 0->height range of the "touch panel physical size frame" the scale value for x axis is: "touch panel physical size frame" width calib_x_fact = ------------------------------------------------- "touch panel values frame" width
"touch panel values frame" width and height are coming from your XBMC resolution(I have width=1280 and height=720). "touch panel physical size frame" width and height are a little more trickier to find but nothing hard. In step 2 above, you have calibrated the touchscreen in XFCE. You got some values returned by xinput_calibrator, something like:
Section "InputClass" Identifier "calibration" MatchProduct "eGalax Inc. USB TouchController" Option "Calibration" "1977 32 1893 131" EndSection
In my case, "touch panel physical size frame" width is 1977 - 32 = 1945 "touch panel physical size frame" height is 1893 - 131 = 1762 Now, compute the values and put them in /home/pi/touchscreen_axes_calib file
b. Translate the "touch panel values frame" to the left and up, to match "touch panel physical size frame". I didn't find a logical method to do this, because we don't know exactly "where is" the "touch panel values frame", so, in order to find calib_x_d and calib_y_d you have to first set them both to zero and then start XBMC. Now, put some sharp pointer on the screen and observe the distances between the cursor on the screen and your pointer's position. Try to approximate these x and y deviations(measured in pixels) and put them in the /home/pi/touchscreen_axes_calib file.
c. Revert direction of axes. This is done in the software(from patches).
5. Math behind. To accomplish these transformations the following formula was implemented in the file xbmc/input/linux/LinuxInputDevices.cpp pointer.x = value_read.x * calib_x_fact + calib_x_d; pointer.y = value_read.y * calib_y_fact + calib_y_d;
After I have successfully calibrated the touchscreen I have discovered that single click was not possible from the touchscreen, just double click. After digging through the code, I have found that this was caused by drag action which was triggered because the previous values of the touch were far(more than 5 pixels) from a new press. For example, at the start of the program, cursor is set at 0,0 coordinates; if user is trying to press a button, let's say at 100, 300, the program(XBMC) will calculate the distance between these two points and will find out that this is greater than 5. Pythagorean theory: (100-0)x(100-0) + (300 - 0)x(300-0) is greater than 5x5 XBMC will treat this as a drag event. This drag issue is not caused when you double click, because the previous point in the second click action is very close to the second click point. This also works for mouses, because the previous value of the pointer is always very close to the new value of the pointer(because mouse's pointer drags on the screen and it doesn't jump - so each new value is very close to the previous one).
I have developed an algorithm to avoid this issue: When the user is pressing the screen(x,y), the touch values are being set to (screen_width+1, screen_height+1 -> outside of the visible screen) just at the first event read(which is BTN_TOUCH PRESS). After this event, the program will receive multiple X and Y absolute values events. The first two events, one for X and one for Y are used to set the previous X value, respectively previous Y value to the current X respective current Y values. And from now on distance is measured and this is preventing no unwanted drag action. The user's finger/pointer will not stay at a single point, because the touchscreen's lack of precision, so it will move around 5-6 pixels in x and y directions. I have also set the click distance to 7. You can change this by changing click_confines value in xbmc/input/MouseStat.h. Originally it was set to 5, but this is not very good for touch screens(I had to click with a sharp pointer and with my nail always, but with a value of 7 I can click with my finger with a slight touch -> really nice).
The next step after setting up the Development Environment for STM32F3-Discovery was to communicate with computer via serial port. I have added usart support to my board using USART2 module, which had TX connected to PA2 pin and RX to PA3 pin(both with alternate function set to 7).
The next step was to connect the pins to PC serial port. I have used a MAX3232 module(note that you need a chip with 3.3V support).
After using printf function I have noticed that linker asks for some functions like _write which are used internally. I have added a file newlib_subs.c to implement these function.
You can download the example project from here. The settings for usart communication are: baudrate: 115200 parity: none data bits: 8 stop bits: 1 flow control: none
If you want to use interrupts to read from USART you can use the code from here.
You can checkmy project via svn from my repository using: svn checkout http://andrei-development.googlecode.com/svn/branches/dev/stm32f3-discovery
ST launched in September a very interesting development board(STM32F3-Discovery). It is a very cheap one(I have got myself one for ~10$). It has a debugger integrated(STLINK) and also some great sensors:
- ST MEMS LSM303DLHC, which contains 3 axis accelerometer(to measure acceleration intensity on each axis) and 3 axis magnetometer(to measure angles to a fixed point - the Earth's magnetic North)
- ST MEMS L3GD20, which has 3 axis gyrometer(to measure rotation speed)
This board is very good for automated pilot controller projects.
After unpacking the board I have found that it was supported just by commercial software and tools. As I am an opensource kind of guy I have struggled myself some time to get this working with Eclipse, OpenOCD and a free toolchain, on Linux.
I have used Ubuntu, but I think the process is the same on every distribution. Also, with little adjustments it can work on Windows.
Here are some steps, that you have to follow to get the led blinking example to work:
1. Install Java Runtime Environment. Here are some steps for Ubuntu:
Open On-Chip Debugger 0.6.1 (2012-10-29-22:02) Licensed under GNU GPL v2 For bug reports, read http://openocd.sourceforge.net/doc/doxygen/bugs.html adapter speed: 1000 kHz srst_only separate srst_nogate srst_open_drain Info : clock speed 1000 kHz Info : stm32f3x.cpu: hardware has 6 breakpoints, 4 watchpoints
You can close the Terminal now.
7. Install toolchain. You can use Codesourcery toolchain, like described in this step, or you can use GCC Arm Embeddedtoolchain(fromhere) which has support for hardware floating point unit and which is free and it is easier to install. For Codesourcery follow the next steps: Go to Codesourcery and download IA32 GNU/Linux Installer. To install it open the Terminal and navigate to the folder where it is downloaded. Type:
chmod a+x arm-2012.03-56-arm-none-eabi.bin
./arm-2012.03-56-arm-none-eabi.bin
Then select next at every step.
8. Download sample project stm32f3.tar.gz file and unpack it.
9. Open the project in Eclipse. Open Eclipse and go to Workbench. Click File->Import and then select General->Existing Projects into Workspace. Select the downloaded project and click finish.
This is a makefile project, so you have to edit makefile if you want to change some project settings. The frst thing you should do is open the Makefile file and check at the very beginning if the toolchain path is correct. This should be like:
TC = <path_to_toolchain>/arm-none-eabi
Now you can build. right click on project name and select build. The correct output is in the Console tab from Eclipse(ignore the warnings and errors from Problems tab).
10. Debugging. After the project was builded correctly select Run->External Tools->External Tools Configuration. Select OpenOCD(restart) in the left tab and click run.
Now, right click project and select Debug as->Debug Configuration and then
select in the left stm32f3-debug and then click Debug.
Note: If you want to add more source files you can add them in the src folder. New headers should be added into hdr folder. If you want to add another folder you have to specify it like the LIB_SRCS in the Makefile and also create LIB_OBJS like variable in the Makefile.