Kernel 6.13: Introduce cas_queue_max_discard_sectors()
Signed-off-by: Robert Baldyga <robert.baldyga@huawei.com> Signed-off-by: Rafal Stefanowski <rafal.stefanowski@huawei.com>
This commit is contained in:
parent
e5607fe9dd
commit
6a275773ce
48
configure.d/1_queue_discard.conf
Normal file
48
configure.d/1_queue_discard.conf
Normal file
@ -0,0 +1,48 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
#
|
||||||
|
# Copyright(c) 2012-2022 Intel Corporation
|
||||||
|
# Copyright(c) 2025 Huawei Technologies
|
||||||
|
# SPDX-License-Identifier: BSD-3-Clause
|
||||||
|
#
|
||||||
|
|
||||||
|
. $(dirname $3)/conf_framework.sh
|
||||||
|
|
||||||
|
check() {
|
||||||
|
cur_name=$(basename $2)
|
||||||
|
config_file_path=$1
|
||||||
|
if compile_module $cur_name "blk_queue_max_discard_sectors(NULL, 0);" "linux/blkdev.h"
|
||||||
|
then
|
||||||
|
echo $cur_name "1" >> $config_file_path
|
||||||
|
else
|
||||||
|
echo $cur_name "2" >> $config_file_path
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
apply() {
|
||||||
|
case "$1" in
|
||||||
|
"1")
|
||||||
|
add_function "
|
||||||
|
static inline void cas_queue_max_discard_sectors(
|
||||||
|
struct request_queue *q,
|
||||||
|
unsigned int max_discard_sectors)
|
||||||
|
{
|
||||||
|
blk_queue_max_discard_sectors(q, max_discard_sectors);
|
||||||
|
}" ;;
|
||||||
|
"2")
|
||||||
|
add_function "
|
||||||
|
static inline void cas_queue_max_discard_sectors(
|
||||||
|
struct request_queue *q,
|
||||||
|
unsigned int max_discard_sectors)
|
||||||
|
{
|
||||||
|
struct queue_limits *lim = &q->limits;
|
||||||
|
|
||||||
|
lim->max_hw_discard_sectors = max_discard_sectors;
|
||||||
|
lim->max_discard_sectors =
|
||||||
|
min(max_discard_sectors, lim->max_user_discard_sectors);
|
||||||
|
}" ;;
|
||||||
|
*)
|
||||||
|
exit 1
|
||||||
|
esac
|
||||||
|
}
|
||||||
|
|
||||||
|
conf_run $@
|
@ -63,13 +63,14 @@ static void blkdev_set_discard_properties(ocf_cache_t cache,
|
|||||||
|
|
||||||
CAS_SET_DISCARD_ZEROES_DATA(exp_q->limits, 0);
|
CAS_SET_DISCARD_ZEROES_DATA(exp_q->limits, 0);
|
||||||
if (core_q && cas_has_discard_support(core_bd)) {
|
if (core_q && cas_has_discard_support(core_bd)) {
|
||||||
blk_queue_max_discard_sectors(exp_q, core_q->limits.max_discard_sectors);
|
cas_queue_max_discard_sectors(exp_q,
|
||||||
|
core_q->limits.max_discard_sectors);
|
||||||
exp_q->limits.discard_alignment =
|
exp_q->limits.discard_alignment =
|
||||||
bdev_discard_alignment(core_bd);
|
bdev_discard_alignment(core_bd);
|
||||||
exp_q->limits.discard_granularity =
|
exp_q->limits.discard_granularity =
|
||||||
core_q->limits.discard_granularity;
|
core_q->limits.discard_granularity;
|
||||||
} else {
|
} else {
|
||||||
blk_queue_max_discard_sectors(exp_q,
|
cas_queue_max_discard_sectors(exp_q,
|
||||||
min((uint64_t)core_sectors, (uint64_t)UINT_MAX));
|
min((uint64_t)core_sectors, (uint64_t)UINT_MAX));
|
||||||
exp_q->limits.discard_granularity = ocf_cache_get_line_size(cache);
|
exp_q->limits.discard_granularity = ocf_cache_get_line_size(cache);
|
||||||
exp_q->limits.discard_alignment = 0;
|
exp_q->limits.discard_alignment = 0;
|
||||||
|
Loading…
Reference in New Issue
Block a user