Template Information

Trang

Chủ đề

BSP (44) Device Drivers (43) WinCE (38) WINDOWS DRIVER (19) Linux Device Drivers (18) ARM (17) Android tools and tips (17) DRIVER FILES (16) Windows Device Driver (16) AUDIO DRIVER (12) 8051 (8) OMAP (7) PRINTER DRIVER FILES (7) C Programming (6) ASUS MOTHERBOARD (5) Interfacing (5) NETWORK ADAPTER (5) VIDEO DRIVER (5) CANON (3) Device Driver Downloads (3) MOBILE PHONE (3) Asus Driver (2) EPSON (2) Epson Printer Driver (2) HP LAPTOP DRIVER (2) LAPTOP DRIVER FILES (2) Logitech Driver (2) NETWORK ADAPTOR (2) OMAP 4430 (2) drivers download (2) ACER (1) ACER TABLET (1) ALL IN ONE DRIVER (1) Acer Aspire 5738 Drivers (1) Analog-to-Digital (1) Asus Drivers (1) Asus Motherboard Drivers (1) Chip Architecture (1) DELL (1) Dell D610 Drivers (1) Dell Drivers (1) Device Drivers Download (1) Device drivers interview questions (1) Display Driver (1) Drivers Download for Windows 7 (1) EEPROMs (1) Free Asus Motherboard Drivers (1) Free Drivers Download for Windows 7 (1) GRAPHIC DRIVER (1) HP Driver (1) Hardware (1) Intel Drivers (1) Intel P35 (1) Intel P35 chipset drivers (1) I²C (1) LAPTOP SERVICE MANUAL (1) LCD (1) Logitech Mouse Driver (1) Logitech webcam driver (1) MODEM DRIVER (1) Motherboard Drivers for Windows 7 (1) PARALLEL PORT (1) Pc Driver (1) RTOS (1) Real Time Clock (1) Sensors (1) USB CABLE DRIVER (1) WEBCAM DRIVER (1) WIRELESS ADAPTOR (1) Windows 7 Drivers (1) Windows Mobile (1) acer driver (1) acer driver downloads (1) acer laptop driver (1) chipset drivers (1) network card driver (1) network driver download (1) sdcc (1)

Bài viết ngẫu nhiên

Xem phim HD Online

Số lượt views

Android eMMC Booting

Thứ Năm, 18 tháng 8, 2011 / 07:00

eMMC binaries

This is the efi partition table as exists on the emmc
Sector#    Size Name

256 128K xloader

512 256K bootloader

2048 8M recovery

18432 8M boot

34816 512M system

1083392 256M cache

1607680 512M userdata

2656256 2183M media

Creating the GPT table

On Target

  1. Connect a USB cable to the OTG port on your platform

  2. Boot your platform up with a stock u-boot and MLO

  3. Once you platform is booted you will see the following:

Fastboot entered...

On Host Machine

locate fastboot in you android filesystem
cd $mydroid/out/host/linux-x86/bin/fastboot

Search for fastboot devices
fastboot devices

Create GPT table on eMMC/SD card
fastboot oem format

From the android build these are the binaries that go into each partition:
Sector#    Size Name            Binary

256 128K xloader MLO

512 256K bootloader u-boot.bin

2048 8M recovery recovery.img

18432 8M boot boot.img

34816 512M system system.img

1083392 256M cache cache.img

1607680 512M userdata userdata.img

2656256 2183M media none



File locations

  • MLO --> x-loader/MLO

  • u-boot --> u-boot/u-boot.bin

  • boot.img --> need to create using zImage + ramdisk.img

  • recovery.img ---> need to create using zImage + ramdisk-recovery.img

  • system.img --> $mydroid/out/target/product/<platform>/system.img

  • cache.img -->

  • userdata.img --> $mydroid/out/target/product/<platform>/userdata.img



All these partitions can be flashed with the given binary using fastboot.
fastboot flash <name> <binary>

Example flashing of all partitions
fastboot flash xloader     MLO

fastboot flash bootloader u-boot.bin

fastboot flash recovery recovery.img

fastboot flash boot boot.img

fastboot flash system system.img

fastboot flash cache cache.img

fastboot flash userdata userdata.img

Modifying .IMG Files

Typically when you want to modify any of the partitions, you would need to unzip-modify-rezip and then fastboot flash.
Following section talks about how to do that for each partition
BOOT.IMG
boot.img = zImage + ramdisk.img

zImage = kernel image

ramdisk.img = out/target/product/blaze/root/

 %./out/host/linux-x86/bin/mkbootimg

--kernel zImage

--ramdisk ramdisk.img

--base 0x80000000

--cmdline "console=ttyO2,115200n8 mem=456M@0x80000000 mem=512M@0xA0000000 init=/init vram=10M omapfb.vram=0:4M androidboot.console=ttyO2"

--board omap4

-o boot.img.new

Output: boot.img.new

**Note: bootarg is passed to kernel via --cmdline option above

To "just" boot boot.img (before flashing) you can use:
%fastboot boot boot.img

RAMDISK.IMG
 %mkdir root

 %cd root

 %gunzip -c ../ramdisk.img | cpio -i

<make changes to root/ contents...>

 %./out/host/linux-x86/bin/mkbootfs root/ | ./out/host/linux-x86/bin/minigzip >ramdisk.img.new

#output: ramdisk.img.new

** Note: any init.rc changes will need to use this method

RECOVERY.IMG
Is just like boot.img. 

recovery.img = zImage + ramdisk-recovery.img

*Follow the same steps as boot.img for packing/unpacking

SYSTEM.IMG
#uncompress

 %./out/host/linux-x86/bin/simg2img system.img system.img.raw

#mount to directory mnt-point/

 %mkdir mnt-point

 %sudo mount -t ext4 -o loop system.img.raw mnt-point/

#modify any .so or apk in the mnt-point/ directory

#rezip

 %sudo out/host/linux-x86/bin/make_ext4fs -s -l 512M -a system system.img.new mnt-point/

 %sudo umount mnt-point/

Output: system.img.new

Instead of having to reflash the whole big system.img, one can selective update any binary in /system folder on running target
%adb remount

%adb push <local> <remote>

Eg:

%adb remount

%adb push out/target/product/blaze/obj/lib/overlay.omap4.so /system/lib/hw/overlay.omap4.so

%adb sync

USERDATA.IMG
#uncompress

 %./out/host/linux-x86/bin/simg2img userdata.img userdata.img.raw

#mount to directory mnt-point/

 %mkdir mnt-point

 %sudo mount -t ext4 -o loop userdata.img.raw mnt-point/

#modify any .so or apk in the mnt-point/ directory

#rezip

 %sudo ./out/host/linux-x86/bin/make_ext4fs -s -l 512M -a userdata userdata.img.new mnt/

 %sudo umount mnt-point/

Output: userdata.img.new

CACHE.IMG
#This is empty ext4 fs image

 %mkdir mnt-point/

 %sudo ./make_ext4fs -s -l 256M -a cache cache.img mnt-point/

Output: cache.img

TI Android build setup

Copy kernel zImage, u-boot.bin and MLO for your board in folder device/ti/blaze/boot/.
Rename as:
 %mv MLO MLO_es2.2_emu 

or

 %mv MLO MLO_es2.2_gp

(based on your board being GP or EMU)

