Whamcloud - gitweb
LU-1330 obdclass: add obd_target.h
[fs/lustre-release.git] / lustre / include / lprocfs_status.h
index dc32c08..63b5174 100644 (file)
@@ -27,7 +27,7 @@
  * Copyright (c) 2007, 2010, Oracle and/or its affiliates. All rights reserved.
  * Use is subject to license terms.
  *
- * Copyright (c) 2011, 2012, Whamcloud, Inc.
+ * Copyright (c) 2011, 2013, Intel Corporation.
  */
 /*
  * This file is part of Lustre, http://www.lustre.org/
@@ -74,8 +74,8 @@ struct lprocfs_static_vars {
 /* if we find more consumers this could be generalized */
 #define OBD_HIST_MAX 32
 struct obd_histogram {
-        cfs_spinlock_t oh_lock;
-        unsigned long  oh_buckets[OBD_HIST_MAX];
+       spinlock_t      oh_lock;
+       unsigned long   oh_buckets[OBD_HIST_MAX];
 };
 
 enum {
@@ -144,25 +144,29 @@ enum {
         LPROCFS_TYPE_CYCLE        = 0x0800,
 };
 
-struct lprocfs_atomic {
-        cfs_atomic_t               la_entry;
-        cfs_atomic_t               la_exit;
-};
-
 #define LC_MIN_INIT ((~(__u64)0) >> 1)
 
+struct lprocfs_counter_header {
+       unsigned int            lc_config;
+       const char              *lc_name;   /* must be static */
+       const char              *lc_units;  /* must be static */
+};
+
 struct lprocfs_counter {
-        struct lprocfs_atomic  lc_cntl;  /* may need to move to per set */
-        unsigned int           lc_config;
-        __s64                  lc_count;
-        __s64                  lc_sum;
-        __s64                  lc_sum_irq;
-        __s64                  lc_min;
-        __s64                  lc_max;
-        __s64                  lc_sumsquare;
-        const char            *lc_name;   /* must be static */
-        const char            *lc_units;  /* must be static */
+       __s64   lc_count;
+       __s64   lc_min;
+       __s64   lc_max;
+       __s64   lc_sumsquare;
+       /*
+        * Every counter has lc_array_sum[0], while lc_array_sum[1] is only
+        * for irq context counter, i.e. stats with
+        * LPROCFS_STATS_FLAG_IRQ_SAFE flag, its counter need
+        * lc_array_sum[1]
+        */
+       __s64   lc_array_sum[1];
 };
+#define lc_sum         lc_array_sum[0]
+#define lc_sum_irq     lc_array_sum[1]
 
 struct lprocfs_percpu {
 #ifndef __GNUC__
@@ -192,16 +196,18 @@ enum lprocfs_fields_flags {
 };
 
 struct lprocfs_stats {
-       unsigned short         ls_num;   /* # of counters */
-       unsigned short         ls_biggest_alloc_num;
-                                        /* 1 + the highest slot index which has
-                                         * been allocated, the 0th entry is
-                                         * a statically intialized template */
-       int                    ls_flags; /* See LPROCFS_STATS_FLAG_* */
+       /* # of counters */
+       unsigned short                  ls_num;
+       /* 1 + the biggest cpu # whose ls_percpu slot has been allocated */
+       unsigned short                  ls_biggest_alloc_num;
+       enum lprocfs_stats_flags        ls_flags;
        /* Lock used when there are no percpu stats areas; For percpu stats,
         * it is used to protect ls_biggest_alloc_num change */
-       cfs_spinlock_t         ls_lock;
-       struct lprocfs_percpu *ls_percpu[0];
+       spinlock_t                      ls_lock;
+
+       /* has ls_num of counter headers */
+       struct lprocfs_counter_header   *ls_cnt_header;
+       struct lprocfs_percpu           *ls_percpu[0];
 };
 
 #define OPC_RANGE(seg) (seg ## _LAST_OPC - seg ## _FIRST_OPC)
@@ -283,7 +289,20 @@ static inline int opcode_offset(__u32 opc) {
                         OPC_RANGE(LDLM) +
                         OPC_RANGE(MDS) +
                         OPC_RANGE(OST));
-        } else {
+       } else if (opc < UPDATE_LAST_OPC) {
+               /* update opcode */
+               return (opc - UPDATE_FIRST_OPC +
+                       OPC_RANGE(FLD) +
+                       OPC_RANGE(SEC) +
+                       OPC_RANGE(SEQ) +
+                       OPC_RANGE(QUOTA) +
+                       OPC_RANGE(LLOG) +
+                       OPC_RANGE(OBD) +
+                       OPC_RANGE(MGS) +
+                       OPC_RANGE(LDLM) +
+                       OPC_RANGE(MDS) +
+                       OPC_RANGE(OST));
+       } else {
                 /* Unknown Opcode */
                 return -1;
         }
@@ -299,7 +318,8 @@ static inline int opcode_offset(__u32 opc) {
                             OPC_RANGE(SEC)  + \
                             OPC_RANGE(SEQ)  + \
                             OPC_RANGE(SEC)  + \
-                            OPC_RANGE(FLD)  )
+                           OPC_RANGE(FLD)  + \
+                           OPC_RANGE(UPDATE))
 
 #define EXTRA_MAX_OPCODES ((PTLRPC_LAST_CNTR - PTLRPC_FIRST_CNTR)  + \
                             OPC_RANGE(EXTRA))
