SDK Quick Start Guide
Product Name: IoT Edge Computer Gateway
Model Name: DSGW-210
Revision History
Specification | Sect. | Update Description | By | |
Rev | Date | |||
1.0 | 2021-08-06 | New version release | ||
1.1 | 2022-04-05 | Add Power management | ||
1.2 | 2022-06-06 | Add serial connection | ||
Approvals
Organization | Name | Title | Date |
This Quick Start Guide explains the basics: how to connect and set up your target on the network; how to install the SDK; and how to build the firmware images.
The Linux Software Developer’s Kit (SDK) is an embedded hardware and software suite that enables Linux developers to create applications on Dusun’s DSGW-210 gateway. Base on the 4.4 Linux kernel, and leveraging existing open source software, the SDK simplifies the process of adding custom applications. Device drivers, GNU toolchain, Predefined configuration profiles, and sample applications are all in included.
SOC: RK3328
Quad-core ARM Cortex-A53
Mali-450MP2 GPU
Power Supply: DC-5V
LTE module: BG96 (LET CAT-1)
Wi-Fi module: 6221A (Wi-Fi chip: RTL8821CS)
Zigbee: EFR32MG1B232F256GM32
Z-wave: ZGM130S037HGN
Bluetooth: EFR32BG21A020F768IM32 eMMC: 8GB SDRAM: 2BG
This section describes how to connect the gateway into your host computer and network.
Connecting a gateway - Power
Make sure that the power adapter is 5V/3A.
Select the appropriate power plug adaptor for your geographical location. Insert it into the slot on the Universal Power Supply; then plug the power supply into an outlet.
Connect the output plug of the power supply to the gateway
Connecting a gateway – USB port
1. Connect one end of the USB cable to the USB port on the laptop or desktop 2. Connect the other end of USB cable to the USB port on the gateway.
Figure3-1. Connecting a gateway via USB port
Connecting a PCBA board – Serial Port
If you want to debug the gateway, you can open the shell, Connect the PC to the PCBA board via Serial to USB tool.
PIN in board for serial connection: TP1100: RX TP1101: TX
Figure3-1. Connecting a PCBA via Serial-USB tool
Please use ubuntu 18.04 .iso image to setup your build environment. You can use a virtual machine or a physical PC to install ubuntu 18.04.
It is recommended that novice users use virtual machines, install ubuntu 18.04 to the virtual machine, and leave enough disk space (at least 100G) for the virtual machine.
The use of physical machine compilation users can use a ubuntu PC.
The source package name will be 3328-linux-*.tar.gz, get it from Dusun FTP.
The next step can be taken only after generating the MD5 value of the source compression package and comparing the MD5 value of the MD5 .txt text to confirm that the MD5 value is the same, and if the MD5 value is not the same, the energy code pack is damaged, please download it again.
$ md5sum rk3328-linux-*.tar.gz
Copy the source code to the corresponding directory and unzip the source code compression package.
$ sudo -i
$ mkdir workdir
$ cd workdir
$ tar -zxvf /path/to/rk3328-linux-*.tar.gz
$ cd rk3328-linux
You can build buildroot, ubuntu or debian rootfs image. Select it in "./build.sh init".
$ ./build.sh init processing option: init ============You're building on Linux=========== Please choose BoardConfig BoardConfig_rp3328_buildroot BoardConfig_rp3328_ubuntu BoardConfig_rp3328_debian Please input num: |
We strongly recommend you to build and run the system with buildroot rootfs to get familiar with the hardware and build environment, when you get started.
After you tried buildroot system, you can try ubuntu and debian system.
This section is for building ubuntu or debian file system. If you want to build the buildroot file system, skip this section.
Compile Ubuntu
Download the root file system compression package ubuntu.tar.gz
The Root file system compresses the package directory: Unzip the compression package
$ tar -zxvf ubuntu.tar.gz // you get ubuntu.img
Copy the root file system to the specified path
$ cd workdir/rk3328-linux $ mkdir ubuntu $ cp /path/to/ubuntu.img ./ubuntu/
Compile Debian
Download the root file system compression package debian.tar.gz
Unzip the compression package
$ tar -zxvf debian.tar.gz // you get linaro-rootfs.img
杭州市大关路 189
Tel:86 -571-86769027/8
Copy the root file system to the specified path
Build a complete directory of firmware files: rockdev/update.img and other separate images, update.img includes all firmware for full upgrade.
The build will take a long time, please wait patiently.
After update.img is built, burn it to the board according to chapter 7.
Connect the RK3328 board serial port to the PC via a USB to UART Bridge.
Use Putty or other Terminal software as your console tool, SERIAL CONSOLE SETTINGS:
115200/8N1
Baud: 115200
Data Bits: 8
Parity Bit: No
Stop Bit: 1
Power UP the board, you can see the boot log on console:
There is no default password for system login.
The update.img is composed of several parts. Main parts are uboot.img, boot.img, recovery.img, rootfs.img. uboot.img contains bootloader uboot boot.img contains the device tree .dtb image, Linux kernel image recovery.img: The system can boot up to recovery mode, recovery.img is the rootfs used in recovery mode.
rootfs.img: The normal rootfs image. In normal mode, system boot and mount this rootfs image.
You may need to build the images separately, especially when you focus on single module (e.g. uboot or kernel driver) development. Then you can build only that part of image and update that partition in flash.
This command making rockdev/*.img scatter firmware packaging builds in the directory update.img
If you use buildroot rootfs, some Dusun test scripts/tools are already installed in the final buildroot rootfs. You can refer to
buildroot/dusun_rootfs/add_ds_rootfs.sh
The following testing are done under the buildroot system.
The "ds_conf_ap.sh" script is for setting up Wi-Fi AP, SSID is "dsap", password is "12345678".
# ds_conf_ap.sh 192.168.10.1 start hostapd Configuration file: /etc/hostapd.conf wlan0: interface state UNINITIALIZED->COUNTRY_UPDATE start dnsmasq Stopping dnsmasq: OK Starting dnsmasq: OK Done!!!!!! # # # iwconfig lo no wireless extensions. wlan0 IEEE 802.11an ESSID:"dsap" Nickname:"<WIFI@REALTEK>" Mode:Master Frequency:5.745 GHz Access Point: 20:57:9E:8B:70:F5 Bit Rate:72.2 Mb/s Sensitivity:0/0 Retry:off RTS thr:off Fragment thr:off Encryption key:off Power Management:off Link Quality=1/100 Signal level=1/100 Noise level=0/100 Rx invalid nwid:0 Rx invalid crypt:0 Rx invalid frag:0 Tx excessive retries:0 Invalid misc:0 Missed beacon:0 eth0 no wireless extensions. # # ifconfig eth0 Link encap:Ethernet HWaddr 0A:11:D3:88:1E:B5 inet addr:192.168.1.4 Bcast:192.168.1.255 Mask:255.255.255.0 inet6 addr: fe80::811:d3ff:fe88:1eb5/64 Scope:Link UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1 RX packets:73386 errors:0 dropped:0 overruns:0 frame:0 TX packets:52722 errors:0 dropped:0 overruns:0 carrier:0 collisions:0 txqueuelen:1000 RX bytes:64535523 (61.5 MiB) TX bytes:4975499 (4.7 MiB) Interrupt:40 lo Link encap:Local Loopback inet addr:127.0.0.1 Mask:255.0.0.0 inet6 addr: ::1/128 Scope:Host UP LOOPBACK RUNNING MTU:65536 Metric:1 |
bg96_dial.sh is used for BG96 dial.
# ifconfig eth0 down # # bg96_dial.sh AT+CPIN? +CPIN: READY OK AT+CSQ +CSQ: 31,99 OK ... sent [IPCP ConfAck id=0x1] rcvd [IPCP ConfNak id=0x3 <addr 172.28.36.150> <ms-dns1 221.131.143.69> <ms-dns2 112.4.0.55>] sent [IPCP ConfReq id=0x4 <addr 172.28.36.150> <ms-dns1 221.131.143.69> <ms-dns2 112.4.0.55>] rcvd [IPCP ConfAck id=0x4 <addr 172.28.36.150> <ms-dns1 221.131.143.69> <ms-dns2 112.4.0.55>] Could not determine remote IP address: defaulting to 10.64.64.64 local IP address 172.28.36.150 remote IP address 10.64.64.64 primary DNS address 221.131.143.69 secondary DNS address 112.4.0.55 <===== after connected, type Ctrl+Z ^Z[1]+ Stopped bg96_dial.sh # # ifconfig lo Link encap:Local Loopback inet addr:127.0.0.1 Mask:255.0.0.0 inet6 addr: ::1/128 Scope:Host UP LOOPBACK RUNNING MTU:65536 Metric:1 RX packets:131 errors:0 dropped:0 overruns:0 frame:0 TX packets:131 errors:0 dropped:0 overruns:0 carrier:0 collisions:0 txqueuelen:1 RX bytes:12350 (12.0 KiB) TX bytes:12350 (12.0 KiB) ppp0 Link encap:Point-to-Point Protocol inet addr:172.28.36.150 P-t-P:10.64.64.64 Mask:255.255.255.255 UP POINTOPOINT RUNNING NOARP MULTICAST MTU:1500 Metric:1 RX packets:6 errors:0 dropped:0 overruns:0 frame:0 TX packets:6 errors:0 dropped:0 overruns:0 carrier:0 collisions:0 txqueuelen:3 RX bytes:96 (96.0 B) TX bytes:114 (114.0 B) wlan0 Link encap:Ethernet HWaddr 20:57:9E:8B:70:F5 inet addr:192.168.10.1 Bcast:0.0.0.0 Mask:255.255.255.0 inet6 addr: fe80::2257:9eff:fe8b:70f5/64 Scope:Link UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1 RX packets:33387 errors:0 dropped:0 overruns:0 frame:0 TX packets:56331 errors:0 dropped:636 overruns:0 carrier:0 collisions:0 txqueuelen:1000 RX bytes:5077398 (4.8 MiB) TX bytes:78164665 (74.5 MiB) # # ping www.baidu.com PING www.baidu.com (36.152.44.96): 56 data bytes |
64 bytes from 36.152.44.96: seq=0 ttl=56 time=317.025 ms
You need to configure APN, username/password for BG96, in quectel-chatconnect and quectel-ppp file. Before you run the test. # cat /etc/ppp/peers/quectel-chat-connect
ABORT "BUSY"
ABORT "NO CARRIER"
ABORT "NO DIALTONE"
ABORT "ERROR"
ABORT "NO ANSWER"
TIMEOUT 5
"" AT OK ATE0 OK AT+CPIN?
READY AT
OK AT+CSQ
OK AT+QCFG="nwscanmode"
OK AT+QCFG="nwscanseq"
OK AT+QCFG="iotopmode" OK AT+QCFG="band"
OK AT+CREG?
OK ATI;+CSUB;+CSQ;+CPIN?;+COPS?;+CGREG?;&D2
# Insert the APN provided by your network operator, default apn is 3gnet <================ OK AT+CGDCONT=1,"IP","3gnet",,0,0
OK ATD*99#
CONNECT
#
#
# cat /etc/ppp/peers/quectel-ppp
# cat /etc/ppp/peers/quectel-ppp
# /etc/ppp/peers/quectel-pppd
# Usage:root>pppd call quectel-pppd
#Modem path, like /dev/ttyUSB3,/dev/ttyACM0, depend on your module, default path is /dev/ttyUSB3
/dev/ttyUSB5 115200
#Insert the Username and Password for authentication, default User and Password are test user "test" password "test" <==========================
# The chat script, customize your APN in this file connect 'chat -s -v -f /etc/ppp/peers/quectel-chat-connect'
# The close script
disconnect 'chat -s -v -f /etc/ppp/peers/quectel-chat-disconnect'
# Hide password in debug messages hide-password
# The phone is not required to authenticate noauth
# Debug info from pppd debug
# If you want to use the HSDPA link as your gateway defaultroute
# pppd must not propose any IP address to the peer noipdefault # No ppp compression novj novjccomp noccp ipcp-accept-local ipcp-accept-remote local
# For sanity, keep a lock on the serial line lock modem dump nodetach
# Hardware flow control nocrtscts remotename 3gppp ipparam 3gppp ipcp-max-failure 30
# Ask the peer for up to 2 DNS server addresses usepeerdns
# #
# dsled
Usage: dsled [r|g|b] [on/off] dsled [r|g|b] [blink_slow|blink_fast] dsled [r|g|b] breathe
#
# dsled r on # dsled b blink_fast
# i2cdetect -y 0
0 1 2 3 4 5 6 7 8 9 a b c d e f 00: -- -- -- -- -- -- -- -- -- -- -- -- -- 10: -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- 20: -- -- -- 23 -- -- -- -- -- -- -- -- -- -- -- --
30: -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- --
40: -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- 50: -- -- -- -- -- 55 -- -- -- -- -- -- -- -- -- --
60: -- -- -- -- -- -- -- -- -- -- 6a -- -- -- -- --
70: -- -- -- -- -- -- -- --
#
Actually LED controlled is I2C interface.
Normal mode buildroot rootfs config file: buildroot/configs/rockchip_rk3328_defconfig Recovery mode buildroot rootfs config file:
buildroot/configs/rockchip_rk3328_recovery_defconfig
#cd buildroot
#make rockchip_rk3328_defconfig
#make menuconfig
#mv .config ./configs/rockchip_rk3328_defconfig <==== after config change, overwrite the old one
If you want to change buildroot configure, here are the steps:
Figure3-1.buildroot make menuconfig
Make directory buildroot/dusun_package/<your_app>
Put APP source code files and Makefile to buildroot/dusun_package/< your_app > your_app.h your_app.c Makefile
Make directory buildroot/package/< your_app >
Config.in your_app.mk
Add Config.in sourcing in buildroot/package/Config.in
menu "Dusun software"
source "package/dsled/Config.in" + source "package/<your_app>/Config.in" endmenu
Make menuconfig to select your APP, and save the configure file as 5.2.
"./build.sh rootfs" to rebuild rootfs
Please refer to buildroot/dusun_package/dsled/, it's a useful example.
If you have built a buildroot system image, and want to switch to ubuntu or debian image. You don't need to clean the make and do a clean rebuild. Just do the following steps:
"./build.sh init" to select ubuntu or debian
"./build.sh rootfs" to rebuild ubuntu or debian rootfs
"./build.sh" to build a the final update.img
Be careful, the dusun tools and scripts are default copied to buildroot rootfs, not to ubuntu or debian rootfs.
If you want to copy them to ubuntu or debian rootfs, you can modify the buildroot/dusun_rootfs/add_ds_rootfs.sh. For the APPs, you can copy the code to the board and build it on the target board ubuntu or debian system, since it has gcc and other toolchains.
Please build a debian system to do the following steps. The code will be compiled on the board, not on host.
root@linaro-alip:~# apt-get update root@linaro-alip:~# apt-get install libncurses5-dev root@linaro-alip:~# apt-get install libreadline-dev root@linaro-alip:~# apt-get install libssl-dev root@linaro-alip:~# apt-get install libjson-c-dev
Prepare some library on the board
scp SDK
"buildroot/dusun_rootfs/target_scripts/export_zigbee_zwave_ble_gpio.sh" from host to board, under /root
root@linaro-alip:~# ./export_zigbee_zwave_ble_gpio.sh root@linaro-alip:~#
Power on wireless modules on board.
Zigbee interface is /dev/ttyUSB0.
Download "Z3GatewayHost_EFR32MG12P433F1024GM48.tar.gz" from Dusun FTP, and copy it to board, under /root.
杭州市大关路 189
Tel:86-571-86769027/8
root@linaro-alip:~# tar xvzf Z3GatewayHost_EFR32MG12P433F1024GM48.tar.gz root@linaro-alip:~# cd Z3GatewayHost_EFR32MG12P433F1024GM48 root@linaro-alip:~/Z3GatewayHost_EFR32MG12P433F1024GM48# make <=============== wait for app build OK root@linaro-alip:~/Z3GatewayHost_EFR32MG12P433F1024GM48# cd build/exe/ root@linaro-alip:~/Z3GatewayHost_EFR32MG12P433F1024GM48/build/exe# root@linaro-alip:~/Z3GatewayHost_EFR32MG12P433F1024GM48/build/exe# ls Z3GatewayHost_EFR32MG12P433F1024GM48 ota-files root@linaro-alip:~/Z3GatewayHost_EFR32MG12P433F1024GM48/build/exe#./ Z3GatewayHost_EFR32MG12P433F1024GM48 -n1 -p /dev/ttyUSB0 -b115200 Reset info: 11 (SOFTWARE) ezsp ver 0x07 stack type 0x02 stack ver. [6.6.5 GA build 204] Ezsp Config: set source route table size to 0x0064:Error: set: 0x35 Ezsp Config: set security level to 0x0005:Success: set Ezsp Config: set address table size to 0x0002:Success: set Ezsp Config: set TC addr cache to 0x0002:Success: set Ezsp Config: set stack profile to 0x0002:Success: set Ezsp Config: set MAC indirect TX timeout to 0x1E00:Success: set Ezsp Config: set max hops to 0x001E:Success: set ... Z3GatewayHost_EFR3 |
Then build Z3Gateway and run.
For more information about Z3Gateway, please visit https://docs.silabs.com/ for more information.
Z-Wave interface is /dev/ttyS1.
Download " rk3328_zwave_test.tar.gz " from Dusun FTP, and copy it to board, under /root.
root@linaro-alip:~# tar xvzf rk3328_zwave_test.tar.gz root@linaro-alip:~# ls Z3GatewayHost_EFR32MG12P433F1024GM48 export_zigbee_zwave_ble_gpio.sh Z3GatewayHost_EFR32MG12P433F1024GM48.tar.gz rk3328_zwave_test.tar.gz zipgateway root@linaro-alip:~# |
Unzip it and you can get ./zipgateway
root@linaro-alip:~# cd zipgateway/zipgateway-7.13.01-Source/usr/local/src/serialapi root@linaro-alip:~/zipgateway/zipgateway-7.13.01-Source/usr/local/src/serialapi# make clean root@linaro-alip:~/zipgateway/zipgateway-7.13.01-Source/usr/local/src/serialapi# make <============= wait for build OK, you get "my_serialapi_test" in ./serialapi root@linaro-alip:~/# ./my_serialapi_test /dev/ttyS1 0 // set region: 0 is EU, 1 is US root@linaro-alip:~/# ./my_serialapi_test /dev/ttyS1 ... dump: <=== pwj: 10 01 15 5a 2d 57 61 76 65 20 37 2e 31 31 00 07 Vesion: Z-Wave 7.11 dump: ===> pwj: 01 03 00 08 f4 dump: <== i Get init data dump: ===> pwj: 01 03 00 02 fe dump: <=== pwj: 25 01 02 08 08 1d 01 00 00 00 00 00 00 00 00 00 pwj: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 pwj: 00 00 00 07 00 dump: nlist pwj: 01 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 pwj: 00 00 00 00 00 00 00 00 00 00 00 00 00 Node [1] GW |
Now build a zwave simple test tool and run:
In "my_serialapi_test", press 'a' to include zwave device, 'r' to exclude device, 'd' to reset to default, 'i' to get devices list and 'q' to quit.
The Zipgateway is siliabs software, "my_serialapi_test" is just a very simple tool. For more information about Zipgateway, please visit https://docs.silabs.com/ for more information.
If for default Dusun built, Z-Wave frequency can be configured in
/etc/config/dusun/zwave/region
0x01 – US | 0x02 – ANZ | 0x03 – HK | 0x04 – Malaysia |
0x05 – India | 0x06 – Israel | 0x07 – Russia | 0x08 – China |
0x20 – Japan | 0x21 - Korea |
BLE interface is /dev/ttyUSB1.
Download "rk3328_ble_test.tar.gz" from Dusun FTP, and copy it to board, under /root.
root@linaro-alip:~# tar xvzf rk3328_ble_test.tar.gz root@linaro-alip:~# cd bletest/test/ root@linaro-alip:~/bletest/test#
Unzip it and you can get ./bletest build ble test tool and run:
More information about the BLE test tool, please visit https://docs.silabs.com/ for more information.
root@linaro-alip:~/bletest/test# make
<========== wait for build OK, and you get ./build/test root@linaro-alip:~/bletest/test# ./build/test /dev/ttyUSB1 115200 -C
Choose the correct interface for LoRaWAN, for example /dev/spidev32766.0. The configuration file for it is in ./sx1302_hal/packet_forwarder/global_conf.json.
Download "sx1302_hal_0210.tar.gz" from Dusun FTP, and copy it to board, under /root.
root@linaro-alip:~# tar xvzf sx1302_hal_0210.tar.gz root@linaro-alip:~# cd sx1302_hal/
Untar it and you can get ./sx1302_hal build LoRaWAN sample code sx1302_hal and run: More information about the LoRaWAN code, please visit
https://www.semtech.com/products/wireless-rf/lora-core/sx1302 for more information.
root@linaro-alip:~/sx1302_hal# make all
<========== wait for build OK, and you get ./packet_forwarder/ root@linaro-alip:~/sx1302_hal/packet_forwarder# ./lora_pkt_fwd
Upgrade tool:AndroidTool_Release_v2.69
Connect the OTG port to the burning computer USB port, it's also act as 5V power supply
Press "Ctrl+C" when uboot is booting up, to enter uboot:
uboot "rbrom" comand to reboot the board into maskrom mode, for a complete "update.img" upgrade.
"rockusb 0 mmc 0" command to reboot board to loader mode, for a partial firmware upgrade or a complete "update.img" upgrade.
The battery management chip Dusun used is BQ25895 Methods to optimize CPU power consumption is listed,
Adjust cpufreq parameter.
/* the default frequency scaling strategy used is interactive, relative parameters are as follows: */ ls -l /sys/devices/system/cpu/cpu0/cpufreq/interactive go_hispeed_load /* when the loading is larger than go_hispeed_load and the frequency is smaller than hispeed_freq, directly jump to hispeed_freq */ hispeed_freq /* when jumping from low frequency to high frequency, need to jump to hispedd_freq first */ above_hispeed_delay /* when the frequency is larger than hispeed_freq, the time duration before each frequency increase */ min_sample_time /* after each frequency increase, if it is to reduce the frequency next time , the time duration before frequency reduce */ target_loads /* the target loading of the frequency scaling */ timer_rate /* the loading sampling time,unit:us */ timer_slack /* the loading sampling time after cpu entering idle */ boost /* when the frequency is smaller than hispeed_freq, keep boost to hispeed_freq */ boostpulse /* when the frequency is smaller than hispeed_freq, boost to hispeed_freq, keep a while */ boostpulse_duration /* time duration of boostpulse, unit:us */ io_is_busy /* whether to compute io wait to cpu loading */ We mainly adjust three parameters: hispeed_freq,target_loads,timer_rate: 1. hispeed_freq: select an appropriate transition frequency, to make cpu stable in the medium frequency, with the best power consumption, too large or too small will cause cpu jump to high frequency easily and increase the power consumption. 2. target_loads:easier to run with low frequency after this value is increased, both the power consumption and the performance will be reduced. 3. timer_rate: easier to run with low frequency after this value is increased, both the power consumption and the performance will be reduced. |
Close some cpu, limit the highest frequency of cpu
/* close cpu2,cpu3 */ echo 0 > /sys/devices/system/cpu/cpu2/online echo 0 > /sys/devices/system/cpu/cpu3/online /* List all the available frequency */ cat /sys/devices/system/cpu/cpu0/cpufreq/scaling_available_frequencies output: 408000 600000 816000 1008000 1200000 1296000 /* set the max frequency of cpu0 to 1200MHz */ echo 1200000 > /sys/devices/system/cpu/cpu0/cpufreq/scaling_max_freq |
SoC with ARM Big-Little architecture can bind the tasks with high loading to little cores through CPUSET since the energy efficiency of the little core is better.
/* Note: SoC with SMP architecture can also bind the tasks to some cpu so that other cpus can enter low power consumption mode, but maybe it will make cpu easy to run with high frequency, which will increase the power consumption. */
/* create group of litte core*/ mkdir /dev/cpuset/little /* set cpu used by group of little core */ echo 0-3 > /dev/cpuset/little/cpus /* add pid=1111 task into the group of little core */ echo 1111 > /dev/cpuset/little/tasks /* Android system creates several groups by default, the framework layer puts the tasks into differenct groups, you can adjust cpus of each group, analyze the power consumption */ ls /dev/cpuset background foreground system-background top-app |
Limit the cpu bandwidth of the tasks with high loading through CPUCTL (need to enable the macro CONFIG_CFS_BANDWIDTH).
/* create the group of bandwidth limitation */ mkdir /dev/cpuctl/mygroup /* set the cycle of bandwidth limitation as 10ms */ echo 10000 > /dev/cpuctl/mygroup/cpu.cfs_quota_us /* within each cycle, total running time of the tasks in the group cannot exceed 5ms, this value can be larger than cfs_quota_us, because it is the total running time of multiple cpus */ echo 5000 > /dev/cpuctl/mygroup/cpu.cfs_period_us /* add relative tasks into the group */ echo 1111 > /dev/cpuctl/mygroup/tasks echo 1112 > /dev/cpuctl/mygroup/tasks /* cpu.shares means to limit the bandwidth of the task through weight, used for performance optimization, without affecting the power consumption */ /dev/cpuctl/mygroup/cpu.shares |