Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/dev/raidframe DIOCCACHESYNC takes an int argument, pass ...
details: https://anonhg.NetBSD.org/src/rev/1fe475a1c1bd
branches: trunk
changeset: 944399:1fe475a1c1bd
user: christos <christos%NetBSD.org@localhost>
date: Sun Sep 27 21:39:08 2020 +0000
description:
DIOCCACHESYNC takes an int argument, pass it through.
diffstat:
sys/dev/raidframe/rf_kintf.h | 4 ++--
sys/dev/raidframe/rf_netbsdkintf.c | 16 ++++++++--------
sys/dev/raidframe/rf_paritymap.c | 8 ++++----
3 files changed, 14 insertions(+), 14 deletions(-)
diffs (114 lines):
diff -r f422a5a0a8e1 -r 1fe475a1c1bd sys/dev/raidframe/rf_kintf.h
--- a/sys/dev/raidframe/rf_kintf.h Sun Sep 27 21:35:16 2020 +0000
+++ b/sys/dev/raidframe/rf_kintf.h Sun Sep 27 21:39:08 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: rf_kintf.h,v 1.25 2018/01/18 00:32:49 mrg Exp $ */
+/* $NetBSD: rf_kintf.h,v 1.26 2020/09/27 21:39:08 christos Exp $ */
/*
* rf_kintf.h
*
@@ -61,7 +61,7 @@
void rf_UnconfigureVnodes( RF_Raid_t * );
void rf_close_component( RF_Raid_t *, struct vnode *, int);
int rf_getdisksize(struct vnode *, RF_RaidDisk_t *);
-int rf_sync_component_caches(RF_Raid_t *);
+int rf_sync_component_caches(RF_Raid_t *, int);
void rf_check_recon_status_ext(RF_Raid_t *, RF_ProgressInfo_t *);
void rf_check_parityrewrite_status_ext(RF_Raid_t *, RF_ProgressInfo_t *);
diff -r f422a5a0a8e1 -r 1fe475a1c1bd sys/dev/raidframe/rf_netbsdkintf.c
--- a/sys/dev/raidframe/rf_netbsdkintf.c Sun Sep 27 21:35:16 2020 +0000
+++ b/sys/dev/raidframe/rf_netbsdkintf.c Sun Sep 27 21:39:08 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: rf_netbsdkintf.c,v 1.389 2020/08/25 13:50:00 skrll Exp $ */
+/* $NetBSD: rf_netbsdkintf.c,v 1.390 2020/09/27 21:39:08 christos Exp $ */
/*-
* Copyright (c) 1996, 1997, 1998, 2008-2011 The NetBSD Foundation, Inc.
@@ -101,7 +101,7 @@
***********************************************************/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: rf_netbsdkintf.c,v 1.389 2020/08/25 13:50:00 skrll Exp $");
+__KERNEL_RCSID(0, "$NetBSD: rf_netbsdkintf.c,v 1.390 2020/09/27 21:39:08 christos Exp $");
#ifdef _KERNEL_OPT
#include "opt_raid_autoconfig.h"
@@ -1754,7 +1754,7 @@
break;
case DIOCCACHESYNC:
- retcode = rf_sync_component_caches(raidPtr);
+ retcode = rf_sync_component_caches(raidPtr, *(int *)data);
break;
default:
@@ -3661,9 +3661,8 @@
*/
static int
-rf_sync_component_cache(RF_Raid_t *raidPtr, int c)
+rf_sync_component_cache(RF_Raid_t *raidPtr, int c, int force)
{
- int force = 1;
int e = 0;
for (int i = 0; i < 5; i++) {
e = VOP_IOCTL(raidPtr->raid_cinfo[c].ci_vp, DIOCCACHESYNC,
@@ -3677,14 +3676,14 @@
}
int
-rf_sync_component_caches(RF_Raid_t *raidPtr)
+rf_sync_component_caches(RF_Raid_t *raidPtr, int force)
{
int c, error;
error = 0;
for (c = 0; c < raidPtr->numCol; c++) {
if (raidPtr->Disks[c].status == rf_ds_optimal) {
- int e = rf_sync_component_cache(raidPtr, c);
+ int e = rf_sync_component_cache(raidPtr, c, force);
if (e && !error)
error = e;
}
@@ -3694,7 +3693,8 @@
int sparecol = raidPtr->numCol + c;
/* Need to ensure that the reconstruct actually completed! */
if (raidPtr->Disks[sparecol].status == rf_ds_used_spare) {
- int e = rf_sync_component_cache(raidPtr, sparecol);
+ int e = rf_sync_component_cache(raidPtr, sparecol,
+ force);
if (e && !error)
error = e;
}
diff -r f422a5a0a8e1 -r 1fe475a1c1bd sys/dev/raidframe/rf_paritymap.c
--- a/sys/dev/raidframe/rf_paritymap.c Sun Sep 27 21:35:16 2020 +0000
+++ b/sys/dev/raidframe/rf_paritymap.c Sun Sep 27 21:39:08 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: rf_paritymap.c,v 1.9 2019/02/09 03:34:00 christos Exp $ */
+/* $NetBSD: rf_paritymap.c,v 1.10 2020/09/27 21:39:08 christos Exp $ */
/*-
* Copyright (c) 2009 Jed Davis.
@@ -27,7 +27,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: rf_paritymap.c,v 1.9 2019/02/09 03:34:00 christos Exp $");
+__KERNEL_RCSID(0, "$NetBSD: rf_paritymap.c,v 1.10 2020/09/27 21:39:08 christos Exp $");
#include <sys/param.h>
#include <sys/callout.h>
@@ -220,10 +220,10 @@
* currently have no way to express that directly.)
*/
if (clearing)
- rf_sync_component_caches(pm->raid);
+ rf_sync_component_caches(pm->raid, 1);
rf_paritymap_kern_write(pm->raid, pm->disk_now);
if (setting)
- rf_sync_component_caches(pm->raid);
+ rf_sync_component_caches(pm->raid, 1);
}
/* Mark all parity as being in need of rewrite. */
Home |
Main Index |
Thread Index |
Old Index