per Intel policy to include file commit date using git cmd below. The policy does not apply to non-Intel (C) notices. git log --follow -C90% --format=%ad --date default <file> | tail -1 and then pull just the year from the result. Intel copyrights were not added to files where Intel either had no contribution ot the contribution lacked substance (ie license header updates, formatting changes, etc) For intel copyrights added, --follow and -C95% were used. Signed-off-by: paul luse <paul.e.luse@intel.com> Change-Id: I2ef86976095b88a9bf5b1003e59f3943cd6bbe4c Reviewed-on: https://review.spdk.io/gerrit/c/spdk/spdk/+/15209 Tested-by: SPDK CI Jenkins <sys_sgci@intel.com> Community-CI: Mellanox Build Bot Reviewed-by: Ben Walker <benjamin.walker@intel.com> Reviewed-by: Krzysztof Karas <krzysztof.karas@intel.com> Reviewed-by: Jim Harris <james.r.harris@intel.com>
105 lines
2.1 KiB
Bash
Executable File
105 lines
2.1 KiB
Bash
Executable File
#!/usr/bin/env bash
|
|
# SPDX-License-Identifier: BSD-3-Clause
|
|
# Copyright (C) 2020 Intel Corporation
|
|
# All rights reserved.
|
|
#
|
|
testdir=$(readlink -f "$(dirname "$0")")
|
|
rootdir=$(readlink -f "$testdir/../../")
|
|
source "$testdir/common.sh"
|
|
|
|
basic_rw() {
|
|
local native_bs=$1
|
|
local count size
|
|
local qds bss
|
|
|
|
qds=(1 64)
|
|
# Generate some bs for tests based on the native_bs
|
|
for bs in {0..2}; do
|
|
bss+=($((native_bs << bs)))
|
|
done
|
|
|
|
for bs in "${bss[@]}"; do
|
|
for qd in "${qds[@]}"; do
|
|
count=$((0xffff / bs))
|
|
count=$((count == 0 ? 1 : count))
|
|
size=$((count * bs))
|
|
|
|
gen_bytes "$size" > "$test_file0"
|
|
|
|
"${DD_APP[@]}" \
|
|
--if="$test_file0" \
|
|
--ob="$bdev0" \
|
|
--bs="$bs" \
|
|
--qd="$qd" \
|
|
--json <(gen_conf)
|
|
|
|
"${DD_APP[@]}" \
|
|
--ib="$bdev0" \
|
|
--of="$test_file1" \
|
|
--bs="$bs" \
|
|
--qd="$qd" \
|
|
--count="$count" \
|
|
--json <(gen_conf)
|
|
|
|
diff -q "$test_file0" "$test_file1"
|
|
clear_nvme "$bdev0" "" "$size"
|
|
done
|
|
done
|
|
}
|
|
|
|
basic_offset() {
|
|
# Check if offsetting works - using default io size of 4k
|
|
local count seek skip data data_check
|
|
|
|
gen_bytes 4096 > "$test_file0"
|
|
((count = seek = skip = 1))
|
|
data=$(< "$test_file0")
|
|
|
|
"${DD_APP[@]}" \
|
|
--if="$test_file0" \
|
|
--ob="$bdev0" \
|
|
--seek="$seek" \
|
|
--json <(gen_conf)
|
|
|
|
"${DD_APP[@]}" \
|
|
--ib="$bdev0" \
|
|
--of="$test_file1" \
|
|
--skip="$skip" \
|
|
--count="$count" \
|
|
--json <(gen_conf)
|
|
|
|
read -rn${#data} data_check < "$test_file1"
|
|
[[ $data == "$data_check" ]]
|
|
}
|
|
|
|
cleanup() {
|
|
clear_nvme "$bdev0"
|
|
rm -f "$test_file0" "$test_file1"
|
|
}
|
|
|
|
trap "cleanup" EXIT
|
|
|
|
nvmes=("$@")
|
|
nvme0=Nvme0 nvme0_pci=${nvmes[0]} bdev0=Nvme0n1
|
|
|
|
declare -A method_bdev_nvme_attach_controller_0=(
|
|
["name"]=$nvme0
|
|
["traddr"]=$nvme0_pci
|
|
["trtype"]=pcie
|
|
)
|
|
|
|
test_file0=$SPDK_TEST_STORAGE/dd.dump0
|
|
test_file1=$SPDK_TEST_STORAGE/dd.dump1
|
|
native_bs=$(get_native_nvme_bs "$nvme0_pci")
|
|
|
|
# Test if running with bs < native_bs successfully fails
|
|
run_test "dd_bs_lt_native_bs" \
|
|
NOT "${DD_APP[@]}" \
|
|
--if=<(:) \
|
|
--ob="$bdev0" \
|
|
--bs=$((native_bs >> 1)) \
|
|
--json <(gen_conf)
|
|
|
|
run_test "dd_rw" basic_rw "$native_bs"
|
|
run_test "dd_rw_offset" basic_offset
|