Friday, 7 December 2012

Hooking Android ICS Mouse Control on PandaBoard

NOTE:
- NERD LEVEL 10 STUFF.
- THIS POST REQUIRES A ROOTED IMAGE OF ANDROID FOR PANDA BOARD OR                 ANY BOARD YOU ARE WORKING ON.



Oookkkkaayyy Guys so this is going to be my longest post so far and this one remained in the editing mode for like 5-6 months now phewwww . So in this post we will see how can we hook mouse control of an already connected mouse in Android. This expedition will consists of following steps:

1. Identifying event interface of the mouse.
2. Sending fake input-event packets on the device’s event interface. 
3. Assigning permissions on the event interface.


Identifying event interface of the mouse:

Event interface assigned for the connected mouse device can be found by parsing the output of the file at : “/proc/bus/input/devices”. The key is to look for that ‘Handler’ tag with which there is one ‘mouseX’ interface and one “eventX” interface present. Following is the java code snippet (present in the android app layer code) for identifying the event interface of the first connected mouse with the device.


    public static String findMouseEventIfc(final Context parent)
    {
            String splitTag = "H: Handlers=mouse";
            String evIfc = "";
            String temp = readFile("/proc/bus/input/devices", true);
            int pos = temp.indexOf(splitTag);


            if(pos > 0)
            {
                    String parts[] = temp.split(splitTag); // we should atleast 2 substrings. can //be more then 1 in case more then 1 mice are connected to the device.
                    if(parts.length > 1)
                    {
                            temp = parts[1];
                                  int start = temp.indexOf("event");
                               int end = temp.indexOf("\n");
                               evIfc = ((String) temp.subSequence(start, end)).trim();
                                Log.i(“tag”, "Mouse Event Interface located at : " + evIf);
                          }


            }
            else
            {
                Log.i(“tag”, "No Mouse Connected with the device.");
            }
 
            return evIfc.trim();
    }


Sending fake input-event packets on the device’s event interface:

Once we have the name of the event interface for the connected mouse, we can send the fake input-event packets on this event interface (located inside /dev/input/) to control the mouse movement on the device.
Following code snippet written in C (present at the NDK layer of the app) sends the fake input-events to move the mouse pointer to (x,y) coordinate on the screen.
NOTE: You will need a rooted device in order to write these input-event packets on the event interface.


void moveCursor(int mouseIfcHandle, int x, int y)
{
        printf("-- > Injecting Mouse Events (x,y) (%d,%d) \n", x, y);
        struct input_event event_x, event_y, event_end;


        memset(&event_x, 0, sizeof(event_x));
        memset(&event_y, 0, sizeof(event_y));
        memset(&event_end, 0, sizeof(event_end));


        gettimeofday(&event_x.time, NULL);
        event_x.type = EV_REL;
        event_x.code = REL_X;
        event_x.value = x; //First lets reset the x-axis


        gettimeofday(&event_y.time, NULL);
        event_y.type = EV_REL;
        event_y.code = REL_Y;
        event_y.value = y; //First lets reset the y-axis


        gettimeofday(&event_end.time, NULL);
        event_end.type = EV_SYN;
        event_end.code = SYN_REPORT;
        event_end.value = 0;


        int ret1, ret2, ret3;
        ret1 = write(mouseIfcHandle, &event_x, sizeof(event_x)); // Move the mouse on x-axis.
        ret2 = write(mouseIfcHandle, &event_y, sizeof(event_y)); // Move the mouse on y-axis.
        ret3 = write(mouseIfcHandle, &event_end, sizeof(event_end)); // Show move
        fsync (mouseIfcHandle);


        printf("-- > x-Injected Bytes: %d  ||  y-Injected Bytes: %d  || sync-Injected Bytes: %d \n", ret1, ret2, ret3);


}


Assigning permissions on the event interface:

