Lines Matching refs:fmsg
32 struct devlink_fmsg *fmsg; in devlink_fmsg_alloc() local
34 fmsg = kzalloc(sizeof(*fmsg), GFP_KERNEL); in devlink_fmsg_alloc()
35 if (!fmsg) in devlink_fmsg_alloc()
38 INIT_LIST_HEAD(&fmsg->item_list); in devlink_fmsg_alloc()
40 return fmsg; in devlink_fmsg_alloc()
43 static void devlink_fmsg_free(struct devlink_fmsg *fmsg) in devlink_fmsg_free() argument
47 list_for_each_entry_safe(item, tmp, &fmsg->item_list, list) { in devlink_fmsg_free()
51 kfree(fmsg); in devlink_fmsg_free()
660 static int devlink_fmsg_nest_common(struct devlink_fmsg *fmsg, in devlink_fmsg_nest_common() argument
670 list_add_tail(&item->list, &fmsg->item_list); in devlink_fmsg_nest_common()
675 int devlink_fmsg_obj_nest_start(struct devlink_fmsg *fmsg) in devlink_fmsg_obj_nest_start() argument
677 if (fmsg->putting_binary) in devlink_fmsg_obj_nest_start()
680 return devlink_fmsg_nest_common(fmsg, DEVLINK_ATTR_FMSG_OBJ_NEST_START); in devlink_fmsg_obj_nest_start()
684 static int devlink_fmsg_nest_end(struct devlink_fmsg *fmsg) in devlink_fmsg_nest_end() argument
686 if (fmsg->putting_binary) in devlink_fmsg_nest_end()
689 return devlink_fmsg_nest_common(fmsg, DEVLINK_ATTR_FMSG_NEST_END); in devlink_fmsg_nest_end()
692 int devlink_fmsg_obj_nest_end(struct devlink_fmsg *fmsg) in devlink_fmsg_obj_nest_end() argument
694 if (fmsg->putting_binary) in devlink_fmsg_obj_nest_end()
697 return devlink_fmsg_nest_end(fmsg); in devlink_fmsg_obj_nest_end()
703 static int devlink_fmsg_put_name(struct devlink_fmsg *fmsg, const char *name) in devlink_fmsg_put_name() argument
707 if (fmsg->putting_binary) in devlink_fmsg_put_name()
721 list_add_tail(&item->list, &fmsg->item_list); in devlink_fmsg_put_name()
726 int devlink_fmsg_pair_nest_start(struct devlink_fmsg *fmsg, const char *name) in devlink_fmsg_pair_nest_start() argument
730 if (fmsg->putting_binary) in devlink_fmsg_pair_nest_start()
733 err = devlink_fmsg_nest_common(fmsg, DEVLINK_ATTR_FMSG_PAIR_NEST_START); in devlink_fmsg_pair_nest_start()
737 err = devlink_fmsg_put_name(fmsg, name); in devlink_fmsg_pair_nest_start()
745 int devlink_fmsg_pair_nest_end(struct devlink_fmsg *fmsg) in devlink_fmsg_pair_nest_end() argument
747 if (fmsg->putting_binary) in devlink_fmsg_pair_nest_end()
750 return devlink_fmsg_nest_end(fmsg); in devlink_fmsg_pair_nest_end()
754 int devlink_fmsg_arr_pair_nest_start(struct devlink_fmsg *fmsg, in devlink_fmsg_arr_pair_nest_start() argument
759 if (fmsg->putting_binary) in devlink_fmsg_arr_pair_nest_start()
762 err = devlink_fmsg_pair_nest_start(fmsg, name); in devlink_fmsg_arr_pair_nest_start()
766 err = devlink_fmsg_nest_common(fmsg, DEVLINK_ATTR_FMSG_ARR_NEST_START); in devlink_fmsg_arr_pair_nest_start()
774 int devlink_fmsg_arr_pair_nest_end(struct devlink_fmsg *fmsg) in devlink_fmsg_arr_pair_nest_end() argument
778 if (fmsg->putting_binary) in devlink_fmsg_arr_pair_nest_end()
781 err = devlink_fmsg_nest_end(fmsg); in devlink_fmsg_arr_pair_nest_end()
785 err = devlink_fmsg_nest_end(fmsg); in devlink_fmsg_arr_pair_nest_end()
793 int devlink_fmsg_binary_pair_nest_start(struct devlink_fmsg *fmsg, in devlink_fmsg_binary_pair_nest_start() argument
798 err = devlink_fmsg_arr_pair_nest_start(fmsg, name); in devlink_fmsg_binary_pair_nest_start()
802 fmsg->putting_binary = true; in devlink_fmsg_binary_pair_nest_start()
807 int devlink_fmsg_binary_pair_nest_end(struct devlink_fmsg *fmsg) in devlink_fmsg_binary_pair_nest_end() argument
809 if (!fmsg->putting_binary) in devlink_fmsg_binary_pair_nest_end()
812 fmsg->putting_binary = false; in devlink_fmsg_binary_pair_nest_end()
813 return devlink_fmsg_arr_pair_nest_end(fmsg); in devlink_fmsg_binary_pair_nest_end()
817 static int devlink_fmsg_put_value(struct devlink_fmsg *fmsg, in devlink_fmsg_put_value() argument
834 list_add_tail(&item->list, &fmsg->item_list); in devlink_fmsg_put_value()
839 static int devlink_fmsg_bool_put(struct devlink_fmsg *fmsg, bool value) in devlink_fmsg_bool_put() argument
841 if (fmsg->putting_binary) in devlink_fmsg_bool_put()
844 return devlink_fmsg_put_value(fmsg, &value, sizeof(value), NLA_FLAG); in devlink_fmsg_bool_put()
847 static int devlink_fmsg_u8_put(struct devlink_fmsg *fmsg, u8 value) in devlink_fmsg_u8_put() argument
849 if (fmsg->putting_binary) in devlink_fmsg_u8_put()
852 return devlink_fmsg_put_value(fmsg, &value, sizeof(value), NLA_U8); in devlink_fmsg_u8_put()
855 int devlink_fmsg_u32_put(struct devlink_fmsg *fmsg, u32 value) in devlink_fmsg_u32_put() argument
857 if (fmsg->putting_binary) in devlink_fmsg_u32_put()
860 return devlink_fmsg_put_value(fmsg, &value, sizeof(value), NLA_U32); in devlink_fmsg_u32_put()
864 static int devlink_fmsg_u64_put(struct devlink_fmsg *fmsg, u64 value) in devlink_fmsg_u64_put() argument
866 if (fmsg->putting_binary) in devlink_fmsg_u64_put()
869 return devlink_fmsg_put_value(fmsg, &value, sizeof(value), NLA_U64); in devlink_fmsg_u64_put()
872 int devlink_fmsg_string_put(struct devlink_fmsg *fmsg, const char *value) in devlink_fmsg_string_put() argument
874 if (fmsg->putting_binary) in devlink_fmsg_string_put()
877 return devlink_fmsg_put_value(fmsg, value, strlen(value) + 1, in devlink_fmsg_string_put()
882 int devlink_fmsg_binary_put(struct devlink_fmsg *fmsg, const void *value, in devlink_fmsg_binary_put() argument
885 if (!fmsg->putting_binary) in devlink_fmsg_binary_put()
888 return devlink_fmsg_put_value(fmsg, value, value_len, NLA_BINARY); in devlink_fmsg_binary_put()
892 int devlink_fmsg_bool_pair_put(struct devlink_fmsg *fmsg, const char *name, in devlink_fmsg_bool_pair_put() argument
897 err = devlink_fmsg_pair_nest_start(fmsg, name); in devlink_fmsg_bool_pair_put()
901 err = devlink_fmsg_bool_put(fmsg, value); in devlink_fmsg_bool_pair_put()
905 err = devlink_fmsg_pair_nest_end(fmsg); in devlink_fmsg_bool_pair_put()
913 int devlink_fmsg_u8_pair_put(struct devlink_fmsg *fmsg, const char *name, in devlink_fmsg_u8_pair_put() argument
918 err = devlink_fmsg_pair_nest_start(fmsg, name); in devlink_fmsg_u8_pair_put()
922 err = devlink_fmsg_u8_put(fmsg, value); in devlink_fmsg_u8_pair_put()
926 err = devlink_fmsg_pair_nest_end(fmsg); in devlink_fmsg_u8_pair_put()
934 int devlink_fmsg_u32_pair_put(struct devlink_fmsg *fmsg, const char *name, in devlink_fmsg_u32_pair_put() argument
939 err = devlink_fmsg_pair_nest_start(fmsg, name); in devlink_fmsg_u32_pair_put()
943 err = devlink_fmsg_u32_put(fmsg, value); in devlink_fmsg_u32_pair_put()
947 err = devlink_fmsg_pair_nest_end(fmsg); in devlink_fmsg_u32_pair_put()
955 int devlink_fmsg_u64_pair_put(struct devlink_fmsg *fmsg, const char *name, in devlink_fmsg_u64_pair_put() argument
960 err = devlink_fmsg_pair_nest_start(fmsg, name); in devlink_fmsg_u64_pair_put()
964 err = devlink_fmsg_u64_put(fmsg, value); in devlink_fmsg_u64_pair_put()
968 err = devlink_fmsg_pair_nest_end(fmsg); in devlink_fmsg_u64_pair_put()
976 int devlink_fmsg_string_pair_put(struct devlink_fmsg *fmsg, const char *name, in devlink_fmsg_string_pair_put() argument
981 err = devlink_fmsg_pair_nest_start(fmsg, name); in devlink_fmsg_string_pair_put()
985 err = devlink_fmsg_string_put(fmsg, value); in devlink_fmsg_string_pair_put()
989 err = devlink_fmsg_pair_nest_end(fmsg); in devlink_fmsg_string_pair_put()
997 int devlink_fmsg_binary_pair_put(struct devlink_fmsg *fmsg, const char *name, in devlink_fmsg_binary_pair_put() argument
1005 err = devlink_fmsg_binary_pair_nest_start(fmsg, name); in devlink_fmsg_binary_pair_put()
1013 err = devlink_fmsg_binary_put(fmsg, value + offset, data_size); in devlink_fmsg_binary_pair_put()
1022 end_err = devlink_fmsg_binary_pair_nest_end(fmsg); in devlink_fmsg_binary_pair_put()
1076 devlink_fmsg_prepare_skb(struct devlink_fmsg *fmsg, struct sk_buff *skb, in devlink_fmsg_prepare_skb() argument
1088 list_for_each_entry(item, &fmsg->item_list, list) { in devlink_fmsg_prepare_skb()
1125 static int devlink_fmsg_snd(struct devlink_fmsg *fmsg, in devlink_fmsg_snd() argument
1150 err = devlink_fmsg_prepare_skb(fmsg, skb, &index); in devlink_fmsg_snd()
1179 static int devlink_fmsg_dumpit(struct devlink_fmsg *fmsg, struct sk_buff *skb, in devlink_fmsg_dumpit() argument
1196 err = devlink_fmsg_prepare_skb(fmsg, skb, &index); in devlink_fmsg_dumpit()
1214 struct devlink_fmsg *fmsg; in devlink_nl_cmd_health_reporter_diagnose_doit() local
1224 fmsg = devlink_fmsg_alloc(); in devlink_nl_cmd_health_reporter_diagnose_doit()
1225 if (!fmsg) in devlink_nl_cmd_health_reporter_diagnose_doit()
1228 err = devlink_fmsg_obj_nest_start(fmsg); in devlink_nl_cmd_health_reporter_diagnose_doit()
1232 err = reporter->ops->diagnose(reporter, fmsg, info->extack); in devlink_nl_cmd_health_reporter_diagnose_doit()
1236 err = devlink_fmsg_obj_nest_end(fmsg); in devlink_nl_cmd_health_reporter_diagnose_doit()
1240 err = devlink_fmsg_snd(fmsg, info, in devlink_nl_cmd_health_reporter_diagnose_doit()
1244 devlink_fmsg_free(fmsg); in devlink_nl_cmd_health_reporter_diagnose_doit()