Sunday, 19 May 2019

APT DNS failure using Android kernel

In my Debian rootfs I was getting DNS temporary failure when I was doing a apt update. This link fixes the problem ---> https://unix.stackexchange.com/questions/321491/android-chroot-networking-issues

Monday, 11 March 2019

LCD Parallel Interface parameter calculations

In this post I would like to describe the different LCD parameters and their calculations.

First we understand the LCD display parameters with the following diagram.


In the diagram we have the following terms:

H-Sync: A horizontal synchronize pulse used to synchronize/signal the start of a scan line. Here a scan line means one row/line (of pixels) in the LCD. The signal can be low or a high pulse of a certain duration determined by the setup time (Thsys) and hold time (Thsyh) of this pulse. It is usually mentioned in nano seconds which can also be converted to dotclks which I will come to later.

V-Sync: A veritical synchronize pulse used to synchronize/signal the start of each frame. Here the frame is inclusive of all the vertical and horizontal porches and the H-Sync pulse. The signal can be a low or a high pulse of a certain duration determined by the setup (Tvsys) and hold time (Tvsyh) of this pulse.

HBP and HFP: Horizontal back and front porches. It is used to "eat away" a certain set of pixel clocks before the active line starts and ends. The porch which is before the active line starts is called the back porch and the porch which is after the active line ends is called the front porch. Linux term is left_margin and right_margin for HBP and HFP respectively.

VBP and VFP: Vertical back and from porches. It is used to "eat away" a certain set of lines before after the actual frame starts and ends. Again the porch which is before the active frame is called the back porch and the porch which is after the active frame ends is called the front porch. Linux term is upper_margin and lower_margin for VBP and VFP respectively.

To illustrate the above concepts I will put some of the figures from datasheets

The below example shows the HSYNC in relation to the active pixels, HBP, HFP and also the DOTCLK.




In the diagram above you can see the HSYNC low pulse. The pixel data will keep sending dummy data till the back porch ends with the continuously ticking DOTCLK providing the timing for the HSYNC, HBP, actual pixel data and the HFP. The HBP and HFP period should be a multiple of the DOTCLK period.

Another timing diagram is from the S3C2440 data sheet.


Here we can see the interrupt for the frame sync i.e. VSYNC which is INT_FrSync. This interrupt is useful for the double buffering technique where we can load the image onto an inactive frame buffer between the VSYNCs. When we get the interrupt from the VSYNC we can just change the pointer from the active framebuffer to the back buffer which becomes the active framebuffer. We can start loading the previous framebuffer which becomes inactive.


As seen in the figure the VSYNC and the HSYNC rising edge of the pulse for the start of the frame coincide. In this case the VSYNC and the HSYNC are high pulses. In the figure the VSYNC pulse width is equal to a HSYNC clock period. The polarity of the SYNC pulses can be controlled in the LCDCON5 register. The DOTCLK polarity too can be controlled. As per the figure we can get the follow formula for the Horizontal line time period:


One horizontal line time period = HSYNC width + Horizontal Back porch width + Horizontal data time + Horizontal Front porch width

Also for the time for a single frame can be calculated as:

One frame time period = Vertical Sync pulse width + Vertical back porch + Complete frame time + Vertical back porch

I will explain why porches are needed in the coming sections.


Monday, 4 February 2019

Android Nougat 7.1.1 boot up on Beaglebone Black

Finally got Android Nougat 7.1.1 boot up on my Beaglebone black. I am not sure whether it is a fluke or for real as I have to replicate it again with a rebuild.

I had removed all the different PRODUCT_PROPERTY_OVERRIDES because of one service complaining about another service not being present. One last thing I removed was config.disable_noncore=true. Now I re-enabled the same and built the whole thing up. I will update the results soon.

*Update*: Tried adding config.disable_noncore and it starts crashing. Did a make clean and rebuilt by removing config.disable_noncore and it started working.
 

Also I bought a new set of microSD cards which are class 10 and is much faster than the previous crappy microSD cards. Let me see if they made a difference. 

*Update*: Yes they make a difference. They are faster to write and it is faster for the overall system too.

There is still a crash which I saw in the first boot which is IpManager.eth0 which was plaguing before.  Leaving the system just like that manages to start the system even though there is a single set of kills of audioserver, cameraserver, media, netd but it recovers. This problem I think I will have to try fixing it. Doing a simple cursory search shows a Linaro chat log saying it is some subtle timing bug introduced by the printing but I am not very sure about this.