Next start standard android build and all img files are generated in:
out/target/product/blaze/*.img

A script is introduced in TI Android release to make this flashing process easier: device/ti/blaze/boot/fastboot.sh
Usage:

cd device/ti/blaze/boot/

%fastboot.sh --emu

or

%fastboot.sh --gp

Running this script will flash whole android system on your board.
Thứ Năm, 18 tháng 8, 2011 07:00 Đọc tiếp >>

Android Porting on PandaBoard

Introduction

This software release has been developed and verified in the following software and hardware environment.
Known Issues
  • AV playback -- not available at this time --TODO: need ducati binaries

  • Mic not tested

  • First start up is slow

  • Screen black out after 30sec. Edit display timing to fix or use ALT-F1 then ALT-F7 to bring back up

  • mouse is slow for first start up

  • android's keyboard does not show up

  • music.apk and other apps are crashing -- latest pre-built-binary release does not have the fix required.

Please note Toolchain is upgraded since L27.7.0 release.
OMAP4 SGX hardware Graphics Accelerator libraries are required to boot AFS.

OS Kernel: Linux® 2.6.35
Android: Gingerbread public project
SGX version: 1.1.17.4403
Toolchain: CodeSourcery compiler version Sourcery G++ Lite 2010q1-202 for ARM GNU/Linux
Reference hardware platform: PandaBoard A1 -- ES2.1, PandaBoard A2
Build Host OS: Ubuntu 10.04, Ubuntu 11.04
HDMI Display: HP2159m, DELL 2408WFP, DELL ST2220L
SD Card: 2GB Kingston Technology, 2GB SanDisk microSD (using ADAPTER)

 Prebuilt binaries

Download binaries: Gingerbread Pre-Built "DRAFT" Release Package
  • Pre-Built Release (WLAN/GFX included)

  • Launcher2.apk

  • kernel and android patches required for building

  • WLAN/BT patches -- Note: to rebuild wlan you need to pull the source and then apply patches

Visit: Create_Android_Rootfs_Directory for more information
Release Details

  • WLAN is functional

  • HDMI to DVI functional

  • GFX functional

  • Audio working

  • ADB enabled

  • Ethernet working

  • Mic not tested

  • TI Video playback -- not working -- requires the release of binaries

  • ARM Video playback -- not tested

  • music.apk and other apps are crashing -- latest pre-built-binary release does not have the fix required. Patch is available within pre-built-binary to fix this on build

Proceed to: Booting Android from SD card

 Building Pandroid

Tools & Dependency for Building

Pre-requisite packages for build Android Filesystem (Note this is with reference to uBuntu 8.04)
If you are behind firewall, you will have to set-up firewall using the instructions in Support Tools
For higher versions of U-buntu please refer to Host PC COnfiguration
The following commands will install the correct packages to your server:
sudo apt-get install git-core flex bison gperf libesd0-dev libwxgtk2.6-dev zlib1g-dev build-essential libstdc++5 tofrodos

sudo apt-get install x-dev

sudo apt-get install libx11-dev

sudo apt-get install libncurses5-dev

sudo apt-get install sun-java6-jdk

64-bit environment users must install g++.multilib:
sudo apt-get install g++-multilib

“Intrepid (8.10) users may need a newer version of libreadline:
sudo apt-get install lib32readline5-dev”

 Android Environment Setup

Use the example below to setup your environment. Your environment may vary...
export YOUR_PATH=`pwd`

mkdir -p $YOUR_PATH/L27.12.1-P2/mydroid

mkdir -p $YOUR_PATH/L27.12.1-P2/build_tools

mkdir -p $YOUR_PATH/L27.12.1-P2/wlan

mkdir -p $YOUR_PATH/L27.12.1-P2/wlan_firmware

cd $YOUR_PATH/L27.12.1-P2/mydroid

export MYDROID=`pwd`

cd $YOUR_PATH/L27.12.1-P2/build_tools/arm-2010q1

 Tool Chain for building Kernel and Drivers

The Kernel and Driver sources are built using Sourcery G++ Lite 2010q1-202 for ARM GNU/Linux version.
Download: arm-2010q1-202 to $Your_PATH/L27.12.1-P2/build_tools/
cd $Your_PATH/L27.12.1-P2/build_tools/

wget http://www.codesourcery.com/sgpp/lite/arm/portal/package6488/public/arm-none-linux-gnueabi/arm-2010q1-202-arm-none-linux-gnueabi-i686-pc-linux-gnu.tar.bz2

tar jxvf arm-2010q1-202-arm-none-linux-gnueabi-i686-pc-linux-gnu.tar.bz2

cd $YOUR_PATH/L27.12.1-P2/build_tools/arm-2010q1/

export PATH=$PATH:$YOUR_PATH/L27.12.1-P2/build_tools/arm-2010q1/bin

 Downloading Release Software

 Installing repo

For detail information regarding repo visit: Using Repo and Git
Other reference links on Git can be found in Techincal References page
Download repo to environment
$ cd $YOUR_PATH/L27.12.1-P2/mydroid

$ curl http://android.git.kernel.org/repo > ./repo

$ chmod a+x repo

 Download Android source

cd $YOUR_PATH/L27.12.1-P2/

cd $MYDROID

repo init -u git://git.omapzoom.org/platform/omapmanifest.git -b 27.x -m RLS27.12.1-P2_Gingerbread.xml

repo sync

Update PandaBoard device directory--- TODO: clean up and remove Blaze items
cd $MYDROID/device/ti/pandaboard

git fetch http://review.omapzoom.org/p/device/ti/pandaboard refs/changes/12/13612/1 && git cherry-pick FETCH_HEAD

Adding Mouse and Keyboard support
cd $MYDROID/frameworks/base

git remote add rowboat git://gitorious.org/rowboat/frameworks-base.git

git fetch rowboat

git cherry-pick 17128d44ab04c5b7cb2911e8b1c9f837aa9b36a5

git cherry-pick 174cb50436065dc092114d69fb40d5a7712e3ca0

Adding Audio Support
  • Patch 1 of 2

cd $MYDROID/hardware/ti/omap3

git fetch http://review.omapzoom.org/p/platform/hardware/ti/omap3 refs/changes/76/13276/5 && git cherry-pick FETCH_HEAD

  • Patch 2 of 2

diff --git a/modules/alsa/Android.mk b/modules/alsa/Android.mk

index 31d4890..b2c1e6b 100644

--- a/modules/alsa/Android.mk

+++ b/modules/alsa/Android.mk

@@ -39,6 +39,7 @@ ifeq ($(strip $(BOARD_USES_ALSA_AUDIO)),true)

endif

ifeq ($(strip $(TARGET_BOARD_PLATFORM)), omap4)

ifeq ($(strip $(TARGET_BOOTLOADER_BOARD_NAME)), pandaboard)

+ LOCAL_CFLAGS += -DOMAP4_PANDA

LOCAL_SRC_FILES:= alsa_panda.cpp

else

LOCAL_SRC_FILES:= alsa_omap4.cpp

diff --git a/modules/alsa/alsa_omap4.h b/modules/alsa/alsa_omap4.h

index cde2a3e..40bb63f 100644

--- a/modules/alsa/alsa_omap4.h

+++ b/modules/alsa/alsa_omap4.h

@@ -26,12 +26,18 @@

#endif



// alsa devices

+#ifdef OMAP4_PANDA

+#define MM_DEFAULT_DEVICE "plughw:0,4"

+#define MM_LP_DEVICE "hw:0,4"

+#define HDMI_DEVICE "plughw:0,6"

+#else

#define MM_DEFAULT_DEVICE "plughw:0,0"

#define BLUETOOTH_SCO_DEVICE "plughw:0,0"

#define FM_TRANSMIT_DEVICE "plughw:0,0"

#define FM_CAPTURE_DEVICE "plughw:0,1"

#define MM_LP_DEVICE "hw:0,6"

#define HDMI_DEVICE "plughw:0,7"

+#endif



// omap4 outputs/inputs

#define OMAP4_OUT_SCO (\

Adding WLAN support
cd $YOUR_PATH/L27.12.1-P2/

git clone git://git.omapzoom.org/platform/hardware/ti/wlan.git

cd $YOUR_PATH/L27.12.1-P2/wlan

git reset --hard 456971003aaa94a6b863b7a368aac8415ff32f8c

Patch for Google apps crashing -- Courtesy of Always Innovating
--- a/frameworks/base/libs/ui/InputReader.cpp

+++ b/frameworks/base/libs/ui/InputReader.cpp

@@ -426,7 +426,7 @@

{ // acquire state lock

AutoMutex _l(mStateLock);



- int32_t touchScreenConfig = InputConfiguration::TOUCHSCREEN_NOTOUCH;

+ int32_t touchScreenConfig = InputConfiguration::TOUCHSCREEN_FINGER;

int32_t keyboardConfig = InputConfiguration::KEYBOARD_NOKEYS;

int32_t navigationConfig = InputConfiguration::NAVIGATION_NONAV;

{ // acquire device registry reader lock

Kernel & Driver Source

To clone kernel source from scratch do:
cd $YOUR_PATH/L27.12.1-P2/

git clone git://git.omapzoom.org/kernel/omap.git kernel/android-2.6.35

cd kernel/android-2.6.35

git checkout ec895072ad0b686d2c130e5d80a3076a03042033

If you already have kernel source cloned then just update it (and add a remote if it is the first time):
cd $YOUR_PATH/L27.12.1-P2/kernel/android-2.6.35

git fetch origin

git checkout ec895072ad0b686d2c130e5d80a3076a03042033

Kernel Patches

  • Audio fixes for kernel:

cd ${YOUR_PATH}/L27.12.1-P2/kernel/android-2.6.35

git fetch http://review.omapzoom.org/p/kernel/omap refs/changes/01/13001/2 && git cherry-pick FETCH_HEAD

git fetch http://review.omapzoom.org/p/kernel/omap refs/changes/02/13002/2 && git cherry-pick FETCH_HEAD

  • EHCI fixes for kernel:

cd ${YOUR_PATH}/L27.12.1-P2/kernel/android-2.6.35

git fetch http://review.omapzoom.org/p/kernel/omap refs/changes/17/13617/1 && git cherry-pick FETCH_HEAD

  • DSS patch

cd ${YOUR_PATH}/L27.12.1-P2/kernel/android-2.6.35

git fetch http://review.omapzoom.org/p/kernel/omap refs/changes/22/13722/2 && git cherry-pick FETCH_HEAD

  • WLAN patches

cd ${YOUR_PATH}/L27.12.1-P2/kernel/android-2.6.35

git fetch http://review.omapzoom.org/p/kernel/omap refs/changes/02/12002/2 && git cherry-pick FETCH_HEAD

git fetch http://review.omapzoom.org/p/kernel/omap refs/changes/03/12003/1 && git cherry-pick FETCH_HEAD

git fetch http://review.omapzoom.org/p/kernel/omap refs/changes/64/14064/1 && git cherry-pick FETCH_HEAD

git fetch http://review.omapzoom.org/p/kernel/omap refs/changes/67/14067/1 && git cherry-pick FETCH_HEAD

git fetch http://review.omapzoom.org/p/kernel/omap refs/changes/68/14068/1 && git cherry-pick FETCH_HEAD

  • update panda_defconfig -- TODO:get this merged:

cd ${YOUR_PATH}/L27.12.1-P2/kernel/android-2.6.35

git fetch http://review.omapzoom.org/p/kernel/omap refs/changes/29/13029/3 && git cherry-pick FETCH_HEAD

git fetch http://review.omapzoom.org/p/kernel/omap refs/changes/61/13861/1 && git cherry-pick FETCH_HEAD

 U-Boot Source

cd $YOUR_PATH/L27.12.1-P2/

git clone git://git.omapzoom.org/repo/u-boot.git u-boot

cd u-boot

git checkout 601ff71c8d46b5e90e13613974a16d10f2006bb3

u-boot patch

a patch is available that changes the bootdelay as well as configures the correct bootargs: bootargs patch

 X-loader Source

cd $YOUR_PATH/L27.12.1-P2/

git clone git://git.omapzoom.org/repo/x-loader.git x-loader

cd x-loader

git checkout c8855fa6b85bd44073bd1b25dbffa99f02cbeeed

 Build Instructions

 Setting up build environment

cd $YOUR_PATH/L27.12.1-P2/

mkdir $MYDROID/logs

export JAVA_HOME=/usr/lib/jvm/java-6-sun

export CROSS_COMPILE=arm-none-linux-gnueabi-

export PATH=$YOUR_PATH/L27.12.1-P2/build_tools/arm-2010q1/bin:$PATH

 Building u-boot

Before building u-boot adjust the bootdelay and bootargs in omap4430panda.h
Note: Anyone wanting to try Fastboot do not adjust the BOOTDELAY
changing bootdelay

vim $YOUR_PATH/L27.12.1-P2/u-boot/include/configs/omap4430panda.h

- #define CONFIG_BOOTDELAY 0

+ #define CONFIG_BOOTDELAY 5

build u-boot

cd $YOUR_PATH/L27.12.1-P2/u-boot

make distclean

make ARCH=arm omap4430panda_config

make 2>&1 |tee $MYDROID/logs/u-boot_make.out

For information regarding Fastboot visit: Android_eMMC_Booting

Building x-loader

cd $YOUR_PATH/L27.12.1-P2/x-loader

make distclean

make ARCH=arm omap4430panda_config

make ift 2>&1 |tee $MYDROID/logs/x-loader_make.out

Building Kernel

Build Kernel

To create kernel uImage you need to add "mkimage" directory path to your "PATH" environment variable. "mkimage" is located in your u-boot/tools/ directory.
cd $YOUR_PATH/L27.12.1-P2/kernel/android-2.6.35

make ARCH=arm distclean #(required for rebuild only)

make ARCH=arm panda_defconfig

make ARCH=arm uImage 2>&1 |tee $MYDROID/logs/kernel_make.out

Building Kernel modules

cd $YOUR_PATH/L27.12.1-P2/kernel/android-2.6.35

make ARCH=arm modules 2>&1 |tee $MYDROID/logs/kernel_modules.out

Building WLAN driver

Build 127x station driver

cd $YOUR_PATH/L27.12.1-P2/wlan/wl1283/platforms/os/linux

export KERNEL_DIR=$YOUR_PATH/L27.12.1-P2/kernel/android-2.6.35

make clean

make TNETW=1273

Build 127x softAp driver

cd $YOUR_PATH/L27.12.1-P2/wlan/wl1283_softAP/platforms/os/linux

make TNETW=1273

Building Android Filesystem (AFS) with TI Codecs enabled

on step below use the number of cores you have available; i.e. -j4 or -j12:
cd $MYDROID

cp -Rfp device/ti/pandaboard/buildspec.mk.default buildspec.mk

make clean #(required for rebuild only)

make TARGET_PRODUCT=pandaboard -j4 2>&1 |tee $MYDROID/logs/android_make.out

Preparing Android binaries SD Setup

This step will prepare a directory, called myfs, containing all necessary Android files that you must include within your SD card.

Create Android Rootfs Directory

cd $YOUR_PATH/L27.12.1-P2/

mkdir myfs

cd myfs

cp -Rfp $YOUR_PATH/L27.12.1-P2/kernel/android-2.6.35/drivers/staging/ti-st/*.ko $MYDROID/out/target/product/pandaboard/root

cp -Rfp $YOUR_PATH/L27.12.1-P2/kernel/android-2.6.35/drivers/bluetooth/btwilink.ko $MYDROID/out/target/product/pandaboard/root

cp -Rfp $YOUR_PATH/L27.12.1-P2/wlan/wl1283/platforms/os/linux/tiwlan_drv.ko $MYDROID/out/target/product/pandaboard/system/etc/wifi/

cp -Rfp $YOUR_PATH/L27.12.1-P2/wlan/wl1283_softAP/platforms/os/linux/tiap_drv.ko $MYDROID/out/target/product/pandaboard/system/etc/wifi/softap/

cp -ax $MYDROID/device/ti/proprietary-open/graphics/omap4/* $MYDROID/out/target/product/pandaboard/

cp -Rfp $MYDROID/out/target/product/pandaboard/root/* .

cp -Rfp $MYDROID/out/target/product/pandaboard/system .

cp -Rfp $MYDROID/out/target/product/pandaboard/data .

Adding BT/WLAN support

Download: GingerBread_L27.12.1-P2_Connectivity_127x-Install to your $YOUR_PATH/L27.12.1-P2/wlan_firmware
  • create diretory within rootfs for firmware

cd $YOUR_PATH/L27.12.1-P2/myfs

mkdir -p system/etc/firmware

  • copy *.ko to rootfs

cd $YOUR_PATH/L27.12.1-P2/myfs

cp -rfp $YOUR_PATH/L27.12.1-P2/wlan/wl1283/platforms/os/linux/*.ko system/etc/wifi/

cp -rfp $YOUR_PATH/L27.12.1-P2/wlan/wl1283_softAP/platforms/os/linux/*.ko system/etc/wifi/softap

  • adding firmware to rootfs

cd $YOUR_PATH/L27.12.1-P2/myfs

cp -rfp $YOUR_PATH/L27.12.1-P2/wlan_firmware/BT_Firmware/* system/etc/firmware/

cp -rfp $YOUR_PATH/L27.12.1-P2/wlan_firmware/WLAN_config/Station_config/tiwlan.ini system/etc/wifi

cp -rfp $YOUR_PATH/L27.12.1-P2/wlan_firmware/WLAN_config/AP_Config/tiwlan_ap.ini system/etc/wifi/softap

cp -rfp $YOUR_PATH/L27.12.1-P2/wlan_firmware/WLAN_Firmware/Station_FW/firmware.bin system/etc/wifi

cp -rfp $YOUR_PATH/L27.12.1-P2/wlan_firmware/WLAN_Firmware/AP_FW/firmware_ap.bin system/etc/wifi/softap

Edit init.omap4430.rc for PandaBoard

cd $YOUR_PATH/L27.12.1-P2/myfs/

vim init.omap4430.rc



on fs

-mount ext4 /dev/block/platform/mmci-omap-hs.0/by-name/system /system wait ro

-mount ext4 /dev/block/platform/mmci-omap-hs.0/by-name/userdata /data wait noatime nosuid nodev

-mount ext4 /dev/block/platform/mmci-omap-hs.0/by-name/cache /cache wait noatime nosuid nodev

on fs

+#mount ext4 /dev/block/platform/mmci-omap-hs.0/by-name/system /system wait ro

+#mount ext4 /dev/block/platform/mmci-omap-hs.0/by-name/userdata /data wait noatime nosuid nodev

+#mount ext4 /dev/block/platform/mmci-omap-hs.0/by-name/cache /cache wait noatime nosuid nodev



#Load IVA firmware

-service baseimage /system/bin/syslink_daemon.out -f /data/base_image_sys_m3.xem3 /data/base_image_app_m3.xem3

- critical

- user media

- group media

#Load IVA firmware

+#service baseimage /system/bin/syslink_daemon.out -f /data/base_image_sys_m3.xem3 /data/base_image_app_m3.xem3

+# critical

+# user media

+# group media

Edit init.rc for PandaBoard

cd $YOUR_PATH/L27.12.1-P2/myfs

vim init.rc

# once everything is setup, no need to modify /

- mount rootfs rootfs / rw remount

+#mount rootfs rootfs / rw remount

Replace Launcher apk

Take this from L27.12.1-P2 binary release.
cd $YOUR_PATH/L27.12.1-P2/myfs

cp -Rfp Patches/android/Launcher2.apk system/app

Booting Kernel and Android from SD

You will need to format your SD for the Linux file system. Connect your SD memory card reader with memory card inserted to a USB port on your Linux Ubuntu PC. You must login as Super User.
$ su

$ fdisk -l

Match the device to the size of your memory card. Look for the /dev/*** device which matches the memory card in the card reader. Use the matching device’s letter prefix in the next command. For example if the device for memory card reader card example was: /dev/sdb1, then use only /dev/sdb in the fdisk command.
Take note of the size in bytes of your SD Card. You will need this to calculate the number of cylinders in a future step.
$ fdisk /dev/sdb  (replace sdb with the letter prefix for your device)



(Delete all partitions on the card if they exist)

Command (m for help): d

Partition number (1-4): 1

Command (m for help): d

Selected partition 2



Command (m for help): x



(Change the number of heads, sectors and cylinders on the device)

Expert command (m for help): h

Number of heads (1-256, default 255): 255

Expert command (m for help): s

Number of sectors (1-63, default 63): 63

Expert command (m for help): c

Number of cylinders (1-1048576, default 248): <You must calculate the number of cylinders for your SD card. To do this, use the following formula:



new_cylinders = (Size in bytes from your fdisk –l command)/8225280

Drop any fractional values and enter the whole number in this command.

Use this number all the steps that refer to the number of cylinders>



(Now return to the main menu)

Expert command (m for help): r



(Create the first partition)

Command (m for help): n

Command action

e extended

p primary partition (1-4)

p

Partition number (1-4): 1

First cylinder (1-248, default 1): 1

Last cylinder or +size or +sizeM or +sizeK (1-248, default 248): +64M



If you plan to use this SD card partition for storing media your can use +1024M assuming a 2+ GB SD card.



(Create the second partition)

Command (m for help): n

Command action

e extended

p primary partition (1-4)

p

Partition number (1-4): 2

First cylinder (10-248, default 10): 10

Last cylinder or +size or +sizeM or +sizeK (124-248, default 248): <use the cylinder value you calculated earlier>



(Change the first partition to at FAT32 partition)

Command (m for help): t

Partition number (1-4): 1

Hex code (type L to list codes): c

Changed system type of partition 1 to c (W95 FAT32 (LBA))



(Toggle the bootable flag for partition 1)

Command (m for help): a

Partition number (1-4): 1



(Print the partition table to confirm your settings)

Command (m for help): p



(Sample Output – your output may differ depending on your SD card’s size and brand)

Disk /dev/sdb: 2041 MB, 2041577472 bytes

255 heads, 63 sectors/track, 248 cylinders

Units = cylinders of 16065 * 512 = 8225280 bytes

Disk identifier: 0x00000000



Device Boot Start End Blocks Id System

/dev/sdb1 * 1 9 72261 c W95 FAT32 (LBA)

/dev/sdb2 10 248 1919767+ 83 Linux



(Write your changes to the SD Card)

Command (m for help): w



(You will see the following output)

The partition table has been altered!



Calling ioctl() to re-read partition table.





WARNING: If you have created or modified any DOS 6.x partitions, please see the fdisk manual page for additional information.

Syncing disks.



Format your partitions typing the following commands (logged as root@ubuntu-box):

$ mkfs.vfat -F 32 -n boot /dev/<your device’s first partition’s name – see the print output from the previous step>

$ mkfs.ext3 -L android_fs /dev/<your device’s second partition’s name – see the print output from the previous step>



There is a shell script that all calculations above automatically; to get it do:

$ wget http://cgit.openembedded.org/cgit.cgi/openembedded/plain/contrib/angstrom/omap3-mkcard.sh



Add execution permission:

$ chmod +x omap3-mkcard.sh



And you are ready to use it by just typing:

$sudo ./omap3-mkcard.sh <your_device (e.g. /dev/sdb)>

Copying Binaries onto SD Card

Now type the following to mount your SD Card on your Linux box:
mkdir /tmp/mmc1

mkdir /tmp/mmc2

sudo mount /dev/<your device’s first partition’s name> /tmp/mmc1

sudo mount /dev/<your device’s second partition’s name> /tmp/mmc2

Load the appropriate software to the SD Card:
sudo cp $YOUR_PATH/L27.12.1-P2/x-loader/MLO /tmp/mmc1   #(if you are using EMU or HS device, plese copy signed MLO instead)

sudo cp $YOUR_PATH/L27.12.1-P2/u-boot/u-boot.bin /tmp/mmc1

sudo cp $YOUR_PATH/L27.12.1-P2/kernel/android-2.6.35/arch/arm/boot/uImage /tmp/mmc1

sudo cp -Rfp $YOUR_PATH/L27.12.1-P2/myfs/* /tmp/mmc2

sudo chmod -R 777 /tmp/mmc2/*

sync

sudo umount /tmp/mmc1

sudo umount /tmp/mmc2

SD Booting

Insert your SD card (with u-boot, x-loader and uImage loaded in FAT partition and ) into PandaBoard SD/MMC card slot, then plug the PandaBoard mini USB port to your PC and open a serial terminal (baudrate:115200, no parity, 8 bits). Power your board up and in your terminal window you should be able to see the ‘New’ u-boot prompt:
“PANDA #”

In your serial terminal define the bootargs and boot as mentioned in the bootarg section.</br>
Right after this your PandaBoard should start booting using the kernel image and loading the Android filesystem from your SD

Bootargs

Note that parameter mem=456M@0x80000000 mem=512M@0xA0000000 should be used in the bootargs
L27.12.1-P2 Bootargs for SD card boot

setenv bootargs 'console=ttyO2,115200n8 androidboot.console=ttyO2 mem=456M@0x80000000 mem=512M@0xA0000000 root=/dev/mmcblk0p2 rw rootdelay=2 init=/init vram="32M" omapfb.vram=0:16M omapdss.def_disp=hdmi consoleblank=0' 

setenv bootcmd 'mmcinit 0;fatload mmc 0 0x80000000 uImage; bootm 0x80000000'

boot

NOTE: some people have reported problems with copy-n-paste with the single line bootargs listed above. use this set of bootargs for paste functions:
setenv console console=ttyO2,115200n8 androidboot.console=ttyO2

setenv memory mem=456M@0x80000000 mem=512M@0xA0000000

setenv rootfs root=/dev/mmcblk0p2 rw rootdelay=2 init=/init

setenv vmem vram="32M" omapfb.vram=0:16M

setenv display omapdss.def_disp=hdmi consoleblank=0

setenv bootargs ${console} ${memory} ${rootfs} ${vmem} ${display}

printenv bootargs

setenv bootcmd 'mmcinit 0;fatload mmc 0 0x80000000 uImage; bootm 0x80000000'

boot

Preparing Android using Fastboot Bootup

Booting into fastboot

Hold down the the input button (button located furthest away from SD card) during bootup. This will bring pandaboard up into fastboot. Below is what you should see:
Texas Instruments X-Loader 1.41 (May 17 2011 - 10:31:50)

Starting OS Bootloader from MMC/SD1 ...



U-Boot 1.1.4-L27.13.1^0-dirty (May 17 2011 - 10:31:23)



Load address: 0x80e80000

DRAM: 1024 MB

Flash: 0 kB

Using default environment



In: serial

Out: serial

Err: serial



efi partition table:

256 128K xloader

512 256K bootloader

2048 8M recovery

18432 8M boot

34816 512M system

1083392 256M cache

1607680 512M userdata

2656256 589M media

Net: KS8851SNL

Panda: GPIO_121 pressed: entering fastboot....

Device Serial Number: 1D62000300000001

Fastboot entered...

Creating SD GPT Partitions

on Host

cd $MYDROID/out/target/product/pandaboard/

sudo ./../../../host/linux-x86/bin/fastboot oem format

new partition table:

256 128K xloader

512 256K bootloader

2048 8M recovery

18432 8M boot

34816 512M system

1083392 256M cache

1607680 512M userdata

2656256 589M media

Flashing bootloader, xloader and boot image.

This step is only done once. This simply creates the GPT table required for booting. If you have a new SD card you should preform this step. If you have already preform this step you can easily just flash binaries to the SD card.
cd $MYDROID/out/target/product/pandaboard/

sudo ./../../../host/linux-x86/bin/fastboot flash bootloader boot/u-boot.bin

sudo ./../../../host/linux-x86/bin/fastboot flash xloader boot/MLO

sudo ./../../../host/linux-x86/bin/fastboot flash boot boot.img

Power down and restart --hold down button during boot and re-enter fastboot

Flashing complete environment

This step will flash the entire android system to the SD card.
cd $MYDROID/out/target/product/pandaboard/

sudo ./fastboot.sh

Thứ Năm, 18 tháng 8, 2011 06:58 Đọc tiếp >>

PandaBoard Cortex-A9

Chủ Nhật, 7 tháng 8, 2011 / 04:31


Like the related open-platform BeagleBoard.org and newer HawkBoard.org projects, PandaBoard.org developed and supports a board incorporating a Texas Instruments SoC that targets hobbyists, as well as professional developers wanting to prototype new embedded designs. (The HawkBoard is built around the ARM9-based OMAP-L138.)



PandaBoard

(Click to enlarge)

Like the BeagleBoard, which recently moved up from its OMAP3530 foundation to a 720p-ready DM3730 SoC in its BeagleBoard-xM version, the PandaBoard is distributed by Digi-Key. Whereas both BeagleBoard versions are based on ARM Cortex-A8 SoCs and targeted at the general embedded device market, the 4.0 x 4.5-inch PandaBoard moves up to the Cortex-A9-based 1GHz OMAP4430 SoC and is more specifically aimed at smartphones and other mobile devices. The board can record and play back video with 1080p quality at 30 frames per second, says PandaBoard.org .
Texas Instruments began sampling the OMAP4430 and OMAP4440 in February. At the same time TI introduced a Linux- and Android-compatible "Blaze" hardware/software development platform in smartphone format. The Blaze (pictured) sports a pico projector, dual 3.7-inch displays, three cameras, an HDMI output, a compass, plus a barometer and other sensors.
The OMAP4 family was announced at the Mobile World Congress (MWC) in Feb. 2008, as we reported at the time. These 45nm SoCs (system on chips) are built around ARM's Cortex-A9 processor, which implements the same ARMv7 used on the Cortex-A8 and adds a MPCore interconnect layer for multiple processor support. While as many as four cores are possible (see block diagram, here), the OMAP4 chips use two, as depicted below.

OMAP44x function block diagram
(Click to enlarge)

Touted OMAP44x features include the following:
  • 10+ hours of 1080p HD video playback
  • 4+ hours of 1080p HD record
  • 140+ hours of CD quality audio playback
  • POWERVR SGX540 graphics engine
  • 3D UI support
  • Resolutions up to WSXGA (1680x1050)
  • HDMI compatible
  • 12 x 12 x 0.4mm POP (package-on-package)
  • Supports Pico projection technology


PandaBoard detail

(Click to enlarge)

As noted in the detail photo above and the block diagram below, the PandaBoard is equipped with 1GB of LPDDR2 DRAM and an SD/MMC memory card slot. An LCD expansion slot is provided, as well as HDMI 1.3 and DVI ports, supporting simultaneous dual displays. Like TI's Blaze reference platform, the PandaBoard is equipped with TI's multipurpose wireless chip, the WiLink 7.0. The WiLink provides the board with 802.11b/g/n Wi-Fi, as well as Bluetooth 2.1 + EDR, FM radio, and a GPS receiver.


PandaBoard block diagram

(Click to enlarge)

The PandaBoard also has a 10/100 Ethernet port,  dual USB 2.0 Host ports, and a USB 2.0 OTG port, says the project. An RS-232 port, camera connector, JTAG port, and stereo audio I/O are also said to be available, along with a "generic expansion connector" that supports interfaces like SD/MMC, USB, GPMC, DSS, ETM, McSPI, I2C, and UARTs. The PandaBoard measures 4.5 x 4.0 inches (114.3 x 101.6mm), up from 3.25 × 3.25 inches for the BeagleBoard-xM. Equipped with a five Volt power supply, the board features power and reset buttons as well as status LEDs, says the project.
Software
The PandaBoard is currently optimized to run several open source Linux operating systems. These include Ubuntu 10.10 and beyond, as well as a minimal Angstrom Linux distribution. There is also an Android port called Pandroid.
In addition, the platform is said to be generally compatible with Linux distributions such as MeeGo and Chrome OS.
Projects listed at the PandaBoard.org community site include RISC OS on OMAP4, XBMC, Wireless sniffer, Gentoo Linux, MeeGo, GeeXboX, OpenBricks, Pandroid, and Ubuntu on PandaBoard.
Testimonials
Stated Jon Melamut, VP of sales and product management, OEM services for Canonical -- in the first example we can recall of Canonical saying Ubuntu will be heading for tablets -- "We expect PandaBoard to be adopted across the industry as the platform of choice for developers and also to increase the impact in accelerating the usage of Ubuntu in key target markets like netbooks, tablets and new in-home products."
Stated Ben Cade, executive officer, Linaro, "PandaBoard combines the performance of a PC in the power footprint of mobile at an affordable cost; it is a very exciting option for software developers. Linaro is investing in open source tools and software to ensure that the advanced features of the dual core Cortex-A9 used on the PandaBoard can be easily used by software developers and distributions around the world."
Stated Jim Zemlin, executive director, the Linux Foundation, "We're pleased to see more and more Linux-based projects and products spring up in the embedded space. PandaBoard looks to be a great addition to the Linux developer community and will give developers access to TI's OMAP platform in a low cost way."



PandaBoard introduction video

Source: PandaBoard.org
(Click to play)

Availability The PandaBoard is available now for $174 from Digi-Key, here. More information on the PandaBoard may be found here, and more on the PandaBoard community and related software should be here.
Chủ Nhật, 7 tháng 8, 2011 04:31 Đọc tiếp >>

PandaBoard

PandaBoard Platform Specifications

PandaBoard: First open OMAP™ 4 mobile software development platform includes the following:
OMAP4430 Processor (Highlights)
  • Dual-core ARM® Cortex™-A9 MPCore™ with Symmetric Multiprocessing (SMP) at 1 GHz each. Allows for 150% performance increase over previous ARM Cortex-A8 cores.
  • Full HD (1080p) multi-standard video encode/decode
  • Imagination Technologies’ POWERVR™ SGX540 graphics core supporting all major API's including OpenGL® ES v2.0, OpenGL ES v1.1, OpenVG v1.1 and EGL v1.3 and delivering 2x sustained performance compared to the previous SGX530 core
  • Low power audio

Technical Specs

Core Logic

  • OMAP4430 applications processor

Display

  • HDMI v1.3 Connector (Type A) to drive HD displays
  • DVI-D Connector (can drive a 2nd display, simultaneous display; requires HDMI to DVI-D adapter)
  • LCD expansion header

Memory

  • 1 GB low power DDR2 RAM
  • Full size SD/MMC card cage with support for High-Speed & High-Capacity SD cards

Audio

  • 3.5"  Audio in/out
  • HDMI Audio out

Connectivity

  • Onboard 10/100 Ethernet

Wireless Connectivity

  • 802.11 b/g/n (based on WiLink™ 6.0)
  • Bluetooth® v2.1 + EDR (based on WiLink™ 6.0)

Expansion

  • 1x USB 2.0 High-Speed On-the-go port
  • 2x USB 2.0 High-Speed host ports
  • General purpose expansion header (I2C, GPMC, USB, MMC, DSS, ETM)
  • Camera expansion header

Debug

  • JTAG
  • UART/RS-232
  • 2 status LEDs (configurable)
  • 1 GPIO Button

Dimensions

  • Height: 4.5" (114.3 mm)
  • Width:  4.0" (101.6 mm)
  • Weight: 2.6 oz (74 grams)
 
Chủ Nhật, 7 tháng 8, 2011 04:27 Đọc tiếp >>

I²C

I²C (play /ˈ skwɛərd ˈs/ or /ˈ t ˈs/; Inter-Integrated Circuit; generically referred to as "two-wire interface") is a multi-master serial single-ended computer bus invented by Philips that is used to attach low-speed peripherals to a motherboard, embedded system, or cellphone or other electronics. Since the mid 1990s several competitors (e.g. Siemens AG (later Infineon Technologies AG), NEC, Texas Instruments, STMicroelectronics (formerly SGS-Thomson), Motorola (later Freescale), Intersil, etc.) brought I²C products on the market, which are fully compatible with the NXP (formerly Philips' semiconductor division) I²C-system. As of October 10, 2006, no licensing fees are required to implement the I²C protocol. However, fees are still required to obtain I²C slave addresses allocated by NXP.[1]
SMBus, defined by Intel in 1995, is a subset of I²C that defines the protocols more strictly. One purpose of SMBus is to promote robustness and interoperability. Accordingly, modern I²C systems incorporate policies and rules from SMBus, sometimes supporting both I²C and SMBus with minimal re-configuration required.

Design

A sample schematic with one master (a microcontroller), three slave nodes (an ADC, a DAC, and a microcontroller), and pull-up resistors Rp
I²C uses only two bidirectional open-drain lines, Serial Data Line (SDA) and Serial Clock (SCL), pulled up with resistors. Typical voltages used are +5 V or +3.3 V although systems with other voltages are permitted.
The I²C reference design has a 7-bit address space with 16 reserved addresses, so a maximum of 112 nodes can communicate on the same bus. Common I²C bus speeds are the 100 kbit/s standard mode and the 10 kbit/s low-speed mode, but arbitrarily low clock frequencies are also allowed. Recent revisions of I²C can host more nodes and run at faster speeds (400 kbit/s Fast mode, 1 Mbit/s Fast mode plus or Fm+, and 3.4 Mbit/s High Speed mode). These speeds are more widely used on embedded systems than on PCs. There are also other features, such as 16-bit addressing.
Note that the bit rates quoted are for the transactions between master and slave without clock stretching or other hardware overhead. Protocol overheads include a slave address and perhaps a register address within the slave device as well as per-byte ACK/NACK bits. So the actual transfer rate of user data is lower than those peak bit rates alone would imply. For example, if each interaction with a slave inefficiently allows only 1 byte of data to be transferred, the data rate will be less than half the peak bit rate.
The maximum number of nodes is limited by the address space, and also by the total bus capacitance of 400 pF, which restricts practical communication distances to a few meters.

[edit] Reference design

The reference design, as mentioned above, is a bus with a clock (SCL) and data (SDA) lines with 7-bit addressing. The bus has two roles for nodes: master and slave:
  • Master node — node that issues the clock and addresses slaves
  • Slave node — node that receives the clock line and address.
The bus is a multi-master bus which means any number of master nodes can be present. Additionally, master and slave roles may be changed between messages (after a STOP is sent).
There are four potential modes of operation for a given bus device, although most devices only use a single role and its two modes:
  • master transmit — master node is sending data to a slave
  • master receive — master node is receiving data from a slave
  • slave transmit — slave node is sending data to the master
  • slave receive — slave node is receiving data from the master
The master is initially in master transmit mode by sending a start bit followed by the 7-bit address of the slave it wishes to communicate with, which is finally followed by a single bit representing whether it wishes to write(0) to or read(1) from the slave.
If the slave exists on the bus then it will respond with an ACK bit (active low for acknowledged) for that address. The master then continues in either transmit or receive mode (according to the read/write bit it sent), and the slave continues in its complementary mode (receive or transmit, respectively).
The address and the data bytes are sent most significant bit first. The start bit is indicated by a high-to-low transition of SDA with SCL high; the stop bit is indicated by a low-to-high transition of SDA with SCL high.
If the master wishes to write to the slave then it repeatedly sends a byte with the slave sending an ACK bit. (In this situation, the master is in master transmit mode and the slave is in slave receive mode.)
If the master wishes to read from the slave then it repeatedly receives a byte from the slave, the master sending an ACK bit after every byte but the last one. (In this situation, the master is in master receive mode and the slave is in slave transmit mode.)
The master then ends transmission with a stop bit, or it may send another START bit if it wishes to retain control of the bus for another transfer (a "combined message").

[edit] Message protocols

I²C defines three basic types of messages, each of which begins with a START and ends with a STOP:
  • Single message where a master writes data to a slave;
  • Single message where a master reads data from a slave;
  • Combined messages, where a master issues at least two reads and/or writes to one or more slaves.
In a combined message, each read or write begins with a START and the slave address. After the first START, these are also called repeated START bits; repeated START bits are not preceded by STOP bits, which is how slaves know the next transfer is part of the same message.
Any given slave will only respond to particular messages, as defined by its product documentation.
Pure I²C systems support arbitrary message structures. SMBus is restricted to nine of those structures, such as read word N and write word N, involving a single slave. PMBus extends SMBus with a Group protocol, allowing multiple such SMBus transactions to be sent in one combined message. The terminating STOP indicates when those grouped actions should take effect. For example, one PMBus operation might reconfigure three power supplies (using three different I2C slave addresses), and their new configurations would take effect at the same time: when they receive that STOP.
With only a few exceptions, neither I²C nor SMBus define message semantics, such as the meaning of data bytes in messages. Message semantics are otherwise product-specific. Those exceptions include messages addressed to the I²C general call address (0x00) or to the SMBus Alert Response Address; and messages involved in the SMBus Address Resolution Protocol (ARP) for dynamic address allocation and management.
In practice, most slaves adopt request/response control models, where one or more bytes following a write command are treated as a command or address. Those bytes determine how subsequent written bytes are treated and/or how the slave responds on subsequent reads. Most SMBus operations involve single byte commands.

[edit] Messaging example: 24c32 EEPROM

One specific example is the 24c32 type EEPROM, which uses two request bytes that are called Address High and Address Low. (Accordingly, these EEPROMs aren't usable by pure SMBus hosts, which only support single byte commands or addresses.) These bytes are used to address bytes within the 32 kbit (4 kB) supported by that EEPROM; the same two byte addressing is also used by larger EEPROMs, such as 24c512 ones storing 512 kbits (64 kB). Writing and reading data to these EEPROMs uses a simple protocol: the address is written, and then data is transferred until the end of the message. (That data transfer part of the protocol also makes trouble for SMBus, since the data bytes are not preceded by a count and more than 32 bytes can be transferred at once. I2C EEPROMs smaller than 32 kbits, such as 2 kbit 24c02 ones, are often used on SMBus with inefficient single byte data transfers.)
To write to the EEPROM, a single message is used. After the START, the master sends the chip's bus address with the direction bit clear (write), then sends the two byte address of data within the EEPROM and then sends data bytes to be written starting at that address, followed by a STOP. When writing multiple bytes, all the bytes must be in the same 32 byte page. While it's busy saving those bytes to memory, the EEPROM won't respond to further I2C requests. (That's another incompatibility with SMBus: SMBus devices must always respond to their bus addresses.)
To read starting at a particular address in the EEPROM, a combined message is used. After a START, the master first writes that chip's bus address with the direction bit clear (write) and then the two bytes of EEPROM data address. It then sends a (repeated) START and the EEPROM's bus address with the direction bit set (read). The EEPROM will then respond with the data bytes beginning at the specified EEPROM data address—a combined message, first a write then a read. The master issues a STOP after the first data byte it NACKs rather than ACKs (when it's read all it wants). The EEPROM increments the address after each data byte transferred; multi-byte reads can retrieve the entire contents of the EEPROM using one combined message.

[edit] Physical layer

At the physical layer, both SCL & SDA lines are of open-drain design, thus, pull-up resistors are needed. Pulling the line to ground is considered a logical zero while letting the line float is a logical one. This is used as a channel access method. High speed systems (and some others) also add a current source pull up, at least on SCL; this supports faster rise times and higher bus capacitance.
Transitions for data bits are always performed while the clock is low; transitions while it is high are "start" and "stop" markers delimiting a bus transaction.
When idle, both lines are high. To start a transaction, SDA is pulled low while SCL remains high. Releasing SDA to float high again would be a stop marker, which would be pointless immediately after a start, so the next step is to pull SCL low.
When one node is transmitting a logical one (i.e., letting the line float to Vdd) and another transmits a logical zero then the first node can sense this because the line is not in a logical one state — it is not pulled up to Vdd. When used on SCL, this is called "clock stretching" and gives slaves a flow control mechanism. When used on SDA, this is called arbitration and ensures there is only one transmitter at a time.
While SCL is low, the transmitter (initially the master) sets SDA to the desired value and (after a small delay to let the value propagate) lets SCL float high. The master then waits for SCL to actually go high; this will be delayed by the finite rise-time of the SCL signal (the RC time constant of the pull-up resistor and the parasitic capacitance of the bus). and may be additionally delayed by a slave's clock stretching.
When SCL is high, the receiver latches the bit, and the master waits a minimum time (4 μs for standard speed I²C), then pulls it low again. This completes transmission of one bit.
After every 8 data bits in one direction, an "acknowledge" bit is transmitted in the other. The transmitter and receiver switch roles for one bit and the erstwhile receiver transmits a single 0 bit (ACK) back. If the transmitter sees a 1 bit (NACK) instead, it learns that:
  • If the master is transmitting, the slave is unable to accept the data. No such slave, command not understood, or unable to accept any more data.
  • If the slave is transmitting, the master wishes it to stop after this data byte.
After the acknowledge bit, the master may do one of three things:
  1. Prepare to transmit another byte of data: set SDA to the desired bit value and pulse SCL high..
  2. Send a "Stop": Set SDA low, let SCL go high, then let SDA go high. This releases the I²C bus.
  3. Send a "Repeated start": Set SDA high, let SCL go high, and pull SDA low again. This starts a new I²C bus transaction without releasing the bus.

[edit] Clock stretching using SCL

One of the more significant features of the I²C protocol is clock stretching. An addressed slave device may hold the clock line (SCL) low after receiving (or sending) a byte, indicating that it is not yet ready to process more data. The master that is communicating with the slave will attempt to raise the clock to transfer the next bit, but must verify that the clock line was actually raised. If the slave is clock stretching, the clock line will still be low (because the connections are open-drain). The same is true if a second, slower, master tries to drive the clock at the same time. (If there is more than one master, all but one of them will normally lose arbitration.)
Although the master may also hold the SCL line low for as long as it desires, the term "clock stretching" is normally used only when slaves do it. If the slave is a microcontroller, its I²C interface will stretch the clock after every byte, until the software decides what to transmit next.
Some masters, such as those found inside custom ASICs may not support clock stretching; often these devices will be labeled as a "two-wire interface" and not I²C.
To ensure a minimum bus throughput, SMBus places limits on how far clocks may be stretched. Hosts and slaves adhering to those limits can't block access to the bus for more than a short time, which is not a guarantee made by pure I²C systems.

[edit] Arbitration using SDA

Every master monitors the bus for start and stop bits, and does not start a message while another master is keeping the bus busy. However, two masters may start transmission at about the same time; in this case, arbitration occurs. Slave transmit mode can also be arbitrated, when a master addresses multiple slaves, but this is less common. In contrast to protocols (such as Ethernet) that use random back-off delays before issuing a retry, I²C has a deterministic arbitration policy. Each transmitter checks the level of the data line (SDA) and compares them with the levels it expects; if they don't match, that transmitter has lost arbitration, and drops out of this protocol interaction.
For example, if one transmitter sets SDA to 1 (not driving a signal) and a second transmitter sets it to 0 (pull to ground), the result is that the line is low. The first transmitter then observes that the level of the line is different than expected, and concludes that another node is transmitting. The first node to notice such a difference is the one that loses arbitration: it stops driving SDA. If it's a master, it also stops driving SCL and waits for a STOP; then it may try to reissue its entire message. In the meantime, the other node has not noticed any difference between the expected and actual levels on SDA, and therefore continues transmission. It can do so without problems because so far the signal has been exactly as it expected; no other transmitter has disturbed its message.
If the two masters are sending a message to two different slaves, the one sending the lower slave address always "wins" arbitration in the address stage. Since the two masters may send messages to the same slave address—and addresses sometimes refer to multiple slaves—arbitration must continue into the data stages.
Arbitration occurs very rarely, but is necessary for proper multi-master support. As with clock-stretching, not all devices support arbitration. Those that do generally label themselves as supporting "multi-master" communication.
In the extremely rare case that two masters simulaneously send the identical messages. then both will regard the communication as successful, but the slave will only see one message. Slaves that can be accessed by multiple masters must have commands that are idempotent for this reason.
SMBus uses arbitration in two additional contexts, both of which are used to pass information asynchronously from slaves to the (single) host. The first context is that hosts must support the "host notify protocol". That is a restricted multi-master mode in which slaves write messages to the reserved "SMBus Host" address (0x08), passing their address and two bytes of data. When two slaves try to notify the host at the same time, one of them will lose arbitration and need to retry. The other context is that pure slave devices which issue the SMBALERT# interrupt need to arbitrate when they reply to requests issued to the reserved "SMBus Alert Response Address" (0x0c), which is a kind of broadcast address. When they successfully reply with their own address, winning an arbitration in "slave transmit" mode, they stop raising that interrupt. In both cases, arbitration applies when the slave address is transmitted.

[edit] Timing diagram

Data transfer sequence
Data transfer is initiated with the START bit (S) when SDA is pulled low while SCL stays high. Then, SDA sets the transferred bit while SCL is low (blue) and the data is sampled (received) when SCL rises (green). When the transfer is complete, a STOP bit (P) is sent by releasing the data line to allow it to be pulled up while SCL is constantly high.

[edit] Example of bit-banging the I2C Master protocol

Below is an example of Bit-banging the I2C protocol as an I2C master. The example is written in pseudo C. It illustrates all of the i2c features described before (Clock stretching, Arbitration, start/stop bit, ack/nack)
/* Hardware-Specific Support Functions That MUST Be Customized */
#define I2CSPEED 100
void I2CDELAY() {volatile int v; int i; for(i=0;i<I2CSPEED/2;i++) v;}
bool READSCL(void) {return 1;} /* Set SCL as input and return current level of line, 0 or 1 */
bool READSDA(void) {return 1;} /* Set SDA as input and return current level of line, 0 or 1 */
void CLRSCL(void) {} /* Actively drive SCL signal low */
void CLRSDA(void) {} /* Actively drive SDA signal low */
void ARBITRATION_LOST(void) {}

