android分区dtbo,verifyDTBO.sh

#!/bin/bash

if [ -z "${ANDROID_HOST_OUT}" ]; then

echo 'ANDROID_HOST_OUT not set. Please run lunch'

exit 1

fi

ANDROID_HOST_BIN_LOCATION=${ANDROID_HOST_OUT}/bin

adb root

tmpdir=$(mktemp -d)

trap 'rm -rf ${tmpdir};' EXIT

cd $tmpdir

#find out the location to read the DTBO image from

boot_suffix=$(adb wait-for-device shell getprop ro.boot.slot_suffix)

dtbo_partition="/dev/block/by-name/dtbo"

dtbo_path=$dtbo_partition$boot_suffix

#read the dtbo image and the final device tree from device

adb pull $dtbo_path dtbo.img > /dev/null

adb pull /sys/firmware/fdt final_dt > /dev/null

#decompile the DTBO image

mkdtimg_path="${ANDROID_HOST_BIN_LOCATION}/mkdtboimg.py"

$mkdtimg_path dump dtbo.img -b dumped_dtbo > /dev/null

#Get the index of the overlay applied from the kernel command line

overlay_idx=$(adb shell cat /proc/cmdline | grep -o "androidboot.dtbo_idx=[^ ]*" | cut -d "=" -f 2)

arg=""

for idx in ${overlay_idx//,/ }

do

arg="${arg}dumped_dtbo.${idx} "

done

#verify that the overlay was correctly applied

verify_bin_path="${ANDROID_HOST_BIN_LOCATION}/ufdt_verify_overlay_host"

$verify_bin_path final_dt $arg

result=$?

if [[ "$result" -eq "0" ]]; then

echo "Overlay was verified successfully"

else

echo "Incorrect overlay application"

fi

exit $result

Bash程序

|

51行

|

1.25 KB

#!/bin/bash

if [ -z "${ANDROID_HOST_OUT}" ]; then

echo 'ANDROID_HOST_OUT not set. Please run lunch'

exit 1

fi

ANDROID_HOST_BIN_LOCATION=${ANDROID_HOST_OUT}/bin

adb root

tmpdir=$(mktemp -d)

trap 'rm -rf ${tmpdir};' EXIT

cd $tmpdir

#find out the location to read the DTBO image from

boot_suffix=$(adb wait-for-device shell getprop ro.boot.slot_suffix)

dtbo_partition="/dev/block/by-name/dtbo"

dtbo_path=$dtbo_partition$boot_suffix

#read the dtbo image and the final device tree from device

adb pull $dtbo_path dtbo.img > /dev/null

adb pull /sys/firmware/fdt final_dt > /dev/null

#decompile the DTBO image

mkdtimg_path="${ANDROID_HOST_BIN_LOCATION}/mkdtboimg.py"

$mkdtimg_path dump dtbo.img -b dumped_dtbo > /dev/null

#Get the index of the overlay applied from the kernel command line

overlay_idx=$(adb shell cat /proc/cmdline | grep -o "androidboot.dtbo_idx=[^ ]*" | cut -d "=" -f 2)

arg=""

for idx in ${overlay_idx//,/ }

do

arg="${arg}dumped_dtbo.${idx} "

done

#verify that the overlay was correctly applied

verify_bin_path="${ANDROID_HOST_BIN_LOCATION}/ufdt_verify_overlay_host"

$verify_bin_path final_dt $arg

result=$?

if [[ "$result" -eq "0" ]]; then

echo "Overlay was verified successfully"

else

echo "Incorrect overlay application"

fi

exit $result

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
很抱歉,我是一名语言模型,无法提供完整的代码。但我可以给你一些基本的概念和示例。 1. 簇表(Clustered Table): 簇表是按照表的主键将数据物理上存储在一起的表。这种表的查询效率较高,但是插入、删除和更新数据的效率较低。以下是一个简单的簇表的创建语句: ``` CREATE CLUSTER my_cluster_table (id NUMBER) TABLESPACE my_tablespace STORAGE (INITIAL 10M NEXT 10M); ``` 2. 范围分区表(Range Partitioned Table): 范围分区表是按照指定的范围将数据分散存储的表。例如,按照日期对数据进行分区。以下是一个简单的范围分区表的创建语句: ``` CREATE TABLE my_range_table (id NUMBER, name VARCHAR2(50), date_of_birth DATE) PARTITION BY RANGE (date_of_birth) (PARTITION p1 VALUES LESS THAN (TO_DATE('01-01-1990','DD-MM-YYYY')), PARTITION p2 VALUES LESS THAN (TO_DATE('01-01-2000','DD-MM-YYYY')), PARTITION p3 VALUES LESS THAN (MAXVALUE)); ``` 3. 散列分区表(Hash Partitioned Table): 散列分区表是根据指定的散列函数将数据分散存储的表。这种分区方式可以有效地平衡数据的分布。以下是一个简单的散列分区表的创建语句: ``` CREATE TABLE my_hash_table (id NUMBER, name VARCHAR2(50), department VARCHAR2(50)) PARTITION BY HASH (department) PARTITIONS 4; ``` 4. 列表分区表(List Partitioned Table): 列表分区表是根据指定的列值将数据分散存储的表。例如,按照地区对数据进行分区。以下是一个简单的列表分区表的创建语句: ``` CREATE TABLE my_list_table (id NUMBER, name VARCHAR2(50), region VARCHAR2(50)) PARTITION BY LIST (region) (PARTITION p1 VALUES ('North'), PARTITION p2 VALUES ('South'), PARTITION p3 VALUES ('East'), PARTITION p4 VALUES ('West')); ``` 5. 组合分区表(Composite Partitioned Table): 组合分区表是根据多个分区键将数据分散存储的表。以下是一个简单的组合分区表的创建语句: ``` CREATE TABLE my_composite_table (id NUMBER, name VARCHAR2(50), date_of_birth DATE, department VARCHAR2(50)) PARTITION BY RANGE (date_of_birth) SUBPARTITION BY HASH (department) SUBPARTITIONS 4 (PARTITION p1 VALUES LESS THAN (TO_DATE('01-01-1990','DD-MM-YYYY')) (SUBPARTITION s1, SUBPARTITION s2, SUBPARTITION s3, SUBPARTITION s4), PARTITION p2 VALUES LESS THAN (TO_DATE('01-01-2000','DD-MM-YYYY')) (SUBPARTITION s5, SUBPARTITION s6, SUBPARTITION s7, SUBPARTITION s8), PARTITION p3 VALUES LESS THAN (MAXVALUE) (SUBPARTITION s9, SUBPARTITION s10, SUBPARTITION s11, SUBPARTITION s12)); ``` 6. 对象表(Object Table): 对象表是存储对象类型数据的表。以下是一个简单的对象表的创建语句: ``` CREATE TYPE my_object AS OBJECT (id NUMBER, name VARCHAR2(50)); CREATE TABLE my_object_table OF my_object; ``` 7. 嵌套表(Nested Table): 嵌套表是存储嵌套表类型数据的表。以下是一个简单的嵌套表的创建语句: ``` CREATE TYPE my_nested AS TABLE OF VARCHAR2(50); CREATE TABLE my_nested_table (id NUMBER, values my_nested); ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值