A 'service list' commands gives the following services:


beagleboneblack:/ # service list
Found 112 services:
0       carrier_config: [com.android.internal.telephony.ICarrierConfigLoader]
1       phone: [com.android.internal.telephony.ITelephony]
2       isms: [com.android.internal.telephony.ISms]
3       iphonesubinfo: [com.android.internal.telephony.IPhoneSubInfo]
4       simphonebook: [com.android.internal.telephony.IIccPhoneBook]
5       telecom: [com.android.internal.telecom.ITelecomService]
6       isub: [com.android.internal.telephony.ISub]
7       contexthub_service: [android.hardware.location.IContextHubService]
8       dns_listener: [android.net.metrics.IDnsEventListener]
9       connmetrics: [android.net.IIpConnectivityMetrics]
10      connectivity_metrics_logger: [android.net.IConnectivityMetricsLogger]
11      imms: [com.android.internal.telephony.IMms]
12      media_projection: [android.media.projection.IMediaProjectionManager]
13      launcherapps: [android.content.pm.ILauncherApps]
14      shortcut: [android.content.pm.IShortcutService]
15      trust: [android.app.trust.ITrustManager]
16      media_router: [android.media.IMediaRouterService]
17      media_session: [android.media.session.ISessionManager]
18      restrictions: [android.content.IRestrictionsManager]
19      graphicsstats: [android.view.IGraphicsStats]
20      assetatlas: [android.view.IAssetAtlas]
21      dreams: [android.service.dreams.IDreamManager]
22      commontime_management: []
23      network_time_update_service: []
24      samplingprofiler: []
25      diskstats: []
26      appwidget: [com.android.internal.appwidget.IAppWidgetService]
27      soundtrigger: [com.android.internal.app.ISoundTriggerService]
28      jobscheduler: [android.app.job.IJobScheduler]
29      hardware_properties: [android.os.IHardwarePropertiesManager]
30      serial: [android.hardware.ISerialManager]
31      usb: [android.hardware.usb.IUsbManager]
32      DockObserver: []
33      audio: [android.media.IAudioService]
34      wallpaper: [android.app.IWallpaperManager]
35      dropbox: [com.android.internal.os.IDropBoxManagerService]
36      search: [android.app.ISearchManager]
37      country_detector: [android.location.ICountryDetector]
38      location: [android.location.ILocationManager]
39      devicestoragemonitor: []
40      notification: [android.app.INotificationManager]
41      recovery: [android.os.IRecoverySystem]
42      updatelock: [android.os.IUpdateLock]
43      servicediscovery: [android.net.nsd.INsdManager]
44      connectivity: [android.net.IConnectivityManager]
45      ethernet: [android.net.IEthernetManager]
46      rttmanager: [android.net.wifi.IRttManager]
47      wifiscanner: [android.net.wifi.IWifiScanner]
48      wifi: [android.net.wifi.IWifiManager]
49      wifip2p: [android.net.wifi.p2p.IWifiP2pManager]
50      netpolicy: [android.net.INetworkPolicyManager]
51      netstats: [android.net.INetworkStatsService]
52      network_score: [android.net.INetworkScoreService]
53      textservices: [com.android.internal.textservice.ITextServicesManager]
54      network_management: [android.os.INetworkManagementService]
55      clipboard: [android.content.IClipboard]
56      statusbar: [com.android.internal.statusbar.IStatusBarService]
57      device_policy: [android.app.admin.IDevicePolicyManager]
58      deviceidle: [android.os.IDeviceIdleController]
59      lock_settings: [com.android.internal.widget.ILockSettings]
60      uimode: [android.app.IUiModeManager]
61      mount: [IMountService]
62      accessibility: [android.view.accessibility.IAccessibilityManager]
63      input_method: [com.android.internal.view.IInputMethodManager]
64      pinner: []
65      vrmanager: [android.service.vr.IVrManager]
66      input: [android.hardware.input.IInputManager]
67      window: [android.view.IWindowManager]
68      alarm: [android.app.IAlarmManager]
69      consumer_ir: [android.hardware.IConsumerIrService]
70      vibrator: [android.os.IVibratorService]
71      content: [android.content.IContentService]
72      account: [android.accounts.IAccountManager]
73      media.camera.proxy: [android.hardware.ICameraServiceProxy]
74      telephony.registry: [com.android.internal.telephony.ITelephonyRegistry]
75      scheduling_policy: [android.os.ISchedulingPolicyService]
76      webviewupdate: [android.webkit.IWebViewUpdateService]
77      usagestats: [android.app.usage.IUsageStatsManager]
78      battery: []
79      sensorservice: [android.gui.SensorServer]
80      processinfo: [android.os.IProcessInfoService]
81      permission: [android.os.IPermissionController]
82      cpuinfo: []
83      dbinfo: []
84      gfxinfo: []
85      meminfo: []
86      procstats: [com.android.internal.app.procstats.IProcessStats]
87      activity: [android.app.IActivityManager]
88      user: [android.os.IUserManager]
89      otadexopt: [android.content.pm.IOtaDexopt]
90      package: [android.content.pm.IPackageManager]
91      display: [android.hardware.display.IDisplayManager]
92      power: [android.os.IPowerManager]
93      appops: [com.android.internal.app.IAppOpsService]
94      batterystats: [com.android.internal.app.IBatteryStats]
95      netd: [android.net.INetd]
96      media.resource_manager: [android.media.IResourceManagerService]
97      media.player: [android.media.IMediaPlayerService]
98      media.drm: [android.media.IMediaDrmService]
99      media.sound_trigger_hw: [android.hardware.ISoundTriggerHwService]
100     media.radio: [android.hardware.IRadioService]
101     media.audio_policy: [android.media.IAudioPolicyService]
102     media.extractor: [android.media.IMediaExtractorService]
103     media.audio_flinger: [android.media.IAudioFlinger]
104     drm.drmManager: [drm.IDrmManagerService]
105     media.camera: [android.hardware.ICameraService]
106     media.codec: [android.media.IMediaCodecService]
107     android.service.gatekeeper.IGateKeeperService: [android.service.gatekeeper.IGateKeeperService]
108     android.security.keystore: [android.security.IKeystoreService]
109     gpu: [android.ui.IGpuService]
110     SurfaceFlinger: [android.ui.ISurfaceComposer]
111     batteryproperties: [android.os.IBatteryPropertiesRegistrar]


