Spdk/test/ocf/management/configuration-change.sh
paul luse eb53c23236 add (c) and SPDX header to bash files as needed
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>
2022-11-29 08:27:51 +00:00

64 lines
2.1 KiB
Bash
Executable File

#!/usr/bin/env bash
# SPDX-License-Identifier: BSD-3-Clause
# Copyright (C) 2021 Intel Corporation
# All rights reserved.
#
curdir=$(dirname $(readlink -f "${BASH_SOURCE[0]}"))
rootdir=$(readlink -f $curdir/../../..)
source $rootdir/test/common/autotest_common.sh
rpc_py=$rootdir/scripts/rpc.py
cache_line_sizes=(4 8 16 32 64)
cache_modes=(wt wb pt wa wi wo)
$SPDK_BIN_DIR/iscsi_tgt &
spdk_pid=$!
waitforlisten $spdk_pid
# Create OCF cache with different cache line sizes
for cache_line_size in "${cache_line_sizes[@]}"; do
$rpc_py bdev_malloc_create 101 512 -b Malloc0
$rpc_py bdev_malloc_create 101 512 -b Malloc1
$rpc_py bdev_ocf_create Cache0 wt Malloc0 Malloc1 --cache-line-size $cache_line_size
$rpc_py bdev_ocf_get_bdevs | jq -e \
'.[0] | .started and .cache.attached and .core.attached'
# Check if cache line size values are reported correctly
$rpc_py bdev_get_bdevs -b Cache0 | jq -e \
".[0] | .driver_specific.cache_line_size == $cache_line_size"
$rpc_py save_subsystem_config -n bdev | jq -e \
".config | .[] | select(.method == \"bdev_ocf_create\") | .params.cache_line_size == $cache_line_size"
$rpc_py bdev_ocf_delete Cache0
$rpc_py bdev_malloc_delete Malloc0
$rpc_py bdev_malloc_delete Malloc1
done
# Prepare OCF cache for dynamic configuration switching
$rpc_py bdev_malloc_create 101 512 -b Malloc0
$rpc_py bdev_malloc_create 101 512 -b Malloc1
$rpc_py bdev_ocf_create Cache0 wt Malloc0 Malloc1
$rpc_py bdev_ocf_get_bdevs | jq -e \
'.[0] | .started and .cache.attached and .core.attached'
# Change cache mode
for cache_mode in "${cache_modes[@]}"; do
$rpc_py bdev_ocf_set_cache_mode Cache0 $cache_mode
# Check if cache mode values are reported correctly
$rpc_py bdev_get_bdevs -b Cache0 | jq -e \
".[0] | .driver_specific.mode == \"$cache_mode\""
$rpc_py save_subsystem_config -n bdev | jq -e \
".config | .[] | select(.method == \"bdev_ocf_create\") | .params.mode == \"$cache_mode\""
done
# Change sequential cutoff
$rpc_py bdev_ocf_set_seqcutoff Cache0 -p always -t 64
$rpc_py bdev_ocf_set_seqcutoff Cache0 -p never -t 16
trap - SIGINT SIGTERM EXIT
killprocess $spdk_pid