Whamcloud - gitweb
LU-1403 ucred: ucred cleanup
[fs/lustre-release.git] / lustre / include / md_object.h
1 /*
2  * GPL HEADER START
3  *
4  * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
5  *
6  * This program is free software; you can redistribute it and/or modify
7  * it under the terms of the GNU General Public License version 2 only,
8  * as published by the Free Software Foundation.
9  *
10  * This program is distributed in the hope that it will be useful, but
11  * WITHOUT ANY WARRANTY; without even the implied warranty of
12  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
13  * General Public License version 2 for more details (a copy is included
14  * in the LICENSE file that accompanied this code).
15  *
16  * You should have received a copy of the GNU General Public License
17  * version 2 along with this program; If not, see
18  * http://www.sun.com/software/products/lustre/docs/GPLv2.pdf
19  *
20  * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
21  * CA 95054 USA or visit www.sun.com if you need additional information or
22  * have any questions.
23  *
24  * GPL HEADER END
25  */
26 /*
27  * Copyright (c) 2007, 2010, Oracle and/or its affiliates. All rights reserved.
28  * Use is subject to license terms.
29  *
30  * Copyright (c) 2011, 2012, Whamcloud, Inc.
31  */
32 /*
33  * This file is part of Lustre, http://www.lustre.org/
34  * Lustre is a trademark of Sun Microsystems, Inc.
35  *
36  * lustre/include/md_object.h
37  *
38  * Extention of lu_object.h for metadata objects
39  */
40
41 #ifndef _LUSTRE_MD_OBJECT_H
42 #define _LUSTRE_MD_OBJECT_H
43
44 /** \defgroup md md
45  * Sub-class of lu_object with methods common for "meta-data" objects in MDT
46  * stack.
47  *
48  * Meta-data objects implement namespace operations: you can link, unlink
49  * them, and treat them as directories.
50  *
51  * Examples: mdt, cmm, and mdt are implementations of md interface.
52  * @{
53  */
54
55
56 /*
57  * super-class definitions.
58  */
59 #include <dt_object.h>
60 #include <lvfs.h>
61
62 /* LU-1051, temperary solution to reduce llog credits */
63 #define DECLARE_LLOG_REWRITE  0
64 #define DECLARE_LLOG_WRITE    INT_MAX
65
66 struct md_device;
67 struct md_device_operations;
68 struct md_object;
69 struct obd_export;
70
71 enum {
72         UCRED_INVALID   = -1,
73         UCRED_INIT      = 0,
74         UCRED_OLD       = 1,
75         UCRED_NEW       = 2
76 };
77
78 enum {
79         MD_CAPAINFO_MAX = 5
80 };
81
82 /** there are at most 5 fids in one operation, see rename, NOTE the last one
83  * is a temporary one used for is_subdir() */
84 struct md_capainfo {
85         __u32                   mc_auth;
86         __u32                   mc_padding;
87         struct lu_fid           mc_fid[MD_CAPAINFO_MAX];
88         struct lustre_capa     *mc_capa[MD_CAPAINFO_MAX];
89 };
90
91 struct md_quota {
92         struct obd_export       *mq_exp;
93 };
94
95 /**
96  * Implemented in mdd/mdd_handler.c.
97  *
98  * XXX should be moved into separate .h/.c together with all md security
99  * related definitions.
100  */
101 struct md_capainfo *md_capainfo(const struct lu_env *env);
102 struct md_quota *md_quota(const struct lu_env *env);
103
104 /** metadata attributes */
105 enum ma_valid {
106         MA_INODE     = (1 << 0),
107         MA_LOV       = (1 << 1),
108         MA_COOKIE    = (1 << 2),
109         MA_FLAGS     = (1 << 3),
110         MA_LMV       = (1 << 4),
111         MA_ACL_DEF   = (1 << 5),
112         MA_LOV_DEF   = (1 << 6),
113         MA_LAY_GEN   = (1 << 7),
114         MA_HSM       = (1 << 8),
115         MA_SOM       = (1 << 9),
116         MA_PFID      = (1 << 10)
117 };
118
119 typedef enum {
120         MDL_MINMODE  = 0,
121         MDL_EX       = 1,
122         MDL_PW       = 2,
123         MDL_PR       = 4,
124         MDL_CW       = 8,
125         MDL_CR       = 16,
126         MDL_NL       = 32,
127         MDL_GROUP    = 64,
128         MDL_MAXMODE
129 } mdl_mode_t;
130
131 typedef enum {
132         MDT_NUL_LOCK = 0,
133         MDT_REG_LOCK = (1 << 0),
134         MDT_PDO_LOCK = (1 << 1)
135 } mdl_type_t;
136
137 struct md_hsm {
138         __u32  mh_flags;
139         __u32  mh_archive_number;
140 };
141
142 #define IOEPOCH_INVAL 0
143
144 struct md_som_data {
145         __u64 msd_ioepoch;
146         __u64 msd_size;
147         __u64 msd_blocks;
148         __u64 msd_mountid;
149 };
150
151 struct md_attr {
152         __u64                   ma_valid;
153         __u64                   ma_need;
154         __u64                   ma_attr_flags;
155         struct lu_attr          ma_attr;
156         struct lu_fid           ma_pfid;
157         struct md_hsm           ma_hsm;
158         struct lov_mds_md      *ma_lmm;
159         struct lmv_stripe_md   *ma_lmv;
160         void                   *ma_acl;
161         struct llog_cookie     *ma_cookie;
162         struct lustre_capa     *ma_capa;
163         struct md_som_data     *ma_som;
164         int                     ma_lmm_size;
165         int                     ma_big_lmm_used:1;
166         int                     ma_lmv_size;
167         int                     ma_acl_size;
168         int                     ma_cookie_size;
169         __u16                   ma_layout_gen;
170 };
171
172 /** Additional parameters for create */
173 struct md_op_spec {
174         union {
175                 /** symlink target */
176                 const char               *sp_symname;
177                 /** parent FID for cross-ref mkdir */
178                 const struct lu_fid      *sp_pfid;
179                 /** eadata for regular files */
180                 struct md_spec_reg {
181                         /** lov objs exist already */
182                         const struct lu_fid   *fid;
183                         const void *eadata;
184                         int  eadatalen;
185                 } sp_ea;
186         } u;
187         /** don't create lov objects or llog cookie - this replay */
188         int no_create;
189
190         /** Create flag from client: such as MDS_OPEN_CREAT, and others. */
191         __u64      sp_cr_flags;
192
193         /** Should mdd do lookup sanity check or not. */
194         int        sp_cr_lookup;
195
196         /** Current lock mode for parent dir where create is performing. */
197         mdl_mode_t sp_cr_mode;
198
199         /** to create directory */
200         const struct dt_index_features *sp_feat;
201 };
202
203 /**
204  * Operations implemented for each md object (both directory and leaf).
205  */
206 struct md_object_operations {
207         int (*moo_permission)(const struct lu_env *env,
208                               struct md_object *pobj, struct md_object *cobj,
209                               struct md_attr *attr, int mask);
210
211         int (*moo_attr_get)(const struct lu_env *env, struct md_object *obj,
212                             struct md_attr *attr);
213
214         int (*moo_attr_set)(const struct lu_env *env, struct md_object *obj,
215                             const struct md_attr *attr);
216
217         int (*moo_xattr_get)(const struct lu_env *env, struct md_object *obj,
218                              struct lu_buf *buf, const char *name);
219
220         int (*moo_xattr_list)(const struct lu_env *env, struct md_object *obj,
221                               struct lu_buf *buf);
222
223         int (*moo_xattr_set)(const struct lu_env *env, struct md_object *obj,
224                              const struct lu_buf *buf, const char *name,
225                              int fl);
226
227         int (*moo_xattr_del)(const struct lu_env *env, struct md_object *obj,
228                              const char *name);
229
230         /** \retval number of bytes actually read upon success */
231         int (*moo_readpage)(const struct lu_env *env, struct md_object *obj,
232                             const struct lu_rdpg *rdpg);
233
234         int (*moo_readlink)(const struct lu_env *env, struct md_object *obj,
235                             struct lu_buf *buf);
236         int (*moo_changelog)(const struct lu_env *env,
237                              enum changelog_rec_type type, int flags,
238                              struct md_object *obj);
239         /** part of cross-ref operation */
240         int (*moo_object_create)(const struct lu_env *env,
241                                  struct md_object *obj,
242                                  const struct md_op_spec *spec,
243                                  struct md_attr *ma);
244
245         int (*moo_ref_add)(const struct lu_env *env,
246                            struct md_object *obj,
247                            const struct md_attr *ma);
248
249         int (*moo_ref_del)(const struct lu_env *env,
250                            struct md_object *obj,
251                            struct md_attr *ma);
252
253         int (*moo_open)(const struct lu_env *env,
254                         struct md_object *obj, int flag);
255
256         int (*moo_close)(const struct lu_env *env, struct md_object *obj,
257                          struct md_attr *ma, int mode);
258
259         int (*moo_capa_get)(const struct lu_env *, struct md_object *,
260                             struct lustre_capa *, int renewal);
261
262         int (*moo_object_sync)(const struct lu_env *, struct md_object *);
263         int (*moo_path)(const struct lu_env *env, struct md_object *obj,
264                         char *path, int pathlen, __u64 *recno, int *linkno);
265         int (*moo_file_lock)(const struct lu_env *env, struct md_object *obj,
266                              struct lov_mds_md *lmm, struct ldlm_extent *extent,
267                              struct lustre_handle *lockh);
268         int (*moo_file_unlock)(const struct lu_env *env, struct md_object *obj,
269                                struct lov_mds_md *lmm,
270                                struct lustre_handle *lockh);
271 };
272
273 /**
274  * Operations implemented for each directory object.
275  */
276 struct md_dir_operations {
277         int (*mdo_is_subdir) (const struct lu_env *env, struct md_object *obj,
278                               const struct lu_fid *fid, struct lu_fid *sfid);
279
280         int (*mdo_lookup)(const struct lu_env *env, struct md_object *obj,
281                           const struct lu_name *lname, struct lu_fid *fid,
282                           struct md_op_spec *spec);
283
284         mdl_mode_t (*mdo_lock_mode)(const struct lu_env *env,
285                                     struct md_object *obj,
286                                     mdl_mode_t mode);
287
288         int (*mdo_create)(const struct lu_env *env, struct md_object *pobj,
289                           const struct lu_name *lname, struct md_object *child,
290                           struct md_op_spec *spec,
291                           struct md_attr *ma);
292
293         /** This method is used for creating data object for this meta object*/
294         int (*mdo_create_data)(const struct lu_env *env, struct md_object *p,
295                                struct md_object *o,
296                                const struct md_op_spec *spec,
297                                struct md_attr *ma);
298
299         int (*mdo_rename)(const struct lu_env *env, struct md_object *spobj,
300                           struct md_object *tpobj, const struct lu_fid *lf,
301                           const struct lu_name *lsname, struct md_object *tobj,
302                           const struct lu_name *ltname, struct md_attr *ma);
303
304         int (*mdo_link)(const struct lu_env *env, struct md_object *tgt_obj,
305                         struct md_object *src_obj, const struct lu_name *lname,
306                         struct md_attr *ma);
307
308         int (*mdo_unlink)(const struct lu_env *env, struct md_object *pobj,
309                           struct md_object *cobj, const struct lu_name *lname,
310                           struct md_attr *ma);
311
312         /** This method is used to compare a requested layout to an existing
313          * layout (struct lov_mds_md_v1/3 vs struct lov_mds_md_v1/3) */
314         int (*mdo_lum_lmm_cmp)(const struct lu_env *env,
315                                struct md_object *cobj,
316                                const struct md_op_spec *spec,
317                                struct md_attr *ma);
318
319         /** partial ops for cross-ref case */
320         int (*mdo_name_insert)(const struct lu_env *env,
321                                struct md_object *obj,
322                                const struct lu_name *lname,
323                                const struct lu_fid *fid,
324                                const struct md_attr *ma);
325
326         int (*mdo_name_remove)(const struct lu_env *env,
327                                struct md_object *obj,
328                                const struct lu_name *lname,
329                                const struct md_attr *ma);
330
331         int (*mdo_rename_tgt)(const struct lu_env *env, struct md_object *pobj,
332                               struct md_object *tobj, const struct lu_fid *fid,
333                               const struct lu_name *lname, struct md_attr *ma);
334 };
335
336 struct md_device_operations {
337         /** meta-data device related handlers. */
338         int (*mdo_root_get)(const struct lu_env *env, struct md_device *m,
339                             struct lu_fid *f);
340
341         int (*mdo_maxsize_get)(const struct lu_env *env, struct md_device *m,
342                                int *md_size, int *cookie_size);
343
344         int (*mdo_statfs)(const struct lu_env *env, struct md_device *m,
345                           struct obd_statfs *sfs);
346
347         int (*mdo_init_capa_ctxt)(const struct lu_env *env, struct md_device *m,
348                                   int mode, unsigned long timeout, __u32 alg,
349                                   struct lustre_capa_key *keys);
350
351         int (*mdo_update_capa_key)(const struct lu_env *env,
352                                    struct md_device *m,
353                                    struct lustre_capa_key *key);
354
355         int (*mdo_llog_ctxt_get)(const struct lu_env *env,
356                                  struct md_device *m, int idx, void **h);
357
358         int (*mdo_iocontrol)(const struct lu_env *env, struct md_device *m,
359                              unsigned int cmd, int len, void *data);
360 };
361
362 enum md_upcall_event {
363         /** Sync the md layer*/
364         MD_LOV_SYNC = (1 << 0),
365         /** Just for split, no need trans, for replay */
366         MD_NO_TRANS = (1 << 1),
367         MD_LOV_CONFIG = (1 << 2),
368         /** Trigger quota recovery */
369         MD_LOV_QUOTA = (1 << 3)
370 };
371
372 struct md_upcall {
373         /** this lock protects upcall using against its removal
374          * read lock is for usage the upcall, write - for init/fini */
375         struct rw_semaphore     mu_upcall_sem;
376         /** device to call, upper layer normally */
377         struct md_device       *mu_upcall_dev;
378         /** upcall function */
379         int (*mu_upcall)(const struct lu_env *env, struct md_device *md,
380                          enum md_upcall_event ev, void *data);
381 };
382
383 struct md_device {
384         struct lu_device                   md_lu_dev;
385         const struct md_device_operations *md_ops;
386         struct md_upcall                   md_upcall;
387 };
388
389 static inline void md_upcall_init(struct md_device *m, void *upcl)
390 {
391         init_rwsem(&m->md_upcall.mu_upcall_sem);
392         m->md_upcall.mu_upcall_dev = NULL;
393         m->md_upcall.mu_upcall = upcl;
394 }
395
396 static inline void md_upcall_dev_set(struct md_device *m, struct md_device *up)
397 {
398         down_write(&m->md_upcall.mu_upcall_sem);
399         m->md_upcall.mu_upcall_dev = up;
400         up_write(&m->md_upcall.mu_upcall_sem);
401 }
402
403 static inline void md_upcall_fini(struct md_device *m)
404 {
405         down_write(&m->md_upcall.mu_upcall_sem);
406         m->md_upcall.mu_upcall_dev = NULL;
407         m->md_upcall.mu_upcall = NULL;
408         up_write(&m->md_upcall.mu_upcall_sem);
409 }
410
411 static inline int md_do_upcall(const struct lu_env *env, struct md_device *m,
412                                 enum md_upcall_event ev, void *data)
413 {
414         int rc = 0;
415         down_read(&m->md_upcall.mu_upcall_sem);
416         if (m->md_upcall.mu_upcall_dev != NULL &&
417             m->md_upcall.mu_upcall_dev->md_upcall.mu_upcall != NULL) {
418                 rc = m->md_upcall.mu_upcall_dev->md_upcall.mu_upcall(env,
419                                               m->md_upcall.mu_upcall_dev,
420                                               ev, data);
421         }
422         up_read(&m->md_upcall.mu_upcall_sem);
423         return rc;
424 }
425
426 struct md_object {
427         struct lu_object                   mo_lu;
428         const struct md_object_operations *mo_ops;
429         const struct md_dir_operations    *mo_dir_ops;
430 };
431
432 /**
433  * md-server site.
434  */
435 struct md_site {
436         struct lu_site       *ms_lu;
437         /**
438          * mds number of this site.
439          */
440         mdsno_t               ms_node_id;
441         /**
442          * Fid location database
443          */
444         struct lu_server_fld *ms_server_fld;
445         struct lu_client_fld *ms_client_fld;
446
447         /**
448          * Server Seq Manager
449          */
450         struct lu_server_seq *ms_server_seq;
451
452         /**
453          * Controller Seq Manager
454          */
455         struct lu_server_seq *ms_control_seq;
456         struct obd_export    *ms_control_exp;
457
458         /**
459          * Client Seq Manager
460          */
461         struct lu_client_seq *ms_client_seq;
462 };
463
464 static inline int lu_device_is_md(const struct lu_device *d)
465 {
466         return ergo(d != NULL, d->ld_type->ldt_tags & LU_DEVICE_MD);
467 }
468
469 static inline struct md_device *lu2md_dev(const struct lu_device *d)
470 {
471         LASSERT(IS_ERR(d) || lu_device_is_md(d));
472         return container_of0(d, struct md_device, md_lu_dev);
473 }
474
475 static inline struct lu_device *md2lu_dev(struct md_device *d)
476 {
477         return &d->md_lu_dev;
478 }
479
480 static inline struct md_object *lu2md(const struct lu_object *o)
481 {
482         LASSERT(o == NULL || IS_ERR(o) || lu_device_is_md(o->lo_dev));
483         return container_of0(o, struct md_object, mo_lu);
484 }
485
486 static inline struct md_object *md_object_next(const struct md_object *obj)
487 {
488         return (obj ? lu2md(lu_object_next(&obj->mo_lu)) : NULL);
489 }
490
491 static inline struct md_device *md_obj2dev(const struct md_object *o)
492 {
493         LASSERT(o == NULL || IS_ERR(o) || lu_device_is_md(o->mo_lu.lo_dev));
494         return container_of0(o->mo_lu.lo_dev, struct md_device, md_lu_dev);
495 }
496
497 static inline struct md_site *lu_site2md(const struct lu_site *s)
498 {
499         return s->ld_md_site;
500 }
501
502 static inline int md_device_init(struct md_device *md, struct lu_device_type *t)
503 {
504         return lu_device_init(&md->md_lu_dev, t);
505 }
506
507 static inline void md_device_fini(struct md_device *md)
508 {
509         lu_device_fini(&md->md_lu_dev);
510 }
511
512 static inline struct md_object *md_object_find_slice(const struct lu_env *env,
513                                                      struct md_device *md,
514                                                      const struct lu_fid *f)
515 {
516         return lu2md(lu_object_find_slice(env, md2lu_dev(md), f, NULL));
517 }
518
519
520 /** md operations */
521 static inline int mo_permission(const struct lu_env *env,
522                                 struct md_object *p,
523                                 struct md_object *c,
524                                 struct md_attr *at,
525                                 int mask)
526 {
527         LASSERT(c->mo_ops->moo_permission);
528         return c->mo_ops->moo_permission(env, p, c, at, mask);
529 }
530
531 static inline int mo_attr_get(const struct lu_env *env,
532                               struct md_object *m,
533                               struct md_attr *at)
534 {
535         LASSERT(m->mo_ops->moo_attr_get);
536         return m->mo_ops->moo_attr_get(env, m, at);
537 }
538
539 static inline int mo_readlink(const struct lu_env *env,
540                               struct md_object *m,
541                               struct lu_buf *buf)
542 {
543         LASSERT(m->mo_ops->moo_readlink);
544         return m->mo_ops->moo_readlink(env, m, buf);
545 }
546
547 static inline int mo_changelog(const struct lu_env *env,
548                                enum changelog_rec_type type,
549                                int flags, struct md_object *m)
550 {
551         LASSERT(m->mo_ops->moo_changelog);
552         return m->mo_ops->moo_changelog(env, type, flags, m);
553 }
554
555 static inline int mo_attr_set(const struct lu_env *env,
556                               struct md_object *m,
557                               const struct md_attr *at)
558 {
559         LASSERT(m->mo_ops->moo_attr_set);
560         return m->mo_ops->moo_attr_set(env, m, at);
561 }
562
563 static inline int mo_xattr_get(const struct lu_env *env,
564                                struct md_object *m,
565                                struct lu_buf *buf,
566                                const char *name)
567 {
568         LASSERT(m->mo_ops->moo_xattr_get);
569         return m->mo_ops->moo_xattr_get(env, m, buf, name);
570 }
571
572 static inline int mo_xattr_del(const struct lu_env *env,
573                                struct md_object *m,
574                                const char *name)
575 {
576         LASSERT(m->mo_ops->moo_xattr_del);
577         return m->mo_ops->moo_xattr_del(env, m, name);
578 }
579
580 static inline int mo_xattr_set(const struct lu_env *env,
581                                struct md_object *m,
582                                const struct lu_buf *buf,
583                                const char *name,
584                                int flags)
585 {
586         LASSERT(m->mo_ops->moo_xattr_set);
587         return m->mo_ops->moo_xattr_set(env, m, buf, name, flags);
588 }
589
590 static inline int mo_xattr_list(const struct lu_env *env,
591                                 struct md_object *m,
592                                 struct lu_buf *buf)
593 {
594         LASSERT(m->mo_ops->moo_xattr_list);
595         return m->mo_ops->moo_xattr_list(env, m, buf);
596 }
597
598 static inline int mo_open(const struct lu_env *env,
599                           struct md_object *m,
600                           int flags)
601 {
602         LASSERT(m->mo_ops->moo_open);
603         return m->mo_ops->moo_open(env, m, flags);
604 }
605
606 static inline int mo_close(const struct lu_env *env,
607                            struct md_object *m,
608                            struct md_attr *ma,
609                            int mode)
610 {
611         LASSERT(m->mo_ops->moo_close);
612         return m->mo_ops->moo_close(env, m, ma, mode);
613 }
614
615 static inline int mo_readpage(const struct lu_env *env,
616                               struct md_object *m,
617                               const struct lu_rdpg *rdpg)
618 {
619         LASSERT(m->mo_ops->moo_readpage);
620         return m->mo_ops->moo_readpage(env, m, rdpg);
621 }
622
623 static inline int mo_object_create(const struct lu_env *env,
624                                    struct md_object *m,
625                                    const struct md_op_spec *spc,
626                                    struct md_attr *at)
627 {
628         LASSERT(m->mo_ops->moo_object_create);
629         return m->mo_ops->moo_object_create(env, m, spc, at);
630 }
631
632 static inline int mo_ref_add(const struct lu_env *env,
633                              struct md_object *m,
634                              const struct md_attr *ma)
635 {
636         LASSERT(m->mo_ops->moo_ref_add);
637         return m->mo_ops->moo_ref_add(env, m, ma);
638 }
639
640 static inline int mo_ref_del(const struct lu_env *env,
641                              struct md_object *m,
642                              struct md_attr *ma)
643 {
644         LASSERT(m->mo_ops->moo_ref_del);
645         return m->mo_ops->moo_ref_del(env, m, ma);
646 }
647
648 static inline int mo_capa_get(const struct lu_env *env,
649                               struct md_object *m,
650                               struct lustre_capa *c,
651                               int renewal)
652 {
653         LASSERT(m->mo_ops->moo_capa_get);
654         return m->mo_ops->moo_capa_get(env, m, c, renewal);
655 }
656
657 static inline int mo_path(const struct lu_env *env, struct md_object *m,
658                           char *path, int pathlen, __u64 *recno, int *linkno)
659 {
660         if (m->mo_ops->moo_path == NULL)
661                 return -ENOSYS;
662         return m->mo_ops->moo_path(env, m, path, pathlen, recno, linkno);
663 }
664
665 static inline int mo_object_sync(const struct lu_env *env, struct md_object *m)
666 {
667         LASSERT(m->mo_ops->moo_object_sync);
668         return m->mo_ops->moo_object_sync(env, m);
669 }
670
671 static inline int mo_file_lock(const struct lu_env *env, struct md_object *m,
672                                struct lov_mds_md *lmm,
673                                struct ldlm_extent *extent,
674                                struct lustre_handle *lockh)
675 {
676         LASSERT(m->mo_ops->moo_file_lock);
677         return m->mo_ops->moo_file_lock(env, m, lmm, extent, lockh);
678 }
679
680 static inline int mo_file_unlock(const struct lu_env *env, struct md_object *m,
681                                  struct lov_mds_md *lmm,
682                                  struct lustre_handle *lockh)
683 {
684         LASSERT(m->mo_ops->moo_file_unlock);
685         return m->mo_ops->moo_file_unlock(env, m, lmm, lockh);
686 }
687
688 static inline int mdo_lookup(const struct lu_env *env,
689                              struct md_object *p,
690                              const struct lu_name *lname,
691                              struct lu_fid *f,
692                              struct md_op_spec *spec)
693 {
694         LASSERT(p->mo_dir_ops->mdo_lookup);
695         return p->mo_dir_ops->mdo_lookup(env, p, lname, f, spec);
696 }
697
698 static inline mdl_mode_t mdo_lock_mode(const struct lu_env *env,
699                                        struct md_object *mo,
700                                        mdl_mode_t lm)
701 {
702         if (mo->mo_dir_ops->mdo_lock_mode == NULL)
703                 return MDL_MINMODE;
704         return mo->mo_dir_ops->mdo_lock_mode(env, mo, lm);
705 }
706
707 static inline int mdo_create(const struct lu_env *env,
708                              struct md_object *p,
709                              const struct lu_name *lchild_name,
710                              struct md_object *c,
711                              struct md_op_spec *spc,
712                              struct md_attr *at)
713 {
714         LASSERT(p->mo_dir_ops->mdo_create);
715         return p->mo_dir_ops->mdo_create(env, p, lchild_name, c, spc, at);
716 }
717
718 static inline int mdo_create_data(const struct lu_env *env,
719                                   struct md_object *p,
720                                   struct md_object *c,
721                                   const struct md_op_spec *spec,
722                                   struct md_attr *ma)
723 {
724         LASSERT(c->mo_dir_ops->mdo_create_data);
725         return c->mo_dir_ops->mdo_create_data(env, p, c, spec, ma);
726 }
727
728 static inline int mdo_rename(const struct lu_env *env,
729                              struct md_object *sp,
730                              struct md_object *tp,
731                              const struct lu_fid *lf,
732                              const struct lu_name *lsname,
733                              struct md_object *t,
734                              const struct lu_name *ltname,
735                              struct md_attr *ma)
736 {
737         LASSERT(tp->mo_dir_ops->mdo_rename);
738         return tp->mo_dir_ops->mdo_rename(env, sp, tp, lf, lsname, t, ltname,
739                                           ma);
740 }
741
742 static inline int mdo_is_subdir(const struct lu_env *env,
743                                 struct md_object *mo,
744                                 const struct lu_fid *fid,
745                                 struct lu_fid *sfid)
746 {
747         LASSERT(mo->mo_dir_ops->mdo_is_subdir);
748         return mo->mo_dir_ops->mdo_is_subdir(env, mo, fid, sfid);
749 }
750
751 static inline int mdo_link(const struct lu_env *env,
752                            struct md_object *p,
753                            struct md_object *s,
754                            const struct lu_name *lname,
755                            struct md_attr *ma)
756 {
757         LASSERT(s->mo_dir_ops->mdo_link);
758         return s->mo_dir_ops->mdo_link(env, p, s, lname, ma);
759 }
760
761 static inline int mdo_unlink(const struct lu_env *env,
762                              struct md_object *p,
763                              struct md_object *c,
764                              const struct lu_name *lname,
765                              struct md_attr *ma)
766 {
767         LASSERT(c->mo_dir_ops->mdo_unlink);
768         return c->mo_dir_ops->mdo_unlink(env, p, c, lname, ma);
769 }
770
771 static inline int mdo_lum_lmm_cmp(const struct lu_env *env,
772                                   struct md_object *c,
773                                   const struct md_op_spec *spec,
774                                   struct md_attr *ma)
775 {
776         LASSERT(c->mo_dir_ops->mdo_lum_lmm_cmp);
777         return c->mo_dir_ops->mdo_lum_lmm_cmp(env, c, spec, ma);
778 }
779
780 static inline int mdo_name_insert(const struct lu_env *env,
781                                   struct md_object *p,
782                                   const struct lu_name *lname,
783                                   const struct lu_fid *f,
784                                   const struct md_attr *ma)
785 {
786         LASSERT(p->mo_dir_ops->mdo_name_insert);
787         return p->mo_dir_ops->mdo_name_insert(env, p, lname, f, ma);
788 }
789
790 static inline int mdo_name_remove(const struct lu_env *env,
791                                   struct md_object *p,
792                                   const struct lu_name *lname,
793                                   const struct md_attr *ma)
794 {
795         LASSERT(p->mo_dir_ops->mdo_name_remove);
796         return p->mo_dir_ops->mdo_name_remove(env, p, lname, ma);
797 }
798
799 static inline int mdo_rename_tgt(const struct lu_env *env,
800                                  struct md_object *p,
801                                  struct md_object *t,
802                                  const struct lu_fid *lf,
803                                  const struct lu_name *lname,
804                                  struct md_attr *ma)
805 {
806         if (t) {
807                 LASSERT(t->mo_dir_ops->mdo_rename_tgt);
808                 return t->mo_dir_ops->mdo_rename_tgt(env, p, t, lf, lname, ma);
809         } else {
810                 LASSERT(p->mo_dir_ops->mdo_rename_tgt);
811                 return p->mo_dir_ops->mdo_rename_tgt(env, p, t, lf, lname, ma);
812         }
813 }
814
815 struct dt_device;
816 /**
817  * Structure to hold object information. This is used to create object
818  * \pre llod_dir exist
819  */
820 struct lu_local_obj_desc {
821         const char                      *llod_dir;
822         const char                      *llod_name;
823         __u32                            llod_oid;
824         int                              llod_is_index;
825         const struct dt_index_features  *llod_feat;
826         cfs_list_t                       llod_linkage;
827 };
828
829 struct md_object *llo_store_resolve(const struct lu_env *env,
830                                     struct md_device *md,
831                                     struct dt_device *dt,
832                                     const char *path,
833                                     struct lu_fid *fid);
834
835 struct md_object *llo_store_open(const struct lu_env *env,
836                                  struct md_device *md,
837                                  struct dt_device *dt,
838                                  const char *dirname,
839                                  const char *objname,
840                                  struct lu_fid *fid);
841
842 struct md_object *llo_store_create_index(const struct lu_env *env,
843                                          struct md_device *md,
844                                          struct dt_device *dt,
845                                          const char *dirname,
846                                          const char *objname,
847                                          const struct lu_fid *fid,
848                                          const struct dt_index_features *feat);
849
850 struct md_object *llo_store_create(const struct lu_env *env,
851                                    struct md_device *md,
852                                    struct dt_device *dt,
853                                    const char *dirname,
854                                    const char *objname,
855                                    const struct lu_fid *fid);
856
857 void llo_local_obj_register(struct lu_local_obj_desc *);
858 void llo_local_obj_unregister(struct lu_local_obj_desc *);
859
860 int llo_local_objects_setup(const struct lu_env *env,
861                              struct md_device * md,
862                              struct dt_device * dt);
863
864 /** @} md */
865 #endif /* _LINUX_MD_OBJECT_H */