/* Global Data */
bool started = false;

void i2c_start_cond(void)
{
/* if started, do a restart cond */
if (started) {
/* set SDA to 1 */
READSDA();
I2CDELAY();
/* Clock stretching */
while (READSCL() == 0)
; /* You should add timeout to this loop */
}
if (READSDA() == 0)
ARBITRATION_LOST();
/* SCL is high, set SDA from 1 to 0 */
CLRSDA();
I2CDELAY();
CLRSCL();
started = true;
}

void i2c_stop_cond(void)
{
/* set SDA to 0 */
CLRSDA();
I2CDELAY();
/* Clock stretching */
while (READSCL() == 0)
; /* You should add timeout to this loop */
/* SCL is high, set SDA from 0 to 1 */
if (READSDA() == 0)
ARBITRATION_LOST();
I2CDELAY();
started = false;
}

/* Write a bit to I2C bus */
void i2c_write_bit(bool bit)
{
if (bit)
READSDA();
else
CLRSDA();
I2CDELAY();
/* Clock stretching */
while (READSCL() == 0)
; /* You should add timeout to this loop */
/* SCL is high, now data is valid */
/* If SDA is high, check that nobody else is driving SDA */
if (bit && READSDA() == 0)
ARBITRATION_LOST();
I2CDELAY();
CLRSCL();
}

