Reference only(All changes merged to rdk-next and available in all releases) |
Introduction
Tiny RDKB is an effort focused on reducing the RFS of mainline RDKB. While there are many different ways are being explored and worked upon for reducing the overall image size, this particular document is aiming at capturing the Tiny RDKB effort .
Major Highlights to be taken in RDKB RPI : Removed the Unused Modules ,XML files ,scripts, systemd files ,configuration files,libraries and binaries/executables from the RDKB RPI RFS. This should be applicable for both Morty and Dunfell builds.
Design
Below are the Overall steps to be taken for Tiny RDKB effort in RPI,
1.Remove sound kernel modules
2.Removal of unused file COSAXcalibur.XML
3.Replace some executables with busybox
4.Replace NTPD package with Busybox configuration
5.Removed UnUsed packages from ccsp packagegroup in RPI platfrom
6.Removed UnUsed packages from OSS packagegroup in RDKB RPI platfrom
7.Removed UnUsed and Duplicate files from RFS in RDKB RPI platfrom
8.Removed unused driver kernel modules of ath,mediatek,realtek in linux-raspberrypi
9.Removed NLS modules from linux-raspberrypi
10.Removed unused driver modules of rtc,usb,input in linux-raspberrypi
11.Removed Unused kernel driver modules of NF,Xtables,PPS,BT from linux-raspberrypi
12.Removed Unused kernel modules of HID and USB from linux-raspberrypi
13.Removed Unused kernel modules of DRM,USB_SERIAL,SPEECH,CAN,W1,YAM from linux-raspberrypi
14.Added PHP->JST Migration
15.Removed Unused packages from util-linux
16.Added nodejs package as DISTRO Features for Morty Builds
17.Removed Unused files from RFS
18.Converted Parental control features kernel modules to in-built modules for reducing the kernel size in RFS.
Comparison of Image Size
S.NO | Yocto Version Builds | Before Tiny RDKB Image Size | After Tiny RDKB Image Size | Difference |
---|
1 | Morty | 380MB | 224 MB | 156MB |
2 | Dunfell | 80MB(After extract the tar 448MB) | 59MB(After extract the tar 306MB) | 21MB(142MB) |
RDKB RPI Memory Comparison
Below are the ways to compare the memories in before and after the Tiny RDKB effort in RPI,
- RAM usage
- CPU Utilization
- Rootfs size on Storage Disk
Initial Boot-up
This below analysis are immediately taken while the fresh image is boot-up,
RAM Usage On Initial Boot-up
CPU Utilization On Initial Boot-up
Rootfs Size on Storage Disk On Initial Boot-up
After one hour from Image Boot-up
The below analysis are taken one hour after form the fresh image boot-up,
RAM Usage On After One Hour
CPU Utilization On After One hour
Rootfs Size on Storage Disk On After One hour
Linux Commands for Memory Usage
Below linux commands are used to find the memory usage of RAM, CPU Utilization and Rootfs Size.
S.NO | Memory Usages | Linux Commands |
---|
1 | RAM Usage | free -m |
2 | CPU Utilization | iostat / top |
3 | Rootfs Size | df -h |
Initial Boot-up - Sample Output from fresh image
root@RaspberryPi-Gateway:~# free -m
total used free shared buff/cache available
Mem: 924 63 827 4 39 842
Swap: 0 0 0 |
|
root@RaspberryPi-Gateway:~# free -m
total used free shared buff/cache available
Mem: 603 60 503 4 36 518
Swap: 0 0 0
|
|
|
root@RaspberryPi-Gateway:~# iostat
Linux 5.4.72-v7 (RaspberryPi-Gateway) 12/09/20 _armv7l_ (4 CPU)
avg-cpu: %user %nice %system %iowait %steal %idle
19.17 0.02 26.86 0.41 2.50 53.46
Device: tps Blk_read/s Blk_wrtn/s Blk_read Blk_wrtn
mmcblk0 14.02 508.65 43.97 95683 8271
mmcblk0p1 0.38 3.88 0.01 729 1
mmcblk0p2 13.39 493.68 43.96 92866 8270
root@RaspberryPi-Gateway:~# |
|
root@RaspberryPi-Gateway:~# iostat
Linux 5.4.72-v7 (RaspberryPi-Gateway) 03/29/21 _armv7l_ (4 CPU)
avg-cpu: %user %nice %system %iowait %steal %idle
17.72 0.02 24.32 1.94 0.00 53.98
Device: tps Blk_read/s Blk_wrtn/s Blk_read Blk_wrtn
mmcblk0 20.85 723.65 73.56 79435 8075
mmcblk0p1 0.58 6.66 0.01 731 1
mmcblk0p2 19.83 697.97 73.55 76616 8074 |
|
|
root@RaspberryPi-Gateway:~# df -h
Filesystem Size Used Available Use% Mounted on
/dev/root 241.6M 139.5M 85.6M 62% /
devtmpfs 173.0M 0 173.0M 0% /dev
tmpfs 301.5M 4.0K 301.5M 0% /dev/shm
tmpfs 301.5M 21.4M 280.1M 7% /run
tmpfs 301.5M 0 301.5M 0% /sys/fs/cgroup
tmpfs 301.5M 2.5M 299.1M 1% /tmp
tmpfs 301.5M 328.0K 301.2M 0% /var/volatile
/dev/mmcblk0p1 50.8M 29.2M 21.6M 58% /boot
tmpfs 60.3M 0 60.3M 0% /run/user/0
root@RaspberryPi-Gateway:~# |
|
root@RaspberryPi-Gateway:~# df -h
Filesystem Size Used Available Use% Mounted on
/dev/root 375.7M 217.2M 135.1M 62% /
devtmpfs 333.7M 0 333.7M 0% /dev
tmpfs 462.2M 4.0K 462.2M 0% /dev/shm
tmpfs 462.2M 25.5M 436.7M 6% /run
tmpfs 462.2M 0 462.2M 0% /sys/fs/cgroup
tmpfs 462.2M 2.9M 459.3M 1% /tmp
tmpfs 462.2M 512.0K 461.7M 0% /var/volatile
/dev/mmcblk0p1 48.5M 27.4M 21.0M 57% /boot
root@RaspberryPi-Gateway:~#
|
|
|
One Hour after from Image Boot-up - Sample Output
root@RaspberryPi-Gateway:~# free -m
total used free shared buff/cache available
Mem: 924 133 712 24 78 750
Swap: 0 0 0
root@RaspberryPi-Gateway:~# |
|
root@RaspberryPi-Gateway:~# free -m
total used free shared buff/cache available
Mem: 603 116 337 99 149 371
Swap: 0 0 0 |
|
|
root@RaspberryPi-Gateway:~# iostat
Linux 5.4.72-v7 (RaspberryPi-Gateway) 03/29/21 _armv7l_ (4 CPU)
avg-cpu: %user %nice %system %iowait %steal %idle
4.63 0.01 24.77 0.09 0.00 71.50
Device: tps Blk_read/s Blk_wrtn/s Blk_read Blk_wrtn
mmcblk0 3.44 91.07 15.14 96231 15997
mmcblk0p1 0.07 0.69 0.00 729 1
mmcblk0p2 3.33 88.41 15.14 93414 15996
|
|
root@RaspberryPi-Gateway:~# iostat
Linux 5.4.72-v7 (RaspberryPi-Gateway) 03/29/21 _armv7l_ (4 CPU)
avg-cpu: %user %nice %system %iowait %steal %idle
4.02 0.01 21.68 0.03 0.00 74.26
Device: tps Blk_read/s Blk_wrtn/s Blk_read Blk_wrtn
mmcblk0 1.33 8.31 10.54 81599 103441
mmcblk0p1 0.01 0.07 0.00 731 1
mmcblk0p2 1.32 8.03 10.54 78780 103440 |
|
|
root@RaspberryPi-Gateway:~# df -h
Filesystem Size Used Available Use% Mounted on
/dev/root 375.7M 216.1M 136.1M 61% /
devtmpfs 333.7M 0 333.7M 0% /dev
tmpfs 462.2M 4.0K 462.2M 0% /dev/shm
tmpfs 462.2M 9.5M 452.7M 2% /run
tmpfs 462.2M 0 462.2M 0% /sys/fs/cgroup
tmpfs 462.2M 2.8M 459.4M 1% /tmp
tmpfs 462.2M 280.0K 461.9M 0% /var/volatile
/dev/mmcblk0p1 48.5M 27.4M 21.0M 57% /boot
|
|
root@RaspberryPi-Gateway:~# df -h
Filesystem Size Used Available Use% Mounted on
/dev/root 241.6M 139.5M 85.6M 62% /
devtmpfs 173.0M 0 173.0M 0% /dev
tmpfs 301.5M 4.0K 301.5M 0% /dev/shm
tmpfs 301.5M 21.4M 280.1M 7% /run
tmpfs 301.5M 0 301.5M 0% /sys/fs/cgroup
tmpfs 301.5M 2.5M 299.1M 1% /tmp
tmpfs 301.5M 328.0K 301.2M 0% /var/volatile
/dev/mmcblk0p1 50.8M 29.2M 21.6M 58% /boot
tmpfs 60.3M 0 60.3M 0% /run/user/0 |
|
|
Limitation
"rbus" and "runit" Integration also part of Tiny RDKB effort but still those changes are not available in stable2 branch.
we will integrated in RPI once those changes are successfully merged in stable2.
References
Jira
Gerrit Links
https://code.rdkcentral.com/r/q/REFPLTB-916