Please add some description (as I already asked)
Wed, Nov 25, 2015 at 05:49:49PM CET, ctcard1(a)gmail.com wrote:
---
libteam/ifinfo.c | 55 +++++++++++++++++++++++++++++++++++++++----------------
1 file changed, 39 insertions(+), 16 deletions(-)
diff --git a/libteam/ifinfo.c b/libteam/ifinfo.c
index 484ac1b..0ad24b4 100644
--- a/libteam/ifinfo.c
+++ b/libteam/ifinfo.c
@@ -333,23 +333,46 @@ int get_ifinfo_list(struct team_handle *th)
};
int ret;
- ret = nl_send_simple(th->nl_cli.sock, RTM_GETLINK, NLM_F_DUMP,
- &rt_hdr, sizeof(rt_hdr));
- if (ret < 0)
- return -nl2syserr(ret);
- orig_cb = nl_socket_get_cb(th->nl_cli.sock);
- cb = nl_cb_clone(orig_cb);
- nl_cb_put(orig_cb);
- if (!cb)
- return -ENOMEM;
-
- nl_cb_set(cb, NL_CB_VALID, NL_CB_CUSTOM, valid_handler, th);
-
- ret = nl_recvmsgs(th->nl_cli.sock, cb);
- nl_cb_put(cb);
+ int retry = 1;
Empty line is missing.
+ while (retry)
+ {
Please be consistent with the rest of the code (as I already asked)
"{" should be at the end of the line.
+ retry = 0;
+ ret = nl_send_simple(th->nl_cli.sock, RTM_GETLINK, NLM_F_DUMP,
+ &rt_hdr, sizeof(rt_hdr));
Line should start right after "(" (see the rest of the code).
+ if (ret < 0)
+ {
+ err(th, "get_ifinfo_list: nl_send_simple failed: ret = %d", ret);
+ return -nl2syserr(ret);
+ }
+ orig_cb = nl_socket_get_cb(th->nl_cli.sock);
+ cb = nl_cb_clone(orig_cb);
+ nl_cb_put(orig_cb);
+ if (!cb)
+ {
+ err(th, "get_ifinfo_list: nl_cb_clone failed");
+ return -ENOMEM;
+ }
+
+ nl_cb_set(cb, NL_CB_VALID, NL_CB_CUSTOM, valid_handler, th);
+
+ ret = nl_recvmsgs(th->nl_cli.sock, cb);
+ nl_cb_put(cb);
+ if (ret < 0)
+ {
+ err(th, "get_ifinfo_list: nl_recvmsgs failed: ret = %d", ret);
No need to print "ret = %d" here. "ret" is properly propagated to the
caller.
+ if (ret != -NLE_DUMP_INTR)
+ {
+ return -nl2syserr(ret);
+ }
No braces needed for one-line statement.
>+ retry = 1;
>+ }
>+ }
>+ ret = check_call_change_handlers(th, TEAM_IFINFO_CHANGE);
> if (ret < 0)
>- return -nl2syserr(ret);
>- return check_call_change_handlers(th, TEAM_IFINFO_CHANGE);
>+ {
>+ err(th, "get_ifinfo_list: check_call_change_handers failed: ret = %d",
ret);
>+ }
>+ return ret;
> }
>
> int ifinfo_list_init(struct team_handle *th)
>--
>2.4.3
>_______________________________________________
>libteam mailing list
>libteam(a)lists.fedorahosted.org
>https://lists.fedorahosted.org/admin/lists/libteam@lists.fedorahosted.org