Difference between revisions of "User:Pau pajuelo"

From IGEP - ISEE Wiki

Jump to: navigation, search
m
m (DM3730: Decode an AAC audio file (OK))
 
(826 intermediate revisions by 2 users not shown)
Line 1: Line 1:
 
= TODO:  =
 
= TODO:  =
  
Update peripheral tutorials  
+
Categorize new tutorials
  
Categorize new tutorials
+
How to manage the kernel modules on Linux
  
Upgrade ethernet gadget tutorial for new IGEP firmware and VM
+
How do I edit my kernel command line
  
Finish tutorials below
+
== AUDIO DSP-ARM==
  
NOTES: Qt, Codeblocks and Eclipse are linked to main page:  
+
===Included (IGEP GST DSP):===
 +
'''AACHEDEC -> DEC AACHE (OK)'''
  
Eclipse -&gt; How to develop under Eclipse (copy manual) (refers at beginning VM and option to install Eclipse(under construction))CONFIGURE REMOTE CONNECTION<br>
+
http://download.wavetlan.com/SVV/Media/HTTP/FAAC-HE-AAC.aac
  
Upgrade ethernet gadget how to
+
gst-launch --gst-debug-level=2 filesrc location=sampleaache.m4a ! TIAuddec1 codecName=aachedec engineName=codecServer ! volume volume=0.25 ! alsasink  sync=false
  
How to setup a cross compiler(link qt creator and Eclipse tutorial)
+
outofthebox->ok
  
igep.ini table<br>
+
----
  
Upgrade <span dir="ltr">IGEP Technology Devices Guides</span>
+
'''MP3DEC -> DEC MP3 (AUDIO ERRORS)'''
  
= How to install Eclipse with IGEP&nbsp;support (under construction)  =
+
- Followed README file from ISEE - IGEP DSP - GST + DMAI Support Package 3.40.00
  
== Overview  ==
+
http://www.stephaniequinn.com/Music/Canon.mp3
  
Eclipse is a multi-language software development environment comprising an integrated development environment (IDE) and an extensible plug-in system. It is written mostly in Java. It can be used to develop applications in Java and, by means of various plug-ins, other programming languages including Ada, C, C++, COBOL, Haskell, Perl, PHP, Python, R, Ruby (including Ruby on Rails framework), Scala, Clojure, Groovy, Android and Scheme.  
+
gst-launch --gst-debug-level=2 filesrc location=Canon.mp3 ! TIAuddec1 codecName=mp3dec engineName=codecServer ! volume volume=0.25 ! alsasink  sync=false
  
Eclipse is very popular among programmers because you can extend its functionalities using plugins. One of these interesting plugins is the Yocto Eclipse IDE Plug-in.
+
'''Random fatal bit error'''
  
