ltp-ddt nand_ecc_tests
{
cat <<-EOF >&2
usage: ./${0##*/} [-n dev_node] [-r rules]
-n dev_node: optional; if not provided, choose one with the biggest size
-r rules: the rules used to inject error bits
-t test_type: optional; by default is positive test. you could pass 'negative'
-e test empty sectors
-h Help print this usage
EOF
exit 0
}
do_cmd dd if=/dev/urandom of="$testfile" bs=1 count=$pagesize
do_cmd nandwrite -p "$dev_node" "$testfile"
orig_nanddump_w_oob="$TMPDIR/testfile_nanddump_w_oob.original"
do_cmd nanddump -l "$pagesize" -o -f "$orig_nanddump_w_oob" "$dev_node" #-o --oob Dump OOB data
test_print_trc "Modifying nand dump file to prepare for ecc test"
corrupted_nanddump="$TMPDIR/testfile_nanddump.corrupted"
modify_nanddump_file "$orig_nanddump_w_oob" "$corrupted_nanddump" "$rules" #associate with rules
test_print_trc "Write the corrupted nanddump file back..."
do_cmd flash_erase -q "$dev_node" 0 0
do_cmd nandwrite -n -o "$dev_node" "$corrupted_nanddump" # -o, --oob Input contains oob data
hexdump_original_w_oob="$TMPDIR/original_w_oob"
hexdump_corrupted_w_oob="$TMPDIR/corrupted_w_oob"
do_cmd "hexdump -C $orig_nanddump_w_oob > "$hexdump_original_w_oob" "
do_cmd "hexdump -C $corrupted_nanddump > "$hexdump_corrupted_w_oob" "
test_print_trc "The below are the errors being injected in the nand page"
test_print_trc "diff "$hexdump_original_w_oob" "$hexdump_corrupted_w_oob" "
diff "$hexdump_original_w_oob" "$hexdump_corrupted_w_oob"
sleep 5
test_print_trc "Dumpping nand..."
corrected_nanddump="$TMPDIR/testfile_nanddump.corrected"
do_cmd "nanddump -l "$pagesize" -f "$corrected_nanddump" "$dev_node" " > $TMPDIR/nanddump_msg 2>&1
cat $TMPDIR/nanddump_msg
cat $TMPDIR/nanddump_msg |grep "uncorrectable bitflip(s)" && result=1 || result=0
echo "result is $result"
if [ $type = 'negative' ]; then
test_print_trc "The bit error(s) are not corrected as expected, checking if dut is ok..."
#check if dut is still stable
do_cmd "cat /proc/mtd"
do_cmd "time dd if=/dev/urandom of=$dev_node bs=1M count=10"
do_cmd flash_erase -q "$dev_node" 0 0
exit 0
else
test_print_trc "Nand dump from uncorrected page ..."
uncorrected_nanddump="$TMPDIR/testfile_nanddump.uncorrected"
do_cmd "nanddump -n -o -l "$pagesize" -f "$uncorrected_nanddump" "$dev_node" "
do_cmd "hexdump -C "$uncorrected_nanddump" "
do_cmd flash_erase -q "$dev_node" 0 0
die "Nand ECC Test failed. Not all errors are corrected"
fi
else
test_print_trc "Nand ECC Test Pass"
do_cmd flash_erase -q "$dev_node" 0 0
exit 0
fi
# Input
# $1: input file
# $2: rules like "<sector#>:byte_offset:mask"~"<oob>:byte_offset:mask"
# sector, byte_offset are decimal. 'mask' could be decimal or hex
# byte_offset starts from 0
# Output
# modified file
modify_nanddump_file()
{
inputfile=$1
outputfile=$2
rules=$3
local filesize=`get_filesize $1`
cp $inputfile $outputfile
ORIG_IFS=$IFS
IFS="~"
for rule in $rules
do
# rule is like "sector#:byte_offset:mask" or "oob:offset:mask"
sector=`echo "$rule" | cut -d":" -f1 | tr [:upper:] [:lower:]`
byte_offset=`echo "$rule" | cut -d":" -f2`
mask=`echo "$rule" | cut -d":" -f3`
if [ $sector = 'oob' ]; then
offset=$(( $pagesize + $byte_offset ))
if [ $offset -ge $filesize ]; then
die "Offset to $inputfile should not be bigger than the filesize"
fi
else
offset=$(( $sector * $sector_size + $byte_offset ))
if [ $offset -ge $pagesize ];then
die "Offset to $inputfile for non-oob data should not bigger than pagesize"
fi
fi
# get the original byte and modify it
orig_byte=`hexdump_onebyte $inputfile $offset`
mod_byte_dec=$(( 0x$orig_byte ^ $mask )) #xor mask
mod_byte=`echo "obase=16; $mod_byte_dec" |bc`
# write the modified byte to replace the original one
replace_onebyte $outputfile $offset $mod_byte
done
IFS=$ORIG_IFS
}
ltp-ddt nand_ecc_tests的更多相关文章
- LTP随笔——本地调用ltp之ltp4j
关于ltp本地调用的相关参考请见LTP的Git项目:https://github.com/HIT-SCIR 以下以/home/lion/Desktop路径为例下面教程中出现的具体路径以你实际配置的为准 ...
- ZH奶酪:自然语言处理工具LTP语言云调用方法
前言 LTP语言云平台 不支持离线调用: 支持分词.词性标注.命名实体识别.依存句法分析.语义角色标注: 不支持自定义词表,但是你可以先用其他支持自定义分词的工具(例如中科院的NLPIR)把文本进行分 ...
- Eclipse DDT
http://www.eclipse.org/downloads/ https://github.com/DDT-IDE/DDT/blob/latest/documentation/UserGuide ...
- ASP.NET中常用的几个李天平开源公共类LTP.Common,Maticsoft.DBUtility,LtpPageControl
ASP.NET中常用的几个开源公共类: LTP.Common.dll: 通用函数类库 源码下载Maticsoft.DBUtility.dll 数据访问类库组件 源码下载LtpPageC ...
- 很好的一篇讲LTP在编解码中的作用的文章
原文链接 LONG-TERM PREDICTION by: Adit Aviv Kfir Grichman introduction: The speech signal has been ...
- ASP.NET中常用的几个李天平开源公共类LTP.Common,Maticsoft.DBUtility,LtpPageControl (转)
ASP.NET中常用的几个开源公共类: LTP.Common.dll: 通用函数类库 源码下载Maticsoft.DBUtility.dll 数据访问类库组件 源码下载LtpPageC ...
- 编译哈工大语言技术平台云LTP(C++)源码及LTP4J(Java)源码
转自:编译哈工大语言技术平台云LTP(C++)源码及LTP4J(Java)源码 JDK:java version “1.8.0_31”Java(TM) SE Runtime Environment ( ...
- LTP学习
下载LTP源码和模型文件: https://github.com/linux-test-project/ltp 官方说明文档 http://ltp.readthedocs.org/zh_CN/late ...
- LTP 分词算法实践
参考链接: https://github.com/HIT-SCIR/ltp/blob/master/doc/install.rst http://www.xfyun.cn/index.php/serv ...
- ltp工具使用配置
ltp是一个比较全的自然语言处理工具,可以用它进行分词.词性标注.语法分析等任务. ---- 准备 下载 下载ltp和ltp4j,在cmake官网下载并安装相应版本的cmake,并且下载ant. 构建 ...
随机推荐
- 01 安装IDEA
https://www.jetbrains.com 1 . 2
- vscode中执行gulp task的简便方法
本文重点是gulp在vscode中执行task任务的方法 如何像webstorm那样简便操作gulp 的task 第1步:安装node.下载地址:https://nodejs.org/zh-cn/ 检 ...
- [AGC001E]BBQ Hard 组合数学
题目描述 Snuke is having another barbeque party. This time, he will make one serving of Skewer Meal. He ...
- C#防止窗口重复打开
修改Program.cs文件 using System; using System.Collections.Generic; using System.Linq; using System.Windo ...
- womenzijide2
<!DOCTYPE html> <html lang="en"> <head> <meta http-equiv="Conten ...
- Centos6.5在线配置安装Java环境与Tomcat环境
书写此文一来记录环境,以便后期查看使用,Linux环境下配置centos与Java开发环境 本文环境:虚拟机系统centos6.5 链接工具:xshell脚本链接工具 一.安装Java开发 ...
- 移动端调试 — chrome模拟器基础调试
打开开发者工具,进入chrome调试状态,点击左上角的手机图标,进入手机模拟器调试状态. 模拟器支持操作: 切换设备类型,模拟网络环境,模拟bar,keyboard弹出状态,横屏状态,更改UserAg ...
- 【CDN+】 Spark入门---Handoop 中的MapReduce计算模型
前言 项目中运用了Spark进行Kafka集群下面的数据消费,本文作为一个Spark入门文章/笔记,介绍下Spark基本概念以及MapReduce模型 Spark的基本概念: 官网: http://s ...
- DOS 查看端口占用,Kill线程
查看端口占用 C:\Users\1>netstat -aon|findstr "8020" TCP 0.0.0.0:8020 0.0.0.0:0 LISTENING 1468 ...
- 为什么有mac地址还学要有IP地址??
历史原因:早期的以太网只有集线器 ,没有交换机,所以发出去的包能被以太网内的所有机器监听到,因此要附带上MAC地址,每个机器只需要接受与自己MAC地址相匹配的包. 个人感觉上面的说法并不是太准确.找明 ...