Document Number: 924-76376 Rev.11.09.02, 9/2011 # i.MX53 START 11.09.01 Linux Release Notes This document contains important information about the package contents, supported features, and known issues/limitations for the i.MX53 START board. ### Contents | 1 | Release Contents | | | | |---|-------------------------------|-------------------------|----|--| | | 1.1 | _ | | | | | 1.2 | License | 3 | | | 2 | | stem Requirements | | | | | | Linux Host Server | | | | | 2.2 | MFG Tool | 4 | | | | 2.3 | i.MX53 START Components | 4 | | | 3 | Wh | nat's New | 4 | | | | 3.1 | New Features | 4 | | | | 3.2 | Defect Fixes | 5 | | | 4 | BS | P Supported Features | 5 | | | 5 | | rnel boot parameters | | | | 6 | Kn | own Issues/Limitations | 11 | | | 7 | Tips for MC34708 START board1 | | | | ## 1 Release Contents ### 1.1 Contents This release consists of the following package files: - L2.6.35\_11.09.01\_ER\_source.tar.gz - L2.6.35\_11.09.01\_ER\_images\_MX5X.tar.gz - L2.6.35\_11.09.01\_ER\_docs.tar.gz Note: i.MX53 START was previously named as i.MX53 LOCO. The machine ID registered under <a href="http://www.arm.linux.org.uk/developer/machines/">http://www.arm.linux.org.uk/developer/machines/</a> was i.MX53 LOCO. However, there are still references to "LOCO" in the source code and binary files. Any instance of "LOCO" needs to be treated as a reference to i.MX53 START. There are two kinds of i.MX53 START board: i.MX53 START board with MC34708 PMIC support and i.MX53 START board with DA9053 PMIC support. The same image can run on both boards. Release version is named as "L<Kernel\_version>\_<yy>.<mm>.<ij>." - "<Kernel\_version>": BSP Kernel version. (For example, "L2.6.35" indicates that this BSP release is based on the kernel version 2.6.35.) - "<yy>.<mm>.<ij>": Release date. (For example, "11.01.00" indicates that this BSP was released in January, 2011.) Table 1-1, Table 1-2, and Table 1-3 list the contents included in each package: Table 1-1. L2.6.35 11.09.01 ER images MX5X.tar.gz Content | File | Description | |--------------------------------------------|----------------------------------------------------------------------------------------------| | u-boot-mx53-loco.bin | U-Boot bootloader for the i.MX53 START board. | | ulmage | Binary kernel image for the Linux 2.6.35 kernel. The same image can run in all i.MX5 boards. | | amd-gpu-x11-bin-mx51_11.09.01-1_armel. deb | Debian package for the GPU driver and the application for X11. | | firmware-imx_11.09.01-1_armel.deb | Debian package for the firmware files, which includes VPU and Atheros WiFi. | | imx-lib_11.09.01-1_armel.deb | Debian package for imx-lib binary. | | imx-test_11.09.01-1_armel.deb | Debian package for the imx unit test binary | | kernel_2.6.35.3-imx_11.09.01_armel.deb | Debian package for the Linux kernel image, kernel modules and the header files. | | libz160-bin_11.09.01-1_armel.deb | Debian package for the GPU Z160 2D driver. | | File | Description | | |----------------------------------------|-------------------------------------------------------|--| | modeps_11.09.01-1_armel.deb | Debianpackage for module dependencies | | | xserver-xorg-video-imx_11.09.01-1_arme | Debian package for the i.MX accelerated video driver. | | | 1.deb | | | | udev-fsl-rules_11.09.01-5_armel.deb | Debian package for udev rules | | Table 1-2. L2.6.35\_11.09.01\_ER\_source.tar.gz Content | File | Description | |-----------------------------------------------------------------|-------------------------------------------------------------------------------------| | EULA | Freescale End User License Agreement | | Install | Install script for LTIB | | ltib.tar.gz | LTIB (Linux Target Image Builder) | | package_manifest.txt | Freescale LTIB open source packages | | Pkgs | Source and patches for the root file system | | pkgs/imx-test-11.09.01.tar.gz | Source code for the unit tests | | pkgs/imx-lib-11.09.01.tar.gz | Source code for the libraries | | pkgs/linux-2.6.35.3-imx_11.09.01.bz2 | Freescale 2.6.35.3-11.09.01 kernel patches | | <pre>pkgs/u-boot-v2009.08-imx_11.09.01.tar. bz2</pre> | i.MX U-Boot patches based on U-Boot version 200908 | | pkgs/firmware-imx-11.09.01.tar.gz | i.MX firmware packages | | <pre>pkgs/xserver-xorg-video-imx-11.09.01.t ar.gz</pre> | Source code of the i.MX accelerated video driver | | pkgs/kobs-ng-11.09.01.tar.gz | Source code of kobs-ng package which is used to flash MX53 NAND U-Boot. | | <pre>pkgs/gcc-4.4.4-glibc-2.11.1-multilib-1 .0-1.i386.rpm</pre> | FSL Open source optimized toolchain gcc 4.4.4 which enables NEON for ARM cortex-A8. | | tftp.zip | A Windows TFTP server program | Table 1-3. L2.6.35\_11.09.01\_ER\_docs.tar.gz Content | File | Description | | |-------------|----------------------------------------------------------------|--| | EULA | Freescale End User License Agreement | | | readme.html | Readme file containing links to additional documentation | | | doc/mx5 | i.MX53 Linux BSP Release Notes, User's Guide, Reference Manual | | ### 1.2 License All source code files of the Board Support Package (BSP) are GNU General Public License (GPL) or GNU Lesser General Public License (LGPL), or another open source license. The following binary files contained in the included root file systems are built from proprietary source not included in the BSP: Files in package libz160-bin-11.09.01.tar.gz Files in package amd-gpu-bin-mx51-11.09.01.tar.gz ## 2 System Requirements ### 2.1 Linux Host Server See "ltib\_build\_host\_setup.pdf" for host server setup. ## 2.2 MFG Tool The Mfgtools-Rel-11.09.01\_ER\_MX53\_UPDATER.zip package contains the image down loading tool. ## 2.3 i.MX53 START Components <u>Table 2-1</u> lists the hardware items contained in the i.MX53 START package. Read MX53 START Hardware user guide, before using it. Item Description i.MX53 START board **Boards** Display VGA output • TVOut • CLAA WVGA panel (Optional Board) Seiko WVGA panel (Optional Board) HDMI daughter card (Optional Board) Cables • DB9 M/F RS-232 serial cable USB type A/M to MicroUSB type B/M shielded cable Ethernet straight cable Data storage SD card MMC/eMMC4.3/eMMC4.4 cards • SATA Power Supply Dedicated power supply box **Table 2-1 Kit Components** ## 3 What's New This section describes the changes in this release, including new features and defect fixes. ## 3.1 New Features See ResolvedEnhancements.html for the complete list of new features and enhancements since the last release. Summary of the main features is as follows: - Enabled i.MX53 START board with MC34708 Rev2.4 support - Added DDR PIN floating operations in system idle to save the power in idle and audio playback mode - Added CEA extend revision 1/2 support for EDID - Fixed the touch screen and I2C failures for DA9053 PMIC - Improved the capture quality of OV5642 and OV3640 - Aligned U-Boot mmc command with community code - Fixed the random failure "the kernel stops at "calibration delay loop..." caused by GPT timer stop. - U-Boot: Switch to use plug-in mode instead of DCD mode ### 3.2 Defect Fixes See ResolvedDefects.html, referenced inside the file readme.html, for the list of the defects fixed in this release. ## 4 BSP Supported Features <u>Table 4-1</u> describes the features that are supported in this BSP release. **Table 4-1 Supported Features** | Feature | Supported? | Comments | | |---------------------------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | Kernel | | | | | Kernel | Yes | Kernel version: 2.6.35.3 | | | File System | Yes | EXT2/EXT3/EXT4 are used as the file system in MMC/SD, SATA | | | Bootloader | | | | | U-Boot | Yes | <ul> <li>U-Boot delivery is based on U-Boot version 200908.</li> <li>Supports Micro SD boot.</li> <li>Support SD/MMC/eMMC4.4/SATA "Read" and "Write" operations.</li> <li>Support I2C commands to manipulate DA9053.</li> <li>Supports FEC and console output.</li> <li>Supports fuse and clock operations.</li> </ul> | | | Machine<br>Specific Layer | | | | | ARM Core | Yes | Supports Cortex-A8 (The default CPU frequency of START board is 1GHZ). | | | Feature | Supported? | Comments | | |-----------------------------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | Memory | Yes | 1G memory is used. The user/kernel space is split as 2G/2G. | | | Interrupt | Yes | Supports MXC TZIC module. | | | Clock | Yes | Control system frequency, clock tree distribution. | | | Timer (GPT) | Yes | System timer tick support. | | | GPIO/EDIO | Yes | GPIO is initialized in earlier phase according to hardware design. Note that all GPIO activate/deactivate functions used in the drivers are dummies (see the MSL code for the details). | | | IOMUX | Yes | Provides the interfaces for IO configuration. IOMUX-V3 version is used. | | | SPBA | Yes | Provides the interfaces to allow different masters to take or release ownership of a shared peripheral. | | | SDMA | Yes | SDMA script version is V1.1.0. | | | Character<br>Device Drivers | | | | | MXC UART | Yes | Console support via UART1. | | | Graphic Drivers | | | | | Frame Buffer<br>Driver | Yes | MXC Frame buffer driver for IPU V3. | | | LVDS | Yes | Supports HannStar LVDS panel | | | VGA | Yes | Support VGA output via TVE module. The following video modes are supported by defaule. XGA SXGA SXGA For additional video modes, timing parameters must be computed and the new video mo added to the source code. | | | TVE | Yes | added to the source code. Support TVOut via the VGA-TV cable. The following video modes are supported: TV-PAL TV-NTSC TV-720P60 TV-720P30 TV-1080I60 TV-1080I50 TV-1080P25 TV-1080P24 | | | HDMI | Yes | Supports Sii902x HDMI chip. Supports EDID feature. | | | WVGA | Yes | Supports CLAA WVGA panel and Seiko WVGA panel. | | | GPU | Yes | <ul> <li>GPU software version: AMD Production Release 1.2.</li> <li>Supports Z430 (3D) and Z160 (2D).</li> <li>Support s OpenGL ES 2.0 and 1.1, OpenVG 1.1, C2D custom API using Z160</li> <li>Provides debian packages to support EGL X-Window.</li> </ul> | | | Multimedia<br>Drivers | | | | | IPU V3 driver | Yes | Provides the interfaces to access IPU V3 modules. | | | V4L2 Output | Yes | Provides V4L2 implementations. Currently V4L only supports one instance. IPU library located in the imx-lib package can support multiple instances. De-interlace function for split mode (> 1024x1024) is not supported in this version. | | | VPU | Yes | VPU firmware version: v1.4.41 | | | Feature | Supported? | Comments | | |-----------------------------------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | | | Supports VPU encoder and VPU decoder. | | | | | For Real Video and DivX3 support information, contact a Freescale representative. | | | Power<br>Management<br>Drivers | | | | | PMIC | Yes | Supports the DA9053 PMIC via I2C interface. Supports the MC34708 PMIC via I2C interface | | | Lower Power mode | Yes | Supports stop mode in mem state. Only supports power key and RTC as wakeup resources. | | | DVFS-Core | Yes | <ul> <li>HW DVFS-Core can be used for CPU frequency adjustment.</li> <li>For 1.2GHZ chip, supports 4 working points (1.2GHZ, 1GHZ, 800MHZ, 400MHZ).</li> <li>For 1GHZ chip, supports 3 working points (1GHZ, 800MHZ, 400MHZ).</li> </ul> | | | CPUFreq | Yes | CPUFreq can be used for CPU frequency adjustment. | | | Bus scaling | Yes | Bus scaling driver can be used for bus frequency adjustment. | | | Sound Drivers | | , , , | | | S/PDIF Tx | Yes | <ul> <li>Supports S/PDIF Transmit to HDMI.</li> <li>Supports inaccurate 48K sample rate because the OSC is 24MHZ.</li> </ul> | | | SSI/SGTL500 | Yes | <ul> <li>Supports the STGL5000 stereo audio codec under ASoC framework.</li> <li>Supports audio playback and record.</li> </ul> | | | ASRC | Yes | Support ASRC module for sample rate conversion. | | | Input Device<br>Drivers | | | | | Touch panel | Yes | Supports P1003 and eGalax capacitive touch screen driver. | | | USB devices | Yes | Supports USB mouse and USB keypad via USB ports | | | MTD driver | | | | | SATA | Yes | Supports SATA driver with internal clock. | | | Networking<br>Drivers | | | | | FEC | Yes | Supports LAN8720 PHY. | | | USB Drivers | | | | | USB Host | Yes | Supports USB HOST1 and USB OTG host. | | | USB Device | Yes | Supports USBOTG device mode. | | | Security Drivers | ., | | | | Security drivers General drivers | Yes | Supports SCC2 and SAHARA. | | | SRTC | Yes | Curry outs for the LD democin | | | Shic | res | Supports for the LP domain. | | | MMC/SD/SDIO | Yes | <ul><li>Supports i.MX eSDHC module with PIO and DMA modes.</li><li>Supports eMMC4.4 DDR and SDR mode via SDHC3.</li></ul> | | | WatchDog | Yes | Supports Watchdog reset. | | | I2C | Yes | Supports I2C master. Supports I2C1, and I2C2. | | | SPI | Yes | Supports SPI master mode. | | | PWM | Yes | Supports the backlight driver via PWM. | | | Accelerometer | Yes | Supports MMA8450. It is disabled by default. | | | WiFi | Yes | , , | | ## 5 Kernel boot parameters Depending on the booting/usage scenario, you may need different kernel boot parameters. The Table below describes different boot parameters. **Table 5-1. Kernel Boot Parameters** | Kernel<br>Parameters | Description | Typical Values | Used When | |----------------------|--------------------------------------------------------|------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------| | console | Where to output kernel logging by printk. | console=ttymxc0 | All cases | | ip | Tell kernel how or whether to get IP address. | <pre>ip=none ip = dhcp ip=static_ip_address</pre> | "ip=dhcp" or "ip=static_ip_address" is mandatory in "boot from TFTP/NFS." | | nfsroot | The location of the NFS server/directory. | <pre>nfsroot=<ip_address>:<rootfs path=""></rootfs></ip_address></pre> | Used in "boot from tftp/NFS" together with "root=/dev/nfs." | | root | The location of the root file system. | <pre>root=/dev/nfs or root=/dev/mmcblk0p2</pre> | Used in "boot from tftp/NFS" (that is, root=/dev/nfs); Used in "boot from SD" (that is, root=/dev/mmcblk0p2). | | rootfstype | Indicates the file system type of the root file system | rootfstype=ext4 | Used in "boot from SD" together with<br>"root=/dev/mmcblk0p2." | | rootwait | Wait (indefinitely) for root device to show up. | rootwait | Used when mounting SD rootfs. | | tve | Enable TVOUT feature. | tve | Used when need enable TVOUT, after enable tve, below video modes will be added into di1 FB mode list: | | | | | TV-1080P24: D:1920x1080p-24 | | | | | TV-1080P25: D:1920x1080p-25 | | | | | TV-1080P30: D:1920x1080p-30 | | | | | TV-1080l50: D:1920x1080i-50 | | | | | TV-1080l60: D:1920x1080i-60 | | | | | TV-720P30: D:1280x720p-30 | | | | | TV-720P60: D:1280x720p-60 | | | | | TV-PAL: D:720x576i-50 | | | | | TV-NTSC: D:720x480i-60 | | | | | First column is FB mode's string name. | | vga | Enable VGA<br>feature. | vga | Used when need enable VGA output, after enable vga, below video modes will be added into di1 FB mode list: VGA-WSXGA+: D:1680x1050p-60 VGA-SXGA: D:1280x1024p-60 VGA-XGA: D:1024x768p-60 VGA-SVGA: D:800x600p-60 First column is FB mode's string name. | |----------------|--------------------------------------------------------------------------------------------------------------------|--------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | hdmi | Enable Sii902x<br>hdmi module. | hdmi | Used when need enable HDMI output, after enable hdmi, the sii902x driver will try to fetch video modes by reading EDID, if succeed, these video modes will be added into di0 FB mode list. | | ldb=di <x></x> | Tells the kernel/driver to enable LDB driver | ldb=di1<br>or<br>ldb=di0 | Used when LVDS panel is connected via LVDS1 port Used when LVDS panel is connected via LVDS0 port | | di1_primary | Tells the<br>kernel/driver that<br>DI1 is the primary<br>display | di1_primary | Used when primary display is on DI1 port. | | di0_primary | Tells the<br>kernel/driver that<br>DI0 is the primary<br>display | di0_primary | Used when primary display is on the DI0 port. | | ddc | Enable common<br>MXC DDC driver. It<br>will try to read EDID<br>info from the I2C<br>bus platform data<br>defined. | ddc | After enable ddc, if EDID reading successful, the video modes will be added to defined di framebuffer modelist. | | video | Tell kernel/driver which resolution/depth and refresh rate should be used for display port 0 or 1. See the parameter information under Documentation/fb/ modedb.txt Tells the kernel/driver which IPU display interface format should be used. | 1. video=mxcdi1fb:GBR24,VGA-XGA di1_primary vga 2.video=mxcdi0fb:RGB565,CLAA -WVGA di0_primary 3. video=mxcdi0fb:RGB24,SEIKO-W VGA di0_primary 4. video=mxcdi0fb:RGB24,1024x76 8M@60 hdmi di0_primary 5. video=mxcdi1fb: YUV444, TV-1080P30 di1_primary tve 6. video=mxcdi0fb:RGB565,int_cl k 800x480M@55 di0_primary 7. video=mxcdi0fb:RGB666,XGA di0_primary ldb=di0 | 1. Used when displaying on VGA with XGA resolution 2. Used when displaying on a CLAA WVGA LCD connected to display port 0 3. Used when displaying on a Seiko WVGA LCD connected to display port 0 4. Used when displaying on a HDMI output devices via HDMI daughter card. The required video mode is 1024x768 at 60 refresh rate. After EDID reading, the nearest video mode will be chosen in EDID video mode list. 5. Used when displaying on a 1080P TV for display port 1. 6. Display port 0 uses 800x480 CVT timing, pixel clock choose internal clock as clock source. If without int_clk option, display driver will automatically choose the clock source, it will try internal first, if not accurate, then external. 7. Used when displaying on the HannStar LVDS via LVDS0 NOTE: GBR24/RGB565/YUV444 etc represent the display HW interface format, typical value for different display devices is like below: TVOUT: YUV444 VGA: GBR24 HDMI&DVI: RGB24 CLAA WVGA LCD: RGB565 | |-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | dmfc | Tells the<br>kernel/driver how to<br>set IPU DMFC<br>segment size | None Or dmfc=3 | "dmfc=1" means DMFC_HIGH_RESOLUTION_DC, "dmfc=2" means DMFC_HIGH_RESOLUTION_DP, "dmfc=3" means DMFC_HIGH_RESOLUTION_ONLY_DP. Note: DMFC_HIGH_RESOLUTION_ONLY_DP can only be set by the command line. | | mem | Tell kernel how much memory can be used. | None or mem=864M | Note: 1G - <mem> - <gpu_memory> is reserved for X-Acceleration.</gpu_memory></mem> | 10 Freescale Semiconductor | gpu_memory | Tell kernel how<br>much memory is<br>reserved for GPU<br>usage. | None or gpu_memory =128M | Used to indicate the memory size reserved for the GPU. | |------------|--------------------------------------------------------------------------------------------------|--------------------------|------------------------------------------------------------------------------------------------------------| | gpu_nommu | Tell the kernel to disable GPU MMU function. The disable of the MMU is required on this release. | Nor or gpu_nommu | Used to disable GPU MMU function. To enable GPU MMU function, DMA zone requirement is something different. | ## 6 Known Issues/Limitations Read through all hardware related reference material and ensure the necessary hardware modifications have been made before using the software. <u>Table 6-1</u> lists some key known issues. Table 6-1 Known Issues and Workarounds | Features | Category | Description | Resolution/Workaround | |----------|---------------|------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Display | Configuration | Display automatic blank functionality is enabled by default. So the display will power off automatically when the time is expired. | To disable LCD automatic blank functionality, enter the command: echo -e "\033[9;0]" > /dev/tty0 When the display is off, enter the following command to power on the display: echo 0 > /sys/class/graphics/fb0/blank | | Video | Configuration | When playing the video for a long time, allocation of contiguous memory may fail (memory fragmentation). | To play video when the system memory is low, run the command: echo 1 > /proc/sys/vm/lowmem_reserve_rati o It protects the DMA zone and avoids memory allocation errors. | | Video | Hardware | Mosaic may be observed when playing video under heavy loading conditions. | The temporary workaround is to increase VCC voltage as 1.35V. The following u-boot commands can achieve it: i2c mw 0x48 0x2f 0x62 i2c mw 0x48 0x3c 0x62 Or reduce peripher clock just like the below: clk periph 380 | | Video | BSP | ENGR151391 (1080P<br>playback: Allocation of the<br>Frame Buffers Failed for some | The workaround is to add "gpu_nommu" command option in launch command line. Or drop | Freescale Semiconductor | Features | Category | Description | Resolution/Workaround | |-------------------------------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | H.264 stream) | ENGR00143019 patches. Or increase DMA zone size by changing CONFIG_DMA_ZONE_SIZE to 128M. | | SATA | Hardware | SATA with internal clock cannot boot. | Ensure the fuse "SATA_ALT_CLK_REF" is<br>blown. The following u-boot command can<br>blown SATA internal boot fuse:<br>iim blow 4 3 4 | | SATA<br>Temperature<br>Sensor | Hardware/BSP | To run the command "cat /sys/class/hwmon/hwmon1/device /temp1_input" on some START boards, the following error is reported: Wait for CR ACK error! imx-ahci-hwmon imx-ahci-hwmon: Read/Write REG error, 0x0! | The workaround is to add more delays in polling operation. See the patch "0001-Fix-the-ack-error-when-read-system-s-temperature-onpatch" | | ASRC | BSP | The ASRC unit test program in 11.09.01 can not work well. | Need to revert one patch for 2.6.38 kernel in imx-test package. Please refer to " | | SRTC | Hardware | The alarm interrupt fails to wake up the system. | Read HW guide for the rework. | | Seiko WVGA | Hardware | Seiko WVGA panel does not work well on REV B boards. | Read HW guide for the rework. | | Touch<br>Screen | Hardware | DA9053 touch screen does not work well. | Check the hardware and ensure TSIREF_GPIO7 is connected to LDO8. | | USB | Hardware | The Lower USB Host Jack and the Micro USB Device Jack are cross connected. | The user can plug one cable into either jack, but cannot plug cables into both jacks at the same time. | | Power | U-Boot | If staying in U-Boot console, the chip becomes hot. | This is because all clocks are enabled in U-boot. So the power in U-boot is higher. But the clocks are disabled in kernel initialization codes. To disable unused clocks in U-boot, the following codes under board/freescale/mx53_loco/lowlevel_init.S can be modified according to the actual use case: can be modified according to the actual use actual use case: | 12 Freescale Semiconductor | Features | Category | Description | Resolution/Workaround | |-------------------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | | /* Restore the default values in the Gate registers */ Idr r1, =0xFFFFFFFF str r1, [r0, #CLKCTL_CCGR0] str r1, [r0, #CLKCTL_CCGR1] | | LTIB Build | LTIB | When you install LTIB host packages and build elftosb, the following error is reported /usr/bin/ld: ElftosbAST.o: in function elftosb::BinaryOpExprASTN ode::reduce(elftosb::Eval Context&):/opt/freescale/ltib/usr/src/rpm/BUILD/elftosb-10.10.00/elftosb2/ElftosbAST.cpp:758: error: undefined reference to 'powf' | Modify elftosb-10.10.00/makefile.rules and change as the following: -LIBS = -lstdc++ +LIBS = -lstdc++ -lm | | ARMV7 | Hardware | ENGcm11413 (Data abort when AXI access with BL>8 is made ): If an 8-bits NEON load to strongly ordered/device memory, and if the access size is more than 8 bytes, the AXI bus will use the burst (burst len more than 8, burst size is 1 byte). MX53 M4IF just supports the burst length up to 8.if burst length is larger than 8, MX53 reports the data abort. | The user should avoid pgprot_noncached to be used in xxx_mmap for DDR memory. The user should use pgprot_writecombine instead of pgprot_noncached to map the DDR memory to the user space. If the pgprot_writecombine is used for mapping a DDR area and DMA is enabled for this area, the user must do DSB(Data Synchronization Barrier) by using dsb() function for drawing the write buffer, before the DMA starting read from this area. | | NEON | Software | NEON should not be used at all for Linux kernel modules | Follow this rule. | | Hannstar<br>touch | Software | Hannstar touch don't work on GNOME | The multi-touch function is not supported in GNOME. To use this touch in GNOME the single touch options needs to be enabled. With the following code changes: a/drivers/input/touchscreen/egalax_ts.c +++ b/drivers/input/touchscreen/egalax_ts.c @@ -28,7 +28,7 @@ - auto idle mode support - early suspend support for android */ | | Features | Category | Description | Resolution/Workaround | |-----------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------| | | | | - +#define FORCE_SINGLE_POINTER_SUPPORT #include <li>inux/module.h&gt; #include <li>inux/init.h&gt; #include <li>inux/i2c.h&gt;</li></li></li> | | | | When writing assembly code to use neon/vfpv3 fpu and assembler it by binutils, vcvt instruction will encoder to vcvtr wrongly, this leading to performance decrease a lot. | Avoid using vcvt instructions. | | | | For example, assembly code test.s with content as: | | | | | .text | | | | | .globl t | | | | | .align 2 | | | | | test: | | | toolchain | toolchain | vcvt.s32. | | | | | f32 s1, s1 | | | | | Assemble with command: | | | | | arm-fsl-linux-gnueabi-as -march=armv7-a -mfpu=neon -mfloat-abi=softfp test.s -o test.o | | | | | The instruction: | | | | | vcvt.s32.f32 s1, | | | | | is wrongly encoded to: | | | | | vcvtr.s32<br>.f32 s1, s1 | | ## 7 Tips for MC34708 START board | Features | Descriptions | Setting on MC34708 START board | |-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | HW<br>Reset | MX53 MC34708 START board supports the HW reset function by two options: To enable a global reset the GLBRST pin (Reset Key) needs to be pulled low for greater than GLBRSTTMR[1:0] seconds and then pulled back high. Configure PWRONx pins and enable PWRONxRSTEN and RESTARTEN bits to generate a system reset. | Current default reset function in MC34708 START board is enabled by a global reset through pressing reset key 4s until the LED is changed from blue clock to red color, then blue color again. However HW reset function is not stable if U-boot applies plug-in method. By switching back to use DCD method (See the patch 0001-ENGR00155891-mx53-mc34708-QS-restore-to-use-DC D-mode.patch), the reset function is much stable. The root cause is under investigation. | | Reboot | MX53 Watchdog output PIN is connected to MC34708 WDI signal. To ensure SW reboot stable, recommend to enable MC34708 WDIRESET bit so that MC34708 can go to Cold Start without passing through off mode. | Please refer to kernel patch "0001-ENGR00155891-mx53_loco-enable-mc34708-s-WDI-f unction.patch" | | Poweroff | MC34708 can support poweroff function by setting PWRONxRSTEN bits as 1. When enabled, a 4 second long press on the power button will cause the device to go to the Off mode, | HW poweroff function is disabled by default. This is because 4s cannot meet the definition of power key. Recommend to implement poweroff function through the software. | #### How to Reach Us: #### Home Page: www.freescale.com #### Web Support: http://www.freescale.com/support ### **USA/Europe or Locations Not Listed:** Freescale Semiconductor Technical Information Center, EL516 2100 East Elliot Road Tempe, Arizona 85284 +1-800-521-6274 or +1-480-768-2130 www.freescale.com/support #### Europe, Middle East, and Africa: Freescale Halbleiter Deutschland GmbH Technical Information Center Schatzbogen 7 81829 Muenchen, Germany +44 1296 380 456 (English) +46 8 52200080 (English) +49 89 92103 559 (German) +33 1 69 35 48 48 (French) www.freescale.com/support ### Japan: Freescale Semiconductor Japan Ltd. Headquarters ARCO Tower 15F 1-8-1, Shimo-Meguro, Meguro-ku, Tokyo 153-0064, Japan 0120 191014 or +81 3 5437 9125 support.japan@freescale.com #### Asia/Pacific: Freescale Semiconductor China Ltd. Exchange Building 23F No. 118 Jianguo Road Chaoyang District Beijing 100022 China +86 010 5879 8000 support.asia@freescale.com ### For Literature Requests Only: Freescale Semiconductor Literature Distribution Center P.O. Box 5405 Denver, Colorado 80217 1-800-441-2447 or 303-675-2140 Fax: 303-675-2150 LDCForFreescaleSemiconductor@hibbertgroup.com Information in this document is provided solely to enable system and software implementers to use Freescale Semiconductor products. There are no express or implied copyright licenses granted hereunder to design or fabricate any integrated circuits or integrated circuits based on the information in this document. Freescale Semiconductor reserves the right to make changes without further notice to any products herein. Freescale Semiconductor makes no warranty, representation or guarantee regarding the suitability of its products for any particular purpose, nor does Freescale Semiconductor assume any liability arising out of the application or use of any product or circuit, and specifically disclaims any and all liability. including without limitation consequential or incidental damages. "Typical" parameters that may be provided in Freescale Semiconductor data sheets and/or specifications can and do vary in different applications and actual performance may vary over time. All operating parameters, including "Typicals", must be validated for each customer application by customer's technical experts. Freescale Semiconductor does not convey any license under its patent rights nor the rights of others. Freescale Semiconductor products are not designed, intended, or authorized for use as components in systems intended for surgical implant into the body, or other applications intended to support or sustain life, or for any other application in which the failure of the Freescale Semiconductor product could create a situation where personal injury or death may occur. Should Buyer purchase or use Freescale Semiconductor products for any such unintended or unauthorized application, Buyer shall indemnify and hold Freescale Semiconductor and its officers, employees, subsidiaries, affiliates, and distributors harmless against all claims, costs, damages, and expenses, and reasonable attorney fees arising out of, directly or indirectly, any claim of personal injury or death associated with such unintended or unauthorized use, even if such claim alleges that Freescale Semiconductor was negligent regarding the design or manufacture of the Freescale and the Freescale logo are trademarks or registered trademarks of Freescale Semiconductor, Inc. in the U.S. and other countries. All other product or service names are the property of their respective owners. Microsoft and Windows are registered trademarks of Microsoft Corporation. © Freescale Semiconductor, Inc. 2011. All rights reserved. Document Number: 924-76376 Rev.11.09.02 10/2011