This is probably the toughest part, In android the device nodes created by the input subsystem are read only, i.e. you can not write fake input-events on them unless you grant rights on these nodes. 
Now in order to grant access on these devices we need to run the “chmod 777 /dev/input/*” as root on the device, running this command inside your C/C++ code i.e. using
                                            system(“chmod 777 /dev/input/*”)
or inside your java code i.e. using
                                            Runtime.getRuntime().exec("chmod 777 /dev/input/*")
will yield nothing as these commands will still be running inside the dalvik virtual machine, from inside which we can’t grant permissions on any other subsystem’s nodes. So we will have to either write a startup script or a daemon (i.e. Linux program) which is run by the root at device startup and then that script or the daemon grants rights on the nodes created by input subsystem.
Here comes the most frustrating part, the startup scripts of android i.e. init.rc & init.<specific-hardware>.rc are present inside the kernel+ramdisk image, and this image is extracted at every boot time. So if you access the init.rc or init.omap4pandaboard.rc file through adb shell and add your startup script, it will have no affect as your modified file will be over written the next time you boot the device. So what do we do then. Well that's the most sexy part :) , If the kernel Image is is in our way to execute our script then we will bring the image to our side and transform it Hooooahhahahhaa (Evil laughter).
So, we will modify Kernel+ram disk image (without recompiling the kernel source) in order to start the daemon or write start up scripts. Following are the 2 steps which will be further required to assign permissions on event interfaces:
1. Modify Kernel + Ramdisk image to start up the daemon on bootup.
2. Write daemon to grant permissions on the nodes created by the input subsystem.


Modify Kernel + Ramdisk image:

In order to modify your Android’s kernel + Ram Disk image you will first have to place your SD-Card (containing the Android OS) in the card reader and wait for the different partitions in it to be mounted.
Once all partitions are mounted, look for the partition called 'boot', open it and compress the uInitrd image file, copy it to your machine inside any folder for instance /home/junaid/android_k+rd/, Then unstitch the kernel+RamDisk Image in the android_k+rd/fs/ drectory, These step can be done by using following commands (Assuming the sd-card got mounted on /dev/sdb):
1. dd bs=1 skip=64 if=/mnt/uInitrd of=/home/junaid/android_k+rd/initrd.gz
                  OR
2. gunzip /mnt/uInitrd of=/home/junaid/android_k+rd/initrd.gz

3. cd /home/junaid/android_k+rd/initrd.gz
4. mkdir fs
5. cd fs
6. cpio -id < ../initrd

Now you can open the startup script present inside the fs/ directory and make changes in them. In order to run the daemon at startup, we will place an entry inside the init.omap4pandaboard.rc file i.e. add following lines in it :


service rightsprivileger /system/bin/rightsprivileger
    class main
    user root
    oneshot


Here, I am assuming the daemon binary has the name 'rightsprivileger' and will be placed at /system/bin/  (by using the adb shell). Moreover we will have to replace the following line inside init.rc file :


    mount ext4 /dev/block/mmcblk0p2 /system ro

 with  

    mount ext4 /dev/block/mmcblk0p2 /system rw


Above change will mount the /system/ in Read-Write mode.
(Complete init.rc & init.omap4pandaboard.rc files are mentioned at the bottom of this document for reference)
Now that we have made required changes, we need to re-stitch the Kernel+RamDisk Header and replace the uInitrd image inside the mounted boot/ with this new & updated one. Follow these steps to re-stitch the Kernel+Ramdisk image:

1. cd fs
2. find ./ | cpio -H newc -o > ../newinitrd
3. cd ..
4. gzip newinitrd
5. mkimage -A arm -O linux -C gzip -T ramdisk -n "My Android Ramdisk Image" -d newinitrd.gz uInitrd-new


Now copy the uInitrd-new file in the boot/  drive, remove the old uInitrd and rename uInitrd-new to uInitrd


Write daemon:

Following simple program will be enough to create a daemon which grant rights to the nodes created by input subsystem:


#include <stdio.h>
#include <unistd.h>
#include <sys/time.h>


int main()
{
  char command1[128]={0};
  char command2[128]={0};
  sprintf(command1,"mkdir /dev/MouseCtrl_Up"); // Tag to show that the daemon is up.
  sprintf(command2,"chmod 777 /dev/input/*");

  int retCommand1 = system(command1);
  while(1)
  {
          int retCommand2 = system(command2);
          sleep(60);
  }


  return 0;
}


This program has to be created with the android’s stand alone toolchain present inside the android-ndk package, simple ARM toolchain won’t be enough as Android uses its own application binary interface i.e. androideabi. Once compiled, place it inside /system/bin/ by running

(on a running android device before modifying the Kernel Image)
1. adb push <your-binary-path> /system/bin/
Or
Simply copy the binary in the mounted SD card inside /system/bin/ folder (if you can locate it).


Once daemon has been written and placed inside the /system/bin directory with all its rights set i.e. (chmoded) and the custom Kernel+Ramdisk image placed in the /boot/ drive, Safely remove the sd-card from the card reader, insert it inside the Pandaboard and power it on. When the system boots you will see that the nodes inside /dev/input/ will have all the permissions set. and your android application could now send the events to move the system pointer.




Reference Links



Android Boot Sequence :
http://elinux.org/Android_Booting


Android Init Process :
http://www.androidenea.com/2009/08/init-process-and-initrc.html


Android Init Language :
https://github.com/android/platform_system_core/blob/master/init/readme.txt


Linux X86 mkbootimg program (For re-stitching the kernel+ramdisk image):
http://forum.xda-developers.com/showthread.php?t=562318


Android kernel+ram disk image’s un-stitching and stitching:
http://ask.linaro.org/questions/364/initrc-in-sd-card


Android - Running Native programs:
http://gimite.net/en/index.php?Run%20native%20executable%20in%20Android%20App


Understanding Linux input system:
http://www.kernel.org/doc/Documentation/input/input-programming.txt
http://lxr.free-electrons.com/source/include/linux/input.h?v=3.2#L26
http://docs.blackfin.uclinux.org/kernel/generated/device-drivers/re707.html
http://www.compsoc.man.ac.uk/~moz/kernelnewbies/documents/kdoc/mousedrivers/driver.html


Writing Loadable Kernel Module:
http://www.compsoc.man.ac.uk/~moz/kernelnewbies/documents/kdoc/mousedrivers/driver.html
http://tldp.org/HOWTO/Module-HOWTO/x839.html
http://stackoverflow.com/questions/4849063/cross-compile-lkm-module-for-android-platform




Reference Material



init.rc 



on early-init
    start ueventd


# create mountpoints
    mkdir /mnt 0775 root system
    mkdir /mnt/sdcard 0000 system system


on init


sysclktz 0


loglevel 3


# setup the global environment
    export PATH /sbin:/vendor/bin:/system/sbin:/system/bin:/system/xbin
    export LD_LIBRARY_PATH /vendor/lib:/system/lib
    export ANDROID_BOOTLOGO 1
    export ANDROID_ROOT /system
    export ANDROID_ASSETS /system/app
    export ANDROID_DATA /data
    export EXTERNAL_STORAGE /mnt/sdcard
    export ASEC_MOUNTPOINT /mnt/asec
    export LOOP_MOUNTPOINT /mnt/obb
    export BOOTCLASSPATH /system/framework/core.jar:/system/framework/core-junit.jar:/system/framework/bouncycastle.jar:/system/framework/ext.jar:/system/framework/framework.jar:/system/framework/android.policy.jar:/system/framework/services.jar:/system/framework/apache-xml.jar:/system/framework/filterfw.jar


# Backward compatibility
    symlink /system/etc /etc
    symlink /sys/kernel/debug /d


# Right now vendor lives on the same filesystem as system,
# but someday that may change.
    symlink /system/vendor /vendor


# Create cgroup mount point for cpu accounting
    mkdir /acct
    mount cgroup none /acct cpuacct
    mkdir /acct/uid


# Backwards Compat (no longer there in stock ICS)
    symlink /mnt/sdcard /sdcard


    mkdir /system
    mkdir /data 0771 system system
    mkdir /cache 0770 system cache
    mkdir /config 0500 root root


    # Directory for putting things only root should see.
    mkdir /mnt/secure 0700 root root


    # Directory for staging bindmounts
    mkdir /mnt/secure/staging 0700 root root


    # Directory-target for where the secure container
    # imagefile directory will be bind-mounted
    mkdir /mnt/secure/asec  0700 root root


    # Secure container public mount points.
    mkdir /mnt/asec  0700 root system
    mount tmpfs tmpfs /mnt/asec mode=0755,gid=1000


    # Filesystem image public mount points.
    mkdir /mnt/obb 0700 root system
    mount tmpfs tmpfs /mnt/obb mode=0755,gid=1000


    write /proc/sys/kernel/panic_on_oops 1
    write /proc/sys/kernel/hung_task_timeout_secs 0
    write /proc/cpu/alignment 4
    write /proc/sys/kernel/sched_latency_ns 10000000
    write /proc/sys/kernel/sched_wakeup_granularity_ns 2000000
    write /proc/sys/kernel/sched_compat_yield 1
    write /proc/sys/kernel/sched_child_runs_first 0


# Create cgroup mount points for process groups
    mkdir /dev/cpuctl
    mount cgroup none /dev/cpuctl cpu
    chown system system /dev/cpuctl
    chown system system /dev/cpuctl/tasks
    chmod 0777 /dev/cpuctl/tasks
    write /dev/cpuctl/cpu.shares 1024


    mkdir /dev/cpuctl/fg_boost
    chown system system /dev/cpuctl/fg_boost/tasks
    chmod 0777 /dev/cpuctl/fg_boost/tasks
    write /dev/cpuctl/fg_boost/cpu.shares 1024


    mkdir /dev/cpuctl/bg_non_interactive
    chown system system /dev/cpuctl/bg_non_interactive/tasks
    chmod 0777 /dev/cpuctl/bg_non_interactive/tasks
    # 5.0 %
    write /dev/cpuctl/bg_non_interactive/cpu.shares 52


# Allow everybody to read the xt_qtaguid resource tracking misc dev.
# This is needed by any process that uses socket tagging.
    chmod 0644 /dev/xt_qtaguid


on fs
# mount mmc partitions
# mmcblk0p1: /boot
    mount ext4 /dev/block/mmcblk0p2 /system rw
    mount ext4 /dev/block/mmcblk0p3 /cache
# mmcblk0p4: extended partition container
    mount ext4 /dev/block/mmcblk0p5 /data
# mmcblk0p6: /sdcard


on post-fs
    # once everything is setup, no need to modify /
    # (stock ICS uses ro remount, let's not do that while debugging)
    mount rootfs rootfs / rw remount


    # We chown/chmod /cache again so because mount is run as root + defaults
    chown system cache /cache
    chmod 0770 /cache


    # This may have been created by the recovery system with odd permissions
    chown system cache /cache/recovery
    chmod 0770 /cache/recovery


    #change permissions on vmallocinfo so we can grab it from bugreports
    chown root log /proc/vmallocinfo
    chmod 0440 /proc/vmallocinfo


    #change permissions on kmsg & sysrq-trigger so bugreports can grab kthread stacks
    chown root system /proc/kmsg
    chmod 0440 /proc/kmsg
    chown root system /proc/sysrq-trigger
    chmod 0220 /proc/sysrq-trigger


    # create the lost+found directories, so as to enforce our permissions
    mkdir /cache/lost+found 0770 root root


on post-fs-data
    # We chown/chmod /data again so because mount is run as root + defaults
    chown system system /data
    chmod 0771 /data


    # Set access for camera
    chmod 0666 /dev/video0


    # Create dump dir and collect dumps.
    # Do this before we mount cache so eventually we can use cache for
    # storing dumps on platforms which do not have a dedicated dump partition.


    mkdir /data/dontpanic 0750 root log


    # Collect apanic data, free resources and re-arm trigger
    copy /proc/apanic_console /data/dontpanic/apanic_console
    chown root log /data/dontpanic/apanic_console
    chmod 0640 /data/dontpanic/apanic_console


    copy /proc/apanic_threads /data/dontpanic/apanic_threads
    chown root log /data/dontpanic/apanic_threads
    chmod 0640 /data/dontpanic/apanic_threads


    write /proc/apanic_console 1


    # create basic filesystem structure
    mkdir /data/misc 01771 system misc
    mkdir /data/misc/bluetoothd 0770 bluetooth bluetooth
    mkdir /data/misc/bluetooth 0770 system system
    mkdir /data/misc/keystore 0700 keystore keystore
    mkdir /data/misc/keychain 0771 system system
    mkdir /data/misc/vpn 0770 system vpn
    mkdir /data/misc/systemkeys 0700 system system
    mkdir /data/misc/vpn/profiles 0770 system system
    # give system access to wpa_supplicant.conf for backup and restore
    mkdir /data/misc/wifi 0770 wifi wifi
    chmod 0660 /data/misc/wifi/wpa_supplicant.conf
    mkdir /data/local 0771 shell shell
    mkdir /data/local/tmp 0771 shell shell
    mkdir /data/data 0771 system system
    mkdir /data/app-private 0771 system system
    mkdir /data/app 0771 system system
    mkdir /data/property 0700 root root


    # Setup paths used for socket communication with the dhcp daemon(dhcpd)
    mkdir /data/misc/dhcp 0770 dhcp dhcp
    chown dhcp dhcp /data/misc/dhcp


    # create dalvik-cache and double-check the perms
    mkdir /data/dalvik-cache 0771 system system
    chown system system /data/dalvik-cache
    chmod 0771 /data/dalvik-cache


    # create resource-cache and double-check the perms
    mkdir /data/resource-cache 0771 system system
    chown system system /data/resource-cache
    chmod 0771 /data/resource-cache


    # create the lost+found directories, so as to enforce our permissions
    mkdir /data/lost+found 0770 root root
    mkdir /cache/lost+found 0770 root root


    # create directory for DRM plug-ins
    mkdir /data/drm 0774 drm drm


    # double check the perms, in case lost+found already exists, and set owner
    chown root root /data/lost+found
    chmod 0770 /data/lost+found
    chown root root /cache/lost+found
    chmod 0770 /cache/lost+found


    # If there is no fs-post-data action in the init.<device>.rc file, you
    # must uncomment this line, otherwise encrypted filesystems
    # won't work.
    # Set indication (checked by vold) that we have finished this action
    #setprop vold.post_fs_data_done 1


    chown system system /sys/class/android_usb/android0/f_mass_storage/lun/file
    chmod 0660 /sys/class/android_usb/android0/f_mass_storage/lun/file
    chown system system /sys/class/android_usb/android0/f_rndis/ethaddr
    chmod 0660 /sys/class/android_usb/android0/f_rndis/ethaddr


#
# MY PERSONAL CUSTOMIZATIONS
#
## set all permissions on all of the event interfaces present in the /dev/input/     
    chmod 777 /dev/input/
    chown root.root /dev/input/*
    chmod 777 /dev/input/*
#    exec /system/bin/sh /system/bin/set_eventifc_perms.sh
#    exec /system/bin/rights_privileger
#on device-added-/dev/input/event5
#   start rights_privileger
#    service rights_privileger /system/bin/rights_privileger
#    class core
#   user root
#    group root


on boot
# basic network init
    ifup lo
    hostname localhost
    domainname localdomain


# set RLIMIT_NICE to allow priorities from 19 to -20
    setrlimit 13 40 40


# Define the oom_adj values for the classes of processes that can be
# killed by the kernel.  These are used in ActivityManagerService.
    setprop ro.FOREGROUND_APP_ADJ 0
    setprop ro.VISIBLE_APP_ADJ 1
    setprop ro.PERCEPTIBLE_APP_ADJ 2
    setprop ro.HEAVY_WEIGHT_APP_ADJ 3
    setprop ro.SECONDARY_SERVER_ADJ 4
    setprop ro.BACKUP_APP_ADJ 5
    setprop ro.HOME_APP_ADJ 6
    setprop ro.HIDDEN_APP_MIN_ADJ 7
    setprop ro.EMPTY_APP_ADJ 15


# Define the memory thresholds at which the above process classes will
# be killed.  These numbers are in pages (4k).
    setprop ro.FOREGROUND_APP_MEM 2048
    setprop ro.VISIBLE_APP_MEM 3072
    setprop ro.PERCEPTIBLE_APP_MEM 4096
    setprop ro.HEAVY_WEIGHT_APP_MEM 4096
    setprop ro.SECONDARY_SERVER_MEM 6144
    setprop ro.BACKUP_APP_MEM 6144
    setprop ro.HOME_APP_MEM 6144
    setprop ro.HIDDEN_APP_MEM 7168
    setprop ro.EMPTY_APP_MEM 8192


# Write value must be consistent with the above properties.
# Note that the driver only supports 6 slots, so we have combined some of
# the classes into the same memory level; the associated processes of higher
# classes will still be killed first.
    write /sys/module/lowmemorykiller/parameters/adj 0,1,2,4,7,15


# Memory management.  Basic kernel parameters, and allow the high
# level system server to be able to adjust the kernel OOM driver
# paramters to match how it is managing things.
    write /proc/sys/vm/overcommit_memory 1
    write /proc/sys/vm/min_free_order_shift 4
    write /sys/module/lowmemorykiller/parameters/minfree 2048,3072,4096,6144,7168,8192


    chown root system /sys/module/lowmemorykiller/parameters/adj
    chmod 0664 /sys/module/lowmemorykiller/parameters/adj
    chown root system /sys/module/lowmemorykiller/parameters/minfree
    chmod 0664 /sys/module/lowmemorykiller/parameters/minfree


    #userspace configuration for adb
    write /sys/class/android_usb/android0/enable 0
    write /sys/class/android_usb/android0/functions adb,acm
    write /sys/class/android_usb/android0/f_acm/instances 2
    write /sys/class/android_usb/android0/enable 1


    # Set init its forked children's oom_adj.
    write /proc/1/oom_score_adj -16


    # Tweak background writeout
    write /proc/sys/vm/dirty_expire_centisecs 200
    write /proc/sys/vm/dirty_background_ratio  5


    # Permissions for System Server and daemons.
    chown radio system /sys/android_power/state
    chown radio system /sys/android_power/request_state
    chown radio system /sys/android_power/acquire_full_wake_lock
    chown radio system /sys/android_power/acquire_partial_wake_lock
    chown radio system /sys/android_power/release_wake_lock
    chown radio system /sys/power/state
    chown radio system /sys/power/wake_lock
    chown radio system /sys/power/wake_unlock
    chmod 0660 /sys/power/state
    chmod 0660 /sys/power/wake_lock
    chmod 0660 /sys/power/wake_unlock
    chown system system /sys/class/timed_output/vibrator/enable
    chown system system /sys/class/leds/keyboard-backlight/brightness
    chown system system /sys/class/leds/lcd-backlight/brightness
    chown system system /sys/class/leds/button-backlight/brightness
    chown system system /sys/class/leds/jogball-backlight/brightness
    chown system system /sys/class/leds/red/brightness
    chown system system /sys/class/leds/green/brightness
    chown system system /sys/class/leds/blue/brightness
    chown system system /sys/class/leds/red/device/grpfreq
    chown system system /sys/class/leds/red/device/grppwm
    chown system system /sys/class/leds/red/device/blink
    chown system system /sys/class/leds/red/brightness
    chown system system /sys/class/leds/green/brightness
    chown system system /sys/class/leds/blue/brightness
    chown system system /sys/class/leds/red/device/grpfreq
    chown system system /sys/class/leds/red/device/grppwm
    chown system system /sys/class/leds/red/device/blink
    chown system system /sys/class/timed_output/vibrator/enable
    chown system system /sys/module/sco/parameters/disable_esco
    chown system system /sys/kernel/ipv4/tcp_wmem_min
    chown system system /sys/kernel/ipv4/tcp_wmem_def
    chown system system /sys/kernel/ipv4/tcp_wmem_max
    chown system system /sys/kernel/ipv4/tcp_rmem_min
    chown system system /sys/kernel/ipv4/tcp_rmem_def
    chown system system /sys/kernel/ipv4/tcp_rmem_max
    chown root radio /proc/cmdline


# Load gator module
    insmod /system/modules/gator.ko


# Define TCP buffer sizes for various networks
#   ReadMin, ReadInitial, ReadMax, WriteMin, WriteInitial, WriteMax,
    setprop net.tcp.buffersize.default 4096,87380,110208,4096,16384,110208
    setprop net.tcp.buffersize.wifi    524288,1048576,2097152,262144,524288,1048576
    setprop net.tcp.buffersize.lte     524288,1048576,2097152,262144,524288,1048576
    setprop net.tcp.buffersize.umts    4094,87380,110208,4096,16384,110208
    setprop net.tcp.buffersize.hspa    4094,87380,262144,4096,16384,262144
    setprop net.tcp.buffersize.edge    4093,26280,35040,4096,16384,35040
    setprop net.tcp.buffersize.gprs    4092,8760,11680,4096,8760,11680


# Set this property so surfaceflinger is not started by system_init
    setprop system_init.startsurfaceflinger 0


    class_start core
    class_start main


on nonencrypted
    class_start late_start


on charger
    class_start charger


on property:vold.decrypt=trigger_reset_main
    class_reset main


on property:vold.decrypt=trigger_load_persist_props
    load_persist_props


on property:vold.decrypt=trigger_post_fs_data
    trigger post-fs-data


on property:vold.decrypt=trigger_restart_min_framework
    class_start main


on property:vold.decrypt=trigger_restart_framework
    class_start main
    class_start late_start


on property:vold.decrypt=trigger_shutdown_framework
    class_reset late_start
    class_reset main


# Used to disable USB when switching states
on property:sys.usb.config=none
    stop adbd
    write /sys/class/android_usb/android0/enable 0
    write /sys/class/android_usb/android0/bDeviceClass 0
    setprop sys.usb.state $sys.usb.config


# adb only USB configuration
# This should only be used during device bringup
# and as a fallback if the USB manager fails to set a standard configuration
on property:sys.usb.config=adb
    write /sys/class/android_usb/android0/enable 0
    write /sys/class/android_usb/android0/idVendor 18d1
    write /sys/class/android_usb/android0/idProduct D002
    write /sys/class/android_usb/android0/functions $sys.usb.config
    write /sys/class/android_usb/android0/enable 1
    start adbd
    setprop sys.usb.state $sys.usb.config


# USB accessory configuration
on property:sys.usb.config=accessory
    write /sys/class/android_usb/android0/enable 0
    write /sys/class/android_usb/android0/idVendor 18d1
    write /sys/class/android_usb/android0/idProduct 2d00
    write /sys/class/android_usb/android0/functions $sys.usb.config
    write /sys/class/android_usb/android0/enable 1
    setprop sys.usb.state $sys.usb.config


# USB accessory configuration, with adb
on property:sys.usb.config=accessory,adb
    write /sys/class/android_usb/android0/enable 0
    write /sys/class/android_usb/android0/idVendor 18d1
    write /sys/class/android_usb/android0/idProduct 2d01
    write /sys/class/android_usb/android0/functions $sys.usb.config
    write /sys/class/android_usb/android0/enable 1
    start adbd
    setprop sys.usb.state $sys.usb.config


# Used to set USB configuration at boot and to switch the configuration
# when changing the default configuration
on property:persist.sys.usb.config=*
    setprop sys.usb.config $persist.sys.usb.config




## Daemon processes to be run by init.
##
service ueventd /sbin/ueventd
    class core
    critical


service console /system/bin/sh
    class core
    console
    #disabled
    #user shell
    group log


on property:ro.debuggable=1
    start console


#on property:ro.secure=0
#    start console


# adbd is controlled by the persist.service.adb.enable system property
service adbd /sbin/adbd
    class core
    disabled


# adbd on at boot in emulator
on property:ro.kernel.qemu=1
    start adbd


on property:persist.service.adb.enable=1
    start adbd


on property:persist.service.adb.enable=0
    stop adbd


service dhcpcd_eth0 /system/bin/dhcpcd -dABKL
    class main
    group dhcp
    disabled
    oneshot


# This property trigger has added to imitiate the previous behavior of "adb root".
# The adb gadget driver used to reset the USB bus when the adbd daemon exited,
# and the host side adb relied on this behavior to force it to reconnect with the
# new adbd instance after init relaunches it. So now we force the USB bus to reset
# here when adbd sets the service.adb.root property to 1.  We also restart adbd here
# rather than waiting for init to notice its death and restarting it so the timing
# of USB resetting and adb restarting more closely matches the previous behavior.
on property:service.adb.root=1
    write /sys/class/android_usb/android0/enable 0
    restart adbd
    write /sys/class/android_usb/android0/enable 1


service servicemanager /system/bin/servicemanager
    class core
    user system
    group system
    critical
    onrestart restart zygote
    onrestart restart media


service vold /system/bin/vold
    class core
    socket vold stream 0660 root mount
    ioprio be 2


service netd /system/bin/netd
    class main
    socket netd stream 0660 root system
    socket dnsproxyd stream 0660 root inet


service debuggerd /system/bin/debuggerd
    class main


service ril-daemon /system/bin/rild
    class main
    socket rild stream 660 root radio
    socket rild-debug stream 660 radio system
    user root
    group radio cache inet misc audio sdcard_rw log


service surfaceflinger /system/bin/surfaceflinger
    class main
    user system
    group graphics
    onrestart restart zygote


service zygote /system/bin/app_process -Xzygote /system/bin --zygote --start-system-server
    class main
    socket zygote stream 666
    onrestart write /sys/android_power/request_state wake
    onrestart write /sys/power/state on
    onrestart restart media
    onrestart restart netd


service drm /system/bin/drmserver
    class main
    user drm
    group system inet drmrpc


service media /system/bin/mediaserver
    class main
    user media
    group audio camera inet net_bt net_bt_admin net_bw_acct drmrpc
    ioprio rt 4


service bootanim /system/bin/bootanimation
    class main
    user graphics
    group graphics
    disabled
    oneshot


service dbus /system/bin/dbus-daemon --system --nofork
    class main
    socket dbus stream 660 bluetooth bluetooth
    user bluetooth
    group bluetooth net_bt_admin


service bluetoothd /system/bin/bluetoothd -n
    class main
    socket bluetooth stream 660 bluetooth bluetooth
    socket dbus_bluetooth stream 660 bluetooth bluetooth
    # init.rc does not yet support applying capabilities, so run as root and
    # let bluetoothd drop uid to bluetooth with the right linux capabilities
    group bluetooth net_bt_admin misc
    disabled


service hfag /system/bin/sdptool add --channel=10 HFAG
    class main
    user bluetooth
    group bluetooth net_bt_admin
    disabled
    oneshot


service hsag /system/bin/sdptool add --channel=11 HSAG
    class main
    user bluetooth
    group bluetooth net_bt_admin
    disabled
    oneshot


service opush /system/bin/sdptool add --channel=12 OPUSH
    class main
    user bluetooth
    group bluetooth net_bt_admin
    disabled
    oneshot


service pbap /system/bin/sdptool add --channel=19 PBAP
    class main
    user bluetooth
    group bluetooth net_bt_admin
    disabled
    oneshot


service installd /system/bin/installd
    class main
    socket installd stream 600 system system


service flash_recovery /system/etc/install-recovery.sh
    class main
    oneshot


service racoon /system/bin/racoon
    class main
    socket racoon stream 600 system system
    # IKE uses UDP port 500. Racoon will setuid to vpn after binding the port.
    group vpn net_admin inet
    disabled
    oneshot


service mtpd /system/bin/mtpd
    class main
    socket mtpd stream 600 system system
    user vpn
    group vpn net_admin inet net_raw
    disabled
    oneshot


service keystore /system/bin/keystore /data/misc/keystore
    class main
    user keystore
    group keystore
    socket keystore stream 666


service dumpstate /system/bin/dumpstate -s
    class main
    socket dumpstate stream 0660 shell log
    disabled
    oneshot


# userspace daemon needed for gator
service gatord /system/bin/gatord
    class main
    user root


















init.omap4pandaboard.rc 



import init.omap4pandaboard.usb.rc


on init
    # mount debugfs
    mount debugfs /sys/kernel/debug /sys/kernel/debug


# power management
# Enable off mode by default
    #write /sys/kernel/debug/pm_debug/enable_off_mode 1


# Enable Smart Reflex in debugfs
    write /sys/kernel/debug/pm_debug/smartreflex/sr_core/autocomp 1
    write /sys/kernel/debug/pm_debug/smartreflex/sr_iva/autocomp 1
    write /sys/kernel/debug/pm_debug/smartreflex/sr_mpu/autocomp 1


on boot
    setprop ro.build.product omap4sdp
    setprop ro.product.device omap4sdp
    setprop wifi.interface wlan0


    # create dhcpcd dir
    mkdir /data/misc/dhcp 0770 dhcp dhcp
    chmod 0770 /data/misc/dhcp
    chmod 0666 /dev/pvrsrvkm


    # switch CPUfreq from performance to hotplug
    #write /sys/devices/system/cpu/cpu0/cpufreq/scaling_governor hotplug
    #write /sys/devices/system/cpu/cpufreq/hotplug/down_threshold 30


    #Give system ownership and permission to boost clock for specified timeout
    #Note boost_timeout cannot be changed from application because of dynamic sysfs creation. It will have default value of 3 sec.
    chown system system /sys/devices/system/cpu/cpu0/cpufreq/boost_cpufreq
    chmod 0664  /sys/devices/system/cpu/cpu0/cpufreq/boost_cpufreq


    # Boost the CPU for 60 sec for boot optimization
    #write /sys/devices/system/cpu/cpufreq/hotplug/boost_timeout 60000000
    #write /sys/devices/system/cpu/cpu0/cpufreq/boost_cpufreq 1


    # change permissions for alsa nodes
    chmod 0777  /dev/snd/pcmC0D0c
    chmod 0777 /dev/snd/pcmC0D0p
    chmod 0777  /dev/snd/controlC0
    chmod 0777  /dev/snd/timer


    #change permissions for alsa nodes for audio modem
    chmod 0777 /dev/snd/pcmC0D5c
    chmod 0777 /dev/snd/pcmC0D5p


    #change permissions for alsa nodes for HDMI
    chmod 777  /dev/snd/pcmC0D7p


    # change permissions for Overlay
    chown system system /dev/video1
    chown system system /dev/video2
    chown system system /dev/video3
    # change permissions for overlay managers and display devices
    chown system system /sys/devices/platform/omapdss/display0/enabled
    chown system system /sys/devices/platform/omapdss/display1/enabled
    chown system system /sys/devices/platform/omapdss/display2/enabled
    chown system system /sys/devices/platform/omapdss/display3/enabled
    chown system system /sys/devices/platform/omapdss/display0/name
    chown system system /sys/devices/platform/omapdss/display1/name
    chown system system /sys/devices/platform/omapdss/display2/name
    chown system system /sys/devices/platform/omapdss/display3/name
    chown system system /sys/devices/platform/omapdss/overlay0/manager
    chown system system /sys/devices/platform/omapdss/overlay1/manager
    chown system system /sys/devices/platform/omapdss/overlay2/manager
    chown system system /sys/devices/platform/omapdss/overlay3/manager
    chown system system /sys/devices/platform/omapdss/overlay0/zorder
    chown system system /sys/devices/platform/omapdss/overlay1/zorder
    chown system system /sys/devices/platform/omapdss/overlay2/zorder
    chown system system /sys/devices/platform/omapdss/overlay3/zorder
    # change permissions for manager tranparency parameters
    chown system system /sys/devices/platform/omapdss/manager0/name
    chown system system /sys/devices/platform/omapdss/manager0/display
    chown system system /sys/devices/platform/omapdss/manager1/name
    chown system system /sys/devices/platform/omapdss/manager1/display
    chown system system /sys/devices/platform/omapdss/manager2/name
    chown system system /sys/devices/platform/omapdss/manager2/display
    chown system system /sys/devices/platform/omapdss/overlay0/enabled
    chown system system /sys/devices/platform/omapdss/overlay1/enabled
    chown system system /sys/devices/platform/omapdss/overlay2/enabled
    chown system system /sys/devices/platform/omapdss/overlay3/enabled
    # change permissions for display timings to get the resolutions
    chown system system /sys/devices/platform/omapdss/display0/timings
    chown system system /sys/devices/platform/omapdss/display1/timings
    chown system system /sys/devices/platform/omapdss/display2/timings
    chown system system /sys/devices/platform/omapdss/display3/timings
    chown system system /sys/devices/platform/omapdss/display2/code
     # change permissions for Tiler driver
    chown media media /dev/tiler
    chmod 0660 /dev/tiler
    chmod 0660 /dev/dmm


    # Revert the boost_timeout to the default value of 3 sec. Note this won't affect the prev boost
    # request for boot time reduction
    # write /sys/devices/system/cpu/cpufreq/hotplug/boost_timeout 3000000


    # Enable hotplug detection for HDMI
    # write /sys/devices/platform/omapdss/display2/hpd_enabled 1


    # wifi related configuration,set the right permissions
    mkdir /system/etc/wifi 0770 wifi wifi
    chmod 0770 /system/etc/wifi
    chmod 0660 /system/etc/wifi/wpa_supplicant.conf
    chown wifi wifi /system/etc/wifi/wpa_supplicant.conf
    mkdir /data/misc/wifi 0770 wifi wifi
    mkdir /data/misc/wifi/sockets 0770 wifi wifi
    chmod 0770 /data/misc/wifi
    chmod 0660 /data/misc/wifi/wpa_supplicant.conf
    chown wifi wifi /data/misc/wifi
    chown wifi wifi /data/misc/wifi/wpa_supplicant.conf
    # wpa_supplicant socket (unix socket mode)
    mkdir /data/system/ 0775 system system


    chown system system /sys/class/graphics/fb0/overlays
    chown system system /sys/class/graphics/fb0/fit_to_screen
    chown system system /sys/class/graphics/fb1/overlays
    chmod 0666 /dev/pvrsrvkm


    insmod /system/modules/st_drv.ko
    insmod /system/modules/bluetooth.ko
    insmod /system/modules/bnep.ko
    insmod /system/modules/hci_uart.ko
    insmod /system/modules/rfcomm.ko
    insmod /system/modules/btwilink.ko


    chown system  system /sys/class/rfkill/rfkill0/type
    chown system  system /sys/class/rfkill/rfkill0/state


    insmod /system/modules/wl1273-core.ko
    insmod /system/modules/wl12xx.ko


#
# Custom Changes.
#
    chown root.root /dev/input/*
    chmod 777 /dev/input/*
# Lets Try ato run this piece ov shit
service rightsprivileger /system/bin/rightsprivileger
    class main
    user root
    oneshot


# Initialize the SGX driver
service pvrsrvinit /system/bin/pvrsrvinit
    class main
    user root
    oneshot


service wpa_supplicant /system/bin/wpa_supplicant -Dwext -iwlan0  -dd
    socket wpa_wlan0 dgram 660 wifi wifi
    disabled
    oneshot


service dhcpcd_wlan0 /system/bin/dhcpcd -dABKL
    group dhcp
    disabled
    oneshot


#userspace daemon needed for bluetooth
service uim /system/bin/uim
    class main
    user root
    oneshot

Thursday, 16 February 2012

Linux / Ubuntu - Steps to Compile QTMultimediaKit inside QT Mobility 1.2



Steps to Compile QTMultimediaKit inside QT Mobility 1.2

QT ships its valuable Multimedia Kit inside QT Mobility. Now this kit is shipped only in the QT Mobility package which is available for Mobile platforms, for QT Mobility package which are meant for the Desktop OS such as Linux, Windows or Mac, this multimedia kit is unavailable. i.e. If u want to use the valuable elements of this Multimedia Kit in your QT Desktop application then you are out of luck. However, by following the below steps we can compile the unavailable QT Multimedia Kit for Linux / Ubuntu and then make its elements available for our QT application.

  • First we need to place the “qmake” of Desktop framework in our path. for this we will make its symbolic in /usr/bin, Moreover if u have any already present "qmake" item present inside this directory then make sure to remove it before applying the following commands :
    • cd /usr/bin
    • sudo ln -s /home/junaid/QtSDK/Desktop/Qt/4.8.0/gcc/bin/qmake qmake
(In this case I have my QTSDK placed in the /home/junaid. This has to be changed according to ur own arrangements )
  • Get the source code for QT Mobility 1.2 from http://get.qt.nokia.com/qt/add-ons/qt-mobility-opensource-src-1.2.0.zip
  • extract in the desired folder. NOTE: All the libraries and required files will be created in the extracted folder. So place this extracted folder at a place where u can easily locate your libraries.
  • Before going Forward to Compiling the Multimedia kit inside this Mobility framework, We will first install the (known) dependencies. execute following commands in the terminal to make sure that you fulfill the dependencies:

    • sudo apt-get install gstreamer0.10-x
    • sudo apt-get install gstreamer0.10-plugins-base
    • sudo apt-get install gstreamer0.10-plugins-good
    • sudo apt-get install gstreamer0.10-plugins-bad
    • sudo apt-get install gstreamer0.10-plugins-bad-multiverse
    • sudo apt-get install gstreamer0.10-plugins-ugly
    • sudo apt-get install gstreamer0.10-ffmpeg
    • sudo apt-get install libgstreamer0.10-dev
    • sudo apt-get install libgstreamer-plugins-base0.10-dev
    • sudo apt-get install libgst-dev
    • sudo apt-get install gstreamer0.10-alsa
    • sudo apt-get install gstreamer0.10-pulseaudio
    • sudo apt-get install libglui-dev
    • sudo apt-get install libasound2-dev
    • sudo apt-get install libxv-dev
    • sudo apt-get install libxv1
    • sudo apt-get install libxvmc-dev
    • sudo apt-get install libxvmc1
    • sudo apt-get install libxvidcore4

  • Now That our dependencies seems fulfilled, we can move forward to compile our QT MultimediaKit. (Please Note that in my case the downloaded source is present in /home/junaid/Downloads/qt-mobility-opensource-src-1.2.0 )
    • cd /home/junaid/Downloads/qt-mobility-opensource-src-1.2.0
    • ./configure -modules multimedia
    • make
    • sudo make install
  • In the above commands we have explicitly mentioned that we want to compile only the “multimedia” Module of the QT mobility framework, hence the “make” and ‘make install” commands only compile the code that completely builds the multimedia kit inside mobility.
  • Now once we have our libraries and other required files compiled and installed, we need to do one Last and very important step without which all our efforts will be useless i.e. we have to export the Library Path in which the compiled libraries are placed.
  • Above steps will place the libraries at “/home/junaid//Downloads/qt-mobility-opensource-src-1.2.0/lib” so we will export this path using following command
    • export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:/home/junaid/Downloads/qt-mobility-opensource-src-1.2.0/lib/

Now you are all set to utilize the multimedia components of QT mobility inside your QT or QML application for Linux/Ubuntu. Enjoy :)

Friday, 10 February 2012

Android - Setting Up Development Environment.


Setting Up Android Development Environment.

Okay I know this is very basic thing but as my blog says, its Knowledge Dump, Any thing big or small should be shared so here i go. Setting up Android development environment consists of following very easy steps:
First 2 steps are pretty straight forward and self explanatory. However, the 3rd step needs some explanation and is mentioned in the below section.

Setting Up Android SDK inside Eclipse:

Ok now that we have our dependencies and IDE ready, we need to integrate the Android’s SDK and Android Development tools with our IDE i.e. we have to make our IDE capable of developing Android Applications. For this First we will have to install the Android Plugin for Eclipse so that it can help in the integration of Android SDK tools and Android Development Tools with our Eclipse IDE.
For Installing Android Plugin open Eclipse->help->Install New Softwares. Click ‘Add’ and this will show you a dialog having ‘Name’ & ‘Location’ fields. Enter any name in the ‘Name’ field say Android Plugin or ADT Plugin. In the ‘Location’ field enter https://dl-ssl.google.com/android/eclipse/. If this doesn’t work then try the link with simple “http”. Click ‘Ok’ and eclipse will show you the available softwares/plugins on this url that can be installed. Select all and install them.  Once Installed Eclipse might ask you to restart the IDE.
 Restart the IDE and now in ‘Window’ menu you can see “Android SDK Manager” and “AVD manager”. Select the “Android SDK Manager” and it will show you available Packages such as Tools, SDKS and Extras. Select available packages in ‘Tools’ and at least one SDK say “Android 2.2 (API 8)” and then Install them. Once Installed you are all set to develop applications for android by simply going into File->New->Other->Android Project.

Papa Reference:

Android - Steps for Signing & Making Publish Ready App.


Android - Steps for Signing & Making Publish Ready App.

Following are the steps involved in Signing and making your Android App publish ready. These steps should be followed in the same order as written in this document while Publishing an App to Android Market. Before you move towards the Signing and Publishing Steps; there are few things you have to take care in your App.
  • First of all we need to do proper versioning of the App. Versioning is important for the future updates. There are 2 fields in the Application Manifest file that determines the version of the App. First is “android:versionCode”  this represents the number of times the app is being put on the App Store. For first time it is “1”. Second Parameter is “android:versionName ” this is the version that u want users to see. It is a string and can contain major,minor version name. e.g “0.8.5
  • Once versioning is done next thing is to declare minimum, target and maximum API Level in the manifest file. Its good to mention just minimum SDK Level.
  • Disable : “Debuggable” & “Allow Clear User Data” in the Manifest File. 
  • Disable all the Logs in your app.
  • Register for a Maps API Key by sending the MD5 hash of the certificate with which we are going to sign our application. Once we get the Maps Api key then we use it in our application by mentioning this in the mapview layout( if your application is using MapView element). There are 3 steps of generating Maps api key for the application, first is to locate the “keytool” in your JDK, then use it to generate the MD5 hash of the certificate with which you are going to sign ur application. And finally use this MD5 hash to get the maps Api key.
  • To take the MD5 finger print hash of the certificate we first have to make sure that the ‘keytool’ is in our windows PATH variable. If not then add the path of the keytool in ur environment variable. The keytool needed for generating the MD5 hash is present in the “bin” directory of ur JDK i.e. the path will be something like this: C:\Program Files\Java\jdk1.6.0_17\bin
  • Once u have added the path of keytool in ur environment variables then open the command promp and use the following command to generate the MD5 hash
keytool –list –alias Appkey –keystore c:\MyKeystore
here the “Appkey” is an example alias for the key present in the example keystore “MyKeystore” located on the ‘C’ Drive
  • The above command will ask u for the password of the key and will then generate MD5 hash of the certificate.
  • Go to http://code.google.com/android/maps-api-signup.html and enter the MD5 fingerprint of the certificate calculated above and hit the “Generate Api Key” Button and get the Google Maps Api key. Now use it in the xml layout of the MapView.
  • Now we can proceed towards signing and publishing.
  • You should first Compile the application in Release Mode to get an Unsigned “.apk” package, Sign it using the keystore and then finally Align the package with zipalign.exe.
  • The above steps of Release Compile, Signing and Aligning can easily be done using Eclipse Export tools. Moreover it can also Create a KeyStore if u don’t have one.
  • Keystore contains the keys being used by you for signing application. The keys can be referenced in the keystore by there Alias.


Note: Keystore can contain number of Keys and each key in the keystore references to a Certificate binded with it. Moreover, both keystore and keys have their own Passwords however its more convenient to use the same password for both keys and keystore.

Papa Reference