diff --git a/.fcoe-utils.metadata b/.fcoe-utils.metadata index a68279a..096b971 100644 --- a/.fcoe-utils.metadata +++ b/.fcoe-utils.metadata @@ -1 +1 @@ -af94ad7bd13d0828be6246f46f04b3b7d6a1ad0a SOURCES/fcoe-utils-1.0.32.tar.gz +263e7e1c31e5c834126afb0a510a852268bd07af SOURCES/fcoe-utils-1.0.33-848bcc6.tar.gz diff --git a/.gitignore b/.gitignore index e1447d8..cf7df6a 100644 --- a/.gitignore +++ b/.gitignore @@ -1 +1 @@ -SOURCES/fcoe-utils-1.0.32.tar.gz +SOURCES/fcoe-utils-1.0.33-848bcc6.tar.gz diff --git a/SOURCES/0001-fcoemon-netlink-buffer-resize-fix.patch b/SOURCES/0001-fcoemon-netlink-buffer-resize-fix.patch deleted file mode 100644 index 58c79e4..0000000 --- a/SOURCES/0001-fcoemon-netlink-buffer-resize-fix.patch +++ /dev/null @@ -1,125 +0,0 @@ -From 3b4ca6b87dae6b11da137b6afb4cf8275687d281 Mon Sep 17 00:00:00 2001 -From: Chris Leech -Date: Thu, 24 Jan 2019 18:16:47 -0800 -Subject: [PATCH] fcoemon: netlink buffer resize fix - -The recv buffer resizing for netlink messages looks to have always been -busted, it discards some of the data in the process of increasing the -buffer size. - -I've recently seen issues where the size of the netlink attributes in a -GETLINK request hit the fcm_link_buf_size window and some of the network -interfaces were ignored by fcoemon (happened mostly with recent kernels, -2 dual-port bnx2 NICs, bonding for LAN traffic on 2 ports and FCoE on -the other 2). When the ignored interface happens to be the one you want -to use for FCoE, it never gets fixed. - -This fixes the buffer resize code to use MSG_PEEK|MSG_TRUNC to check for -the needed buffer size first, and then resize with realloc when needed. -This might not actually be needed, with an 8k buffer I don't think the -kernel side will send more at once until after it sees the application -post a larger buffer, but I did force a resize and see that it worked. - -Signed-off-by: Chris Leech ---- - fcoemon.c | 54 ++++++++++++++++++------------------------------------ - 1 file changed, 18 insertions(+), 36 deletions(-) - -diff --git a/fcoemon.c b/fcoemon.c -index 9a400c56b72..9af0f1284af 100644 ---- a/fcoemon.c -+++ b/fcoemon.c -@@ -328,7 +328,6 @@ static int fcm_link_socket; - static int fcm_link_seq; - static void fcm_link_recv(void *); - static void fcm_link_getlink(void); --static int fcm_link_buf_check(size_t); - static void clear_dcbd_info(struct fcm_netif *ff); - static int fcoe_vid_from_ifname(const char *ifname); - -@@ -354,8 +353,7 @@ char progname[20]; - * large enough to fit and expand it if we ever do a read that almost fills it. - */ - static char *fcm_link_buf; --static size_t fcm_link_buf_size = 4096; /* initial size */ --static const size_t fcm_link_buf_fuzz = 300; /* "almost full" remainder */ -+static size_t fcm_link_buf_size = 8192; /* initial size */ - - /* - * A value must be surrounded by quates, e.g. "x". -@@ -1848,8 +1846,22 @@ static void fcm_link_recv(UNUSED void *arg) - size_t plen; - size_t rlen; - -+ /* check to make sure our receive buffer is large enough, -+ * or scale it up as needed */ -+ rc = recv(fcm_link_socket, NULL, 0, MSG_PEEK | MSG_TRUNC); -+ if (rc > fcm_link_buf_size) { -+ FCM_LOG_DBG("resizing link buf to %d bytes\n", rc); -+ void *resize = realloc(fcm_link_buf, rc); -+ if (resize) { -+ fcm_link_buf = resize; -+ fcm_link_buf_size = rc; -+ } else { -+ FCM_LOG_ERR(errno, "Failed to allocate link buffer"); -+ } -+ } -+ - buf = fcm_link_buf; -- rc = read(fcm_link_socket, buf, fcm_link_buf_size); -+ rc = recv(fcm_link_socket, buf, fcm_link_buf_size, 0); - if (rc <= 0) { - if (rc < 0) - FCM_LOG_ERR(errno, "Error reading from " -@@ -1858,11 +1870,6 @@ static void fcm_link_recv(UNUSED void *arg) - return; - } - -- if (fcm_link_buf_check(rc)) { -- fcm_link_getlink(); -- return; -- } -- - hp = (struct nlmsghdr *)buf; - rlen = rc; - for (hp = (struct nlmsghdr *)buf; NLMSG_OK(hp, rlen); -@@ -1927,34 +1934,9 @@ static void fcm_link_getlink(void) - msg.nl.nlmsg_pid = getpid(); - msg.ifi.ifi_family = AF_UNSPEC; - msg.ifi.ifi_type = ARPHRD_ETHER; -- rc = write(fcm_link_socket, &msg, sizeof(msg)); -+ rc = send(fcm_link_socket, &msg, sizeof(msg), 0); - if (rc < 0) -- FCM_LOG_ERR(errno, "write error"); --} -- --/* -- * Check for whether buffer needs to grow based on amount read. -- * Free's the old buffer so don't use that after this returns non-zero. -- */ --static int fcm_link_buf_check(size_t read_len) --{ -- char *buf; -- size_t len = read_len; -- -- if (len > fcm_link_buf_size - fcm_link_buf_fuzz) { -- len = fcm_link_buf_size; -- len = len + len / 2; /* grow by 50% */ -- buf = malloc(len); -- if (buf != NULL) { -- free(fcm_link_buf); -- fcm_link_buf = buf; -- fcm_link_buf_size = len; -- return 1; -- } else { -- FCM_LOG_ERR(errno, "failed to allocate link buffer"); -- } -- } -- return 0; -+ FCM_LOG_ERR(errno, "send error"); - } - - static void fcm_fcoe_init(void) --- -2.21.0 - diff --git a/SOURCES/fcoe-utils-gcc7-fmt-truc-err.patch b/SOURCES/fcoe-utils-gcc7-fmt-truc-err.patch deleted file mode 100644 index 3de42b4..0000000 --- a/SOURCES/fcoe-utils-gcc7-fmt-truc-err.patch +++ /dev/null @@ -1,53 +0,0 @@ -diff --git a/fipvlan.c b/fipvlan.c -index 7c00c7c..065b742 100644 ---- a/fipvlan.c -+++ b/fipvlan.c -@@ -621,8 +621,10 @@ create_and_start_vlan(struct fcf *fcf, bool vn2vn) - real_dev->ifname, fcf->vlan, vlan->ifname); - rc = 0; - } else { -- snprintf(vlan_name, IFNAMSIZ, "%s.%d%s", -- real_dev->ifname, fcf->vlan, config.suffix); -+ rc = snprintf(vlan_name, IFNAMSIZ, "%s.%d%s", -+ real_dev->ifname, fcf->vlan, config.suffix); -+ if (rc >= IFNAMSIZ) -+ return -E2BIG; - rc = vlan_create(fcf->ifindex, fcf->vlan, vlan_name); - if (rc < 0) - printf("Failed to create VLAN device %s\n\t%s\n", -diff --git a/libopenfcoe.c b/libopenfcoe.c -index 07090d5..98fb975 100644 ---- a/libopenfcoe.c -+++ b/libopenfcoe.c -@@ -59,6 +59,7 @@ static int add_fcoe_fcf_device(struct dirent *dp, void *arg) - { - struct fcoe_ctlr_device *ctlr = (struct fcoe_ctlr_device *)arg; - struct fcoe_fcf_device *fcf; -+ int rc; - - if (!strstr(dp->d_name, "fcf") || - (!strcmp(dp->d_name, "fcf_dev_loss_tmo"))) -@@ -71,8 +72,10 @@ static int add_fcoe_fcf_device(struct dirent *dp, void *arg) - memset(fcf, 0, sizeof(struct fcoe_fcf_device)); - - /* Save the path */ -- snprintf(fcf->path, sizeof(fcf->path), -- "%s/%s", ctlr->path, dp->d_name); -+ rc = snprintf(fcf->path, sizeof(fcf->path), -+ "%s/%s", ctlr->path, dp->d_name); -+ if (rc >= sizeof(fcf->path)) -+ goto fail; - - /* Use the index from the logical enumeration */ - fcf->index = atoi(dp->d_name + sizeof("fcf_") - 1); -@@ -198,7 +201,9 @@ static int read_fcoe_ctlr_device(struct dirent *dp, void *arg) - sa_sys_read_line(ctlr->path, "mode", buf, sizeof(buf)); - sa_enum_encode(fip_conn_type_table, buf, &ctlr->mode); - -- snprintf(lesb_path, sizeof(lesb_path), "%s/lesb/", ctlr->path); -+ rc = snprintf(lesb_path, sizeof(lesb_path), "%s/lesb/", ctlr->path); -+ if (rc >= sizeof(lesb_path)) -+ goto fail; - - /* Get LESB statistics */ - sa_sys_read_u32(lesb_path, "link_fail", diff --git a/SOURCES/fcoe-utils-gcc8-fmt-truc-err.patch b/SOURCES/fcoe-utils-gcc8-fmt-truc-err.patch deleted file mode 100644 index d7602b0..0000000 --- a/SOURCES/fcoe-utils-gcc8-fmt-truc-err.patch +++ /dev/null @@ -1,119 +0,0 @@ -From: Chris Leech -Subject: fix build warnings/errors with GCC format-truncation checks - -diff --git a/fcoeadm_display.c b/fcoeadm_display.c -index 120c6084b7ca..f10cfb53d454 100644 ---- a/fcoeadm_display.c -+++ b/fcoeadm_display.c -@@ -254,6 +254,7 @@ static void show_full_lun_info(unsigned int hba, unsigned int port, - struct dirent *dp; - struct port_attributes *rport_attrs; - struct port_attributes *port_attrs; -+ int rc; - - snprintf(path, sizeof(path), - "/sys/class/scsi_device/%u:%u:%u:%u", -@@ -287,10 +288,18 @@ static void show_full_lun_info(unsigned int hba, unsigned int port, - - osname = dp->d_name; - -- snprintf(npath, sizeof(npath), "%s/%s/", path, osname); -+ rc = snprintf(npath, sizeof(npath), "%s/%s/", path, osname); -+ if (rc < 0 || rc >= sizeof(npath)) { -+ /* error or truncation, bailing out */ -+ return; -+ } - sa_sys_read_u64(npath, "size", &lba); - -- snprintf(npath, sizeof(npath), "%s/%s/queue/", path, osname); -+ rc = snprintf(npath, sizeof(npath), "%s/%s/queue/", path, osname); -+ if (rc < 0 || rc >= sizeof(npath)) { -+ /* error or truncation, bailing out */ -+ return; -+ } - sa_sys_read_u32(npath, "hw_sector_size", &blksize); - } - -@@ -340,6 +349,7 @@ static void show_short_lun_info(unsigned int hba, unsigned int port, - char *capstr = "Unknown"; - char *osname = "Unknown"; - uint64_t size; -+ int rc; - - snprintf(path, sizeof(path), - "/sys/class/scsi_device/%u:%u:%u:%u/device/", -@@ -363,10 +373,18 @@ static void show_short_lun_info(unsigned int hba, unsigned int port, - - osname = dp->d_name; - -- snprintf(npath, sizeof(npath), "%s/%s/", path, osname); -+ rc = snprintf(npath, sizeof(npath), "%s/%s/", path, osname); -+ if (rc < 0 || rc >= sizeof(npath)) { -+ /* error or truncation, bailing out */ -+ return; -+ } - sa_sys_read_u64(npath, "size", &size); - -- snprintf(npath, sizeof(npath), "%s/%s/queue/", path, osname); -+ rc = snprintf(npath, sizeof(npath), "%s/%s/queue/", path, osname); -+ if (rc < 0 || rc >= sizeof(npath)) { -+ /* error or truncation, bailing out */ -+ return; -+ } - sa_sys_read_u32(npath, "hw_sector_size", &blksize); - } - -diff --git a/fcoemon.c b/fcoemon.c -index 9a400c56b72a..bf73a0d4c89e 100644 ---- a/fcoemon.c -+++ b/fcoemon.c -@@ -939,6 +939,7 @@ static struct fcoe_port *fcm_new_vlan(int ifindex, int vid, bool vn2vn) - [false] = CLIF_FLAGS_FABRIC, - [true] = CLIF_FLAGS_VN2VN, - }; -+ int rc; - - if (vn2vn) - FCM_LOG_DBG("Auto VLAN found vn2vn on VID %d\n", vid); -@@ -947,8 +948,15 @@ static struct fcoe_port *fcm_new_vlan(int ifindex, int vid, bool vn2vn) - - if (rtnl_find_vlan(ifindex, vid, vlan_name)) { - rtnl_get_linkname(ifindex, real_name); -- snprintf(vlan_name, sizeof(vlan_name), FCOE_VLAN_FORMAT, -- real_name, vid); -+ rc = snprintf(vlan_name, sizeof(vlan_name), FCOE_VLAN_FORMAT, -+ real_name, vid); -+ if (rc >= sizeof(vlan_name)) { -+ FCM_LOG("Warning: Generating FCoE VLAN device name for" -+ "interface %s VLAN %d: format resulted in a" -+ "name larger than IFNAMSIZ\n", real_name, vid); -+ vlan_name[sizeof(vlan_name) - 1] = 0; -+ FCM_LOG("\tTruncating VLAN name to %s\n", vlan_name); -+ } - vlan_create(ifindex, vid, vlan_name); - } - rtnl_set_iff_up(0, vlan_name); -@@ -3549,7 +3557,7 @@ static void fcm_srv_receive(void *arg) - } - - cmd = data->cmd; -- strncpy(ifname, data->ifname, sizeof(data->ifname)); -+ strncpy(ifname, data->ifname, sizeof(ifname) - 1); - ifname[sizeof(data->ifname)] = 0; - - if (cmd != CLIF_PID_CMD) { -diff --git a/libopenfcoe.c b/libopenfcoe.c -index 07090d5a09aa..c1190adc2328 100644 ---- a/libopenfcoe.c -+++ b/libopenfcoe.c -@@ -179,7 +179,9 @@ static int read_fcoe_ctlr_device(struct dirent *dp, void *arg) - if (!rc) - goto fail; - -- sprintf(hpath, "%s/%s/", SYSFS_FCHOST, fchost); -+ rc = snprintf(hpath, MAX_STR_LEN, "%s/%s/", SYSFS_FCHOST, fchost); -+ if (rc < 0 || rc >= MAX_STR_LEN) -+ goto fail; - - rc = sa_sys_read_line(hpath, "symbolic_name", buf, sizeof(buf)); - diff --git a/SOURCES/fcoe-utils-v1.0.32-1-fcoe-utils-Fix-get_ctlr_num-for-large-ctlr_-indices.patch b/SOURCES/fcoe-utils-v1.0.32-1-fcoe-utils-Fix-get_ctlr_num-for-large-ctlr_-indices.patch deleted file mode 100644 index ce72ba1..0000000 --- a/SOURCES/fcoe-utils-v1.0.32-1-fcoe-utils-Fix-get_ctlr_num-for-large-ctlr_-indices.patch +++ /dev/null @@ -1,34 +0,0 @@ -From f369a89e914eb1f14b26d6e84fa32fdf8a591cfc Mon Sep 17 00:00:00 2001 -From: Andrey Grafin -Date: Mon, 18 Sep 2017 17:35:08 +0300 -Subject: [PATCH 1/1] fcoe-utils: Fix get_ctlr_num() for large ctlr_* indices - -Each creation of a FCoE device increases counter which is used as a suffix -in a FCoE device name in sysfs (i.e. /sys/bus/fcoe/devices/ctlr_1). -Once this counter reaches the value of two digits (10 and larger), -get_ctlr_num() stopped working properly and a command like `fcoeadm -i` -which depends on get_ctlr_num() call doesn't show anything. -This patch solves this problem. - -Signed-off-by: Andrey Grafin -Signed-off-by: Johannes Thumshirn ---- - lib/sysfs_hba.c | 2 +- - 1 file changed, 1 insertion(+), 1 deletion(-) - -diff --git a/lib/sysfs_hba.c b/lib/sysfs_hba.c -index 5cb7fd3fa5d5..786215440bac 100644 ---- a/lib/sysfs_hba.c -+++ b/lib/sysfs_hba.c -@@ -606,7 +606,7 @@ static int get_ctlr_num(const char *netdev) - if (!ctlr) - continue; - -- ctlr_num = atoi(&ctlr[strlen(ctlr) - 1]); -+ ctlr_num = atoi(&ctlr[sizeof("ctlr_") - 1]); - break; - } - --- -2.14.4 - diff --git a/SPECS/fcoe-utils.spec b/SPECS/fcoe-utils.spec index fc08ef0..d9fffe6 100644 --- a/SPECS/fcoe-utils.spec +++ b/SPECS/fcoe-utils.spec @@ -1,26 +1,23 @@ # https://fedoraproject.org/wiki/Packaging:Guidelines#Compiler_flags %global _hardened_build 1 -%global checkout f5cbb9a +# v1.0.33-9-g848bcc6ba8c +%global commit0 848bcc6ba8cda1f344663b4e73f1bc4857bcb4e3 +%global shortcommit0 %(c=%{commit0}; echo ${c:0:7}) Name: fcoe-utils -Version: 1.0.32 -Release: 7%{?dist} +Version: 1.0.33 +Release: 1.git%{shortcommit0}%{?dist} Summary: Fibre Channel over Ethernet utilities Group: Applications/System License: GPLv2 URL: http://www.open-fcoe.org -# git://open-fcoe.org/fcoe/fcoe-utils.git -Source0: https://github.com/morbidrsa/fcoe-utils/archive/v%{version}.tar.gz#/%{name}-%{version}.tar.gz +Source0: https://github.com/openSUSE/fcoe-utils/archive/%{commit0}.tar.gz#/%{name}-%{version}-%{shortcommit0}.tar.gz Source1: quickstart.txt Source2: fcoe.service Source3: fcoe.config ExcludeArch: ppc s390 -Patch0: fcoe-utils-gcc7-fmt-truc-err.patch -Patch1: fcoe-utils-gcc8-fmt-truc-err.patch -Patch2: fcoe-utils-v1.0.32-1-fcoe-utils-Fix-get_ctlr_num-for-large-ctlr_-indices.patch -Patch3: fcoe-utils-set-default-DCB_REQUIRED-to-no.patch -Patch4: 0001-fcoemon-netlink-buffer-resize-fix.patch +Patch0: fcoe-utils-set-default-DCB_REQUIRED-to-no.patch BuildRequires: autoconf BuildRequires: automake BuildRequires: libpciaccess-devel @@ -40,7 +37,7 @@ fcoeadm - command line tool for configuring FCoE interfaces fcoemon - service to configure DCB Ethernet QOS filters, works with lldpad %prep -%autosetup -p1 +%autosetup -p1 -n fcoe-utils-%{commit0} cp -v %{SOURCE1} quickstart.txt %build @@ -81,10 +78,16 @@ rm -f %{buildroot}/%{_sysconfdir}/fcoe/config %{_sysconfdir}/fcoe/ %config(noreplace) %{_sysconfdir}/fcoe/cfg-ethx %config(noreplace) %{_sysconfdir}/sysconfig/fcoe -%{_sysconfdir}/bash_completion.d/* +%{_datadir}/bash-completion/completions/* %{_libexecdir}/fcoe/ %changelog +* Tue Nov 03 2020 Chris Leech - 1.0.33-1.git848bcc6 +- 1889536 add back default change of DCB_REQUIRED="no" for RHEL 8 + +* Tue Nov 03 2020 Chris Leech - 1.0.33-0.git848bcc6 +- 1889536 new version + * Fri Dec 06 2019 Chris Leech - 1.0.32-7 - 1776492 fcoemon: fix ignored devices from recv buffer resize bug