]> granicus.if.org Git - spl/commitdiff
Additional dkio support for TRIM/Discard
authorTim Chase <tim@chase2k.com>
Fri, 24 Jul 2015 20:36:59 +0000 (15:36 -0500)
committerBrian Behlendorf <behlendorf1@llnl.gov>
Wed, 2 Dec 2015 21:44:35 +0000 (13:44 -0800)
Replace DKIOCTRIM with DKIOCFREE and add additional support required
for Nextenta's TRIM support.

Signed-off-by: Tim Chase <tim@chase2k.com>
Signed-off-by: Brian Behlendorf <behlendorf1@llnl.gov>
Closes #469

include/sys/Makefile.am
include/sys/dkio.h
include/sys/dkioc_free_util.h [new file with mode: 0644]

index 73c4a84217829d204bb0b42d4fb9a21d21a28f1d..a16bd6ce6feddff1a66c84126038a880dfee0174 100644 (file)
@@ -29,6 +29,7 @@ KERNEL_H = \
        $(top_srcdir)/include/sys/dirent.h \
        $(top_srcdir)/include/sys/disp.h \
        $(top_srcdir)/include/sys/dkio.h \
+       $(top_srcdir)/include/sys/dkioc_free_util.h \
        $(top_srcdir)/include/sys/dklabel.h \
        $(top_srcdir)/include/sys/dnlc.h \
        $(top_srcdir)/include/sys/dumphdr.h \
index d8c700718ff1fd19964859f59c06575dfea15b29..dd7a95f137b9920f0dde39622fa3bf237efe9dd2 100644 (file)
 #ifndef _SPL_DKIO_H
 #define        _SPL_DKIO_H
 
-struct dk_callback {
-       void (*dkc_callback)(void *dkc_cookie, int error);
-       void *dkc_cookie;
-       int dkc_flag;
-};
+#define        DFL_SZ(num_exts) \
+       (sizeof (dkioc_free_list_t) + (num_exts - 1) * 16)
 
-#define        DKIOC                   (0x04 << 8)
-#define        DKIOCFLUSHWRITECACHE    (DKIOC | 34)
-#define        DKIOCTRIM               (DKIOC | 35)
+#define        DKIOC           (0x04 << 8)
+#define        DKIOCFLUSHWRITECACHE    (DKIOC|34)      /* flush cache to phys medium */
+
+/*
+ * ioctl to free space (e.g. SCSI UNMAP) off a disk.
+ * Pass a dkioc_free_list_t containing a list of extents to be freed.
+ */
+#define        DKIOCFREE       (DKIOC|50)
 
 #endif /* _SPL_DKIO_H */
diff --git a/include/sys/dkioc_free_util.h b/include/sys/dkioc_free_util.h
new file mode 100644 (file)
index 0000000..a424d42
--- /dev/null
@@ -0,0 +1,54 @@
+/*****************************************************************************\
+ *  Copyright (C) 2007-2010 Lawrence Livermore National Security, LLC.
+ *  Copyright (C) 2007 The Regents of the University of California.
+ *  Produced at Lawrence Livermore National Laboratory (cf, DISCLAIMER).
+ *  Written by Brian Behlendorf <behlendorf1@llnl.gov>.
+ *  UCRL-CODE-235197
+ *
+ *  This file is part of the SPL, Solaris Porting Layer.
+ *  For details, see <http://zfsonlinux.org/>.
+ *
+ *  The SPL is free software; you can redistribute it and/or modify it
+ *  under the terms of the GNU General Public License as published by the
+ *  Free Software Foundation; either version 2 of the License, or (at your
+ *  option) any later version.
+ *
+ *  The SPL is distributed in the hope that it will be useful, but WITHOUT
+ *  ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ *  FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
+ *  for more details.
+ *
+ *  You should have received a copy of the GNU General Public License along
+ *  with the SPL.  If not, see <http://www.gnu.org/licenses/>.
+\*****************************************************************************/
+
+#ifndef _SPL_DKIOC_UTIL_H
+#define        _SPL_DKIOC_UTIL_H
+
+#include <sys/dkio.h>
+
+typedef struct dkioc_free_list_ext_s {
+       uint64_t                dfle_start;
+       uint64_t                dfle_length;
+} dkioc_free_list_ext_t;
+
+typedef struct dkioc_free_list_s {
+       uint64_t                dfl_flags;
+       uint64_t                dfl_num_exts;
+       int64_t                 dfl_offset;
+
+       /*
+        * N.B. this is only an internal debugging API! This is only called
+        * from debug builds of sd for pre-release checking. Remove before GA!
+        */
+       void                    (*dfl_ck_func)(uint64_t, uint64_t, void *);
+       void                    *dfl_ck_arg;
+
+       dkioc_free_list_ext_t   dfl_exts[1];
+} dkioc_free_list_t;
+
+static inline void dfl_free(dkioc_free_list_t *dfl) {
+       kmem_free(dfl, DFL_SZ(dfl->dfl_num_exts));
+}
+
+#endif /* _SPL_DKIOC_UTIL_H */