The Yocto Eclipse IDE Plug-in integrates the functionality of the Yocto Project Application Development Toolkit (ADT) and toolchain into the Eclipse IDE. This allows its users direct access to deploy, build, run and debug your own project. More information about Eclipse software [http://en.wikipedia.org/wiki/Eclipse_%28software%29 here].
+
'''mp3-plugin doesn't resolve the error'''
  
<br> '''NOTE:''' If you use IGEP&nbsp;SDK&nbsp;Virtual Machine you don't need to follow this guide, go directly to How to develop with Eclipse IDE under IGEP technology
+
----
  
== Requirements  ==
+
'''G711DEC -> DEC PCM uLAW (speech) (NOT TESTED)'''
  
*PC with Linux, for example [http://www.linuxmint.com/ Linux Mint distribution].
+
'''G711ENC -> ENC PCM uLAW (speech) (NOT TESTED)'''
*[http://www.isee.biz/component/zoo/item/igep-yocto-toolcahin-sdk IGEP YOCTO Toolchain SDK]
 
*[http://www.eclipse.org/downloads/packages/eclipse-ide-cc-linux-developers-includes-incubating-components/indigor Eclipse IDE for C/C++ Linux Developers]
 
*[http://www.yoctoproject.org/projects/eclipse-ide-plug Yocto Eclipse IDE Plug-in]
 
  
{{Message/Information Message|message= This guide was tested under Linux Mint Lisa 12, Eclipse 3.7 Indigo and Yocto IDE Plug-in 1.2}}
+
===Not included  (IGEP GST DSP):===
 +
'''ACCLCDEC -> DEC AACLE (NOT TESTED)'''
  
== Install  ==
+
'''AACLDDEC -> DEC AACLD (NOT TESTED)'''
  
=== Install Java Runtime Environment  ===
+
'''WMA9 -> DEC WMA9 (COMPILING ISSUES)'''
  
Eclipse IDE has Java dependencies. Java Runtime Environment should be installed, but if you don't have it type next command:
+
'''ACCLCENC -> ENC AACLE (NOT TESTED)'''
<pre>sudo apt-get install sun-java6-bin sun-java6-jre</pre>  
 
=== Install Eclipse IDE  ===
 
  
[http://www.eclipse.org/downloads/packages/eclipse-ide-cc-linux-developers-includes-incubating-components/indigor Download] Eclipse 3.7 Indigo for C/C++ Linux Developers, choose 32 or 64 bits version depends your machine.
+
'''ACCHEENC -> ENC AACHE (NOT TESTED)'''
  
Maybe you want to install build essential to test programs in your Host computer. Install it using the next command:
+
'''AACLDENC -> ENC AACLD (NOT TESTED)'''
<pre>sudo apt-get install build-essential </pre>
 
Extract Eclipse binaries:
 
<pre>jdoe@ubuntu ~/Downloads $ tar xzf eclipse-linuxtools-indigo-incubation-linux-gtk.tar.gz -C ~/ </pre>  
 
=== Install Yocto SDK  ===
 
  
{{#lst:How to setup a cross compiler|install_sdk}}
+
'''WMA8 -> ENC WMA8 (NOT TESTED)'''
  
== Configure  ==
+
'''Problems adding codecs into igep-gst-dsp'''
  
=== Open Eclipse IDE  ===
+
== DM3730==
  
Eclipse binaries are located in ~/eclipse directory, follow the next instructions to open it:<br>
+
=== DM3730: Decode a MP3 file (OK) (ADDED TO REPOSISTORIES)===
  
{| cellspacing="1" cellpadding="1" width="200" border="1"
+
'''under contruction'''
|-
 
| [[Image:Eclipse open.png|331px]]
 
| [[Image:Eclipse loading.png|331px]]
 
|-
 
| [[Image:Eclipse set workspace.png|331px]]
 
| [[Image:Eclipse workspace.png|331px]]
 
|}
 
  
'''<sup>Click to enlarge image</sup>'''
+
'''does not have an accelerated audio decoder element'''
  
== Update Eclipse IDE  ==
+
- Compiled gst-plugins-ugly using yocto tools
  
Follow the next instructions to update it:
+
- rpm -igst-plugins-ugly-0.*.rpm
  
{| cellspacing="1" cellpadding="1" width="200" border="1"
+
- rpm -i libmad0-0.*.rpm
|-
 
| [[Image:Eclipse update1.png|250px]]
 
| [[Image:Eclipse update2.png|250px]]
 
| [[Image:Eclipse update3.png|250px]]
 
|-
 
| [[Image:Eclipse update4.png|250px]]
 
| [[Image:Eclipse update5.png|250px]]
 
| [[Image:Eclipse update6.png|250px]]
 
|}
 
  
'''<sup>Click to enlarge image</sup>'''
+
- rpm -i gst-plugins-ugly-mad-0.*.rpm
  
=== Install Linux tools  ===
+
- gst-launch filesrc location=sample.mp3 ! mad ! volume volume=0.25 ! alsasink
  
Yocto Eclipse IDE Plug-in has Linux tools plugin dependencies, install this plugin:  
+
=== DM3730: Decode a RA or RM audio file (ERRORS)===
  
{| cellspacing="1" cellpadding="1" width="200" border="1"
+
gst-launch --gst-debug-level=3 filesrc location=sample.ra ! rmdemux ! volume volume=0.25 ! alsasink
|-
 
| [[Image:Eclipse linuxtools1.png|250px]]
 
| [[Image:Eclipse linuxtools2.png|250px]]
 
| [[Image:Eclipse linuxtools3.png|250px]]
 
| [[Image:Eclipse linuxtools4.png|250px]]
 
|-
 
| [[Image:Eclipse linuxtools5.png|250px]]
 
| [[Image:Eclipse linuxtools6.png|250px]]
 
| [[Image:Eclipse linuxtools7.png|250px]]
 
| [[Image:Eclipse linuxtools8.png|250px]]
 
|}
 
  
'''<sup>Click to enlarge image</sup>'''
+
http://www.superluminal.com/andalib/ra/listen.ra
  
=== Install Yocto Eclipse IDE Plug-in  ===
+
gst-plugins-ugly-rmdemux-0.10.19-r1.armv7a.rpm
  
{| cellspacing="1" cellpadding="1" width="200" border="1"
+
libgstsdp-0.10-0-0.10.36-r3.armv7a.rpm:
|-
+
libgstsdp-0.10-0
| [[Image:Eclipse linuxtools1.png|250px]]
+
libgstsdp-0.10.so.0
| [[Image:Eclipse yocto2.png|250px]]
 
| [[Image:Eclipse yocto3.png|250px]]
 
| [[Image:Eclipse yocto4.png|250px]]
 
|-
 
| [[Image:Eclipse yocto5.png|250px]]
 
| [[Image:Eclipse yocto6.png|250px]]
 
| [[Image:Eclipse yocto7.png|250px]]
 
| [[Image:Eclipse linuxtools8.png|250px]]
 
|}
 
  
'''<sup>Click to enlarge image</sup>''''''<sup></sup>'''
+
libgstrtsp-0.10-0-0.10.36-r3.armv7a.rpm:
 +
libgstrtsp-0.10-0
 +
libgstrtsp-0.10.so.0
  
*Image 3, at location field copy: http://downloads.yoctoproject.org/releases/eclipse-plugin/1.2/
+
'''Error:'''
  
=== Configure Yocto Eclipse IDE Plug-in ===
+
0:00:00.084839071 1550  0xa137b0 WARN                rmdemux rmdemux.c:1012:gst_rmdemux_chain:<rmdemux0> Bogus looking header, unprintable FOURCC
  
{| cellspacing="1" cellpadding="1" width="200" border="1"
+
0:00:00.085052695  1550  0xa137b0 WARN                rmdemux rmdemux.c:1012:gst_rmdemux_chain:<rmdemux0> Bogus looking header, unprintable FOURCC
|-
 
| [[Image:Eclipse_configyocto1.png|331px]]
 
| [[Image:Eclipse_configyocto2.png|331px]]
 
|}
 
  
== Set up a connection between IGEP and Host computer (under construcion) ==
+
0:00:00.085540976  1550  0xa137b0 WARN                rmdemux rmdemux.c:1057:gst_rmdemux_chain:<rmdemux0> Unknown object_id .ra4
  
= How to develop with Eclipse IDE under IGEP technology (under construction) =
+
0:00:00.085693564  1550  0xa137b0 WARN                rmdemux rmdemux.c:1012:gst_rmdemux_chain:<rmdemux0> Bogus looking header, unprintable FOURCC
  
use eclipse ide examples
+
0:00:00.085815634  1550  0xa137b0 WARN                rmdemux rmdemux.c:1012:gst_rmdemux_chain:<rmdemux0> Bogus looking header, unprintable FOURCC
  
= Getting started with IGEPv2 Expansion<br> =
+
0:00:00.085907187  1550  0xa137b0 WARN                rmdemux rmdemux.c:1057:gst_rmdemux_chain:<rmdemux0> Unknown object_id RaTC
  
{{Table/IGEP Technology Devices
+
=== DM3730: Decode an AAC audio file (OK)===
|Tech_Family={{#lst:Template:Links|IGEPv2_EXPANSION_Tech_Family}}
 
|Tech_ID={{#lst:Template:Links|IGEPv2_EXPANSION_Tech_ID}}
 
|Name={{#lst:Template:Links|IGEPv2_EXPANSION_Name}}
 
|Image={{#lst:Template:Links|IGEPv2_EXPANSION_Image}}
 
|ISEE_MainPage={{#lst:Template:Links|IGEPv2_EXPANSION_ISEE_MainPage}}
 
|ISEE_Hardware={{#lst:Template:Links|IGEPv2_EXPANSION_ISEE_Hardware}}
 
}}
 
  
<br> __TOC__
+
EXTRA_OECONF += "--disable-examples --disable-experimental --disable-sdl --disable-cdaudio --disable-directfb \
 +
                --with-plugins=musicbrainz,wavpack,ivorbis,mpegvideoparse,'''faad2''' --disable-vdpau --disable-apexsink \
 +
                --disable-orc"
 +
Install:
  
= Overview  =
 
  
This is the 1/3 chapter of IGEPv2 Expansion Tutorial Guide.  
+
faad2-2.7-r2.armv7a.rpm
 +
libfaad2-2.7-r2.armv7a.rpm
 +
gst-plugins-bad-faad-0.10.23-r2.armv7a.rpm
  
In this first chapter, we will learn how to connect some expansion peripherals.  
+
'''maybe there are necessary more packages, compare actual gst-bad-recipe and add changes. Necessary add faad2 recipe'''
 +
<pre>bitbake faad2 gst-plugins-bad</pre>
 +
<pre> rpm -i faad2-2.7-r2.armv7a.rpm
 +
rpm -i libfaad2-2.7-r2.armv7a.rpm
 +
rpm -i gst-plugins-bad-faad-0.10.23-r2.1.armv7a.rpm
 +
</pre>
  
= Requirements  =
+
gst-launch --gst-debug-level=3 filesrc location=sample.aac ! faad ! volume volume=0.10 ! alsasink
  
In these tutorials we are going to need the following components&nbsp;:  
+
==== DM3730: Decode an WMA audio file (OK)====
  
*[http://www.isee.biz/products/processor-boards/igepv2-board IGEPv2], [http://shop.isee.biz/buy-online/accesories/power-supply-2600ma-ac-6w.html +5V DC power supply], Ethernet cable and a PC with Linux or Windows.<br>  
+
<pre>bitbake gst-ffmpeg</pre>
*Powertrip 4.3" or [http://shop.isee.biz/buy-online/accesories/tft-24-bits-seiko-7.html Seiko 7"] screen if you need a touch screen.
 
*DB9 connector and USB serial converter to follow serial communication tutorial<br>
 
*4 pin connector for CAN Bus with another IGEPv2 and Expansion to follow CAN Bus communication tutorial<br>
 
*SIM card with an antenna to follow Telit modem tutorial<br>
 
*Composite video cable, composite video output peripheral (PAL or NTSC) and a screen to follow TVP5151 tutorial<br>
 
  
= Getting started =
+
<pre>gst-launch -v filesrc location=sample.wma ! asfdemux ! decodebin ! audioconvert ! volume volume=0.25 ! alsasink </pre>
  
== Connect IGEPv2 Expansion with IGEPv2 Board  ==
+
=== DM3730: Decode an OGG audio file (OK)===
  
'''Basic'''  
+
'''Into repositories (base plugins):'''
  
The IGEPv2 Expansion connects to the IGEPv2 Board through J990, JA41, JA42, JC30 and J960 connectors. Some IGEPv2 Expansion may include three jumpers, you should remove it because they are designed for test and lab purposes. Just take a look on the figure below to mount it:<br>
+
http://upload.wikimedia.org/wikipedia/en/0/04/Rayman_2_music_sample.ogg
  
{| align="center" cellspacing="1" cellpadding="1" border="1" width="200"
+
gst-launch -v filesrc location=sample.ogg ! oggdemux ! vorbisdec ! audioconvert ! volume volume=0.25 ! alsasink
|-
 
| [[Image:Igepv2expconnectoigepv2.PNG|268px]]<br>
 
| [[Image:Igepv2expconnectoigepv2 2.PNG|268px]]<br>
 
|}
 
  
== TFT and Touchscreen  ==
+
== BASE0033 CONNECTOR SUMMARY TABLE==
  
'''Basic'''
+
== Configure a static IP using the same private network range ==
  
[[Image:IGEP0022 PROTO RA DSC 0142.JPG|right|200px]] IGEPv2 Expansion integrates a LCD backlight driver (Texas instruments TPS61081) and touch screen controller (Texas instruments TSC2046), 4-wire touch screen controller which supports a low-voltage I/O interface which can be directly connected to a SEIKO 7” LCD or to a POWERTIP 4.3” LCD. Use J301 connector for POWERTRIP 4.3" or use J302, J303 and J304 connector for SEIKO 7".<br>
+
'''under construction'''
  
'''Know more'''<br>
+
IGEP Firmware Yocto uses the following Ethernet network configuration (IP addresses)
  
IGEPv2 Expansion integrates LCD backlight driver (TPS61081) and touch screen controller (TSC2046), a 4-wire touch screen controller which supports a low voltage I/O interface from 1.5V to 5.25V.  
+
*eth0 − 192.168.5.1
 +
*eth0:0 − assigned via dhcp.  
  
== Serial port  ==
+
This Ethernet network configuration is really useful when you work using a Linux operating system like IGEP SDK Virtual Machine. Because you use eth0 device to communicate easily with your board and eth0:0 device to get Internet acces using dhcp protocol.
  
'''Basic''' [[Image:Igepv2expdb9connector.PNG|right|200px]]
+
But some scenarios this network configuration is not useful, for example: if you use a non-Linux operating system, connect to two IP private range interfaces is not simple. This How-to can be useful to
  
IGEPv2 Expansion integrates a DB9 RS232 connector. Plug a DB9 cable. <br>
+
(Make diagram one: IGEP and Linux defualt communication. Diagram 2 IGEP and other SO alternative configuration)
  
'''Know more'''
+
= igep.ini parameters  =
  
This peripheral (UART 3) can be used to debug system using kernel traces, getting a remote prompt, etc. <br> <br> <br>
+
The kernel command line syntax is name=value1. These next parameters are supported in igep.ini since IGEP-X_Loader 2.4.0-2:
  
== VGA monitor ==
+
=== [kernel] ===
  
'''Basic'''&nbsp;
+
{| align="JUSTIFY" cellpadding="1" border="1" style="width: 900px; height: 240px;"
 
+
|-
{| align="right" cellspacing="1" cellpadding="1" border="1" width="363"
+
| '''Parameter Name'''
 +
| '''Description'''
 +
| '''Default value'''
 +
| '''Comments'''
 +
|-
 +
| kaddress
 +
| Kernel copy address
 +
| =0x80008000
 +
| Hex memory address
 +
|-
 +
| rdaddress
 +
| Ram Disk location address
 +
| =0x81600000
 +
| Hex memory address;<br>disabled by default
 +
|-
 +
| serial.low
 +
| Serial number (low part)
 +
| =00000001
 +
| Numeric
 +
|-
 +
| serial.high
 +
| Serial number (high part)
 +
| =00000000
 +
| Numeric
 +
|-
 +
| revision
 +
| Revision ID
 +
| =0003
 +
| Numeric
 +
|-
 +
| kImageName
 +
| Kernel, binary image name
 +
| =zImage
 +
| Kernel or binary image name
 +
|-
 +
| kRdImageName
 +
| Kernel RAM Disk Image Name
 +
| -
 +
| Ram Disk image name
 +
|-
 +
| MachineID
 +
| Machine ID (kernel ID)
 +
| ;IGEPv2<br>=2344
 +
| ;Module<br>=2717<br>;Proton<br>=3203
 
|-
 
|-
| [[Image:Igepv2expconnecttovga.jpg|150px]]
+
| Mode
| [[Image:Igepv2expvgaconnector.PNG|200px]]
+
| Boot Mode
 +
| ;Linux kernel<br>=kernel
 +
| ;Other image (like uboot)<br>[binary image]
 
|}
 
|}
  
IGEPv2 Expansion integrates a VGA connector, the output VGA signal is equal to HDMI connector. Plug a monitor with VGA&nbsp;input.
+
=== [kparams]  ===
  
'''Know more'''  
+
{| align="JUSTIFY" cellpadding="1" border="1" style="width: 900px; height: 1095px;"
 
+
|-
This output is controled by ADV7125KSTZ140 Integrated Circuit.
+
| '''Parameter Name'''
 
+
| '''Description'''
<br> <br> <br>  
+
| '''Default value'''  
 
+
| '''Comments'''
== CAN bus  ==
+
|-
 
+
| buddy
'''Basic'''
+
| Enable/disable expansion board support
 
+
| &nbsp;;IGEPv2 Expansion Board support<br>=igep0022
[[Image:Igepv2expcanconnector.PNG|right|200px]]IGEPv2 Expansion integrates a CAN peripheral. Connect any CAN bus device or network to the CAN bus connector (J703).<br>
+
| &nbsp;;Berlin and Paris Expansion Board support<br>=base0010<br>New York Expansion<br>=ilms0015
 
+
|-
'''Know more'''
+
| console
 
+
| Setup the kernel console parameters
This output is controled by MICROCHIP MCP2515. J703 is a 3.5 mm pitch terminal blocks 4 Positions:
+
| =ttyO2,115200n8
 
+
| -
{| cellspacing="1" cellpadding="1" border="1" width="350"
+
|-
 +
| earlyprintk
 +
| Enable early printk
 +
| -
 +
| -
 +
|-
 +
| mem
 +
| Setup the Board Memory Configuration
 +
| =430M
 +
| -
 +
|-
 +
| boot_delay
 +
| Setup the boot delay
 +
| =0
 +
| -
 +
|-
 +
| mpurate
 +
| Setup ARM Processor Speed
 +
| -
 +
| -
 +
|-
 +
| loglevel
 +
| Setup the loglevel
 +
| -
 +
| -
 +
|-
 +
| debug
 +
| Enable kernel debug output
 +
| -
 +
| -
 +
|-
 +
| fixrtc
 +
| Fix RTC variable
 +
| -
 +
| -
 +
|-
 +
| nocompcache
 +
| Configure nocompcache variable
 +
| =1
 +
| -
 +
|-
 +
| omapfb.mode
 +
| Configure frame bugger configuration
 +
| =dvi:hd720-16@50
 +
| &nbsp;;Other configuration<br>=dvi:1280x720MR-16@60
 +
|-
 +
| vram
 +
| Configure Video RAM assigned to every frame buffer
 +
| -
 +
| -
 +
|-
 +
| omapfb.vram
 +
| Configure Video RAM assigned to every frame buffer
 +
| -
 +
| -
 +
|-
 +
| omapfb.debug
 +
| Configure frame buffer debug output
 +
| -
 +
| -
 +
|-
 +
| omapdss.debug
 +
| Configure DSS Video debug output  
 +
| -
 +
| -
 +
|-
 +
| smsc911x.mac0
 +
| Configure Board Ethernet Mac Address
 +
| =0xb2,0xb0,0x14,0xb5,0xcd,0xde
 +
| For IGEP BERLIN
 +
|-
 +
| smsc911x.mac1
 +
| Configure Board Ethernet Mac Address
 +
| =0xb2,0xb0,0x14,0xb5,0xcd,0xdf
 +
| For IGEP BERLIN (only with IGEP PROTON)
 +
|-
 +
| smsc911x.mac
 +
| Configure Board Ethernet Mac Address
 +
| =0xb2,0xb0,0x14,0xb5,0xcd,0xde
 +
| For IGEPv2, IGEP PROTON, IGEP PARIS and IGEP BERLIN
 +
|-
 +
| ubi.mtd
 +
| Fot UBI FS boot
 +
| -
 +
| -
 +
|-
 +
| root
 +
| Configure root directory for MMC, NFS or UBI
 +
| &nbsp;;For mmc memory<br>=/dev/mmcblk0p2 rw rootwait
 +
| &nbsp;;For flash memory<br>=/dev/mtdblock2
 +
|-
 +
| nfsroot
 +
| For NFS boot
 +
| -
 +
| -
 
|-
 
|-
| Signal Name
+
| rootfstype
| Pin #<br>
+
| For UBI FS boot
| Description
+
| -
 +
| -
 
|-
 
|-
| VDD_CAN
+
| ip
| J703:1
+
| For NFS boot
| Supply Voltage (+5V DC)
+
| -
 +
| -
 
|-
 
|-
| CANL
+
| init
| J703:2
+
| Assign init program
| CAN Low-Level Voltage I/O
+
| -
 +
| -
 
|-
 
|-
| GND
+
| musb_hdrc.debug
| J703:3
+
| USB debug
| Ground
+
| -
 +
| -
 
|-
 
|-
| CANH
+
| musb_hdrc.use_dma
| J703:4
+
| USB over network
| CAN High-Level Voltage I/O
+
| -  
|}
+
| -
 
 
== GSM/GPRS modem  ==
 
 
 
'''Basic'''
 
 
 
{| align="right" cellspacing="1" cellpadding="1" border="1" width="200"
 
 
|-
 
|-
| [[Image:IGEP0022 Modem with antenna.png|200px]]
+
| libertas.libertas_debug
| [[Image:Igepv2expcardreader.PNG|right|200px]]
+
| Configure libertas debug
 +
| -
 +
| -
 
|-
 
|-
| GSM-GPRS antenna (highly recommended)
+
| board.ei485
| SIM card reader
+
| Enable/disable RS485
|}
+
| &nbsp;;Enable RS485<br>=yes
 
+
| &nbsp;;Disable RS485<br>=no
IGEPv2 Expansion integrates a GSM/GPRS&nbsp;modem to make phone calls or to send SMS or to write and read data from it, etc.<br>
 
 
 
'''Know more''' Modem chip Telit GE865 is a small GSM/GPRS Ball-Grid-Array BGA module with next main features:
 
 
 
*Quad-band EGSM 850 / 900 / 1800 / 1900 MHz
 
*Power consumption (typical values)
 
 
 
&nbsp;&nbsp;&nbsp; - Power off: ‹ 62 uA<br>&nbsp;&nbsp;&nbsp; - Idle (registered, power saving): 1.6 mA @ DRX=9 <br> <br> <br>
 
 
 
== Composite Video Decoder  ==
 
 
 
'''Basic'''
 
 
 
[[Image:Igepv2expvideocompositeconnector.PNG|right|200px]]IGEPv2 Expansion integrates two composite video connectors to decode analog input signal. Plug some peripheral with video composite output.<br>
 
 
 
'''Know more'''
 
 
 
Analog input is decoded by TVP5151.
 
 
 
<br> {{Navigation/IGEP Technology Guides/Getting Started/Ending
 
|Next_Step={{#lst:Template:Links|IGEPv2_EXPANSION_Community_Guides_2}}
 
}}
 
 
 
{{Table/IGEP Technology Devices
 
|Tech_Family={{#lst:Template:Links|IGEPv2_EXPANSION_Tech_Family}}
 
|Tech_ID={{#lst:Template:Links|IGEPv2_EXPANSION_Tech_ID}}
 
|Name={{#lst:Template:Links|IGEPv2_EXPANSION_Name}}
 
|Image={{#lst:Template:Links|IGEPv2_EXPANSION_Image}}
 
|ISEE_MainPage={{#lst:Template:Links|IGEPv2_EXPANSION_ISEE_MainPage}}
 
|ISEE_Hardware={{#lst:Template:Links|IGEPv2_EXPANSION_ISEE_Hardware}}
 
}}
 
 
 
<br>  
 
 
 
= What can i do with igepv2 expansion  =
 
 
 
{{Table/IGEP Technology Devices
 
|Tech_Family={{#lst:Template:Links|IGEPv2_EXPANSION_Tech_Family}}
 
|Tech_ID={{#lst:Template:Links|IGEPv2_EXPANSION_Tech_ID}}
 
|Name={{#lst:Template:Links|IGEPv2_EXPANSION_Name}}
 
|Image={{#lst:Template:Links|IGEPv2_EXPANSION_Image}}
 
|ISEE_MainPage={{#lst:Template:Links|IGEPv2_EXPANSION_ISEE_MainPage}}
 
|ISEE_Hardware={{#lst:Template:Links|IGEPv2_EXPANSION_ISEE_Hardware}}
 
}}
 
 
 
<br> __TOC__
 
 
 
<br>
 
 
 
= Overview  =
 
 
 
This is the 2/3 chapter of IGEPv2 Expansion Tutorial Guide.
 
 
 
We will learn some basic tasks such add support to IGEPv2 Expansion, control some peripherals, etc.<br>
 
 
 
= What can I do<br>  =
 
 
 
== How to use Serial communication (DB9 connector)  ==
 
 
 
'''Basic'''
 
 
 
RS232 link for UART 3 (/dev/ttyO2) can be obtained through J502 DB9 connector. You can use PuTTy to get a shell prompt to IGEP:
 
 
 
*Power up IGEPv2
 
*Open PuTTy.
 
*Choose Serial line. If you are running PuTTy on Windows, the Serial line will be like (COM1 or COM2 or COM3, etc.). If you are running PuTTy on Ubuntu, the Serial line will be like&nbsp;(/dev/ttyS0 or /dev/ttyS1 or /dev/ttyS3, etc.). Note that if you are using a USB-&gt;Serial converter, the Serial line will be like /dev/ttyUSB0
 
*Configure Speed to 115200
 
*Select Serial Connection type
 
*Press on Open button
 
*You will successfully started the console.
 
 
 
<br>  
 
 
 
{| cellspacing="1" cellpadding="1" border="1" width="200"
 
 
|-
 
|-
| [[Image:IGEPV2EXPCHMDB9.png|250px]]
+
| board.modem
| [[Image:Remoteshellpromptdb9putty.jpg|250px]]
+
| Enable/disable GPRS modem  
|}
+
| &nbsp;;Enable modem (IGEPv2 Expansion)<br>=no
 
+
| &nbsp;;Enable modem (IGEPv2 Expansion)<br>=yes
'''Know more'''
 
 
 
[[How to use UARTs|Read this tutorial]] to learn about UARTs.
 
 
 
== How to use TFT and Touchscreen  ==
 
 
 
Seiko a Powertip touch screens are not supported by default in IGEPv2. Use the following steps for it:
 
 
 
*Log into IGEPv2 (via SSH, [http://labs.isee.biz/index.php/Getting_started_with_IGEPv2#Log_into_IGEPv2_via_Ethernet_interface as shown in the previous chapter]), and run the following commands:
 
<pre>ssh root@192.168.5.1
 
mkdir /tmp/temp
 
mount -t jffs2 /dev/mtdblock1 /tmp/temp
 
vi /tmp/temp/igep.ini </pre>
 
*In Seiko screen add the following line:
 
<pre>omapdss.def_disp=lcd-70</pre>
 
*In Powertip screen add the following line:
 
<pre>omapdss.def_disp=lcd-43</pre>
 
*Save changes and reboot your IGEP Device to finish it.<br>
 
 
 
== How to use Telit Modem  ==
 
 
 
'''Basic'''
 
 
 
Telit modem is not supported by default in IGEPv2. Use the following steps for it:
 
 
 
*Log into IGEPv2 (via SSH, [http://labs.isee.biz/index.php/Getting_started_with_IGEPv2#Log_into_IGEPv2_via_Ethernet_interface as shown in the previous chapter]), and run the following commands:
 
<pre>ssh root@192.168.5.1
 
mkdir /tmp/temp
 
mount -t jffs2 /dev/mtdblock1 /tmp/temp
 
vi /tmp/temp/igep.ini </pre>
 
*Add the following line (press i to insert content):
 
 
 
buddy.modem=yes
 
 
 
*Save changes (ESC -&gt;&nbsp;:wq -&gt; Enter) and reboot your IGEP Device
 
*Power up the modem. You can power off using again these commands:
 
<pre>echo 0 &gt; /sys/class/gpio/gpio140/value
 
echo 1 &gt; /sys/class/gpio/gpio141/value
 
sleep 1
 
echo 0 &gt; /sys/class/gpio/gpio141/value
 
</pre>
 
*Once the modem is on (led D401, near SIM card reader, is blinking now), you can interact with it via UART 2. You can use Microcom to comunicate with it from the serial debug console:
 
<pre>microcom -s 115200 /dev/ttyO1</pre>
 
*To check the modem status use the command:<br>
 
<pre>at</pre>
 
*Answer should be OK.<br>  
 
*Now unlock it by inserting your SIM card PIN number. Use the command:
 
<pre>at+cpin=&lt;PIN&gt;</pre>
 
*If you correctly inserted the PIN number, the answer should be OK.&nbsp;If you fail more than 3 times, your SIM card will lock and you will have to insert PUK number.
 
*Now you are ready to use the GSM/GPS modem.<br>
 
 
 
=== Examples  ===
 
 
 
If you successfully '''followed the the previous instructions''', you are ready to test the GSM/GPRS modem. Here are some examples:
 
 
 
You can check the complete list of AT commands at the Official manufacturer [http://telit.com/module/infopool/download.php?id=522 Software User Guide].
 
 
 
==== Test received signal strength<br>  ====
 
 
 
Use the instruction:
 
<pre>at+csq</pre>
 
The answer should be: +CSQ: X,0, where X is the signal strenght. For example 12 is poor and 18 is good. If the answer is +CSQ:99,99 you should check your coverage or use an antenna<br>
 
 
 
==== Making a phone call<br>  ====
 
 
 
Use the instruction, replace number_to_call with your number:
 
<pre>atd number_to_call
 
</pre>
 
Press any key to end call
 
 
 
'''NOTE:''' If "NO CARRIER" message appears, check your coverage or use an antenna.
 
 
 
==== Sending a SMS<br>  ====
 
 
 
First of all, you need to configure the SMS format type. Telit GE865 GSM/GPRS supports PDU format and Text format. We use Text format. Type the following command:
 
<pre>AT+CMGF=1</pre>
 
There are so many ways in this modem to send a message. Here you have a simple example. Use the instruction, replace destination_number with your number:
 
<pre>at+cmgs= destination_number
 
&gt; insert here your text message
 
</pre>
 
When you are ready to send your message use Ctrl+Z to send it.
 
 
 
If you want to cancel or restart the message press ESC.<br>
 
 
 
'''NOTE:''' If "NO CARRIER" message appears, check your coverage or use an antenna.
 
 
 
'''NOTE:''' Don't use special characters in SMS text message like &lt;`´'"&gt;.<br>
 
 
 
'''Know more'''<br>
 
 
 
Here you have the official manuals from the manufacturer's webpage:<br>
 
 
 
*[http://telit.com/module/infopool/download.php?id=1666 Telit GE865-QUAD Hardware User Guide]<br>
 
*[http://telit.com/module/infopool/download.php?id=522 Telit Modules Software User Guide]<br>
 
 
 
== How to use TVP5151 Video Decoder <br>  ==
 
 
 
'''Basic'''
 
 
 
Use the following steps to capture analog video:
 
 
 
*Connect a video composite input to J501 connector from IGEPv2 Expansion (near CAN Bus)
 
*Connect a screen, for example HDMI monitor.
 
*Log into IGEPv2 (via SSH, [http://labs.isee.biz/index.php/Getting_started_with_IGEPv2#Log_into_IGEPv2_via_Ethernet_interface as shown in the previous chapter]), and run the following commands:
 
<pre>ssh root@192.168.5.1
 
</pre>
 
*Now you have a remote igep terminal<br>  
 
*Refresh repositories and accept it.
 
<pre>zypper ref </pre>
 
*Install video4linux2 plugin
 
<pre>zypper in gst-plugins-good-video4linux2
 
</pre>
 
*Load OMAP ISP kernel module<br>
 
<pre>modprobe omap3-isp
 
</pre>
 
*Configure ISP, for PAL resulution use 720x576 for NTSC resolution use 720x480:<br>
 
<pre>media-ctl -r -l '"tvp5150 2-005c":0-&gt;"OMAP3 ISP CCDC":0[1], "OMAP3 ISP CCDC":1-&gt;"OMAP3 ISP CCDC output":0[1]'
 
media-ctl -v --set-format '"tvp5150 2-005c":0 [UYVY 720x480]'
 
media-ctl -v --set-format '"OMAP3 ISP CCDC":0 [UYVY 720x480]'
 
media-ctl -v --set-format '"OMAP3 ISP CCDC":1 [UYVY 720x480]' </pre>
 
*Export display
 
<pre>export DISPLAY=:0.0 </pre>
 
*Launch gstreamer
 
<pre>gst-launch-0.10 -v v4l2src device=/dev/video2 queue-size=8&nbsp;! video/x-raw-yuv,format=\(fourcc\)UYVY,width=720,height=480&nbsp;! ffmpegcolorspace&nbsp;! autovideosink</pre>
 
*Now you can see in your IGEP screen a result similar like this
 
 
 
{| cellspacing="1" cellpadding="1" border="1" width="200"
 
 
|-
 
|-
| [[Image:Igepv2expgstreamercapture.jpg|400px]]
+
| buddy.revision
 +
| Enable hardware buddy revision [A or B]  
 +
| Only for base0010<br>=A
 +
| Only for base0010<br>=B
 
|}
 
|}
 
<br>
 
 
'''Know more'''<br>
 
 
You can use other programs like [[Labs.isee.biz/index.php/How to setup tvp5151 video decoder#Play|yavta]]
 
 
== How to use EEPROM  ==
 
 
'''Basic'''
 
 
The IGEP0022 expansion board provides an AT24C01B serial EEPROM memory which is connected to the OMAP via I2C (register 50).<br>
 
 
Use i2c-tools to manage it:
 
<pre>i2cget &lt;bus&gt; &lt;chip&gt; &lt;register&gt;
 
i2cset &lt;bus&gt; &lt;chip&gt; &lt;register&gt; &lt;value&gt;</pre>
 
For example, the following writes the value 0x22 to register 0x10 of device 0x50 on i2c bus 2:
 
<pre>i2cset -f -y 2 0x50 0x10 0x22
 
i2cget -f -y 2 0x50 0x10</pre>
 
'''Know more'''
 
 
See also: i2dump(8), i2cget(8) and i2cset(8) man page
 
 
== How to use CAN bus (under construction)  ==
 
 
{{#lst:How to use CAN bus|IGEPv2 EXPANSION}} {{Template:Navigation/IGEP Technology Guides/What can I do/Ending}} {{Table/IGEP Technology Devices
 
|Tech_Family={{#lst:Template:Links|IGEPv2_EXPANSION_Tech_Family}}
 
|Tech_ID={{#lst:Template:Links|IGEPv2_EXPANSION_Tech_ID}}
 
|Name={{#lst:Template:Links|IGEPv2_EXPANSION_Name}}
 
|Image={{#lst:Template:Links|IGEPv2_EXPANSION_Image}}
 
|ISEE_MainPage={{#lst:Template:Links|IGEPv2_EXPANSION_ISEE_MainPage}}
 
|ISEE_Hardware={{#lst:Template:Links|IGEPv2_EXPANSION_ISEE_Hardware}}
 
}}
 
 
[[Category:IGEP_Technology_Devices_Guides]]
 

Latest revision as of 15:28, 5 September 2014

TODO:

Categorize new tutorials

How to manage the kernel modules on Linux

How do I edit my kernel command line

AUDIO DSP-ARM

Included (IGEP GST DSP):

AACHEDEC -> DEC AACHE (OK)

http://download.wavetlan.com/SVV/Media/HTTP/FAAC-HE-AAC.aac

gst-launch --gst-debug-level=2 filesrc location=sampleaache.m4a ! TIAuddec1 codecName=aachedec engineName=codecServer ! volume volume=0.25 ! alsasink sync=false

outofthebox->ok


MP3DEC -> DEC MP3 (AUDIO ERRORS)

- Followed README file from ISEE - IGEP DSP - GST + DMAI Support Package 3.40.00

http://www.stephaniequinn.com/Music/Canon.mp3

gst-launch --gst-debug-level=2 filesrc location=Canon.mp3 ! TIAuddec1 codecName=mp3dec engineName=codecServer ! volume volume=0.25 ! alsasink sync=false

Random fatal bit error

mp3-plugin doesn't resolve the error


G711DEC -> DEC PCM uLAW (speech) (NOT TESTED)

G711ENC -> ENC PCM uLAW (speech) (NOT TESTED)

Not included (IGEP GST DSP):

ACCLCDEC -> DEC AACLE (NOT TESTED)

AACLDDEC -> DEC AACLD (NOT TESTED)

WMA9 -> DEC WMA9 (COMPILING ISSUES)

ACCLCENC -> ENC AACLE (NOT TESTED)

ACCHEENC -> ENC AACHE (NOT TESTED)

AACLDENC -> ENC AACLD (NOT TESTED)

WMA8 -> ENC WMA8 (NOT TESTED)

Problems adding codecs into igep-gst-dsp

DM3730

DM3730: Decode a MP3 file (OK) (ADDED TO REPOSISTORIES)

under contruction

does not have an accelerated audio decoder element

- Compiled gst-plugins-ugly using yocto tools

- rpm -igst-plugins-ugly-0.*.rpm

- rpm -i libmad0-0.*.rpm

- rpm -i gst-plugins-ugly-mad-0.*.rpm

- gst-launch filesrc location=sample.mp3 ! mad ! volume volume=0.25 ! alsasink

DM3730: Decode a RA or RM audio file (ERRORS)

gst-launch --gst-debug-level=3 filesrc location=sample.ra ! rmdemux ! volume volume=0.25 ! alsasink

http://www.superluminal.com/andalib/ra/listen.ra

gst-plugins-ugly-rmdemux-0.10.19-r1.armv7a.rpm

libgstsdp-0.10-0-0.10.36-r3.armv7a.rpm: libgstsdp-0.10-0 libgstsdp-0.10.so.0

libgstrtsp-0.10-0-0.10.36-r3.armv7a.rpm: libgstrtsp-0.10-0 libgstrtsp-0.10.so.0

Error:

0:00:00.084839071 1550 0xa137b0 WARN rmdemux rmdemux.c:1012:gst_rmdemux_chain:<rmdemux0> Bogus looking header, unprintable FOURCC

0:00:00.085052695 1550 0xa137b0 WARN rmdemux rmdemux.c:1012:gst_rmdemux_chain:<rmdemux0> Bogus looking header, unprintable FOURCC

0:00:00.085540976 1550 0xa137b0 WARN rmdemux rmdemux.c:1057:gst_rmdemux_chain:<rmdemux0> Unknown object_id .ra4

0:00:00.085693564 1550 0xa137b0 WARN rmdemux rmdemux.c:1012:gst_rmdemux_chain:<rmdemux0> Bogus looking header, unprintable FOURCC

0:00:00.085815634 1550 0xa137b0 WARN rmdemux rmdemux.c:1012:gst_rmdemux_chain:<rmdemux0> Bogus looking header, unprintable FOURCC

0:00:00.085907187 1550 0xa137b0 WARN rmdemux rmdemux.c:1057:gst_rmdemux_chain:<rmdemux0> Unknown object_id RaTC

DM3730: Decode an AAC audio file (OK)

EXTRA_OECONF += "--disable-examples --disable-experimental --disable-sdl --disable-cdaudio --disable-directfb \

                --with-plugins=musicbrainz,wavpack,ivorbis,mpegvideoparse,faad2 --disable-vdpau --disable-apexsink \
                --disable-orc"

Install:


faad2-2.7-r2.armv7a.rpm libfaad2-2.7-r2.armv7a.rpm gst-plugins-bad-faad-0.10.23-r2.armv7a.rpm

maybe there are necessary more packages, compare actual gst-bad-recipe and add changes. Necessary add faad2 recipe

bitbake faad2 gst-plugins-bad
 rpm -i faad2-2.7-r2.armv7a.rpm
rpm -i libfaad2-2.7-r2.armv7a.rpm
rpm -i gst-plugins-bad-faad-0.10.23-r2.1.armv7a.rpm
 

gst-launch --gst-debug-level=3 filesrc location=sample.aac ! faad ! volume volume=0.10 ! alsasink

DM3730: Decode an WMA audio file (OK)

bitbake gst-ffmpeg
gst-launch -v filesrc location=sample.wma ! asfdemux ! decodebin ! audioconvert ! volume volume=0.25 ! alsasink  

DM3730: Decode an OGG audio file (OK)

Into repositories (base plugins):

http://upload.wikimedia.org/wikipedia/en/0/04/Rayman_2_music_sample.ogg

gst-launch -v filesrc location=sample.ogg ! oggdemux ! vorbisdec ! audioconvert ! volume volume=0.25 ! alsasink

BASE0033 CONNECTOR SUMMARY TABLE

Configure a static IP using the same private network range

under construction

IGEP Firmware Yocto uses the following Ethernet network configuration (IP addresses)

  • eth0 − 192.168.5.1
  • eth0:0 − assigned via dhcp.

This Ethernet network configuration is really useful when you work using a Linux operating system like IGEP SDK Virtual Machine. Because you use eth0 device to communicate easily with your board and eth0:0 device to get Internet acces using dhcp protocol.

But some scenarios this network configuration is not useful, for example: if you use a non-Linux operating system, connect to two IP private range interfaces is not simple. This How-to can be useful to

(Make diagram one: IGEP and Linux defualt communication. Diagram 2 IGEP and other SO alternative configuration)

igep.ini parameters

The kernel command line syntax is name=value1. These next parameters are supported in igep.ini since IGEP-X_Loader 2.4.0-2:

[kernel]

Parameter Name Description Default value Comments
kaddress Kernel copy address =0x80008000 Hex memory address
rdaddress Ram Disk location address =0x81600000 Hex memory address;
disabled by default
serial.low Serial number (low part) =00000001 Numeric
serial.high Serial number (high part) =00000000 Numeric
revision Revision ID =0003 Numeric
kImageName Kernel, binary image name =zImage Kernel or binary image name
kRdImageName Kernel RAM Disk Image Name - Ram Disk image name
MachineID Machine ID (kernel ID)  ;IGEPv2
=2344
 ;Module
=2717
;Proton
=3203
Mode Boot Mode  ;Linux kernel
=kernel
 ;Other image (like uboot)
[binary image]

[kparams]

Parameter Name Description Default value Comments
buddy Enable/disable expansion board support  ;IGEPv2 Expansion Board support
=igep0022
 ;Berlin and Paris Expansion Board support
=base0010
New York Expansion
=ilms0015
console Setup the kernel console parameters =ttyO2,115200n8 -
earlyprintk Enable early printk - -
mem Setup the Board Memory Configuration =430M -
boot_delay Setup the boot delay =0 -
mpurate Setup ARM Processor Speed - -
loglevel Setup the loglevel - -
debug Enable kernel debug output - -
fixrtc Fix RTC variable - -
nocompcache Configure nocompcache variable =1 -
omapfb.mode Configure frame bugger configuration =dvi:hd720-16@50  ;Other configuration
=dvi:1280x720MR-16@60
vram Configure Video RAM assigned to every frame buffer - -
omapfb.vram Configure Video RAM assigned to every frame buffer - -
omapfb.debug Configure frame buffer debug output - -
omapdss.debug Configure DSS Video debug output - -
smsc911x.mac0 Configure Board Ethernet Mac Address =0xb2,0xb0,0x14,0xb5,0xcd,0xde For IGEP BERLIN
smsc911x.mac1 Configure Board Ethernet Mac Address =0xb2,0xb0,0x14,0xb5,0xcd,0xdf For IGEP BERLIN (only with IGEP PROTON)
smsc911x.mac Configure Board Ethernet Mac Address =0xb2,0xb0,0x14,0xb5,0xcd,0xde For IGEPv2, IGEP PROTON, IGEP PARIS and IGEP BERLIN
ubi.mtd Fot UBI FS boot - -
root Configure root directory for MMC, NFS or UBI  ;For mmc memory
=/dev/mmcblk0p2 rw rootwait
 ;For flash memory
=/dev/mtdblock2
nfsroot For NFS boot - -
rootfstype For UBI FS boot - -
ip For NFS boot - -
init Assign init program - -
musb_hdrc.debug USB debug - -
musb_hdrc.use_dma USB over network - -
libertas.libertas_debug Configure libertas debug - -
board.ei485 Enable/disable RS485  ;Enable RS485
=yes
 ;Disable RS485
=no
board.modem Enable/disable GPRS modem  ;Enable modem (IGEPv2 Expansion)
=no
 ;Enable modem (IGEPv2 Expansion)
=yes
buddy.revision Enable hardware buddy revision [A or B] Only for base0010
=A
Only for base0010
=B