ceph: simplify the metrics struct
authorXiubo Li <xiubli@redhat.com>
Thu, 13 May 2021 01:40:52 +0000 (09:40 +0800)
committerIlya Dryomov <idryomov@gmail.com>
Mon, 28 Jun 2021 22:15:51 +0000 (00:15 +0200)
Signed-off-by: Xiubo Li <xiubli@redhat.com>
Reviewed-by: Jeff Layton <jlayton@kernel.org>
Signed-off-by: Ilya Dryomov <idryomov@gmail.com>
fs/ceph/metric.c
fs/ceph/metric.h

index 28b6b42..77417b4 100644 (file)
@@ -22,6 +22,7 @@ static bool ceph_mdsc_send_metrics(struct ceph_mds_client *mdsc,
        struct ceph_opened_inodes *inodes;
        struct ceph_client_metric *m = &mdsc->metric;
        u64 nr_caps = atomic64_read(&m->total_caps);
+       u32 header_len = sizeof(struct ceph_metric_header);
        struct ceph_msg *msg;
        struct timespec64 ts;
        s64 sum;
@@ -43,10 +44,10 @@ static bool ceph_mdsc_send_metrics(struct ceph_mds_client *mdsc,
 
        /* encode the cap metric */
        cap = (struct ceph_metric_cap *)(head + 1);
-       cap->type = cpu_to_le32(CLIENT_METRIC_TYPE_CAP_INFO);
-       cap->ver = 1;
-       cap->compat = 1;
-       cap->data_len = cpu_to_le32(sizeof(*cap) - 10);
+       cap->header.type = cpu_to_le32(CLIENT_METRIC_TYPE_CAP_INFO);
+       cap->header.ver = 1;
+       cap->header.compat = 1;
+       cap->header.data_len = cpu_to_le32(sizeof(*cap) - header_len);
        cap->hit = cpu_to_le64(percpu_counter_sum(&m->i_caps_hit));
        cap->mis = cpu_to_le64(percpu_counter_sum(&m->i_caps_mis));
        cap->total = cpu_to_le64(nr_caps);
@@ -54,10 +55,10 @@ static bool ceph_mdsc_send_metrics(struct ceph_mds_client *mdsc,
 
        /* encode the read latency metric */
        read = (struct ceph_metric_read_latency *)(cap + 1);
-       read->type = cpu_to_le32(CLIENT_METRIC_TYPE_READ_LATENCY);
-       read->ver = 1;
-       read->compat = 1;
-       read->data_len = cpu_to_le32(sizeof(*read) - 10);
+       read->header.type = cpu_to_le32(CLIENT_METRIC_TYPE_READ_LATENCY);
+       read->header.ver = 1;
+       read->header.compat = 1;
+       read->header.data_len = cpu_to_le32(sizeof(*read) - header_len);
        sum = m->read_latency_sum;
        jiffies_to_timespec64(sum, &ts);
        read->sec = cpu_to_le32(ts.tv_sec);
@@ -66,10 +67,10 @@ static bool ceph_mdsc_send_metrics(struct ceph_mds_client *mdsc,
 
        /* encode the write latency metric */
        write = (struct ceph_metric_write_latency *)(read + 1);
-       write->type = cpu_to_le32(CLIENT_METRIC_TYPE_WRITE_LATENCY);
-       write->ver = 1;
-       write->compat = 1;
-       write->data_len = cpu_to_le32(sizeof(*write) - 10);
+       write->header.type = cpu_to_le32(CLIENT_METRIC_TYPE_WRITE_LATENCY);
+       write->header.ver = 1;
+       write->header.compat = 1;
+       write->header.data_len = cpu_to_le32(sizeof(*write) - header_len);
        sum = m->write_latency_sum;
        jiffies_to_timespec64(sum, &ts);
        write->sec = cpu_to_le32(ts.tv_sec);
@@ -78,10 +79,10 @@ static bool ceph_mdsc_send_metrics(struct ceph_mds_client *mdsc,
 
        /* encode the metadata latency metric */
        meta = (struct ceph_metric_metadata_latency *)(write + 1);
-       meta->type = cpu_to_le32(CLIENT_METRIC_TYPE_METADATA_LATENCY);
-       meta->ver = 1;
-       meta->compat = 1;
-       meta->data_len = cpu_to_le32(sizeof(*meta) - 10);
+       meta->header.type = cpu_to_le32(CLIENT_METRIC_TYPE_METADATA_LATENCY);
+       meta->header.ver = 1;
+       meta->header.compat = 1;
+       meta->header.data_len = cpu_to_le32(sizeof(*meta) - header_len);
        sum = m->metadata_latency_sum;
        jiffies_to_timespec64(sum, &ts);
        meta->sec = cpu_to_le32(ts.tv_sec);
@@ -90,10 +91,10 @@ static bool ceph_mdsc_send_metrics(struct ceph_mds_client *mdsc,
 
        /* encode the dentry lease metric */
        dlease = (struct ceph_metric_dlease *)(meta + 1);
-       dlease->type = cpu_to_le32(CLIENT_METRIC_TYPE_DENTRY_LEASE);
-       dlease->ver = 1;
-       dlease->compat = 1;
-       dlease->data_len = cpu_to_le32(sizeof(*dlease) - 10);
+       dlease->header.type = cpu_to_le32(CLIENT_METRIC_TYPE_DENTRY_LEASE);
+       dlease->header.ver = 1;
+       dlease->header.compat = 1;
+       dlease->header.data_len = cpu_to_le32(sizeof(*dlease) - header_len);
        dlease->hit = cpu_to_le64(percpu_counter_sum(&m->d_lease_hit));
        dlease->mis = cpu_to_le64(percpu_counter_sum(&m->d_lease_mis));
        dlease->total = cpu_to_le64(atomic64_read(&m->total_dentries));
@@ -103,30 +104,30 @@ static bool ceph_mdsc_send_metrics(struct ceph_mds_client *mdsc,
 
        /* encode the opened files metric */
        files = (struct ceph_opened_files *)(dlease + 1);
-       files->type = cpu_to_le32(CLIENT_METRIC_TYPE_OPENED_FILES);
-       files->ver = 1;
-       files->compat = 1;
-       files->data_len = cpu_to_le32(sizeof(*files) - 10);
+       files->header.type = cpu_to_le32(CLIENT_METRIC_TYPE_OPENED_FILES);
+       files->header.ver = 1;
+       files->header.compat = 1;
+       files->header.data_len = cpu_to_le32(sizeof(*files) - header_len);
        files->opened_files = cpu_to_le64(atomic64_read(&m->opened_files));
        files->total = cpu_to_le64(sum);
        items++;
 
        /* encode the pinned icaps metric */
        icaps = (struct ceph_pinned_icaps *)(files + 1);
-       icaps->type = cpu_to_le32(CLIENT_METRIC_TYPE_PINNED_ICAPS);
-       icaps->ver = 1;
-       icaps->compat = 1;
-       icaps->data_len = cpu_to_le32(sizeof(*icaps) - 10);
+       icaps->header.type = cpu_to_le32(CLIENT_METRIC_TYPE_PINNED_ICAPS);
+       icaps->header.ver = 1;
+       icaps->header.compat = 1;
+       icaps->header.data_len = cpu_to_le32(sizeof(*icaps) - header_len);
        icaps->pinned_icaps = cpu_to_le64(nr_caps);
        icaps->total = cpu_to_le64(sum);
        items++;
 
        /* encode the opened inodes metric */
        inodes = (struct ceph_opened_inodes *)(icaps + 1);
-       inodes->type = cpu_to_le32(CLIENT_METRIC_TYPE_OPENED_INODES);
-       inodes->ver = 1;
-       inodes->compat = 1;
-       inodes->data_len = cpu_to_le32(sizeof(*inodes) - 10);
+       inodes->header.type = cpu_to_le32(CLIENT_METRIC_TYPE_OPENED_INODES);
+       inodes->header.ver = 1;
+       inodes->header.compat = 1;
+       inodes->header.data_len = cpu_to_le32(sizeof(*inodes) - header_len);
        inodes->opened_inodes = cpu_to_le64(percpu_counter_sum(&m->opened_inodes));
        inodes->total = cpu_to_le64(sum);
        items++;
index e984eb2..1bdc454 100644 (file)
@@ -38,14 +38,16 @@ enum ceph_metric_type {
        CLIENT_METRIC_TYPE_MAX,                 \
 }
 
-/* metric caps header */
-struct ceph_metric_cap {
+struct ceph_metric_header {
        __le32 type;     /* ceph metric type */
-
        __u8  ver;
        __u8  compat;
-
        __le32 data_len; /* length of sizeof(hit + mis + total) */
+} __packed;
+
+/* metric caps header */
+struct ceph_metric_cap {
+       struct ceph_metric_header header;
        __le64 hit;
        __le64 mis;
        __le64 total;
@@ -53,48 +55,28 @@ struct ceph_metric_cap {
 
 /* metric read latency header */
 struct ceph_metric_read_latency {
-       __le32 type;     /* ceph metric type */
-
-       __u8  ver;
-       __u8  compat;
-
-       __le32 data_len; /* length of sizeof(sec + nsec) */
+       struct ceph_metric_header header;
        __le32 sec;
        __le32 nsec;
 } __packed;
 
 /* metric write latency header */
 struct ceph_metric_write_latency {
-       __le32 type;     /* ceph metric type */
-
-       __u8  ver;
-       __u8  compat;
-
-       __le32 data_len; /* length of sizeof(sec + nsec) */
+       struct ceph_metric_header header;
        __le32 sec;
        __le32 nsec;
 } __packed;
 
 /* metric metadata latency header */
 struct ceph_metric_metadata_latency {
-       __le32 type;     /* ceph metric type */
-
-       __u8  ver;
-       __u8  compat;
-
-       __le32 data_len; /* length of sizeof(sec + nsec) */
+       struct ceph_metric_header header;
        __le32 sec;
        __le32 nsec;
 } __packed;
 
 /* metric dentry lease header */
 struct ceph_metric_dlease {
-       __le32 type;     /* ceph metric type */
-
-       __u8  ver;
-       __u8  compat;
-
-       __le32 data_len; /* length of sizeof(hit + mis + total) */
+       struct ceph_metric_header header;
        __le64 hit;
        __le64 mis;
        __le64 total;
@@ -102,36 +84,21 @@ struct ceph_metric_dlease {
 
 /* metric opened files header */
 struct ceph_opened_files {
-       __le32 type;     /* ceph metric type */
-
-       __u8  ver;
-       __u8  compat;
-
-       __le32 data_len; /* length of sizeof(opened_files + total) */
+       struct ceph_metric_header header;
        __le64 opened_files;
        __le64 total;
 } __packed;
 
 /* metric pinned i_caps header */
 struct ceph_pinned_icaps {
-       __le32 type;     /* ceph metric type */
-
-       __u8  ver;
-       __u8  compat;
-
-       __le32 data_len; /* length of sizeof(pinned_icaps + total) */
+       struct ceph_metric_header header;
        __le64 pinned_icaps;
        __le64 total;
 } __packed;
 
 /* metric opened inodes header */
 struct ceph_opened_inodes {
-       __le32 type;     /* ceph metric type */
-
-       __u8  ver;
-       __u8  compat;
-
-       __le32 data_len; /* length of sizeof(opened_inodes + total) */
+       struct ceph_metric_header header;
        __le64 opened_inodes;
        __le64 total;
 } __packed;