@@ -365,7 +385,7 @@ typedef void (*cntr_init_callback)(struct lprocfs_stats *stats);
 struct obd_job_stats {
        cfs_hash_t        *ojs_hash;
        cfs_list_t         ojs_list;
-       cfs_rwlock_t       ojs_lock; /* protect the obj_list */
+       rwlock_t       ojs_lock; /* protect the obj_list */
        cntr_init_callback ojs_cntr_init_fn;
        int                ojs_cntr_num;
        int                ojs_cleanup_interval;
@@ -384,40 +404,41 @@ static inline int lprocfs_stats_lock(struct lprocfs_stats *stats, int opc,
                                     unsigned long *flags)
 {
        int             rc = 0;
-       unsigned int    cpuid;
 
        switch (opc) {
        default:
                LBUG();
 
        case LPROCFS_GET_SMP_ID:
-               /* percpu counter stats */
-               if ((stats->ls_flags & LPROCFS_STATS_FLAG_NOPERCPU) == 0) {
-                       cpuid = cfs_get_cpu();
-
-                       if (unlikely(stats->ls_percpu[cpuid + 1] == NULL))
-                               rc = lprocfs_stats_alloc_one(stats, cpuid + 1);
-                       return rc < 0 ? rc : cpuid + 1;
+               if (stats->ls_flags & LPROCFS_STATS_FLAG_NOPERCPU) {
+                       if (stats->ls_flags & LPROCFS_STATS_FLAG_IRQ_SAFE)
+                               spin_lock_irqsave(&stats->ls_lock, *flags);
+                       else
+                               spin_lock(&stats->ls_lock);
+                       return 0;
+               } else {
+                       unsigned int cpuid = cfs_get_cpu();
+
+                       if (unlikely(stats->ls_percpu[cpuid] == NULL)) {
+                               rc = lprocfs_stats_alloc_one(stats, cpuid);
+                               if (rc < 0) {
+                                       cfs_put_cpu();
+                                       return rc;
+                               }
+                       }
+                       return cpuid;
                }
 
-               /* non-percpu counter stats */
-               if ((stats->ls_flags & LPROCFS_STATS_FLAG_IRQ_SAFE) != 0)
-                       cfs_spin_lock_irqsave(&stats->ls_lock, *flags);
-               else
-                       cfs_spin_lock(&stats->ls_lock);
-               return 0;
-
        case LPROCFS_GET_NUM_CPU:
-               /* percpu counter stats */
-               if ((stats->ls_flags & LPROCFS_STATS_FLAG_NOPERCPU) == 0)
+               if (stats->ls_flags & LPROCFS_STATS_FLAG_NOPERCPU) {
+                       if (stats->ls_flags & LPROCFS_STATS_FLAG_IRQ_SAFE)
+                               spin_lock_irqsave(&stats->ls_lock, *flags);
+                       else
+                               spin_lock(&stats->ls_lock);
+                       return 1;
+               } else {
                        return stats->ls_biggest_alloc_num;
-
-               /* non-percpu counter stats */
-               if ((stats->ls_flags & LPROCFS_STATS_FLAG_IRQ_SAFE) != 0)
-                       cfs_spin_lock_irqsave(&stats->ls_lock, *flags);
-               else
-                       cfs_spin_lock(&stats->ls_lock);
-               return 1;
+               }
        }
 }
 
@@ -431,10 +452,10 @@ static inline void lprocfs_stats_unlock(struct lprocfs_stats *stats, int opc,
        case LPROCFS_GET_SMP_ID:
                if (stats->ls_flags & LPROCFS_STATS_FLAG_NOPERCPU) {
                        if (stats->ls_flags & LPROCFS_STATS_FLAG_IRQ_SAFE) {
-                               cfs_spin_unlock_irqrestore(&stats->ls_lock,
+                               spin_unlock_irqrestore(&stats->ls_lock,
                                                           *flags);
                        } else {
-                               cfs_spin_unlock(&stats->ls_lock);
+                               spin_unlock(&stats->ls_lock);
                        }
                } else {
                        cfs_put_cpu();
@@ -444,16 +465,47 @@ static inline void lprocfs_stats_unlock(struct lprocfs_stats *stats, int opc,
        case LPROCFS_GET_NUM_CPU:
                if (stats->ls_flags & LPROCFS_STATS_FLAG_NOPERCPU) {
                        if (stats->ls_flags & LPROCFS_STATS_FLAG_IRQ_SAFE) {
-                               cfs_spin_unlock_irqrestore(&stats->ls_lock,
+                               spin_unlock_irqrestore(&stats->ls_lock,
                                                           *flags);
                        } else {
-                               cfs_spin_unlock(&stats->ls_lock);
+                               spin_unlock(&stats->ls_lock);
                        }
                }
                return;
        }
 }
 
+static inline unsigned int
+lprocfs_stats_counter_size(struct lprocfs_stats *stats)
+{
+       unsigned int percpusize;
+
+       percpusize = offsetof(struct lprocfs_percpu, lp_cntr[stats->ls_num]);
+
+       /* irq safe stats need lc_array_sum[1] */
+       if ((stats->ls_flags & LPROCFS_STATS_FLAG_IRQ_SAFE) != 0)
+               percpusize += stats->ls_num * sizeof(__s64);
+
+       if ((stats->ls_flags & LPROCFS_STATS_FLAG_NOPERCPU) == 0)
+               percpusize = CFS_L1_CACHE_ALIGN(percpusize);
+
+       return percpusize;
+}
+
+static inline struct lprocfs_counter *
+lprocfs_stats_counter_get(struct lprocfs_stats *stats, unsigned int cpuid,
+                         int index)
+{
+       struct lprocfs_counter *cntr;
+
+       cntr = &stats->ls_percpu[cpuid]->lp_cntr[index];
+
+       if ((stats->ls_flags & LPROCFS_STATS_FLAG_IRQ_SAFE) != 0)
+               cntr = (void *)cntr + index * sizeof(__s64);
+
+       return cntr;
+}
+
 /* Two optimized LPROCFS counter increment functions are provided:
  *     lprocfs_counter_incr(cntr, value) - optimized for by-one counters
  *     lprocfs_counter_add(cntr) - use for multi-valued counters
@@ -472,7 +524,9 @@ extern void lprocfs_counter_sub(struct lprocfs_stats *stats, int idx,
         lprocfs_counter_sub(stats, idx, 1)
 
 extern __s64 lprocfs_read_helper(struct lprocfs_counter *lc,
-                                 enum lprocfs_fields_flags field);
+                                struct lprocfs_counter_header *header,
+                                enum lprocfs_stats_flags flags,
+                                enum lprocfs_fields_flags field);
 static inline __u64 lprocfs_stats_collector(struct lprocfs_stats *stats,
                                             int idx,
                                             enum lprocfs_fields_flags field)
@@ -488,8 +542,10 @@ static inline __u64 lprocfs_stats_collector(struct lprocfs_stats *stats,
        for (i = 0; i < num_cpu; i++) {
                if (stats->ls_percpu[i] == NULL)
                        continue;
-               ret += lprocfs_read_helper(&(stats->ls_percpu[i]->lp_cntr[idx]),
-                                          field);
+               ret += lprocfs_read_helper(
+                               lprocfs_stats_counter_get(stats, i, idx),
+                               &stats->ls_cnt_header[idx], stats->ls_flags,
+                               field);
        }
        lprocfs_stats_unlock(stats, LPROCFS_GET_NUM_CPU, &flags);
        return ret;
@@ -562,12 +618,14 @@ extern int lprocfs_obd_setup(struct obd_device *obd, struct lprocfs_vars *list);
 extern int lprocfs_obd_cleanup(struct obd_device *obd);
 extern struct file_operations lprocfs_evict_client_fops;
 
-extern int lprocfs_seq_create(cfs_proc_dir_entry_t *parent, char *name,
-                              mode_t mode, struct file_operations *seq_fops,
-                              void *data);
-extern int lprocfs_obd_seq_create(struct obd_device *dev, char *name,
-                                  mode_t mode, struct file_operations *seq_fops,
-                                  void *data);
+extern int lprocfs_seq_create(cfs_proc_dir_entry_t *parent, const char *name,
+                             mode_t mode,
+                             const struct file_operations *seq_fops,
+                             void *data);
+extern int lprocfs_obd_seq_create(struct obd_device *dev, const char *name,
+                                 mode_t mode,
+                                 const struct file_operations *seq_fops,
+                                 void *data);
 
 /* Generic callbacks */
 
@@ -585,8 +643,6 @@ extern int lprocfs_rd_uuid(char *page, char **start, off_t off,
                            int count, int *eof, void *data);
 extern int lprocfs_rd_name(char *page, char **start, off_t off,
                            int count, int *eof, void *data);
-extern int lprocfs_rd_fstype(char *page, char **start, off_t off,
-                             int count, int *eof, void *data);
 extern int lprocfs_rd_server_uuid(char *page, char **start, off_t off,
                                   int count, int *eof, void *data);
 extern int lprocfs_rd_conn_uuid(char *page, char **start, off_t off,
@@ -634,19 +690,6 @@ extern int lprocfs_rd_filesfree(char *page, char **start, off_t off,
                                 int count, int *eof, void *data);
 extern int lprocfs_rd_filegroups(char *page, char **start, off_t off,
                                  int count, int *eof, void *data);
-extern int lprocfs_osd_rd_blksize(char *page, char **start, off_t off,
-                               int count, int *eof, void *data);
-extern int lprocfs_osd_rd_kbytesfree(char *page, char **start, off_t off,
-                               int count, int *eof, void *data);
-extern int lprocfs_osd_rd_kbytesavail(char *page, char **start, off_t off,
-                               int count, int *eof, void *data);
-extern int lprocfs_osd_rd_filestotal(char *page, char **start, off_t off,
-                               int count, int *eof, void *data);
-extern int lprocfs_osd_rd_filesfree(char *page, char **start, off_t off,
-                               int count, int *eof, void *data);
-extern int lprocfs_osd_rd_kbytestotal(char *page, char **start, off_t off,
-                               int count, int *eof, void *data);
-
 
 extern int lprocfs_write_helper(const char *buffer, unsigned long count,
                                 int *val);
@@ -659,6 +702,8 @@ extern int lprocfs_write_u64_helper(const char *buffer, unsigned long count,
 extern int lprocfs_write_frac_u64_helper(const char *buffer,
                                          unsigned long count,
                                          __u64 *val, int mult);
+char *lprocfs_find_named_value(const char *buffer, const char *name,
+                               unsigned long *count);
 void lprocfs_oh_tally(struct obd_histogram *oh, unsigned int value);
 void lprocfs_oh_tally_log2(struct obd_histogram *oh, unsigned int value);
 void lprocfs_oh_clear(struct obd_histogram *oh);
@@ -688,14 +733,14 @@ extern int lprocfs_seq_release(cfs_inode_t *, struct file *);
  * the import in a client obd_device for a lprocfs entry */
 #define LPROCFS_CLIMP_CHECK(obd) do {           \
         typecheck(struct obd_device *, obd);    \
-        cfs_down_read(&(obd)->u.cli.cl_sem);    \
+       down_read(&(obd)->u.cli.cl_sem);    \
         if ((obd)->u.cli.cl_import == NULL) {   \
-             cfs_up_read(&(obd)->u.cli.cl_sem); \
+            up_read(&(obd)->u.cli.cl_sem); \
              return -ENODEV;                    \
         }                                       \
 } while(0)
 #define LPROCFS_CLIMP_EXIT(obd)                 \
-        cfs_up_read(&(obd)->u.cli.cl_sem);
+       up_read(&(obd)->u.cli.cl_sem);
 
 
 /* write the name##_seq_show function, call LPROC_SEQ_FOPS_RO for read-only
@@ -752,8 +797,6 @@ int lprocfs_obd_rd_recovery_time_hard(char *page, char **start, off_t off,
 int lprocfs_obd_wr_recovery_time_hard(struct file *file,
                                       const char *buffer,
                                       unsigned long count, void *data);
-int lprocfs_obd_rd_mntdev(char *page, char **start, off_t off,
-                          int count, int *eof, void *data);
 int lprocfs_obd_rd_max_pages_per_rpc(char *page, char **start, off_t off,
                                      int count, int *eof, void *data);
 int lprocfs_obd_wr_max_pages_per_rpc(struct file *file, const char *buffer,