In the mean time a screenshot to celebrate.


Thursday, 31 January 2019

Binder driver protocol does not match user space protocol

After updating my Kernel 4.4 branch and also Android repo syncing of Nougat I started getting Binder driver protocol does not match user space protocol.

Log of my work follows:

  1. Updating kernel headers in bionic is the first step which was highlighted in my previous post
  2. Next I started snooping around and found that frameworks/libs/binder/ProcessState.cpp checks the version and then fails
  3. I wrote a simple C program to check what version the binder driver and the ioctl responds with Version 8
  4. Next I check the kernel headers and find that there is a version switch when BINDER_IPC_32BIT is defined or something else possibly BINDER_IPC_64BIT Ref: https://elixir.bootlin.com/linux/v4.4/source/include/uapi/linux/android/binder.h#L43 and https://elixir.bootlin.com/linux/v4.4/source/include/uapi/linux/android/binder.h#L94
  5. Changed it in the source external/kernel-headers/original/....../binder.h and commented out the BINDER_IPC_32BIT and kept only the 64 bit. This is because the kernel has moved on to 64 bit and there is no support for 32 bit. Due to this the KConfig variable is removed. I have still experiment by manually modifying the .config variable
  6. Ran tools/update_all.py and finally rebuilt the whole AOSP. 
These steps finally  fixed all the issues related to binder.

Next step is to fix the hwcomposer not found issue. Let us see how that goes.

Wednesday, 30 January 2019

Updating kernel headers in the AOSP

I updated Linux Kernel 4.4 to the latest revision. I am now trying with AOSP kernel rather than the linux stable kernel.

To update the kernel headers I follow this excellent guide:

https://android.googlesource.com/platform/bionic/+/master/libc/kernel/README.TXT

I am now fixing the errors after the update. I will be updating my progress soon.

Tuesday, 29 January 2019

Timed out waiting for device dev-ttyO0.device

While booting my Beaglebone black on debian Rootfs I stumbled upon the following problem:

"Timed out waiting for device dev-ttyO0.device"

To fix this enable CONFIG_FHANDLE in the kernel.

Credits: https://medium.com/@madhav2code/timed-out-waiting-for-device-dev-ttys0-device-827391917c5d