/* Read a bit from I2C bus */
bool i2c_read_bit(void)
{
bool bit;
/* Let the slave drive data */
READSDA();
I2CDELAY();
/* Clock stretching */
while (READSCL() == 0)
; /* You should add timeout to this loop */
/* SCL is high, now data is valid */
bit = READSDA();
I2CDELAY();
CLRSCL();
return bit;
}

/* Write a byte to I2C bus. Return 0 if ack by the slave */
bool i2c_write_byte(bool send_start, bool send_stop, unsigned char byte)
{
unsigned bit;
bool nack;
if (send_start)
i2c_start_cond();
for (bit = 0; bit < 8; bit++) {
i2c_write_bit((byte & 0x80) != 0);
byte <<= 1;
}
nack = i2c_read_bit();
if (send_stop)
i2c_stop_cond();
return nack;
}

/* Read a byte from I2C bus */
unsigned char i2c_read_byte(bool nack, bool send_stop)
{
unsigned char byte = 0;
unsigned bit;
for (bit = 0; bit < 8; bit++)
byte = (byte << 1) | i2c_read_bit();
i2c_write_bit(nack);
if (send_stop)
i2c_stop_cond();
return byte;
}

Chủ Nhật, 7 tháng 8, 2011 04:20 Đọc tiếp >>

New Tools For Using the DSP on Hawkboard

Last week, TI released two new software development tools that they hope will encourage more developers (especially ARM developers) to make use of the DSP on their ARM+DSP platforms (which includes the OMAP-L138 at the heart of the Hawkboard).
The first tool, called C6Run, aims to provide an automated way to compile and run code on the DSP core, without having to learn any new tools or APIs.  When programs built using these tools are run, from the target Linux system, the DSP is enabled, loaded and communicated with by the ARM.  Individual portions of applications, or entire applications can be executed on the DSP. Documentation for the tool is available on TI’s embedded processor wiki. This tool is also open source and is being developed on TI’s external subversion server.
The second tool, called C6Accel, provides pre-defined APIs to access the collection of TI’s optimized DSP libraries for their C6000 architecture.  As the DSP core in the OMAP-L138 is both a fixed-point and floating-point DSP, the exposed libraries include optimized fixed- and floating- point code.  The exposed libraries include simple math libraries, image processing routines, and optimized signal processing routinesDocumentation for this tool is also available on TI’s embedded processor wiki.
It will be interesting to see if ARM developers actually start making use of these to utilize the DSP.
Chủ Nhật, 7 tháng 8, 2011 04:16 Đọc tiếp >>