staging: lustre: obd: implement md_read_page
authorwang di <di.wang@intel.com>
Tue, 16 Aug 2016 20:19:27 +0000 (16:19 -0400)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Sun, 21 Aug 2016 13:57:39 +0000 (15:57 +0200)
This patch adds md_read_page which is a new more
flexiable api that will replace md_readpage.

Signed-off-by: wang di <di.wang@intel.com>
Reviewed-on: http://review.whamcloud.com/10761
Intel-bug-id: https://jira.hpdd.intel.com/browse/LU-4906
Reviewed-by: John L. Hammond <john.hammond@intel.com>
Reviewed-by: Andreas Dilger <andreas.dilger@intel.com>
Reviewed-by: Oleg Drokin <oleg.drokin@intel.com>
Signed-off-by: James Simmons <jsimmons@infradead.org>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/staging/lustre/lustre/include/obd.h
drivers/staging/lustre/lustre/include/obd_class.h

index e91f65ad5209ba08263b467b4c3165329f584721..92eebff7c3b5a8eeda5bf5d4faf6e1945f489b19 100644 (file)
@@ -830,6 +830,15 @@ struct md_op_data {
        struct lustre_handle    op_lease_handle;
 };
 
+#define op_stripe_offset       op_ioepoch
+#define op_max_pages           op_valid
+
+struct md_callback {
+       int (*md_blocking_ast)(struct ldlm_lock *lock,
+                              struct ldlm_lock_desc *desc,
+                              void *data, int flag);
+};
+
 enum op_cli_flags {
        CLI_SET_MEA     = 1 << 0,
        CLI_RM_ENTRY    = 1 << 1,
@@ -1039,7 +1048,9 @@ struct md_ops {
                    struct ptlrpc_request **);
        int (*readpage)(struct obd_export *, struct md_op_data *,
                        struct page **, struct ptlrpc_request **);
-
+       int (*read_page)(struct obd_export *, struct md_op_data *,
+                        struct md_callback *cb_op, __u64 hash_offset,
+                        struct page **ppage);
        int (*unlink)(struct obd_export *, struct md_op_data *,
                      struct ptlrpc_request **);
 
index 69b628b4b6b38437d27806502b0eba42f67ca588..daca5a0ed5c5a4b3d89610f8802a6fa28b99a7cf 100644 (file)
@@ -1535,6 +1535,21 @@ static inline int md_readpage(struct obd_export *exp, struct md_op_data *opdata,
        return rc;
 }
 
+static inline int md_read_page(struct obd_export *exp,
+                              struct md_op_data *op_data,
+                              struct md_callback *cb_op,
+                              __u64  hash_offset,
+                              struct page **ppage)
+{
+       int rc;
+
+       EXP_CHECK_MD_OP(exp, read_page);
+       EXP_MD_COUNTER_INCREMENT(exp, read_page);
+       rc = MDP(exp->exp_obd, read_page)(exp, op_data, cb_op, hash_offset,
+                                         ppage);
+       return rc;
+}
+
 static inline int md_unlink(struct obd_export *exp, struct md_op_data *op_data,
                            struct ptlrpc_request **request)
 {