import iscsi-initiator-utils-6.2.0.877-1.gitf71581b.el8
This commit is contained in:
		
						commit
						9323f0fb9c
					
				
							
								
								
									
										1
									
								
								.gitignore
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								.gitignore
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1 @@ | |||||||
|  | SOURCES/open-iscsi-f71581b.tar.gz | ||||||
							
								
								
									
										1
									
								
								.iscsi-initiator-utils.metadata
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								.iscsi-initiator-utils.metadata
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1 @@ | |||||||
|  | 3d3234035cc7884aa512161e06be6737ade52077 SOURCES/open-iscsi-f71581b.tar.gz | ||||||
							
								
								
									
										123
									
								
								SOURCES/0001-Coverity-scan-fixes.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										123
									
								
								SOURCES/0001-Coverity-scan-fixes.patch
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,123 @@ | |||||||
|  | From f8e7499e9f69465668fc6e5e7bcfb9ce09e8a457 Mon Sep 17 00:00:00 2001 | ||||||
|  | From: Chris Leech <cleech@redhat.com> | ||||||
|  | Date: Wed, 5 Jun 2019 09:08:39 -0700 | ||||||
|  | Subject: [PATCH] Coverity scan fixes | ||||||
|  | 
 | ||||||
|  | ---
 | ||||||
|  |  iscsiuio/src/unix/libs/qedi.c |  2 +- | ||||||
|  |  iscsiuio/src/unix/main.c      | 12 ++++++++++-- | ||||||
|  |  libopeniscsiusr/idbm.c        | 11 +++++------ | ||||||
|  |  usr/idbm.c                    | 10 ++++------ | ||||||
|  |  usr/iscsid.c                  |  2 +- | ||||||
|  |  5 files changed, 21 insertions(+), 16 deletions(-) | ||||||
|  | 
 | ||||||
|  | diff --git a/iscsiuio/src/unix/libs/qedi.c b/iscsiuio/src/unix/libs/qedi.c
 | ||||||
|  | index b7595d5..47300b0 100644
 | ||||||
|  | --- a/iscsiuio/src/unix/libs/qedi.c
 | ||||||
|  | +++ b/iscsiuio/src/unix/libs/qedi.c
 | ||||||
|  | @@ -1023,7 +1023,7 @@ static int qedi_read(nic_t *nic, packet_t *pkt)
 | ||||||
|  |   | ||||||
|  |  	LOG_DEBUG(PFX "%s:hw_prod %d bd_prod %d, rx_pkt_idx %d, rxlen %d", | ||||||
|  |  		  nic->log_name, hw_prod, bd_prod, rx_bd->rx_pkt_index, len); | ||||||
|  | -	LOG_DEBUG(PFX "%s: sw_con %d bd_cons %d num BD %d",
 | ||||||
|  | +	LOG_DEBUG(PFX "%s: sw_con %d bd_cons %d num BD %lu",
 | ||||||
|  |  		  nic->log_name, sw_cons, bd_cons, QEDI_NUM_RX_BD); | ||||||
|  |   | ||||||
|  |  	if (bd_cons != bd_prod) { | ||||||
|  | diff --git a/iscsiuio/src/unix/main.c b/iscsiuio/src/unix/main.c
 | ||||||
|  | index 5168e4e..ed41931 100644
 | ||||||
|  | --- a/iscsiuio/src/unix/main.c
 | ||||||
|  | +++ b/iscsiuio/src/unix/main.c
 | ||||||
|  | @@ -340,7 +340,10 @@ int main(int argc, char *argv[])
 | ||||||
|  |   | ||||||
|  |  			/* parent: wait for child msg then exit */ | ||||||
|  |  			close(pipefds[1]); | ||||||
|  | -			read(pipefds[0], msgbuf, sizeof(msgbuf));
 | ||||||
|  | +			if (read(pipefds[0], msgbuf, sizeof(msgbuf)) < 0) {
 | ||||||
|  | +				fprintf(stderr, "ERR: Waiting for child process failed\n");
 | ||||||
|  | +				exit(1);
 | ||||||
|  | +			}
 | ||||||
|  |  			exit(0); | ||||||
|  |  		} | ||||||
|  |   | ||||||
|  | @@ -386,6 +389,9 @@ int main(int argc, char *argv[])
 | ||||||
|  |  	sigaddset(&set, SIGTERM); | ||||||
|  |  	sigaddset(&set, SIGUSR1); | ||||||
|  |  	rc = pthread_sigmask(SIG_SETMASK, &set, NULL); | ||||||
|  | +	if (rc != 0) {
 | ||||||
|  | +		LOG_ERR("Failed to set thread signal mask");
 | ||||||
|  | +	}
 | ||||||
|  |   | ||||||
|  |  	/*  Spin off the signal handling thread */ | ||||||
|  |  	pthread_attr_init(&attr); | ||||||
|  | @@ -415,7 +421,9 @@ int main(int argc, char *argv[])
 | ||||||
|  |  	if (!foreground) { | ||||||
|  |  		/* signal parent they can go away now */ | ||||||
|  |  		close(pipefds[0]); | ||||||
|  | -		write(pipefds[1], "ok\n", 3);
 | ||||||
|  | +		if (write(pipefds[1], "ok\n", 3) < 0) {
 | ||||||
|  | +			LOG_ERR("Failed to signal parent process of completed initialization");
 | ||||||
|  | +		}
 | ||||||
|  |  		close(pipefds[1]); | ||||||
|  |  	} | ||||||
|  |   | ||||||
|  | diff --git a/libopeniscsiusr/idbm.c b/libopeniscsiusr/idbm.c
 | ||||||
|  | index d020e6c..342aab5 100644
 | ||||||
|  | --- a/libopeniscsiusr/idbm.c
 | ||||||
|  | +++ b/libopeniscsiusr/idbm.c
 | ||||||
|  | @@ -287,12 +287,11 @@ int _idbm_lock(struct iscsi_context *ctx)
 | ||||||
|  |  		return 0; | ||||||
|  |  	} | ||||||
|  |   | ||||||
|  | -	if (access(LOCK_DIR, F_OK) != 0) {
 | ||||||
|  | -		if (mkdir(LOCK_DIR, 0660) != 0) {
 | ||||||
|  | -			_error(ctx, "Could not open %s: %d %s", LOCK_DIR, errno,
 | ||||||
|  | -				_strerror(errno, strerr_buff));
 | ||||||
|  | -			return LIBISCSI_ERR_IDBM;
 | ||||||
|  | -		}
 | ||||||
|  | +	if (((mkdir(LOCK_DIR, 0660) != 0) && (errno != EEXIST)) ||
 | ||||||
|  | +	    (access(LOCK_DIR, F_OK) != 0)) {
 | ||||||
|  | +		_error(ctx, "Could not open %s: %d %s", LOCK_DIR, errno,
 | ||||||
|  | +			_strerror(errno, strerr_buff));
 | ||||||
|  | +		return LIBISCSI_ERR_IDBM;
 | ||||||
|  |  	} | ||||||
|  |   | ||||||
|  |  	fd = open(LOCK_FILE, O_RDWR | O_CREAT, 0666); | ||||||
|  | diff --git a/usr/idbm.c b/usr/idbm.c
 | ||||||
|  | index 89a6c27..a3343fe 100644
 | ||||||
|  | --- a/usr/idbm.c
 | ||||||
|  | +++ b/usr/idbm.c
 | ||||||
|  | @@ -1332,12 +1332,10 @@ int idbm_lock(void)
 | ||||||
|  |  		return 0; | ||||||
|  |  	} | ||||||
|  |   | ||||||
|  | -	if (access(LOCK_DIR, F_OK) != 0) {
 | ||||||
|  | -		if (mkdir(LOCK_DIR, 0660) != 0) {
 | ||||||
|  | -			log_error("Could not open %s: %s", LOCK_DIR,
 | ||||||
|  | -				  strerror(errno));
 | ||||||
|  | -			return ISCSI_ERR_IDBM;
 | ||||||
|  | -		}
 | ||||||
|  | +	if (((mkdir(LOCK_DIR, 0660) != 0) && (errno != EEXIST)) ||
 | ||||||
|  | +	    (access(LOCK_DIR, F_OK) != 0)) {
 | ||||||
|  | +		log_error("Could not open %s: %s", LOCK_DIR, strerror(errno));
 | ||||||
|  | +		return ISCSI_ERR_IDBM;
 | ||||||
|  |  	} | ||||||
|  |   | ||||||
|  |  	fd = open(LOCK_FILE, O_RDWR | O_CREAT, 0666); | ||||||
|  | diff --git a/usr/iscsid.c b/usr/iscsid.c
 | ||||||
|  | index 37c13b3..1891784 100644
 | ||||||
|  | --- a/usr/iscsid.c
 | ||||||
|  | +++ b/usr/iscsid.c
 | ||||||
|  | @@ -489,8 +489,8 @@ int main(int argc, char *argv[])
 | ||||||
|  |  				log_close(log_pid); | ||||||
|  |  				exit(ISCSI_ERR); | ||||||
|  |  			} | ||||||
|  | +			close(fd);
 | ||||||
|  |  		} | ||||||
|  | -		close(fd);
 | ||||||
|  |   | ||||||
|  |  		if ((control_fd = ipc->ctldev_open()) < 0) { | ||||||
|  |  			log_close(log_pid); | ||||||
|  | -- 
 | ||||||
|  | 2.21.0 | ||||||
|  | 
 | ||||||
							
								
								
									
										49
									
								
								SOURCES/0001-fix-iscsiuio-build-with-libsystemd.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										49
									
								
								SOURCES/0001-fix-iscsiuio-build-with-libsystemd.patch
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,49 @@ | |||||||
|  | From aeca36572c02a8bf314037d82c4a2625636b175a Mon Sep 17 00:00:00 2001 | ||||||
|  | From: Chris Leech <cleech@redhat.com> | ||||||
|  | Date: Mon, 3 Jun 2019 14:36:48 -0700 | ||||||
|  | Subject: [PATCH] fix iscsiuio build with libsystemd | ||||||
|  | 
 | ||||||
|  | ---
 | ||||||
|  |  iscsiuio/configure.ac         | 2 ++ | ||||||
|  |  iscsiuio/src/unix/Makefile.am | 6 ++++-- | ||||||
|  |  2 files changed, 6 insertions(+), 2 deletions(-) | ||||||
|  | 
 | ||||||
|  | diff --git a/iscsiuio/configure.ac b/iscsiuio/configure.ac
 | ||||||
|  | index ae23078..6138e0e 100644
 | ||||||
|  | --- a/iscsiuio/configure.ac
 | ||||||
|  | +++ b/iscsiuio/configure.ac
 | ||||||
|  | @@ -73,6 +73,8 @@ AC_CONFIG_COMMANDS([default],[[
 | ||||||
|  |      echo 'char *build_date;'> src/unix/build_date.h | ||||||
|  |  ]],[[]]) | ||||||
|  |   | ||||||
|  | +PKG_CHECK_MODULES([LIBSYSTEMD], [libsystemd])
 | ||||||
|  | +
 | ||||||
|  |  AC_PREFIX_DEFAULT() | ||||||
|  |   | ||||||
|  |  AC_OUTPUT([Makefile | ||||||
|  | diff --git a/iscsiuio/src/unix/Makefile.am b/iscsiuio/src/unix/Makefile.am
 | ||||||
|  | index a989ef0..ea5f59e 100644
 | ||||||
|  | --- a/iscsiuio/src/unix/Makefile.am
 | ||||||
|  | +++ b/iscsiuio/src/unix/Makefile.am
 | ||||||
|  | @@ -25,7 +25,8 @@ iscsiuio_SOURCES =	build_date.c		\
 | ||||||
|  |   | ||||||
|  |  iscsiuio_CFLAGS = 	$(AM_CFLAGS)		\ | ||||||
|  |  			$(LIBNL_CFLAGS)		\ | ||||||
|  | -			-DBYTE_ORDER=@ENDIAN@
 | ||||||
|  | +			-DBYTE_ORDER=@ENDIAN@   \
 | ||||||
|  | +			$(LIBSYSTEMD_CFLAGS)
 | ||||||
|  |   | ||||||
|  |  iscsiuio_LDFLAGS= 	$(AM_LDADD)		\ | ||||||
|  |  			-ldl			\ | ||||||
|  | @@ -36,6 +37,7 @@ iscsiuio_LDFLAGS= 	$(AM_LDADD)		\
 | ||||||
|  |  iscsiuio_LDADD  = 	${top_srcdir}/src/uip/lib_iscsi_uip.a	\ | ||||||
|  |  			${top_srcdir}/src/apps/dhcpc/lib_apps_dhcpc.a\ | ||||||
|  |  			${top_srcdir}/src/apps/brcm-iscsi/lib_apps_brcm_iscsi.a \ | ||||||
|  | -			${top_srcdir}/src/unix/libs/lib_iscsiuio_hw_cnic.a
 | ||||||
|  | +			${top_srcdir}/src/unix/libs/lib_iscsiuio_hw_cnic.a \
 | ||||||
|  | +			$(LIBSYSTEMD_LIBS)
 | ||||||
|  |   | ||||||
|  |  iscsiuio_YFLAGS = -d | ||||||
|  | -- 
 | ||||||
|  | 2.21.0 | ||||||
|  | 
 | ||||||
							
								
								
									
										54
									
								
								SOURCES/0001-idmb_rec_write-check-for-tpgt-first.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										54
									
								
								SOURCES/0001-idmb_rec_write-check-for-tpgt-first.patch
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,54 @@ | |||||||
|  | From dbec0a5b7737142f8a1462cdf826c35a78e899b2 Mon Sep 17 00:00:00 2001 | ||||||
|  | From: Chris Leech <cleech@redhat.com> | ||||||
|  | Date: Tue, 13 Aug 2013 10:59:44 -0700 | ||||||
|  | Subject: [PATCH 01/32] idmb_rec_write, check for tpgt first | ||||||
|  | 
 | ||||||
|  | Factor out the check for a tpgt to a single place, before going crazy on | ||||||
|  | the rec files.  Makes flow of this function easier to follow, and preps | ||||||
|  | for splitting it up. | ||||||
|  | ---
 | ||||||
|  |  usr/idbm.c | 18 +++++------------- | ||||||
|  |  1 file changed, 5 insertions(+), 13 deletions(-) | ||||||
|  | 
 | ||||||
|  | diff --git a/usr/idbm.c b/usr/idbm.c
 | ||||||
|  | index 830189f571ea..ab3577878e86 100644
 | ||||||
|  | --- a/usr/idbm.c
 | ||||||
|  | +++ b/usr/idbm.c
 | ||||||
|  | @@ -2042,6 +2042,10 @@ static int idbm_rec_write(node_rec_t *rec)
 | ||||||
|  |  	if (rc) | ||||||
|  |  		goto free_portal; | ||||||
|  |   | ||||||
|  | +	if (rec->tpgt == PORTAL_GROUP_TAG_UNKNOWN)
 | ||||||
|  | +		/* drop down to old style portal as config */
 | ||||||
|  | +		goto open_conf;
 | ||||||
|  | +
 | ||||||
|  |  	rc = stat(portal, &statb); | ||||||
|  |  	if (rc) { | ||||||
|  |  		rc = 0; | ||||||
|  | @@ -2050,22 +2054,10 @@ static int idbm_rec_write(node_rec_t *rec)
 | ||||||
|  |  		 * set the tgpt. In new versions you must pass all the info in | ||||||
|  |  		 * from the start | ||||||
|  |  		 */ | ||||||
|  | -		if (rec->tpgt == PORTAL_GROUP_TAG_UNKNOWN)
 | ||||||
|  | -			/* drop down to old style portal as config */
 | ||||||
|  | -			goto open_conf;
 | ||||||
|  | -		else
 | ||||||
|  | -			goto mkdir_portal;
 | ||||||
|  | +		goto mkdir_portal;
 | ||||||
|  |  	} | ||||||
|  |   | ||||||
|  |  	if (!S_ISDIR(statb.st_mode)) { | ||||||
|  | -		/*
 | ||||||
|  | -		 * older iscsiadm versions had you create the config then set
 | ||||||
|  | -		 * set the tgpt. In new versions you must pass all the info in
 | ||||||
|  | -		 * from the start
 | ||||||
|  | -		 */
 | ||||||
|  | -		if (rec->tpgt == PORTAL_GROUP_TAG_UNKNOWN)
 | ||||||
|  | -			/* drop down to old style portal as config */
 | ||||||
|  | -			goto open_conf;
 | ||||||
|  |  		/* | ||||||
|  |  		 * Old style portal as a file, but with tpgt. Let's update it. | ||||||
|  |  		 */ | ||||||
|  | -- 
 | ||||||
|  | 2.14.4 | ||||||
|  | 
 | ||||||
							
								
								
									
										146
									
								
								SOURCES/0001-service-file-tweaks.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										146
									
								
								SOURCES/0001-service-file-tweaks.patch
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,146 @@ | |||||||
|  | From efba620a01a2c2fa57b672bced47e88f25078b00 Mon Sep 17 00:00:00 2001 | ||||||
|  | From: rpm-build <rpm-build> | ||||||
|  | Date: Tue, 4 Jun 2019 13:23:32 -0700 | ||||||
|  | Subject: [PATCH] service file tweaks | ||||||
|  | 
 | ||||||
|  | ---
 | ||||||
|  |  etc/systemd/iscsi-mark-root-nodes  | 30 ++++++++++++++++++++++++++++++ | ||||||
|  |  etc/systemd/iscsi-shutdown.service | 14 ++++++++++++++ | ||||||
|  |  etc/systemd/iscsi.service          | 23 +++++++++++++---------- | ||||||
|  |  etc/systemd/iscsid.service         |  6 ++++-- | ||||||
|  |  etc/systemd/iscsiuio.service       |  2 +- | ||||||
|  |  5 files changed, 62 insertions(+), 13 deletions(-) | ||||||
|  |  create mode 100755 etc/systemd/iscsi-mark-root-nodes | ||||||
|  |  create mode 100644 etc/systemd/iscsi-shutdown.service | ||||||
|  | 
 | ||||||
|  | diff --git a/etc/systemd/iscsi-mark-root-nodes b/etc/systemd/iscsi-mark-root-nodes
 | ||||||
|  | new file mode 100755 | ||||||
|  | index 0000000..c693707
 | ||||||
|  | --- /dev/null
 | ||||||
|  | +++ b/etc/systemd/iscsi-mark-root-nodes
 | ||||||
|  | @@ -0,0 +1,30 @@
 | ||||||
|  | +#!/bin/bash
 | ||||||
|  | +
 | ||||||
|  | +ISCSIADM=/usr/sbin/iscsiadm
 | ||||||
|  | +start_iscsid=0
 | ||||||
|  | +start_iscsiuio=0
 | ||||||
|  | +
 | ||||||
|  | +while read t num p target flash; do
 | ||||||
|  | +  # strip tag number from portal, keep "ip:port"
 | ||||||
|  | +  portal=${p%,*}
 | ||||||
|  | +  transport=${t%:}
 | ||||||
|  | +
 | ||||||
|  | +  $ISCSIADM -m node -p $portal -T $target -o update -n node.startup -v onboot
 | ||||||
|  | +
 | ||||||
|  | +  start_iscsid=1
 | ||||||
|  | +
 | ||||||
|  | +  if [ "$transport" = bnx2i ] || [ "$transport" = qedi ]; then
 | ||||||
|  | +    start_iscsiuio=1
 | ||||||
|  | +  fi
 | ||||||
|  | +done < <( $ISCSIADM -m session )
 | ||||||
|  | +
 | ||||||
|  | +# force iscsid and iscsiuio to start if needed for
 | ||||||
|  | +# recovering sessions created in the initrd
 | ||||||
|  | +
 | ||||||
|  | +if [ "$start_iscsid" -eq 1 ]; then
 | ||||||
|  | +  systemctl --no-block start iscsid.service
 | ||||||
|  | +fi
 | ||||||
|  | +if [ "$start_iscsiuio" -eq 1 ]; then
 | ||||||
|  | +  systemctl --no-block start iscsiuio.service
 | ||||||
|  | +fi
 | ||||||
|  | +
 | ||||||
|  | diff --git a/etc/systemd/iscsi-shutdown.service b/etc/systemd/iscsi-shutdown.service
 | ||||||
|  | new file mode 100644 | ||||||
|  | index 0000000..69c1c77
 | ||||||
|  | --- /dev/null
 | ||||||
|  | +++ b/etc/systemd/iscsi-shutdown.service
 | ||||||
|  | @@ -0,0 +1,14 @@
 | ||||||
|  | +[Unit]
 | ||||||
|  | +Description=Logout off all iSCSI sessions on shutdown
 | ||||||
|  | +Documentation=man:iscsid(8) man:iscsiadm(8)
 | ||||||
|  | +DefaultDependencies=no
 | ||||||
|  | +Conflicts=shutdown.target
 | ||||||
|  | +After=systemd-remount-fs.service network.target iscsid.service iscsiuio.service
 | ||||||
|  | +Before=remote-fs-pre.target
 | ||||||
|  | +Wants=remote-fs-pre.target
 | ||||||
|  | +RefuseManualStop=yes
 | ||||||
|  | +
 | ||||||
|  | +[Service]
 | ||||||
|  | +Type=oneshot
 | ||||||
|  | +RemainAfterExit=true
 | ||||||
|  | +ExecStop=-/usr/sbin/iscsiadm -m node --logoutall=all
 | ||||||
|  | diff --git a/etc/systemd/iscsi.service b/etc/systemd/iscsi.service
 | ||||||
|  | index e475888..eadfcec 100644
 | ||||||
|  | --- a/etc/systemd/iscsi.service
 | ||||||
|  | +++ b/etc/systemd/iscsi.service
 | ||||||
|  | @@ -1,18 +1,21 @@
 | ||||||
|  |  [Unit] | ||||||
|  |  Description=Login and scanning of iSCSI devices | ||||||
|  | -Documentation=man:iscsiadm(8) man:iscsid(8)
 | ||||||
|  | -Before=remote-fs.target
 | ||||||
|  | -After=network.target network-online.target iscsid.service
 | ||||||
|  | -Requires=iscsid.service
 | ||||||
|  | -ConditionPathExists=/etc/iscsi/initiatorname.iscsi
 | ||||||
|  | +Documentation=man:iscsid(8) man:iscsiadm(8)
 | ||||||
|  | +DefaultDependencies=no
 | ||||||
|  | +Conflicts=shutdown.target
 | ||||||
|  | +After=systemd-remount-fs.service network.target iscsid.service iscsiuio.service
 | ||||||
|  | +Before=remote-fs-pre.target
 | ||||||
|  | +Wants=remote-fs-pre.target iscsi-shutdown.service
 | ||||||
|  | +ConditionDirectoryNotEmpty=|/var/lib/iscsi/nodes
 | ||||||
|  | +ConditionDirectoryNotEmpty=|/sys/class/iscsi_session
 | ||||||
|  |   | ||||||
|  |  [Service] | ||||||
|  |  Type=oneshot | ||||||
|  | -ExecStart=/sbin/iscsiadm -m node --loginall=automatic
 | ||||||
|  | -ExecStop=/sbin/iscsiadm -m node --logoutall=automatic
 | ||||||
|  | -ExecStop=/sbin/iscsiadm -m node --logoutall=manual
 | ||||||
|  | -SuccessExitStatus=21
 | ||||||
|  |  RemainAfterExit=true | ||||||
|  | +ExecStart=-/usr/libexec/iscsi-mark-root-nodes
 | ||||||
|  | +ExecStart=-/usr/sbin/iscsiadm -m node --loginall=automatic
 | ||||||
|  | +ExecReload=-/usr/sbin/iscsiadm -m node --loginall=automatic
 | ||||||
|  | +SuccessExitStatus=21
 | ||||||
|  |   | ||||||
|  |  [Install] | ||||||
|  | -WantedBy=remote-fs.target
 | ||||||
|  | +WantedBy=sysinit.target
 | ||||||
|  | diff --git a/etc/systemd/iscsid.service b/etc/systemd/iscsid.service
 | ||||||
|  | index 4fef168..8d50cf0 100644
 | ||||||
|  | --- a/etc/systemd/iscsid.service
 | ||||||
|  | +++ b/etc/systemd/iscsid.service
 | ||||||
|  | @@ -1,14 +1,16 @@
 | ||||||
|  |  [Unit] | ||||||
|  |  Description=Open-iSCSI | ||||||
|  | -Documentation=man:iscsid(8) man:iscsiuio(8) man:iscsiadm(8)
 | ||||||
|  | +Documentation=man:iscsid(8) man:iscsiadm(8)
 | ||||||
|  |  DefaultDependencies=no | ||||||
|  | +Conflicts=shutdown.target
 | ||||||
|  |  After=network.target iscsiuio.service | ||||||
|  |  Before=remote-fs-pre.target | ||||||
|  |   | ||||||
|  |  [Service] | ||||||
|  |  Type=notify | ||||||
|  |  NotifyAccess=main | ||||||
|  | -ExecStart=/sbin/iscsid -f
 | ||||||
|  | +ExecStart=/usr/sbin/iscsid -f
 | ||||||
|  | +ExecStop=/usr/sbin/iscsiadm -k 0 2
 | ||||||
|  |  KillMode=mixed | ||||||
|  |  Restart=on-failure | ||||||
|  |   | ||||||
|  | diff --git a/etc/systemd/iscsiuio.service b/etc/systemd/iscsiuio.service
 | ||||||
|  | index e4d9fd0..8620cde 100644
 | ||||||
|  | --- a/etc/systemd/iscsiuio.service
 | ||||||
|  | +++ b/etc/systemd/iscsiuio.service
 | ||||||
|  | @@ -11,7 +11,7 @@ Before=remote-fs-pre.target iscsid.service
 | ||||||
|  |  [Service] | ||||||
|  |  Type=notify | ||||||
|  |  NotifyAccess=main | ||||||
|  | -ExecStart=/sbin/iscsiuio -f
 | ||||||
|  | +ExecStart=/usr/sbin/iscsiuio -f
 | ||||||
|  |  KillMode=mixed | ||||||
|  |  Restart=on-failure | ||||||
|  |   | ||||||
|  | -- 
 | ||||||
|  | 2.21.0 | ||||||
|  | 
 | ||||||
| @ -0,0 +1,180 @@ | |||||||
|  | From b9d89091daab823eb2dc72c6c568af7897f83137 Mon Sep 17 00:00:00 2001 | ||||||
|  | From: Chris Leech <cleech@redhat.com> | ||||||
|  | Date: Tue, 13 Aug 2013 11:34:31 -0700 | ||||||
|  | Subject: [PATCH 02/32] idbm_rec_write, seperate old and new style writes | ||||||
|  | 
 | ||||||
|  | Duplicates a small bit of code, but easier to understand and extened. | ||||||
|  | ---
 | ||||||
|  |  usr/idbm.c | 116 +++++++++++++++++++++++++++++++++++++++++-------------------- | ||||||
|  |  1 file changed, 79 insertions(+), 37 deletions(-) | ||||||
|  | 
 | ||||||
|  | diff --git a/usr/idbm.c b/usr/idbm.c
 | ||||||
|  | index ab3577878e86..21ff61ab2bd8 100644
 | ||||||
|  | --- a/usr/idbm.c
 | ||||||
|  | +++ b/usr/idbm.c
 | ||||||
|  | @@ -2001,7 +2001,7 @@ mkdir_portal:
 | ||||||
|  |  	return f; | ||||||
|  |  } | ||||||
|  |   | ||||||
|  | -static int idbm_rec_write(node_rec_t *rec)
 | ||||||
|  | +static int idbm_rec_write_new(node_rec_t *rec)
 | ||||||
|  |  { | ||||||
|  |  	struct stat statb; | ||||||
|  |  	FILE *f; | ||||||
|  | @@ -2013,38 +2013,8 @@ static int idbm_rec_write(node_rec_t *rec)
 | ||||||
|  |  		log_error("Could not alloc portal"); | ||||||
|  |  		return ISCSI_ERR_NOMEM; | ||||||
|  |  	} | ||||||
|  | -
 | ||||||
|  | -	snprintf(portal, PATH_MAX, "%s", NODE_CONFIG_DIR);
 | ||||||
|  | -	if (access(portal, F_OK) != 0) {
 | ||||||
|  | -		if (mkdir(portal, 0660) != 0) {
 | ||||||
|  | -			log_error("Could not make %s: %s", portal,
 | ||||||
|  | -				  strerror(errno));
 | ||||||
|  | -			rc = ISCSI_ERR_IDBM;
 | ||||||
|  | -			goto free_portal;
 | ||||||
|  | -		}
 | ||||||
|  | -	}
 | ||||||
|  | -
 | ||||||
|  | -	snprintf(portal, PATH_MAX, "%s/%s", NODE_CONFIG_DIR, rec->name);
 | ||||||
|  | -	if (access(portal, F_OK) != 0) {
 | ||||||
|  | -		if (mkdir(portal, 0660) != 0) {
 | ||||||
|  | -			log_error("Could not make %s: %s", portal,
 | ||||||
|  | -				  strerror(errno));
 | ||||||
|  | -			rc = ISCSI_ERR_IDBM;
 | ||||||
|  | -			goto free_portal;
 | ||||||
|  | -		}
 | ||||||
|  | -	}
 | ||||||
|  | -
 | ||||||
|  |  	snprintf(portal, PATH_MAX, "%s/%s/%s,%d", NODE_CONFIG_DIR, | ||||||
|  |  		 rec->name, rec->conn[0].address, rec->conn[0].port); | ||||||
|  | -	log_debug(5, "Looking for config file %s", portal);
 | ||||||
|  | -
 | ||||||
|  | -	rc = idbm_lock();
 | ||||||
|  | -	if (rc)
 | ||||||
|  | -		goto free_portal;
 | ||||||
|  | -
 | ||||||
|  | -	if (rec->tpgt == PORTAL_GROUP_TAG_UNKNOWN)
 | ||||||
|  | -		/* drop down to old style portal as config */
 | ||||||
|  | -		goto open_conf;
 | ||||||
|  |   | ||||||
|  |  	rc = stat(portal, &statb); | ||||||
|  |  	if (rc) { | ||||||
|  | @@ -2065,11 +2035,11 @@ static int idbm_rec_write(node_rec_t *rec)
 | ||||||
|  |  			log_error("Could not convert %s: %s", portal, | ||||||
|  |  				  strerror(errno)); | ||||||
|  |  			rc = ISCSI_ERR_IDBM; | ||||||
|  | -			goto unlock;
 | ||||||
|  | +			goto free_portal;
 | ||||||
|  |  		} | ||||||
|  |  	} else { | ||||||
|  |  		rc = ISCSI_ERR_INVAL; | ||||||
|  | -		goto unlock;
 | ||||||
|  | +		goto free_portal;
 | ||||||
|  |  	} | ||||||
|  |   | ||||||
|  |  mkdir_portal: | ||||||
|  | @@ -2080,24 +2050,96 @@ mkdir_portal:
 | ||||||
|  |  			log_error("Could not make dir %s: %s", | ||||||
|  |  				  portal, strerror(errno)); | ||||||
|  |  			rc = ISCSI_ERR_IDBM; | ||||||
|  | -			goto unlock;
 | ||||||
|  | +			goto free_portal;
 | ||||||
|  |  		} | ||||||
|  |  	} | ||||||
|  |   | ||||||
|  |  	snprintf(portal, PATH_MAX, "%s/%s/%s,%d,%d/%s", NODE_CONFIG_DIR, | ||||||
|  |  		 rec->name, rec->conn[0].address, rec->conn[0].port, rec->tpgt, | ||||||
|  |  		 rec->iface.name); | ||||||
|  | -open_conf:
 | ||||||
|  | +/* open_conf: */
 | ||||||
|  |  	f = fopen(portal, "w"); | ||||||
|  |  	if (!f) { | ||||||
|  |  		log_error("Could not open %s: %s", portal, strerror(errno)); | ||||||
|  |  		rc = ISCSI_ERR_IDBM; | ||||||
|  | -		goto unlock;
 | ||||||
|  | +		goto free_portal;
 | ||||||
|  |  	} | ||||||
|  |   | ||||||
|  |  	idbm_print(IDBM_PRINT_TYPE_NODE, rec, 1, f); | ||||||
|  |  	fclose(f); | ||||||
|  | -unlock:
 | ||||||
|  | +free_portal:
 | ||||||
|  | +	free(portal);
 | ||||||
|  | +	return rc;
 | ||||||
|  | +}
 | ||||||
|  | +
 | ||||||
|  | +static int idbm_rec_write_old(node_rec_t *rec)
 | ||||||
|  | +{
 | ||||||
|  | +	FILE *f;
 | ||||||
|  | +	char *portal;
 | ||||||
|  | +	int rc = 0;
 | ||||||
|  | +
 | ||||||
|  | +	portal = malloc(PATH_MAX);
 | ||||||
|  | +	if (!portal) {
 | ||||||
|  | +		log_error("Could not alloc portal");
 | ||||||
|  | +		return ISCSI_ERR_NOMEM;
 | ||||||
|  | +	}
 | ||||||
|  | +	snprintf(portal, PATH_MAX, "%s/%s/%s,%d", NODE_CONFIG_DIR,
 | ||||||
|  | +		 rec->name, rec->conn[0].address, rec->conn[0].port);
 | ||||||
|  | +
 | ||||||
|  | +	f = fopen(portal, "w");
 | ||||||
|  | +	if (!f) {
 | ||||||
|  | +		log_error("Could not open %s: %sd", portal, strerror(errno));
 | ||||||
|  | +		rc = ISCSI_ERR_IDBM;
 | ||||||
|  | +		goto free_portal;
 | ||||||
|  | +	}
 | ||||||
|  | +	idbm_print(IDBM_PRINT_TYPE_NODE, rec, 1, f);
 | ||||||
|  | +	fclose(f);
 | ||||||
|  | +free_portal:
 | ||||||
|  | +	free(portal);
 | ||||||
|  | +	return rc;
 | ||||||
|  | +}
 | ||||||
|  | +
 | ||||||
|  | +static int idbm_rec_write(node_rec_t *rec)
 | ||||||
|  | +{
 | ||||||
|  | +	char *portal;
 | ||||||
|  | +	int rc = 0;
 | ||||||
|  | +
 | ||||||
|  | +	portal = malloc(PATH_MAX);
 | ||||||
|  | +	if (!portal) {
 | ||||||
|  | +		log_error("Could not alloc portal");
 | ||||||
|  | +		return ISCSI_ERR_NOMEM;
 | ||||||
|  | +	}
 | ||||||
|  | +
 | ||||||
|  | +	snprintf(portal, PATH_MAX, "%s", NODE_CONFIG_DIR);
 | ||||||
|  | +	if (access(portal, F_OK) != 0) {
 | ||||||
|  | +		if (mkdir(portal, 0660) != 0) {
 | ||||||
|  | +			log_error("Could not make %s: %s", portal,
 | ||||||
|  | +				  strerror(errno));
 | ||||||
|  | +			rc = ISCSI_ERR_IDBM;
 | ||||||
|  | +			goto free_portal;
 | ||||||
|  | +		}
 | ||||||
|  | +	}
 | ||||||
|  | +
 | ||||||
|  | +	snprintf(portal, PATH_MAX, "%s/%s", NODE_CONFIG_DIR, rec->name);
 | ||||||
|  | +	if (access(portal, F_OK) != 0) {
 | ||||||
|  | +		if (mkdir(portal, 0660) != 0) {
 | ||||||
|  | +			log_error("Could not make %s: %s", portal,
 | ||||||
|  | +				  strerror(errno));
 | ||||||
|  | +			rc = ISCSI_ERR_IDBM;
 | ||||||
|  | +			goto free_portal;
 | ||||||
|  | +		}
 | ||||||
|  | +	}
 | ||||||
|  | +
 | ||||||
|  | +	rc = idbm_lock();
 | ||||||
|  | +	if (rc)
 | ||||||
|  | +		goto free_portal;
 | ||||||
|  | +
 | ||||||
|  | +	if (rec->tpgt == PORTAL_GROUP_TAG_UNKNOWN)
 | ||||||
|  | +		/* old style portal as config */
 | ||||||
|  | +		rc = idbm_rec_write_old(rec);
 | ||||||
|  | +	else
 | ||||||
|  | +		rc = idbm_rec_write_new(rec);
 | ||||||
|  | +
 | ||||||
|  |  	idbm_unlock(); | ||||||
|  |  free_portal: | ||||||
|  |  	free(portal); | ||||||
|  | -- 
 | ||||||
|  | 2.14.4 | ||||||
|  | 
 | ||||||
| @ -0,0 +1,87 @@ | |||||||
|  | From bf6a05987a418e4d7eeb3a24f0912c5cfc9e533d Mon Sep 17 00:00:00 2001 | ||||||
|  | From: Chris Leech <cleech@redhat.com> | ||||||
|  | Date: Tue, 13 Aug 2013 12:39:07 -0700 | ||||||
|  | Subject: [PATCH] idbw_rec_write, pick tpgt from existing record | ||||||
|  | 
 | ||||||
|  | On a static add (-m node -o new) without a user specified tpgt, looks | ||||||
|  | for existing new style records with tpgt before creating an old style | ||||||
|  | record without.  If one exists, take the tpgt from it an write an | ||||||
|  | updated new style record instead. | ||||||
|  | ---
 | ||||||
|  |  usr/idbm.c | 40 ++++++++++++++++++++++++++++++++++++++++ | ||||||
|  |  1 file changed, 40 insertions(+) | ||||||
|  | 
 | ||||||
|  | diff --git a/usr/idbm.c b/usr/idbm.c
 | ||||||
|  | index c29cbed..00955e4 100644
 | ||||||
|  | --- a/usr/idbm.c
 | ||||||
|  | +++ b/usr/idbm.c
 | ||||||
|  | @@ -28,6 +28,7 @@
 | ||||||
|  |  #include <dirent.h> | ||||||
|  |  #include <limits.h> | ||||||
|  |  #include <fcntl.h> | ||||||
|  | +#include <glob.h>
 | ||||||
|  |  #include <sys/stat.h> | ||||||
|  |  #include <sys/file.h> | ||||||
|  |  #include <inttypes.h> | ||||||
|  | @@ -164,6 +165,8 @@ static struct idbm *db;
 | ||||||
|  |  	_n++; \ | ||||||
|  |  } while(0) | ||||||
|  |   | ||||||
|  | +static int idbm_remove_disc_to_node_link(node_rec_t *rec, char *portal);
 | ||||||
|  | +
 | ||||||
|  |  static void | ||||||
|  |  idbm_recinfo_discovery(discovery_rec_t *r, recinfo_t *ri) | ||||||
|  |  { | ||||||
|  | @@ -2080,12 +2083,49 @@ static int idbm_rec_write_old(node_rec_t *rec)
 | ||||||
|  |  	FILE *f; | ||||||
|  |  	char *portal; | ||||||
|  |  	int rc = 0; | ||||||
|  | +	glob_t globbuf;
 | ||||||
|  | +	int i;
 | ||||||
|  | +	int tpgt = PORTAL_GROUP_TAG_UNKNOWN;
 | ||||||
|  |   | ||||||
|  |  	portal = malloc(PATH_MAX); | ||||||
|  |  	if (!portal) { | ||||||
|  |  		log_error("Could not alloc portal"); | ||||||
|  |  		return ISCSI_ERR_NOMEM; | ||||||
|  |  	} | ||||||
|  | +
 | ||||||
|  | +	/* check for newer portal dir with tpgt */
 | ||||||
|  | +	snprintf(portal, PATH_MAX, "%s/%s/%s,%d,*", NODE_CONFIG_DIR,
 | ||||||
|  | +		 rec->name, rec->conn[0].address, rec->conn[0].port);
 | ||||||
|  | +	rc = glob(portal, GLOB_ONLYDIR, NULL, &globbuf);
 | ||||||
|  | +	if (!rc) {
 | ||||||
|  | +		if (globbuf.gl_pathc > 1)
 | ||||||
|  | +			log_warning("multiple tpg records for portal "
 | ||||||
|  | +				    "%s/%s:%d found", rec->name,
 | ||||||
|  | +				    rec->conn[0].address, rec->conn[0].port);
 | ||||||
|  | +		/* set pattern for sscanf matching of tpgt */
 | ||||||
|  | +		snprintf(portal, PATH_MAX, "%s/%s/%s,%d,%%u", NODE_CONFIG_DIR,
 | ||||||
|  | +			 rec->name, rec->conn[0].address, rec->conn[0].port);
 | ||||||
|  | +		for (i = 0; i < globbuf.gl_pathc; i++) {
 | ||||||
|  | +			rc = sscanf(globbuf.gl_pathv[i], portal, &tpgt);
 | ||||||
|  | +			if (rc == 1)
 | ||||||
|  | +				break;
 | ||||||
|  | +		}
 | ||||||
|  | +		if (tpgt == PORTAL_GROUP_TAG_UNKNOWN)
 | ||||||
|  | +			log_warning("glob match on existing records, "
 | ||||||
|  | +				    "but no valid tpgt found");
 | ||||||
|  | +	}
 | ||||||
|  | +	globfree(&globbuf);
 | ||||||
|  | +	rc = 0;
 | ||||||
|  | +
 | ||||||
|  | +	/* if a tpgt was selected from an old record, write entry in new format */
 | ||||||
|  | +	if (tpgt != PORTAL_GROUP_TAG_UNKNOWN) {
 | ||||||
|  | +		log_warning("using tpgt %u from existing record", tpgt);
 | ||||||
|  | +		rec->tpgt = tpgt;
 | ||||||
|  | +		rc = idbm_remove_disc_to_node_link(rec, portal);
 | ||||||
|  | +		free(portal);
 | ||||||
|  | +		return idbm_rec_write_new(rec);
 | ||||||
|  | +	}
 | ||||||
|  | +
 | ||||||
|  |  	snprintf(portal, PATH_MAX, "%s/%s/%s,%d", NODE_CONFIG_DIR, | ||||||
|  |  		 rec->name, rec->conn[0].address, rec->conn[0].port); | ||||||
|  |   | ||||||
|  | -- 
 | ||||||
|  | 2.21.0 | ||||||
|  | 
 | ||||||
							
								
								
									
										127
									
								
								SOURCES/0006-update-initscripts-and-docs.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										127
									
								
								SOURCES/0006-update-initscripts-and-docs.patch
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,127 @@ | |||||||
|  | From 2e6f564ebb3c85cb9a457d282b845374776a54ae Mon Sep 17 00:00:00 2001 | ||||||
|  | From: Chris Leech <cleech@redhat.com> | ||||||
|  | Date: Mon, 19 Nov 2012 16:37:13 -0800 | ||||||
|  | Subject: [PATCH 06/32] update initscripts and docs | ||||||
|  | 
 | ||||||
|  | ---
 | ||||||
|  |  README          | 10 ++++------ | ||||||
|  |  etc/iscsid.conf | 21 ++++++++++----------- | ||||||
|  |  usr/idbm.c      |  4 ++++ | ||||||
|  |  3 files changed, 18 insertions(+), 17 deletions(-) | ||||||
|  | 
 | ||||||
|  | diff --git a/README b/README
 | ||||||
|  | index 2499d9a7b638..c05814a2593b 100644
 | ||||||
|  | --- a/README
 | ||||||
|  | +++ b/README
 | ||||||
|  | @@ -77,11 +77,6 @@ the cache sync command will fail.
 | ||||||
|  |  - iscsiadm's -P 3 option will not print out scsi devices. | ||||||
|  |  - iscsid will not automatically online devices. | ||||||
|  |   | ||||||
|  | -You need to enable "Cryptographic API" under "Cryptographic options" in the
 | ||||||
|  | -kernel config. And you must enable "CRC32c CRC algorithm" even if
 | ||||||
|  | -you do not use header or data digests. They are the kernel options
 | ||||||
|  | -CONFIG_CRYPTO and CONFIG_CRYPTO_CRC32C, respectively.
 | ||||||
|  | -
 | ||||||
|  |  The userspace components iscsid, iscsiadm and iscsistart require the | ||||||
|  |  open-isns library, which can be found here: | ||||||
|  |  	https://github.com/gonzoleeman/open-isns/releases | ||||||
|  | @@ -1151,7 +1146,7 @@ Red Hat or Fedora:
 | ||||||
|  |  ----------------- | ||||||
|  |  To start open-iscsi in Red Hat/Fedora you can do: | ||||||
|  |   | ||||||
|  | -	service open-iscsi start
 | ||||||
|  | +	service iscsi start
 | ||||||
|  |   | ||||||
|  |  To get open-iscsi to automatically start at run time you may have to | ||||||
|  |  run: | ||||||
|  | @@ -1353,6 +1348,9 @@ iscsid will only perform rediscovery when it gets a SCN from the server.
 | ||||||
|  |  #   linux-isns (SLES's iSNS server) where it sometimes does not send SCN | ||||||
|  |  #   events in the proper format, so they may not get handled. | ||||||
|  |   | ||||||
|  | +To set the startup value, so that nodes are not logged into automatically
 | ||||||
|  | +use the value "manual".
 | ||||||
|  | +
 | ||||||
|  |  Examples | ||||||
|  |  -------- | ||||||
|  |   | ||||||
|  | diff --git a/etc/iscsid.conf b/etc/iscsid.conf
 | ||||||
|  | index fee11482a09b..3539ac4cd578 100644
 | ||||||
|  | --- a/etc/iscsid.conf
 | ||||||
|  | +++ b/etc/iscsid.conf
 | ||||||
|  | @@ -19,7 +19,7 @@
 | ||||||
|  |  # the time then leave this attribute commented out. | ||||||
|  |  # | ||||||
|  |  # Default for Fedora and RHEL. (uncomment to activate). | ||||||
|  | -# iscsid.startup = /bin/systemctl start iscsid.socket iscsiuio.soccket
 | ||||||
|  | +iscsid.startup = /bin/systemctl start iscsid.socket iscsiuio.socket
 | ||||||
|  |  #  | ||||||
|  |  # Default if you are not using systemd (uncomment to activate) | ||||||
|  |  # iscsid.startup = /usr/bin/service start iscsid | ||||||
|  | @@ -41,8 +41,8 @@
 | ||||||
|  |  # To request that the iscsi initd scripts startup a session set to "automatic". | ||||||
|  |  # node.startup = automatic | ||||||
|  |  # | ||||||
|  | -# To manually startup the session set to "manual". The default is manual.
 | ||||||
|  | -node.startup = manual
 | ||||||
|  | +# To manually startup the session set to "manual". The default is automatic.
 | ||||||
|  | +node.startup = automatic
 | ||||||
|  |   | ||||||
|  |  # For "automatic" startup nodes, setting this to "Yes" will try logins on each | ||||||
|  |  # available iface until one succeeds, and then stop.  The default "No" will try | ||||||
|  | @@ -264,28 +264,27 @@ node.conn[0].iscsi.MaxXmitDataSegmentLength = 0
 | ||||||
|  |  discovery.sendtargets.iscsi.MaxRecvDataSegmentLength = 32768 | ||||||
|  |   | ||||||
|  |  # To allow the targets to control the setting of the digest checking, | ||||||
|  | -# with the initiator requesting a preference of enabling the checking, uncomment# one or both of the following lines:
 | ||||||
|  | +# with the initiator requesting a preference of enabling the checking, uncomment
 | ||||||
|  | +# the following lines (Data digests are not supported.):
 | ||||||
|  |  #node.conn[0].iscsi.HeaderDigest = CRC32C,None | ||||||
|  | -#node.conn[0].iscsi.DataDigest = CRC32C,None
 | ||||||
|  | +
 | ||||||
|  |  # | ||||||
|  |  # To allow the targets to control the setting of the digest checking, | ||||||
|  |  # with the initiator requesting a preference of disabling the checking, | ||||||
|  | -# uncomment one or both of the following lines:
 | ||||||
|  | +# uncomment the following line:
 | ||||||
|  |  #node.conn[0].iscsi.HeaderDigest = None,CRC32C | ||||||
|  | -#node.conn[0].iscsi.DataDigest = None,CRC32C
 | ||||||
|  |  # | ||||||
|  |  # To enable CRC32C digest checking for the header and/or data part of | ||||||
|  | -# iSCSI PDUs, uncomment one or both of the following lines:
 | ||||||
|  | +# iSCSI PDUs, uncomment the following line:
 | ||||||
|  |  #node.conn[0].iscsi.HeaderDigest = CRC32C | ||||||
|  | -#node.conn[0].iscsi.DataDigest = CRC32C
 | ||||||
|  |  # | ||||||
|  |  # To disable digest checking for the header and/or data part of | ||||||
|  | -# iSCSI PDUs, uncomment one or both of the following lines:
 | ||||||
|  | +# iSCSI PDUs, uncomment the following line:
 | ||||||
|  |  #node.conn[0].iscsi.HeaderDigest = None | ||||||
|  | -#node.conn[0].iscsi.DataDigest = None
 | ||||||
|  |  # | ||||||
|  |  # The default is to never use DataDigests or HeaderDigests. | ||||||
|  |  # | ||||||
|  | +node.conn[0].iscsi.HeaderDigest = None
 | ||||||
|  |   | ||||||
|  |  # For multipath configurations, you may want more than one session to be | ||||||
|  |  # created on each iface record.  If node.session.nr_sessions is greater | ||||||
|  | diff --git a/usr/idbm.c b/usr/idbm.c
 | ||||||
|  | index cd705fa2b033..0aa3870a76fd 100644
 | ||||||
|  | --- a/usr/idbm.c
 | ||||||
|  | +++ b/usr/idbm.c
 | ||||||
|  | @@ -518,9 +518,13 @@ idbm_recinfo_node(node_rec_t *r, recinfo_t *ri)
 | ||||||
|  |  				 IDBM_SHOW, "None", "CRC32C", "CRC32C,None", | ||||||
|  |  				 "None,CRC32C", num, 1); | ||||||
|  |  		sprintf(key, CONN_DATA_DIGEST, i); | ||||||
|  | +
 | ||||||
|  | +#if 0
 | ||||||
|  | +We do not support data digests
 | ||||||
|  |  		__recinfo_int_o4(key, ri, r, conn[i].iscsi.DataDigest, IDBM_SHOW, | ||||||
|  |  				 "None", "CRC32C", "CRC32C,None", | ||||||
|  |  				 "None,CRC32C", num, 1); | ||||||
|  | +#endif
 | ||||||
|  |  		sprintf(key, CONN_IFMARKER, i); | ||||||
|  |  		__recinfo_int_o2(key, ri, r, conn[i].iscsi.IFMarker, IDBM_SHOW, | ||||||
|  |  				"No", "Yes", num, 1); | ||||||
|  | -- 
 | ||||||
|  | 2.14.4 | ||||||
|  | 
 | ||||||
							
								
								
									
										255
									
								
								SOURCES/0007-use-var-for-config.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										255
									
								
								SOURCES/0007-use-var-for-config.patch
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,255 @@ | |||||||
|  | From 29769497994066772429d57937dc3a8c0f515304 Mon Sep 17 00:00:00 2001 | ||||||
|  | From: Chris Leech <cleech@redhat.com> | ||||||
|  | Date: Mon, 19 Nov 2012 16:38:45 -0800 | ||||||
|  | Subject: [PATCH] use var for config | ||||||
|  | 
 | ||||||
|  | ---
 | ||||||
|  |  README         | 33 ++++++++++++++++----------------- | ||||||
|  |  doc/iscsiadm.8 |  8 ++++---- | ||||||
|  |  doc/iscsid.8   |  2 +- | ||||||
|  |  usr/idbm.c     |  6 +++--- | ||||||
|  |  usr/idbm.h     | 13 +++++++------ | ||||||
|  |  usr/iface.h    |  3 ++- | ||||||
|  |  6 files changed, 33 insertions(+), 32 deletions(-) | ||||||
|  | 
 | ||||||
|  | diff --git a/README b/README
 | ||||||
|  | index c05814a..326c3b0 100644
 | ||||||
|  | --- a/README
 | ||||||
|  | +++ b/README
 | ||||||
|  | @@ -172,8 +172,7 @@ Usage: iscsid [OPTION]
 | ||||||
|  |   | ||||||
|  |  Open-iSCSI persistent configuration is stored in a number of | ||||||
|  |  directories under a configuration root directory, using a flat-file | ||||||
|  | -format. This configuration root directory is /etc/iscsi by default,
 | ||||||
|  | -but may also commonly be in /var/lib/iscsi.
 | ||||||
|  | +format. This configuration root directory is /var/lib/iscsi by default.
 | ||||||
|  |   | ||||||
|  |  Configuration is contained in directories for: | ||||||
|  |   | ||||||
|  | @@ -561,7 +560,7 @@ a scsi_host per HBA port).
 | ||||||
|  |  To manage both types of initiator stacks, iscsiadm uses the interface (iface) | ||||||
|  |  structure. For each HBA port or for software iscsi for each network | ||||||
|  |  device (ethX) or NIC, that you wish to bind sessions to you must create | ||||||
|  | -a iface config /etc/iscsi/ifaces.
 | ||||||
|  | +a iface config /var/lib/iscsi/ifaces.
 | ||||||
|  |   | ||||||
|  |  Prep | ||||||
|  |  ---- | ||||||
|  | @@ -594,7 +593,7 @@ Running
 | ||||||
|  |  The command | ||||||
|  |  	iscsiadm -m iface | ||||||
|  |   | ||||||
|  | -will report iface configurations that are setup in /etc/iscsi/ifaces:
 | ||||||
|  | +will report iface configurations that are setup in /var/lib/iscsi/ifaces:
 | ||||||
|  |   | ||||||
|  |  	iface0 qla4xxx,00:c0:dd:08:63:e8,20.15.0.7,default,iqn.2005-06.com.redhat:madmax | ||||||
|  |  	iface1 qla4xxx,00:c0:dd:08:63:ea,20.15.0.9,default,iqn.2005-06.com.redhat:madmax | ||||||
|  | @@ -604,10 +603,10 @@ The format is:
 | ||||||
|  |   | ||||||
|  |  For software iscsi, you can create the iface configs by hand, but it is | ||||||
|  |  recommended that you use iscsiadm's iface mode. There is an iface.example in | ||||||
|  | -/etc/iscsi/ifaces which can be used as a template for the daring.
 | ||||||
|  | +/var/lib/iscsi/ifaces which can be used as a template for the daring.
 | ||||||
|  |   | ||||||
|  |  For each network object you wish to bind a session to, you must create | ||||||
|  | -a separate iface config in /etc/iscsi/ifaces and each iface config file
 | ||||||
|  | +a separate iface config in /var/lib/iscsi/ifaces and each iface config file
 | ||||||
|  |  must have a unique name which is less than or equal to 64 characters. | ||||||
|  |   | ||||||
|  |  Example | ||||||
|  | @@ -615,12 +614,12 @@ Example
 | ||||||
|  |   | ||||||
|  |  If you have NIC1 with MAC address 00:0F:1F:92:6B:BF and NIC2 with | ||||||
|  |  MAC address 00:C0:DD:08:63:E7, and you wanted to do software iscsi over | ||||||
|  | -TCP/IP, then in /etc/iscsi/ifaces/iface0 you would enter:
 | ||||||
|  | +TCP/IP, then in /var/lib/iscsi/ifaces/iface0 you would enter:
 | ||||||
|  |   | ||||||
|  |  	iface.transport_name = tcp | ||||||
|  |  	iface.hwaddress = 00:0F:1F:92:6B:BF | ||||||
|  |   | ||||||
|  | -and in /etc/iscsi/ifaces/iface1 you would enter:
 | ||||||
|  | +and in /var/lib/iscsi/ifaces/iface1 you would enter:
 | ||||||
|  |   | ||||||
|  |  	iface.transport_name = tcp | ||||||
|  |  	iface.hwaddress = 00:C0:DD:08:63:E7 | ||||||
|  | @@ -662,7 +661,7 @@ port. The iface name will be of the form:
 | ||||||
|  |  Running the following command: | ||||||
|  |  	iscsiadm -m iface | ||||||
|  |   | ||||||
|  | -will report iface configurations that are setup in /etc/iscsi/ifaces:
 | ||||||
|  | +will report iface configurations that are setup in /var/lib/iscsi/ifaces:
 | ||||||
|  |   | ||||||
|  |  	default tcp,<empty>,<empty>,<empty>,<empty> | ||||||
|  |  	iser iser,<empty>,<empty>,<empty>,<empty> | ||||||
|  | @@ -742,7 +741,7 @@ need a separate network connection to the target for discovery purposes.
 | ||||||
|  |  *This will be fixed in the next version of open-iscsi* | ||||||
|  |   | ||||||
|  |  For compatibility reasons, when you run iscsiadm to do discovery, it | ||||||
|  | -will check for interfaces in /etc/iscsi/iscsi/ifaces that are using
 | ||||||
|  | +will check for interfaces in /var/lib/iscsi/iscsi/ifaces that are using
 | ||||||
|  |  tcp for the iface.transport, and it will bind the portals that are discovered | ||||||
|  |  so that they will be logged in through those ifaces. This behavior can also | ||||||
|  |  be overridden by passing in the interfaces you want to use. For the case | ||||||
|  | @@ -757,7 +756,7 @@ If you had defined interfaces but wanted the old behavior, where we do not
 | ||||||
|  |  bind a session to an iface, then you can use the special iface "default": | ||||||
|  |  	iscsiadm -m discoverydb -t st -p ip:port -I default --discover -P 1 | ||||||
|  |   | ||||||
|  | -And if you did not define any interfaces in /etc/iscsi/ifaces and do
 | ||||||
|  | +And if you did not define any interfaces in /var/lib/iscsi/ifaces and do
 | ||||||
|  |  not pass anything into iscsiadm, running iscsiadm will do the default | ||||||
|  |  behavior, allowing the network subsystem to decide which device to use. | ||||||
|  |   | ||||||
|  | @@ -793,7 +792,7 @@ Discovery mode
 | ||||||
|  |  		ID [192.168.1.1:3260]: | ||||||
|  |  	iscsiadm -m discoverydb -t st -p 192.168.1.1:3260 --discover | ||||||
|  |   | ||||||
|  | -	This will search /etc/iscsi/send_targets for a record with the
 | ||||||
|  | +	This will search /var/lib/iscsi/send_targets for a record with the
 | ||||||
|  |  	ID [portal = 192.168.1.1:3260 and type = sendtargets. If found it | ||||||
|  |  	will perform discovery using the settings stored in the record. | ||||||
|  |  	If a record does not exist, it will be created using the iscsid.conf | ||||||
|  | @@ -802,7 +801,7 @@ Discovery mode
 | ||||||
|  |  	The argument to -p may also be a hostname instead of an address: | ||||||
|  |  		iscsiadm -m discoverydb -t st -p somehost --discover | ||||||
|  |   | ||||||
|  | -	For the ifaces, iscsiadm will first search /etc/iscsi/ifaces for
 | ||||||
|  | +	For the ifaces, iscsiadm will first search /var/lib/iscsi/ifaces for
 | ||||||
|  |  	interfaces using software iscsi. If any are found then nodes found | ||||||
|  |  	during discovery will be setup so that they can logged in through | ||||||
|  |  	those interfaces. To specify a specific iface, pass the | ||||||
|  | @@ -853,7 +852,7 @@ Discovery mode
 | ||||||
|  |   | ||||||
|  |  - SendTargets iSCSI Discovery with a specific interface. | ||||||
|  |  		If you wish to only use a subset of the interfaces in | ||||||
|  | -		/etc/iscsi/ifaces, then you can pass them in during discovery:
 | ||||||
|  | +		/var/lib/iscsi/ifaces, then you can pass them in during discovery:
 | ||||||
|  |  	iscsiadm -m discoverydb -t sendtargets -p 192.168.1.1:3260 \ | ||||||
|  |  		--interface=iface0 --interface=iface1 --discover | ||||||
|  |   | ||||||
|  | @@ -1223,8 +1222,8 @@ where targetname is the name of the target and ip_address:port is the address
 | ||||||
|  |  and port of the portal. tpgt is the Target Portal Group Tag of | ||||||
|  |  the portal, and is not used in iscsiadm commands except for static | ||||||
|  |  record creation. ifacename is the name of the iscsi interface | ||||||
|  | -defined in /etc/iscsi/ifaces. If no interface was defined in
 | ||||||
|  | -/etc/iscsi/ifaces or passed in, the default behavior is used.
 | ||||||
|  | +defined in /var/lib/iscsi/ifaces. If no interface was defined in
 | ||||||
|  | +/var/lib/iscsi/ifaces or passed in, the default behavior is used.
 | ||||||
|  |  Default here is iscsi_tcp/tcp to be used over whichever NIC the | ||||||
|  |  network layer decides is best. | ||||||
|  |   | ||||||
|  | @@ -1336,7 +1335,7 @@ If set, iscsid will perform discovery to the address every
 | ||||||
|  |  discovery.isns.discoveryd_poll_inval or | ||||||
|  |  discovery.sendtargets.discoveryd_poll_inval seconds, | ||||||
|  |  and it will log into any portals found from the discovery source using | ||||||
|  | -the ifaces in /etc/iscsi/ifaces.
 | ||||||
|  | +the ifaces in /var/lib/iscsi/ifaces.
 | ||||||
|  |   | ||||||
|  |  Note that for iSNS the poll_interval does not have to be set. If not set, | ||||||
|  |  iscsid will only perform rediscovery when it gets a SCN from the server. | ||||||
|  | diff --git a/doc/iscsiadm.8 b/doc/iscsiadm.8
 | ||||||
|  | index bf23dd2..9cfce16 100644
 | ||||||
|  | --- a/doc/iscsiadm.8
 | ||||||
|  | +++ b/doc/iscsiadm.8
 | ||||||
|  | @@ -228,7 +228,7 @@ This option is only valid for ping submode.
 | ||||||
|  |  .TP | ||||||
|  |  \fB\-I\fR, \fB\-\-interface=\fI[iface]\fR | ||||||
|  |  The interface argument specifies the iSCSI interface to use for the operation. | ||||||
|  | -iSCSI interfaces (iface) are defined in /etc/iscsi/ifaces. For hardware
 | ||||||
|  | +iSCSI interfaces (iface) are defined in /var/lib/iscsi/ifaces. For hardware
 | ||||||
|  |  iSCSI (qla4xxx) the iface config must have the hardware address | ||||||
|  |  (iface.hwaddress = port's MAC address) | ||||||
|  |  and the driver/transport_name (iface.transport_name). The iface's name is | ||||||
|  | @@ -301,7 +301,7 @@ If no other options are specified: for \fIdiscovery\fR, \fIdiscoverydb\fR and
 | ||||||
|  |  \fInode\fR, all of their respective records are displayed; for \fIsession\fR, | ||||||
|  |  all active sessions and connections are displayed; for \fIfw\fR, all boot | ||||||
|  |  firmware values are displayed; for \fIhost\fR, all iSCSI hosts are displayed; | ||||||
|  | -and for \fIiface\fR, all ifaces setup in /etc/iscsi/ifaces are displayed.
 | ||||||
|  | +and for \fIiface\fR, all ifaces setup in /var/lib/iscsi/ifaces are displayed.
 | ||||||
|  |  .TP | ||||||
|  |  \fB\-n\fR, \fB\-\-name=\fIname\fR | ||||||
|  |  In node mode, specify a field \fIname\fR in a record. In flashnode submode | ||||||
|  | @@ -640,10 +640,10 @@ The configuration file read by \fBiscsid\fR and \fBiscsiadm\fR on startup.
 | ||||||
|  |  The file containing the iSCSI InitiatorName and InitiatorAlias read by | ||||||
|  |  \fBiscsid\fR and \fBiscsiadm\fR on startup. | ||||||
|  |  .TP | ||||||
|  | -/etc/iscsi/nodes/
 | ||||||
|  | +/var/lib/iscsi/nodes/
 | ||||||
|  |  This directory contains the nodes with their targets. | ||||||
|  |  .TP | ||||||
|  | -/etc/iscsi/send_targets
 | ||||||
|  | +/var/lib/iscsi/send_targets
 | ||||||
|  |  This directory contains the portals. | ||||||
|  |  .SH "SEE ALSO" | ||||||
|  |  .BR iscsid (8) | ||||||
|  | diff --git a/doc/iscsid.8 b/doc/iscsid.8
 | ||||||
|  | index 6f9218f..0da0551 100644
 | ||||||
|  | --- a/doc/iscsid.8
 | ||||||
|  | +++ b/doc/iscsid.8
 | ||||||
|  | @@ -65,7 +65,7 @@ and
 | ||||||
|  |  .B iscsiadm | ||||||
|  |  on startup. | ||||||
|  |  .TP | ||||||
|  | -/etc/iscsi/nodes
 | ||||||
|  | +/var/lib/iscsi/nodes
 | ||||||
|  |  Open-iSCSI persistent configuration database | ||||||
|  |   | ||||||
|  |  .SH "SEE ALSO" | ||||||
|  | diff --git a/usr/idbm.c b/usr/idbm.c
 | ||||||
|  | index f3c812e..8b96146 100644
 | ||||||
|  | --- a/usr/idbm.c
 | ||||||
|  | +++ b/usr/idbm.c
 | ||||||
|  | @@ -2929,9 +2929,9 @@ free_info:
 | ||||||
|  |  int idbm_init(idbm_get_config_file_fn *fn) | ||||||
|  |  { | ||||||
|  |  	/* make sure root db dir is there */ | ||||||
|  | -	if (access(ISCSI_CONFIG_ROOT, F_OK) != 0) {
 | ||||||
|  | -		if (mkdir(ISCSI_CONFIG_ROOT, 0660) != 0) {
 | ||||||
|  | -			log_error("Could not make %s %d", ISCSI_CONFIG_ROOT,
 | ||||||
|  | +	if (access(ISCSIVAR, F_OK) != 0) {
 | ||||||
|  | +		if (mkdir(ISCSIVAR, 0660) != 0) {
 | ||||||
|  | +			log_error("Could not make %s %d", ISCSIVAR,
 | ||||||
|  |  				   errno); | ||||||
|  |  			return errno; | ||||||
|  |  		} | ||||||
|  | diff --git a/usr/idbm.h b/usr/idbm.h
 | ||||||
|  | index b83c0bb..2b05d78 100644
 | ||||||
|  | --- a/usr/idbm.h
 | ||||||
|  | +++ b/usr/idbm.h
 | ||||||
|  | @@ -29,12 +29,13 @@
 | ||||||
|  |  #include "list.h" | ||||||
|  |  #include "flashnode.h" | ||||||
|  |   | ||||||
|  | -#define NODE_CONFIG_DIR		ISCSI_CONFIG_ROOT"nodes"
 | ||||||
|  | -#define SLP_CONFIG_DIR		ISCSI_CONFIG_ROOT"slp"
 | ||||||
|  | -#define ISNS_CONFIG_DIR		ISCSI_CONFIG_ROOT"isns"
 | ||||||
|  | -#define STATIC_CONFIG_DIR	ISCSI_CONFIG_ROOT"static"
 | ||||||
|  | -#define FW_CONFIG_DIR		ISCSI_CONFIG_ROOT"fw"
 | ||||||
|  | -#define ST_CONFIG_DIR		ISCSI_CONFIG_ROOT"send_targets"
 | ||||||
|  | +#define ISCSIVAR		"/var/lib/iscsi/"
 | ||||||
|  | +#define NODE_CONFIG_DIR		ISCSIVAR"nodes"
 | ||||||
|  | +#define SLP_CONFIG_DIR		ISCSIVAR"slp"
 | ||||||
|  | +#define ISNS_CONFIG_DIR		ISCSIVAR"isns"
 | ||||||
|  | +#define STATIC_CONFIG_DIR	ISCSIVAR"static"
 | ||||||
|  | +#define FW_CONFIG_DIR		ISCSIVAR"fw"
 | ||||||
|  | +#define ST_CONFIG_DIR		ISCSIVAR"send_targets"
 | ||||||
|  |  #define ST_CONFIG_NAME		"st_config" | ||||||
|  |  #define ISNS_CONFIG_NAME	"isns_config" | ||||||
|  |   | ||||||
|  | diff --git a/usr/iface.h b/usr/iface.h
 | ||||||
|  | index 6c06f7f..c8b9de9 100644
 | ||||||
|  | --- a/usr/iface.h
 | ||||||
|  | +++ b/usr/iface.h
 | ||||||
|  | @@ -21,8 +21,9 @@
 | ||||||
|  |  #define ISCSI_IFACE_H | ||||||
|  |   | ||||||
|  |  #include <libopeniscsiusr/libopeniscsiusr.h> | ||||||
|  | +#include "idbm.h"
 | ||||||
|  |   | ||||||
|  | -#define IFACE_CONFIG_DIR	ISCSI_CONFIG_ROOT"ifaces"
 | ||||||
|  | +#define IFACE_CONFIG_DIR	ISCSIVAR"ifaces"
 | ||||||
|  |   | ||||||
|  |  struct iface_rec; | ||||||
|  |  struct list_head; | ||||||
|  | -- 
 | ||||||
|  | 2.21.0 | ||||||
|  | 
 | ||||||
							
								
								
									
										39
									
								
								SOURCES/0008-use-red-hat-for-name.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										39
									
								
								SOURCES/0008-use-red-hat-for-name.patch
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,39 @@ | |||||||
|  | From ea35362504329e7fe86f4af17a88bed009c5069c Mon Sep 17 00:00:00 2001 | ||||||
|  | From: Chris Leech <cleech@redhat.com> | ||||||
|  | Date: Mon, 19 Nov 2012 16:40:04 -0800 | ||||||
|  | Subject: [PATCH 08/32] use red hat for name | ||||||
|  | 
 | ||||||
|  | ---
 | ||||||
|  |  doc/iscsi-iname.8   | 2 +- | ||||||
|  |  utils/iscsi-iname.c | 2 +- | ||||||
|  |  2 files changed, 2 insertions(+), 2 deletions(-) | ||||||
|  | 
 | ||||||
|  | diff --git a/doc/iscsi-iname.8 b/doc/iscsi-iname.8
 | ||||||
|  | index a55d666d1af3..dd77ed9f3165 100644
 | ||||||
|  | --- a/doc/iscsi-iname.8
 | ||||||
|  | +++ b/doc/iscsi-iname.8
 | ||||||
|  | @@ -14,7 +14,7 @@ generates a unique iSCSI node name on every invocation.
 | ||||||
|  |  Display help | ||||||
|  |  .TP | ||||||
|  |  .BI [-p=]\fIprefix\fP | ||||||
|  | -Use the prefix passed in instead of the default "iqn.2005-03.org.open-iscsi"
 | ||||||
|  | +Use the prefix passed in instead of the default "iqn.1994-05.com.redhat"
 | ||||||
|  |   | ||||||
|  |  .SH AUTHORS | ||||||
|  |  Open-iSCSI project <http://www.open-iscsi.com/> | ||||||
|  | diff --git a/utils/iscsi-iname.c b/utils/iscsi-iname.c
 | ||||||
|  | index 6347edc46293..cb2f6c8b8651 100644
 | ||||||
|  | --- a/utils/iscsi-iname.c
 | ||||||
|  | +++ b/utils/iscsi-iname.c
 | ||||||
|  | @@ -73,7 +73,7 @@ main(int argc, char *argv[])
 | ||||||
|  |  			exit(0); | ||||||
|  |  		} | ||||||
|  |  	} else { | ||||||
|  | -		prefix = "iqn.2005-03.org.open-iscsi";
 | ||||||
|  | +		prefix = "iqn.1994-05.com.redhat";
 | ||||||
|  |  	} | ||||||
|  |   | ||||||
|  |  	/* try to feed some entropy from the pool to MD5 in order to get | ||||||
|  | -- 
 | ||||||
|  | 2.14.4 | ||||||
|  | 
 | ||||||
							
								
								
									
										4014
									
								
								SOURCES/0009-libiscsi.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										4014
									
								
								SOURCES/0009-libiscsi.patch
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										45
									
								
								SOURCES/0010-remove-the-offload-boot-supported-ifdef.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										45
									
								
								SOURCES/0010-remove-the-offload-boot-supported-ifdef.patch
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,45 @@ | |||||||
|  | From 71b576b10a03651f67173d19883a929e91a3423a Mon Sep 17 00:00:00 2001 | ||||||
|  | From: Chris Leech <cleech@redhat.com> | ||||||
|  | Date: Mon, 19 Nov 2012 17:09:24 -0800 | ||||||
|  | Subject: [PATCH 10/32] remove the offload boot supported ifdef | ||||||
|  | 
 | ||||||
|  | ---
 | ||||||
|  |  usr/iface.c | 7 +------ | ||||||
|  |  1 file changed, 1 insertion(+), 6 deletions(-) | ||||||
|  | 
 | ||||||
|  | diff --git a/usr/iface.c b/usr/iface.c
 | ||||||
|  | index 137138f5af67..889fe8cd8202 100644
 | ||||||
|  | --- a/usr/iface.c
 | ||||||
|  | +++ b/usr/iface.c
 | ||||||
|  | @@ -993,6 +993,7 @@ int iface_setup_from_boot_context(struct iface_rec *iface,
 | ||||||
|  |  { | ||||||
|  |  	struct iscsi_transport *t = NULL; | ||||||
|  |  	uint32_t hostno; | ||||||
|  | +	int rc;
 | ||||||
|  |   | ||||||
|  |  	if (strlen(context->initiatorname)) | ||||||
|  |  		strlcpy(iface->iname, context->initiatorname, | ||||||
|  | @@ -1006,10 +1007,7 @@ int iface_setup_from_boot_context(struct iface_rec *iface,
 | ||||||
|  |  			return 0; | ||||||
|  |  		} | ||||||
|  |  	} else if (strlen(context->iface)) { | ||||||
|  | -/* this ifdef is only temp until distros and firmwares are updated */
 | ||||||
|  | -#ifdef OFFLOAD_BOOT_SUPPORTED
 | ||||||
|  |  		char transport_name[ISCSI_TRANSPORT_NAME_MAXLEN]; | ||||||
|  | -		int rc;
 | ||||||
|  |   | ||||||
|  |  		memset(transport_name, 0, ISCSI_TRANSPORT_NAME_MAXLEN); | ||||||
|  |  		/* make sure offload driver is loaded */ | ||||||
|  | @@ -1035,9 +1033,6 @@ int iface_setup_from_boot_context(struct iface_rec *iface,
 | ||||||
|  |  		} | ||||||
|  |   | ||||||
|  |  		strlcpy(iface->netdev, context->iface, sizeof(iface->netdev)); | ||||||
|  | -#else
 | ||||||
|  | -		return 0;
 | ||||||
|  | -#endif
 | ||||||
|  |  	} else | ||||||
|  |  		return 0; | ||||||
|  |   | ||||||
|  | -- 
 | ||||||
|  | 2.14.4 | ||||||
|  | 
 | ||||||
| @ -0,0 +1,34 @@ | |||||||
|  | From 6629618e3581cbe632b7408a49437270bc04a8d4 Mon Sep 17 00:00:00 2001 | ||||||
|  | From: Chris Leech <cleech@redhat.com> | ||||||
|  | Date: Mon, 24 Feb 2014 09:33:33 -0800 | ||||||
|  | Subject: [PATCH 13/32] Revert "iscsiadm: return error when login fails" | ||||||
|  | 
 | ||||||
|  | This reverts commit fc2a8e9a2911bc76f961fe3e4a159fab9b8b9691. | ||||||
|  | 
 | ||||||
|  | Done to address RHBZ #1015563 | ||||||
|  | ---
 | ||||||
|  |  usr/session_mgmt.c | 4 ++-- | ||||||
|  |  1 file changed, 2 insertions(+), 2 deletions(-) | ||||||
|  | 
 | ||||||
|  | diff --git a/usr/session_mgmt.c b/usr/session_mgmt.c
 | ||||||
|  | index 596085b1f640..07f587d2bafb 100644
 | ||||||
|  | --- a/usr/session_mgmt.c
 | ||||||
|  | +++ b/usr/session_mgmt.c
 | ||||||
|  | @@ -178,12 +178,12 @@ int iscsi_login_portal(void *data, struct list_head *list, struct node_rec *rec)
 | ||||||
|  |  		goto done; | ||||||
|  |  	} | ||||||
|  |  	if (session_count >= rec->session.nr_sessions) { | ||||||
|  | -		log_warning("%s: %d session%s requested, but %d "
 | ||||||
|  | +		log_debug(1, "%s: %d session%s requested, but %d "
 | ||||||
|  |  			  "already present.", | ||||||
|  |  			  rec->iface.name, rec->session.nr_sessions, | ||||||
|  |  			  rec->session.nr_sessions == 1 ? "" : "s", | ||||||
|  |  			  session_count); | ||||||
|  | -		rc = ISCSI_ERR_SESS_EXISTS;
 | ||||||
|  | +		rc = 0;
 | ||||||
|  |  		goto done; | ||||||
|  |  	} | ||||||
|  |   | ||||||
|  | -- 
 | ||||||
|  | 2.14.4 | ||||||
|  | 
 | ||||||
							
								
								
									
										56
									
								
								SOURCES/0018-Add-macros-to-release-GIL-lock.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										56
									
								
								SOURCES/0018-Add-macros-to-release-GIL-lock.patch
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,56 @@ | |||||||
|  | From bd26fd7e7f91e5c4c6903c3d7e1a375a14261a48 Mon Sep 17 00:00:00 2001 | ||||||
|  | From: Jiri Konecny <jkonecny@redhat.com> | ||||||
|  | Date: Mon, 11 May 2015 13:16:26 +0200 | ||||||
|  | Subject: [PATCH 18/32] Add macros to release GIL lock | ||||||
|  | 
 | ||||||
|  | Other threads are blocked when GIL is not released before the time consuming | ||||||
|  | functions. | ||||||
|  | ---
 | ||||||
|  |  libiscsi/pylibiscsi.c | 16 +++++++++++++--- | ||||||
|  |  1 file changed, 13 insertions(+), 3 deletions(-) | ||||||
|  | 
 | ||||||
|  | diff --git a/libiscsi/pylibiscsi.c b/libiscsi/pylibiscsi.c
 | ||||||
|  | index 88008538f04f..40b59553a28e 100644
 | ||||||
|  | --- a/libiscsi/pylibiscsi.c
 | ||||||
|  | +++ b/libiscsi/pylibiscsi.c
 | ||||||
|  | @@ -364,8 +364,13 @@ static PyObject *PyIscsiNode_str(PyObject *self)
 | ||||||
|  |  static PyObject *PyIscsiNode_login(PyObject *self) | ||||||
|  |  { | ||||||
|  |  	PyIscsiNode *node = (PyIscsiNode *)self; | ||||||
|  | +	int ret;
 | ||||||
|  |   | ||||||
|  | -	if (libiscsi_node_login(context, &node->node)) {
 | ||||||
|  | +	Py_BEGIN_ALLOW_THREADS
 | ||||||
|  | +	ret = libiscsi_node_login(context, &node->node);
 | ||||||
|  | +	Py_END_ALLOW_THREADS
 | ||||||
|  | +
 | ||||||
|  | +	if (ret) {
 | ||||||
|  |  		PyErr_SetString(PyExc_IOError, | ||||||
|  |  				libiscsi_get_error_string(context)); | ||||||
|  |  		return NULL; | ||||||
|  | @@ -551,6 +556,7 @@ static PyObject *pylibiscsi_discover_sendtargets(PyObject *self,
 | ||||||
|  |  	const struct libiscsi_auth_info *authinfo = NULL; | ||||||
|  |  	struct libiscsi_node *found_nodes; | ||||||
|  |  	PyObject* found_node_list; | ||||||
|  | +	int ret;
 | ||||||
|  |   | ||||||
|  |  	if (!PyArg_ParseTupleAndKeywords(args, kwds, "s|iO", | ||||||
|  |  					kwlist, &address, &port, | ||||||
|  | @@ -570,8 +576,12 @@ static PyObject *pylibiscsi_discover_sendtargets(PyObject *self,
 | ||||||
|  |  		} | ||||||
|  |  	} | ||||||
|  |   | ||||||
|  | -	if (libiscsi_discover_sendtargets(context, address, port, authinfo,
 | ||||||
|  | -					  &nr_found, &found_nodes)) {
 | ||||||
|  | +	Py_BEGIN_ALLOW_THREADS
 | ||||||
|  | +	ret = libiscsi_discover_sendtargets(context, address, port, authinfo,
 | ||||||
|  | +					    &nr_found, &found_nodes);
 | ||||||
|  | +	Py_END_ALLOW_THREADS
 | ||||||
|  | +
 | ||||||
|  | +	if (ret) {
 | ||||||
|  |  		PyErr_SetString(PyExc_IOError, | ||||||
|  |  				libiscsi_get_error_string(context)); | ||||||
|  |  		return NULL; | ||||||
|  | -- 
 | ||||||
|  | 2.14.4 | ||||||
|  | 
 | ||||||
							
								
								
									
										290
									
								
								SOURCES/0019-libiscsi-introduce-sessions-API.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										290
									
								
								SOURCES/0019-libiscsi-introduce-sessions-API.patch
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,290 @@ | |||||||
|  | From 7671cd56d36a76e954318cbdce3f08fc40aa3fe4 Mon Sep 17 00:00:00 2001 | ||||||
|  | From: Peter Hatina <phatina@redhat.com> | ||||||
|  | Date: Mon, 5 Oct 2015 16:50:36 -0700 | ||||||
|  | Subject: [PATCH 19/32] libiscsi introduce sessions API | ||||||
|  | 
 | ||||||
|  | ---
 | ||||||
|  |  libiscsi/libiscsi.c | 125 ++++++++++++++++++++++++++++++++++++++++++++++++++++ | ||||||
|  |  libiscsi/libiscsi.h |  56 +++++++++++++++++++++++ | ||||||
|  |  usr/iscsi_sysfs.c   |   6 +++ | ||||||
|  |  usr/iscsi_sysfs.h   |   2 + | ||||||
|  |  4 files changed, 189 insertions(+) | ||||||
|  | 
 | ||||||
|  | diff --git a/libiscsi/libiscsi.c b/libiscsi/libiscsi.c
 | ||||||
|  | index 064e4b570d0b..755c18ca8e3b 100644
 | ||||||
|  | --- a/libiscsi/libiscsi.c
 | ||||||
|  | +++ b/libiscsi/libiscsi.c
 | ||||||
|  | @@ -3,6 +3,7 @@
 | ||||||
|  |   * | ||||||
|  |   * Copyright (C) 2008-2009 Red Hat, Inc. All rights reserved. | ||||||
|  |   * Copyright (C) 2008-2009 Hans de Goede <hdegoede@redhat.com> | ||||||
|  | + * Copyright (C) 2015      Peter Hatina <phatina@redhat.com>
 | ||||||
|  |   * maintained by open-iscsi@googlegroups.com | ||||||
|  |   * | ||||||
|  |   * This program is free software; you can redistribute it and/or modify | ||||||
|  | @@ -469,6 +470,130 @@ leave:
 | ||||||
|  |  	return rc; | ||||||
|  |  } | ||||||
|  |   | ||||||
|  | +struct libiscsi_session_array {
 | ||||||
|  | +	int cnt;
 | ||||||
|  | +	int size;
 | ||||||
|  | +	struct libiscsi_session_info *data;
 | ||||||
|  | +};
 | ||||||
|  | +
 | ||||||
|  | +static void libiscsi_session_array_init(struct libiscsi_session_array *arr)
 | ||||||
|  | +{
 | ||||||
|  | +	arr->cnt = 0;
 | ||||||
|  | +	arr->size = 0;
 | ||||||
|  | +	arr->data = NULL;
 | ||||||
|  | +}
 | ||||||
|  | +
 | ||||||
|  | +static int libiscsi_session_array_grow(struct libiscsi_session_array *arr)
 | ||||||
|  | +{
 | ||||||
|  | +	if (arr->size == 0)
 | ||||||
|  | +		arr->size = 4;
 | ||||||
|  | +	else
 | ||||||
|  | +		arr->size *= 2;
 | ||||||
|  | +
 | ||||||
|  | +	arr->data = (struct libiscsi_session_info *) realloc(
 | ||||||
|  | +		arr->data,
 | ||||||
|  | +		arr->size * sizeof(struct libiscsi_session_info));
 | ||||||
|  | +
 | ||||||
|  | +	return arr->data ? 0 : 1;
 | ||||||
|  | +}
 | ||||||
|  | +
 | ||||||
|  | +static int libiscsi_session_array_grow_ondemand(struct libiscsi_session_array *arr)
 | ||||||
|  | +{
 | ||||||
|  | +	if (arr->size == arr->cnt)
 | ||||||
|  | +		return libiscsi_session_array_grow(arr);
 | ||||||
|  | +	return 0;
 | ||||||
|  | +}
 | ||||||
|  | +
 | ||||||
|  | +static int libiscsi_session_array_resize_precize(struct libiscsi_session_array *arr)
 | ||||||
|  | +{
 | ||||||
|  | +	arr->data = (struct libiscsi_session_info *) realloc(
 | ||||||
|  | +		arr->data,
 | ||||||
|  | +		arr->cnt * sizeof(struct libiscsi_session_info));
 | ||||||
|  | +	arr->size = arr->cnt;
 | ||||||
|  | +
 | ||||||
|  | +	return arr->data ? 0 : 1;
 | ||||||
|  | +}
 | ||||||
|  | +
 | ||||||
|  | +static void copy_session_info_to_libiscsi_session_info(
 | ||||||
|  | +	struct libiscsi_session_info *info,
 | ||||||
|  | +	struct session_info *s_info)
 | ||||||
|  | +{
 | ||||||
|  | +	/* Copy session info to public struct. */
 | ||||||
|  | +	info->sid = s_info->sid;
 | ||||||
|  | +	/* Timeouts */
 | ||||||
|  | +	memcpy(&info->tmo, &s_info->tmo, sizeof(struct libiscsi_session_timeout));
 | ||||||
|  | +	/* CHAP authentication information */
 | ||||||
|  | +	memcpy(&info->chap, &s_info->chap, sizeof(struct libiscsi_chap_auth_info));
 | ||||||
|  | +	/* Target information */
 | ||||||
|  | +	strncpy(info->targetname, s_info->targetname, LIBISCSI_VALUE_MAXLEN);
 | ||||||
|  | +	strncpy(info->address, s_info->address, NI_MAXHOST);
 | ||||||
|  | +	strncpy(info->persistent_address, s_info->persistent_address, NI_MAXHOST);
 | ||||||
|  | +	info->tpgt = s_info->tpgt;
 | ||||||
|  | +	info->persistent_port = s_info->persistent_port;
 | ||||||
|  | +}
 | ||||||
|  | +
 | ||||||
|  | +static int get_sessions_helper(void *data, struct session_info *s_info)
 | ||||||
|  | +{
 | ||||||
|  | +	struct libiscsi_session_array *arr = (struct libiscsi_session_array *) data;
 | ||||||
|  | +
 | ||||||
|  | +	if (libiscsi_session_array_grow_ondemand(arr) != 0)
 | ||||||
|  | +		return 1;
 | ||||||
|  | +
 | ||||||
|  | +	copy_session_info_to_libiscsi_session_info(&arr->data[arr->cnt++], s_info);
 | ||||||
|  | +
 | ||||||
|  | +	return 0;
 | ||||||
|  | +}
 | ||||||
|  | +
 | ||||||
|  | +int libiscsi_get_session_infos(struct libiscsi_context *context,
 | ||||||
|  | +	struct libiscsi_session_info **infos,
 | ||||||
|  | +	int *nr_sessions)
 | ||||||
|  | +{
 | ||||||
|  | +	int rc = 0;
 | ||||||
|  | +	int nr_found = 0;
 | ||||||
|  | +	struct libiscsi_session_array arr;
 | ||||||
|  | +
 | ||||||
|  | +	if (!context || !infos || !nr_sessions)
 | ||||||
|  | +		return 1;
 | ||||||
|  | +
 | ||||||
|  | +	libiscsi_session_array_init(&arr);
 | ||||||
|  | +
 | ||||||
|  | +	rc = iscsi_sysfs_for_each_session((void *) &arr, &nr_found,
 | ||||||
|  | +		get_sessions_helper, 0);
 | ||||||
|  | +	if (rc != 0 || nr_found == 0) {
 | ||||||
|  | +		strcpy(context->error_str, "No matching session");
 | ||||||
|  | +		return ENODEV;
 | ||||||
|  | +	}
 | ||||||
|  | +
 | ||||||
|  | +	if (libiscsi_session_array_resize_precize(&arr) != 0) {
 | ||||||
|  | +		strcpy(context->error_str, "Can't allocate memory for session infos");
 | ||||||
|  | +		return ENOMEM;
 | ||||||
|  | +	}
 | ||||||
|  | +
 | ||||||
|  | +	*infos = arr.data;
 | ||||||
|  | +	*nr_sessions = nr_found;
 | ||||||
|  | +
 | ||||||
|  | +	return 0;
 | ||||||
|  | +}
 | ||||||
|  | +
 | ||||||
|  | +int libiscsi_get_session_info_by_id(struct libiscsi_context *context,
 | ||||||
|  | +	struct libiscsi_session_info *info,
 | ||||||
|  | +	const char *session)
 | ||||||
|  | +{
 | ||||||
|  | +	struct session_info s_info;
 | ||||||
|  | +
 | ||||||
|  | +	if (!context || !info || !session)
 | ||||||
|  | +		return 1;
 | ||||||
|  | +
 | ||||||
|  | +	if (iscsi_sysfs_get_sessioninfo_by_id(&s_info, (char*) session) != 0) {
 | ||||||
|  | +		strcpy(context->error_str, "No matching session");
 | ||||||
|  | +		return ENODEV;
 | ||||||
|  | +	}
 | ||||||
|  | +
 | ||||||
|  | +	copy_session_info_to_libiscsi_session_info(info, &s_info);
 | ||||||
|  | +
 | ||||||
|  | +	return 0;
 | ||||||
|  | +}
 | ||||||
|  | +
 | ||||||
|  |  int libiscsi_node_set_parameter(struct libiscsi_context *context, | ||||||
|  |  	const struct libiscsi_node *node, | ||||||
|  |  	const char *parameter, const char *value) | ||||||
|  | diff --git a/libiscsi/libiscsi.h b/libiscsi/libiscsi.h
 | ||||||
|  | index 756590e14d8b..a9891f48b7d6 100644
 | ||||||
|  | --- a/libiscsi/libiscsi.h
 | ||||||
|  | +++ b/libiscsi/libiscsi.h
 | ||||||
|  | @@ -3,6 +3,7 @@
 | ||||||
|  |   * | ||||||
|  |   * Copyright (C) 2008-2009 Red Hat, Inc. All rights reserved. | ||||||
|  |   * Copyright (C) 2008-2009 Hans de Goede <hdegoede@redhat.com> | ||||||
|  | + * Copyright (C) 2015      Peter Hatina <phatina@redhat.com>
 | ||||||
|  |   * maintained by open-iscsi@googlegroups.com | ||||||
|  |   * | ||||||
|  |   * This program is free software; you can redistribute it and/or modify | ||||||
|  | @@ -56,6 +57,17 @@ enum libiscsi_auth_t {
 | ||||||
|  |   */ | ||||||
|  |  struct libiscsi_context; | ||||||
|  |   | ||||||
|  | +/** \brief iSCSI session timeouts
 | ||||||
|  | + *
 | ||||||
|  | + * Struct holding session timeouts.
 | ||||||
|  | + */
 | ||||||
|  | +struct libiscsi_session_timeout {
 | ||||||
|  | +    int abort_tmo;
 | ||||||
|  | +    int lu_reset_tmo;
 | ||||||
|  | +    int recovery_tmo;
 | ||||||
|  | +    int tgt_reset_tmo;
 | ||||||
|  | +};
 | ||||||
|  | +
 | ||||||
|  |  /** \brief iSCSI node record | ||||||
|  |   * | ||||||
|  |   * Struct holding data uniquely identifying an iSCSI node. | ||||||
|  | @@ -84,6 +96,24 @@ struct libiscsi_chap_auth_info {
 | ||||||
|  |      char reverse_password[LIBISCSI_VALUE_MAXLEN] /** Reverse Password */; | ||||||
|  |  }; | ||||||
|  |   | ||||||
|  | +/** \brief iSCSI session
 | ||||||
|  | + *
 | ||||||
|  | + * Struct hoding iSCSI session information.
 | ||||||
|  | + */
 | ||||||
|  | +struct libiscsi_session_info {
 | ||||||
|  | +    int sid;
 | ||||||
|  | +
 | ||||||
|  | +    struct libiscsi_session_timeout tmo;
 | ||||||
|  | +    struct libiscsi_chap_auth_info chap;
 | ||||||
|  | +
 | ||||||
|  | +    char targetname[LIBISCSI_VALUE_MAXLEN];
 | ||||||
|  | +    int tpgt;
 | ||||||
|  | +    char address[NI_MAXHOST];
 | ||||||
|  | +    int port;
 | ||||||
|  | +    char persistent_address[NI_MAXHOST];
 | ||||||
|  | +    int persistent_port;
 | ||||||
|  | +};
 | ||||||
|  | +
 | ||||||
|  |  /** \brief generic libiscsi authentication information struct | ||||||
|  |   * | ||||||
|  |   * Struct holding authentication information for discovery and login. | ||||||
|  | @@ -248,6 +278,32 @@ PUBLIC int libiscsi_node_login(struct libiscsi_context *context,
 | ||||||
|  |  PUBLIC int libiscsi_node_logout(struct libiscsi_context *context, | ||||||
|  |      const struct libiscsi_node *node); | ||||||
|  |   | ||||||
|  | +/** \brief Get an array of iSCSI sessions.
 | ||||||
|  | + *
 | ||||||
|  | + * Get the array containing iSCSI sessions' information.
 | ||||||
|  | + *
 | ||||||
|  | + * \param context       libiscsi context to operate on.
 | ||||||
|  | + * \param infos         Array of iSCSI sessions' information.
 | ||||||
|  | + *                      Release with free().
 | ||||||
|  | + * \param nr_sessions   The number of elements in \e infos.
 | ||||||
|  | + * \return              0 on success, otherwise a standard error code
 | ||||||
|  | + *                      (from errno.h).
 | ||||||
|  | + */
 | ||||||
|  | +PUBLIC int libiscsi_get_session_infos(struct libiscsi_context *context,
 | ||||||
|  | +    struct libiscsi_session_info **infos, int *nr_sessions);
 | ||||||
|  | +
 | ||||||
|  | +/** \brief Get session information by session ID.
 | ||||||
|  | + *
 | ||||||
|  | + * \param context       libiscsi context to operate on.
 | ||||||
|  | + * \param info          iSCSI session information.
 | ||||||
|  | + * \param session       Session name.
 | ||||||
|  | + * \return              0 on success, otherwise a standard error code
 | ||||||
|  | + *                      (from errno.h)
 | ||||||
|  | + */
 | ||||||
|  | +PUBLIC int libiscsi_get_session_info_by_id(struct libiscsi_context *context,
 | ||||||
|  | +    struct libiscsi_session_info *info,
 | ||||||
|  | +    const char *session);
 | ||||||
|  | +
 | ||||||
|  |  /** \brief Set an iSCSI parameter for the given node | ||||||
|  |   * | ||||||
|  |   * Set the given nodes iSCSI parameter named by \e parameter to value \e value. | ||||||
|  | diff --git a/usr/iscsi_sysfs.c b/usr/iscsi_sysfs.c
 | ||||||
|  | index fdc26c7bd9ba..80b7b0210fd1 100644
 | ||||||
|  | --- a/usr/iscsi_sysfs.c
 | ||||||
|  | +++ b/usr/iscsi_sysfs.c
 | ||||||
|  | @@ -3,6 +3,7 @@
 | ||||||
|  |   * | ||||||
|  |   * Copyright (C) 2006 Mike Christie | ||||||
|  |   * Copyright (C) 2006 Red Hat, Inc. All rights reserved. | ||||||
|  | + * Copyright (C) 2015      Peter Hatina <phatina@redhat.com>
 | ||||||
|  |   * | ||||||
|  |   * This program is free software; you can redistribute it and/or modify | ||||||
|  |   * it under the terms of the GNU General Public License as published | ||||||
|  | @@ -1146,6 +1147,11 @@ free_info:
 | ||||||
|  |  	return rc; | ||||||
|  |  } | ||||||
|  |   | ||||||
|  | +const char *iscsi_sysfs_get_session_path(void)
 | ||||||
|  | +{
 | ||||||
|  | +	return ISCSI_SESSION_DIR;
 | ||||||
|  | +}
 | ||||||
|  | +
 | ||||||
|  |  int iscsi_sysfs_for_each_iface_on_host(void *data, uint32_t host_no, | ||||||
|  |  				       int *nr_found, | ||||||
|  |  				       iscsi_sysfs_iface_op_fn *fn) | ||||||
|  | diff --git a/usr/iscsi_sysfs.h b/usr/iscsi_sysfs.h
 | ||||||
|  | index cdcefa65f683..12ad87f96c8c 100644
 | ||||||
|  | --- a/usr/iscsi_sysfs.h
 | ||||||
|  | +++ b/usr/iscsi_sysfs.h
 | ||||||
|  | @@ -3,6 +3,7 @@
 | ||||||
|  |   * | ||||||
|  |   * Copyright (C) 2006 Mike Christie | ||||||
|  |   * Copyright (C) 2006 Red Hat, Inc. All rights reserved. | ||||||
|  | + * Copyright (C) 2015      Peter Hatina <phatina@redhat.com>
 | ||||||
|  |   * | ||||||
|  |   * This program is free software; you can redistribute it and/or modify | ||||||
|  |   * it under the terms of the GNU General Public License as published | ||||||
|  | @@ -47,6 +48,7 @@ typedef int (iscsi_sysfs_flashnode_op_fn)(void *, struct flashnode_rec *,
 | ||||||
|  |  					  uint32_t, uint32_t); | ||||||
|  |  typedef int (iscsi_sysfs_iface_op_fn)(void *, struct iface_rec *); | ||||||
|  |   | ||||||
|  | +extern const char *iscsi_sysfs_get_session_path(void);
 | ||||||
|  |  extern int iscsi_sysfs_for_each_iface_on_host(void *data, uint32_t host_no, | ||||||
|  |  					      int *nr_found, | ||||||
|  |  					      iscsi_sysfs_iface_op_fn *fn); | ||||||
|  | -- 
 | ||||||
|  | 2.14.4 | ||||||
|  | 
 | ||||||
| @ -0,0 +1,25 @@ | |||||||
|  | From 92aac85cf423d1c566d324255a86de0116d33015 Mon Sep 17 00:00:00 2001 | ||||||
|  | From: Chris Leech <cleech@redhat.com> | ||||||
|  | Date: Mon, 21 Jan 2013 15:43:36 -0800 | ||||||
|  | Subject: [PATCH 20/32] use Red Hat version string to match RPM package version | ||||||
|  | 
 | ||||||
|  | ---
 | ||||||
|  |  usr/version.h | 2 +- | ||||||
|  |  1 file changed, 1 insertion(+), 1 deletion(-) | ||||||
|  | 
 | ||||||
|  | diff --git a/usr/version.h b/usr/version.h
 | ||||||
|  | index 4dfef4ccfb77..1334d47c6bb3 100644
 | ||||||
|  | --- a/usr/version.h
 | ||||||
|  | +++ b/usr/version.h
 | ||||||
|  | @@ -6,7 +6,7 @@
 | ||||||
|  |   * This may not be the same value as the kernel versions because | ||||||
|  |   * some other maintainer could merge a patch without going through us | ||||||
|  |   */ | ||||||
|  | -#define ISCSI_VERSION_STR	"2.0-877"
 | ||||||
|  | +#define ISCSI_VERSION_STR	"6.2.0.877-0"
 | ||||||
|  |  #define ISCSI_VERSION_FILE	"/sys/module/scsi_transport_iscsi/version" | ||||||
|  |   | ||||||
|  |  #endif | ||||||
|  | -- 
 | ||||||
|  | 2.14.4 | ||||||
|  | 
 | ||||||
| @ -0,0 +1,32 @@ | |||||||
|  | From 1aa35262d566d829d711bc746f944dee5c2d9e7a Mon Sep 17 00:00:00 2001 | ||||||
|  | From: rpm-build <rpm-build> | ||||||
|  | Date: Tue, 28 Feb 2017 09:00:41 -0800 | ||||||
|  | Subject: [PATCH 21/32] libiscsi: fix discovery request timeout regression | ||||||
|  | 
 | ||||||
|  | ---
 | ||||||
|  |  libiscsi/libiscsi.c | 2 ++ | ||||||
|  |  1 file changed, 2 insertions(+) | ||||||
|  | 
 | ||||||
|  | diff --git a/libiscsi/libiscsi.c b/libiscsi/libiscsi.c
 | ||||||
|  | index 755c18ca8e3b..bb17dfcafded 100644
 | ||||||
|  | --- a/libiscsi/libiscsi.c
 | ||||||
|  | +++ b/libiscsi/libiscsi.c
 | ||||||
|  | @@ -136,6 +136,7 @@ int libiscsi_discover_sendtargets(struct libiscsi_context *context,
 | ||||||
|  |   | ||||||
|  |  	/* Fill the drec struct with all needed info */ | ||||||
|  |  	memset(&drec, 0, sizeof drec); | ||||||
|  | +	drec.iscsid_req_tmo = -1;
 | ||||||
|  |  	idbm_sendtargets_defaults(&drec.u.sendtargets); | ||||||
|  |  	drec.type = DISCOVERY_TYPE_SENDTARGETS; | ||||||
|  |  	strlcpy(drec.address, address, sizeof(drec.address)); | ||||||
|  | @@ -228,6 +229,7 @@ int libiscsi_discover_firmware(struct libiscsi_context *context,
 | ||||||
|  |  	CHECK(iface_create_ifaces_from_boot_contexts(&ifaces, &targets)); | ||||||
|  |   | ||||||
|  |  	memset(&drec, 0, sizeof(drec)); | ||||||
|  | +	drec.iscsid_req_tmo = -1;
 | ||||||
|  |  	drec.type = DISCOVERY_TYPE_FW; | ||||||
|  |  	rc = idbm_bind_ifaces_to_nodes(discovery_fw, &drec, &ifaces, &rec_list); | ||||||
|  |  	if (rc) { | ||||||
|  | -- 
 | ||||||
|  | 2.14.4 | ||||||
|  | 
 | ||||||
							
								
								
									
										35
									
								
								SOURCES/0022-libiscsi-format-security-build-errors.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										35
									
								
								SOURCES/0022-libiscsi-format-security-build-errors.patch
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,35 @@ | |||||||
|  | From 1b2b6b683bd7ca3a7030889daf8c326dda797319 Mon Sep 17 00:00:00 2001 | ||||||
|  | From: rpm-build <rpm-build> | ||||||
|  | Date: Tue, 28 Feb 2017 10:06:42 -0800 | ||||||
|  | Subject: [PATCH 22/32] libiscsi format-security build errors | ||||||
|  | 
 | ||||||
|  | ---
 | ||||||
|  |  libiscsi/libiscsi.c | 5 +++-- | ||||||
|  |  1 file changed, 3 insertions(+), 2 deletions(-) | ||||||
|  | 
 | ||||||
|  | diff --git a/libiscsi/libiscsi.c b/libiscsi/libiscsi.c
 | ||||||
|  | index bb17dfcafded..7003388e3346 100644
 | ||||||
|  | --- a/libiscsi/libiscsi.c
 | ||||||
|  | +++ b/libiscsi/libiscsi.c
 | ||||||
|  | @@ -177,7 +177,8 @@ int libiscsi_discover_sendtargets(struct libiscsi_context *context,
 | ||||||
|  |  		*found_nodes = calloc(found, sizeof **found_nodes); | ||||||
|  |  		if (*found_nodes == NULL) { | ||||||
|  |  			snprintf(context->error_str, | ||||||
|  | -				 sizeof(context->error_str), strerror(ENOMEM));
 | ||||||
|  | +				 sizeof(context->error_str),
 | ||||||
|  | +				 "%s", strerror(ENOMEM));
 | ||||||
|  |  			rc = ENOMEM; | ||||||
|  |  			goto leave; | ||||||
|  |  		} | ||||||
|  | @@ -634,7 +635,7 @@ static int get_parameter_helper(void *data, node_rec_t *rec)
 | ||||||
|  |  	info = idbm_recinfo_alloc(MAX_KEYS); | ||||||
|  |  	if (!info) { | ||||||
|  |  		snprintf(context->error_str, sizeof(context->error_str), | ||||||
|  | -			 strerror(ENOMEM));
 | ||||||
|  | +			 "%s", strerror(ENOMEM));
 | ||||||
|  |  		return ENOMEM; | ||||||
|  |  	} | ||||||
|  |   | ||||||
|  | -- 
 | ||||||
|  | 2.14.4 | ||||||
|  | 
 | ||||||
							
								
								
									
										36
									
								
								SOURCES/0023-libiscsi-fix-build-to-use-libopeniscsiusr.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										36
									
								
								SOURCES/0023-libiscsi-fix-build-to-use-libopeniscsiusr.patch
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,36 @@ | |||||||
|  | From b0d26441cebf6f1d78a2b4523ee9c348578b3d91 Mon Sep 17 00:00:00 2001 | ||||||
|  | From: rpm-build <rpm-build> | ||||||
|  | Date: Thu, 24 May 2018 15:17:05 -0700 | ||||||
|  | Subject: [PATCH 23/32] libiscsi fix build to use libopeniscsiusr | ||||||
|  | 
 | ||||||
|  | ---
 | ||||||
|  |  libiscsi/Makefile | 6 ++++-- | ||||||
|  |  1 file changed, 4 insertions(+), 2 deletions(-) | ||||||
|  | 
 | ||||||
|  | diff --git a/libiscsi/Makefile b/libiscsi/Makefile
 | ||||||
|  | index 317a7ec4db30..1196bb5c0cf4 100644
 | ||||||
|  | --- a/libiscsi/Makefile
 | ||||||
|  | +++ b/libiscsi/Makefile
 | ||||||
|  | @@ -4,7 +4,9 @@ OSNAME=$(shell uname -s)
 | ||||||
|  |  OPTFLAGS ?= -O2 -g | ||||||
|  |  WARNFLAGS ?= -Wall -Wstrict-prototypes | ||||||
|  |  CFLAGS = $(OPTFLAGS) $(WARNFLAGS) -I../include -I../usr \ | ||||||
|  | -		-D$(OSNAME) -fPIC -D_GNU_SOURCE -fvisibility=hidden
 | ||||||
|  | +		-D$(OSNAME) -fPIC -D_GNU_SOURCE -fvisibility=hidden \
 | ||||||
|  | +		-I../libopeniscsiusr
 | ||||||
|  | +LDFLAGS = -L../libopeniscsiusr -lopeniscsiusr
 | ||||||
|  |  LIB = libiscsi.so.0 | ||||||
|  |  TESTS = tests/test_discovery_sendtargets tests/test_discovery_firmware | ||||||
|  |  TESTS += tests/test_login tests/test_logout tests/test_params | ||||||
|  | @@ -19,7 +21,7 @@ FW_PARAM_SRCS = fw_entry.o prom_lex.o prom_parse.tab.o fwparam_ppc.o fwparam_sys
 | ||||||
|  |  # sources shared with the userspace utils, note we build these separately | ||||||
|  |  # to get PIC versions. | ||||||
|  |  COMMON_OBJS = $(patsubst %.o, common-objs/%.o, $(COMMON_SRCS)) | ||||||
|  | -USR_OBJS = $(patsubst %.o, usr-objs/%.o, $(ISCSI_LIB_SRCS) strings.o)
 | ||||||
|  | +USR_OBJS = $(patsubst %.o, usr-objs/%.o, $(ISCSI_LIB_SRCS) local_strings.o)
 | ||||||
|  |  FW_OBJS = $(patsubst %.o, fw-objs/%.o, $(FW_PARAM_SRCS)) | ||||||
|  |   | ||||||
|  |  # Flags for the tests | ||||||
|  | -- 
 | ||||||
|  | 2.14.4 | ||||||
|  | 
 | ||||||
							
								
								
									
										25
									
								
								SOURCES/0024-dont-install-scripts.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										25
									
								
								SOURCES/0024-dont-install-scripts.patch
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,25 @@ | |||||||
|  | From 09485b397990aca06d5e98a855bab2444c9ec572 Mon Sep 17 00:00:00 2001 | ||||||
|  | From: rpm-build <rpm-build> | ||||||
|  | Date: Fri, 25 May 2018 09:39:07 -0700 | ||||||
|  | Subject: [PATCH 24/32] dont install scripts | ||||||
|  | 
 | ||||||
|  | ---
 | ||||||
|  |  Makefile | 2 +- | ||||||
|  |  1 file changed, 1 insertion(+), 1 deletion(-) | ||||||
|  | 
 | ||||||
|  | diff --git a/Makefile b/Makefile
 | ||||||
|  | index 80afe86d6558..a35082daa9f9 100644
 | ||||||
|  | --- a/Makefile
 | ||||||
|  | +++ b/Makefile
 | ||||||
|  | @@ -99,7 +99,7 @@ install_udev_rules:
 | ||||||
|  |  	$(INSTALL) -d $(DESTDIR)$(rulesdir) | ||||||
|  |  	$(INSTALL) -m 644 $(RULESFILES) $(DESTDIR)/$(rulesdir) | ||||||
|  |   | ||||||
|  | -install_programs:  $(PROGRAMS) $(SCRIPTS)
 | ||||||
|  | +install_programs:  $(PROGRAMS) # $(SCRIPTS)
 | ||||||
|  |  	$(INSTALL) -d $(DESTDIR)$(sbindir) | ||||||
|  |  	$(INSTALL) -m 755 $^ $(DESTDIR)$(sbindir) | ||||||
|  |   | ||||||
|  | -- 
 | ||||||
|  | 2.14.4 | ||||||
|  | 
 | ||||||
							
								
								
									
										109
									
								
								SOURCES/0028-use-var-lib-iscsi-in-libopeniscsiusr.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										109
									
								
								SOURCES/0028-use-var-lib-iscsi-in-libopeniscsiusr.patch
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,109 @@ | |||||||
|  | From 089cd6910d9f0d1e459e1d8d00b754843437526d Mon Sep 17 00:00:00 2001 | ||||||
|  | From: rpm-build <rpm-build> | ||||||
|  | Date: Wed, 30 May 2018 16:08:30 -0700 | ||||||
|  | Subject: [PATCH 28/28] use /var/lib/iscsi in libopeniscsiusr | ||||||
|  | 
 | ||||||
|  | ---
 | ||||||
|  |  libopeniscsiusr/idbm.h                                  | 3 ++- | ||||||
|  |  libopeniscsiusr/iface.c                                 | 2 +- | ||||||
|  |  libopeniscsiusr/libopeniscsiusr/libopeniscsiusr.h       | 8 ++++---- | ||||||
|  |  libopeniscsiusr/libopeniscsiusr/libopeniscsiusr_iface.h | 2 +- | ||||||
|  |  libopeniscsiusr/node.h                                  | 2 +- | ||||||
|  |  5 files changed, 9 insertions(+), 8 deletions(-) | ||||||
|  | 
 | ||||||
|  | diff --git a/libopeniscsiusr/idbm.h b/libopeniscsiusr/idbm.h
 | ||||||
|  | index 3fd0864a797d..c84d332ff949 100644
 | ||||||
|  | --- a/libopeniscsiusr/idbm.h
 | ||||||
|  | +++ b/libopeniscsiusr/idbm.h
 | ||||||
|  | @@ -31,7 +31,8 @@
 | ||||||
|  |  #include "libopeniscsiusr/libopeniscsiusr_common.h" | ||||||
|  |   | ||||||
|  |  #define ISCSI_CONFIG_ROOT	"/etc/iscsi/" | ||||||
|  | -#define IFACE_CONFIG_DIR	ISCSI_CONFIG_ROOT"ifaces"
 | ||||||
|  | +#define ISCSI_VAR_LIB		"/var/lib/iscsi/"
 | ||||||
|  | +#define IFACE_CONFIG_DIR	ISCSI_VAR_LIB"ifaces"
 | ||||||
|  |  #define AUTH_STR_MAX_LEN	256 | ||||||
|  |  #define BOOT_NAME_MAXLEN	256 | ||||||
|  |  #define IDBM_DUMP_SIZE		8192 | ||||||
|  | diff --git a/libopeniscsiusr/iface.c b/libopeniscsiusr/iface.c
 | ||||||
|  | index e2355bc0fff0..cd9dd7326ae6 100644
 | ||||||
|  | --- a/libopeniscsiusr/iface.c
 | ||||||
|  | +++ b/libopeniscsiusr/iface.c
 | ||||||
|  | @@ -383,7 +383,7 @@ int iscsi_default_iface_setup(struct iscsi_context *ctx)
 | ||||||
|  |   | ||||||
|  |  	_good(_iscsi_hids_get(ctx, &hids, &hid_count), rc, out); | ||||||
|  |  	for (i = 0; i < hid_count; ++i) { | ||||||
|  | -		/* Create /etc/iscsi/ifaces/<iface_name> file if not found
 | ||||||
|  | +		/* Create /var/lib/iscsi/ifaces/<iface_name> file if not found
 | ||||||
|  |  		 */ | ||||||
|  |  		_good(_iscsi_ifaces_get_from_sysfs(ctx, hids[i], &ifaces, &iface_count), | ||||||
|  |  			rc, out); | ||||||
|  | diff --git a/libopeniscsiusr/libopeniscsiusr/libopeniscsiusr.h b/libopeniscsiusr/libopeniscsiusr/libopeniscsiusr.h
 | ||||||
|  | index 439590249212..81582da9e1e6 100644
 | ||||||
|  | --- a/libopeniscsiusr/libopeniscsiusr/libopeniscsiusr.h
 | ||||||
|  | +++ b/libopeniscsiusr/libopeniscsiusr/libopeniscsiusr.h
 | ||||||
|  | @@ -339,7 +339,7 @@ __DLL_EXPORT void iscsi_session_free(struct iscsi_session *se);
 | ||||||
|  |   *	* bnx2i | ||||||
|  |   * | ||||||
|  |   * It will also create configuration files for iSCSI hardware offload cards in | ||||||
|  | - * /etc/iscsi/ifaces/<iface_name>.
 | ||||||
|  | + * /var/lib/iscsi/ifaces/<iface_name>.
 | ||||||
|  |   * | ||||||
|  |   * @ctx: | ||||||
|  |   *	Pointer of 'struct iscsi_context'. | ||||||
|  | @@ -369,7 +369,7 @@ __DLL_EXPORT int iscsi_default_iface_setup(struct iscsi_context *ctx);
 | ||||||
|  |   * Retrieves all iSCSI interfaces. For the properties of 'struct iscsi_iface', | ||||||
|  |   * please refer to the functions defined in 'libopeniscsiusr_iface.h' file. | ||||||
|  |   * The returned results contains default iSCSI interfaces(iser and iscsi_tcp) | ||||||
|  | - * and iSCSI interfaces configured in "/etc/iscsi/ifaces/".
 | ||||||
|  | + * and iSCSI interfaces configured in "/var/lib/iscsi/ifaces/".
 | ||||||
|  |   * Illegal configuration file will be skipped and warned. | ||||||
|  |   * To generate iSCSI interface configuration when new card installed, please | ||||||
|  |   * use iscsi_default_iface_setup(). | ||||||
|  | @@ -427,7 +427,7 @@ __DLL_EXPORT void iscsi_ifaces_free(struct iscsi_iface **ifaces,
 | ||||||
|  |   * iscsi_iface_get() - Retrieve specified iSCSI interface. | ||||||
|  |   * | ||||||
|  |   * Retrieves specified iSCSI interfaces by reading configuration from | ||||||
|  | - * "/etc/iscsi/iface/<iface_name>".
 | ||||||
|  | + * "/var/lib/iscsi/iface/<iface_name>".
 | ||||||
|  |   * To generate iSCSI interface configuration when new card installed, please | ||||||
|  |   * use iscsi_default_iface_setup(). | ||||||
|  |   * Illegal configuration file will be treated as error LIBISCSI_ERR_IDBM. | ||||||
|  | @@ -438,7 +438,7 @@ __DLL_EXPORT void iscsi_ifaces_free(struct iscsi_iface **ifaces,
 | ||||||
|  |   *	If this pointer is NULL, your program will be terminated by assert. | ||||||
|  |   * @iface_name: | ||||||
|  |   *	String. Name of iSCSI interface. Also the file name of configuration | ||||||
|  | - *	file "/etc/iscsi/iface/<iface_name>".
 | ||||||
|  | + *	file "/var/lib/iscsi/iface/<iface_name>".
 | ||||||
|  |   *	If this pointer is NULL or empty string, your program will be terminated | ||||||
|  |   *	by assert. | ||||||
|  |   * @iface: | ||||||
|  | diff --git a/libopeniscsiusr/libopeniscsiusr/libopeniscsiusr_iface.h b/libopeniscsiusr/libopeniscsiusr/libopeniscsiusr_iface.h
 | ||||||
|  | index a1a255246d20..95b01602fb37 100644
 | ||||||
|  | --- a/libopeniscsiusr/libopeniscsiusr/libopeniscsiusr_iface.h
 | ||||||
|  | +++ b/libopeniscsiusr/libopeniscsiusr/libopeniscsiusr_iface.h
 | ||||||
|  | @@ -182,7 +182,7 @@ __DLL_EXPORT const char *iscsi_iface_name_get(struct iscsi_iface *iface);
 | ||||||
|  |   * | ||||||
|  |   * Dump all configurations of specified iSCSI interface. Will skip empty | ||||||
|  |   * configuration so that output string could be saved directly to | ||||||
|  | - * /etc/iscsi/ifaces/<iface_name> file.
 | ||||||
|  | + * /var/lib/iscsi/ifaces/<iface_name> file.
 | ||||||
|  |   * | ||||||
|  |   * @iface: | ||||||
|  |   *	Pointer of 'struct iscsi_iface'. | ||||||
|  | diff --git a/libopeniscsiusr/node.h b/libopeniscsiusr/node.h
 | ||||||
|  | index 39e07b3befae..9eba7fa6077c 100644
 | ||||||
|  | --- a/libopeniscsiusr/node.h
 | ||||||
|  | +++ b/libopeniscsiusr/node.h
 | ||||||
|  | @@ -44,7 +44,7 @@ struct iscsi_node {
 | ||||||
|  |  	char					portal[NI_MAXHOST * 2]; | ||||||
|  |  }; | ||||||
|  |   | ||||||
|  | -#define NODE_CONFIG_DIR		ISCSI_CONFIG_ROOT"nodes"
 | ||||||
|  | +#define NODE_CONFIG_DIR		ISCSI_VAR_LIB"nodes"
 | ||||||
|  |   | ||||||
|  |  /* Might be public in the future */ | ||||||
|  |  __DLL_LOCAL void iscsi_node_free(struct iscsi_node *node); | ||||||
|  | -- 
 | ||||||
|  | 2.14.4 | ||||||
|  | 
 | ||||||
							
								
								
									
										7
									
								
								SOURCES/04-iscsi
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										7
									
								
								SOURCES/04-iscsi
									
									
									
									
									
										Executable file
									
								
							| @ -0,0 +1,7 @@ | |||||||
|  | #!/bin/sh | ||||||
|  | 
 | ||||||
|  | case "$2" in | ||||||
|  | 	up|vpn-up) | ||||||
|  | 		/bin/systemctl --no-block reload iscsi.service || : | ||||||
|  | 		;; | ||||||
|  | esac | ||||||
							
								
								
									
										2
									
								
								SOURCES/iscsi-tmpfiles.conf
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										2
									
								
								SOURCES/iscsi-tmpfiles.conf
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,2 @@ | |||||||
|  | d /run/lock/iscsi 0700 root root - | ||||||
|  | f /run/lock/iscsi/lock 0600 root root - | ||||||
							
								
								
									
										584
									
								
								SPECS/iscsi-initiator-utils.spec
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										584
									
								
								SPECS/iscsi-initiator-utils.spec
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,584 @@ | |||||||
|  | %global open_iscsi_version	2.0 | ||||||
|  | %global open_iscsi_build	877 | ||||||
|  | %global commit0			f71581bd641dc26d330cb8b97e5ec272dd08f811 | ||||||
|  | %global shortcommit0		%(c=%{commit0}; echo ${c:0:7}) | ||||||
|  | 
 | ||||||
|  | %if 0%{?rhel} > 7 | ||||||
|  | # Disable python2 build by default | ||||||
|  | %bcond_with python2 | ||||||
|  | %else | ||||||
|  | %bcond_without python2 | ||||||
|  | %endif | ||||||
|  | 
 | ||||||
|  | Summary: iSCSI daemon and utility programs | ||||||
|  | Name: iscsi-initiator-utils | ||||||
|  | Version: 6.%{open_iscsi_version}.%{open_iscsi_build} | ||||||
|  | Release: 1.git%{shortcommit0}%{?dist} | ||||||
|  | Group: System Environment/Daemons | ||||||
|  | License: GPLv2+ | ||||||
|  | URL: http://www.open-iscsi.org | ||||||
|  | Source0: https://github.com/open-iscsi/open-iscsi/archive/%{commit0}.tar.gz#/open-iscsi-%{shortcommit0}.tar.gz | ||||||
|  | Source4: 04-iscsi | ||||||
|  | Source5: iscsi-tmpfiles.conf | ||||||
|  | 
 | ||||||
|  | Patch0001: 0001-service-file-tweaks.patch | ||||||
|  | Patch0002: 0001-fix-iscsiuio-build-with-libsystemd.patch | ||||||
|  | Patch0003: 0001-idmb_rec_write-check-for-tpgt-first.patch | ||||||
|  | Patch0004: 0002-idbm_rec_write-seperate-old-and-new-style-writes.patch | ||||||
|  | Patch0005: 0003-idbw_rec_write-pick-tpgt-from-existing-record.patch | ||||||
|  | Patch0006: 0006-update-initscripts-and-docs.patch | ||||||
|  | Patch0007: 0007-use-var-for-config.patch | ||||||
|  | Patch0008: 0008-use-red-hat-for-name.patch | ||||||
|  | Patch0009: 0009-libiscsi.patch | ||||||
|  | Patch0010: 0010-remove-the-offload-boot-supported-ifdef.patch | ||||||
|  | Patch0011: 0013-Revert-iscsiadm-return-error-when-login-fails.patch | ||||||
|  | Patch0012: 0018-Add-macros-to-release-GIL-lock.patch | ||||||
|  | Patch0013: 0019-libiscsi-introduce-sessions-API.patch | ||||||
|  | Patch0014: 0020-use-Red-Hat-version-string-to-match-RPM-package-vers.patch | ||||||
|  | Patch0015: 0021-libiscsi-fix-discovery-request-timeout-regression.patch | ||||||
|  | Patch0016: 0022-libiscsi-format-security-build-errors.patch | ||||||
|  | Patch0017: 0023-libiscsi-fix-build-to-use-libopeniscsiusr.patch | ||||||
|  | Patch0018: 0024-dont-install-scripts.patch | ||||||
|  | Patch0019: 0028-use-var-lib-iscsi-in-libopeniscsiusr.patch | ||||||
|  | Patch0099: 0001-Coverity-scan-fixes.patch | ||||||
|  | 
 | ||||||
|  | BuildRequires: flex bison doxygen kmod-devel systemd-units | ||||||
|  | BuildRequires: autoconf automake libtool libmount-devel openssl-devel | ||||||
|  | BuildRequires: isns-utils-devel | ||||||
|  | BuildRequires: systemd-devel | ||||||
|  | # For dir ownership | ||||||
|  | Requires: %{name}-iscsiuio >= %{version}-%{release} | ||||||
|  | Requires(post): systemd | ||||||
|  | Requires(preun): systemd | ||||||
|  | Requires(postun): systemd | ||||||
|  | 
 | ||||||
|  | %global _hardened_build 1 | ||||||
|  | %global __provides_exclude_from ^(%{python2_sitearch}/.*\\.so|%{python3_sitearch}/.*\\.so)$ | ||||||
|  | 
 | ||||||
|  | %description | ||||||
|  | The iscsi package provides the server daemon for the iSCSI protocol, | ||||||
|  | as well as the utility programs used to manage it. iSCSI is a protocol | ||||||
|  | for distributed disk access using SCSI commands sent over Internet | ||||||
|  | Protocol networks. | ||||||
|  | 
 | ||||||
|  | # I don't think we're ready to expose these just yet | ||||||
|  | # For now just add the needed library to the base package | ||||||
|  | 
 | ||||||
|  | #%package -n libopeniscsiusr | ||||||
|  | #Summary: library providing access to Open-iSCSI initiator functionality | ||||||
|  | #Group: Development/Libraries | ||||||
|  | #License: BSD | ||||||
|  | 
 | ||||||
|  | #%description -n libopeniscsiusr | ||||||
|  | #The libopeniscsiusr library provides a C API for access to the Open-iSCSI | ||||||
|  | #initiator. It is used by the Open-iSCSI command line tools. | ||||||
|  | 
 | ||||||
|  | #%package -n libopeniscsiusr-devel | ||||||
|  | #Summary: Development files for libopeniscsiusr | ||||||
|  | #Group: Development/Libraries | ||||||
|  | #Requires: libopeniscsiusr = %{version}-%{release} | ||||||
|  | 
 | ||||||
|  | #%description -n libopeniscsiusr-devel | ||||||
|  | #The libopeniscsiusr-devel package contains libraries and header files for | ||||||
|  | #developing applications that use libopeniscsiusr. | ||||||
|  | 
 | ||||||
|  | %package iscsiuio | ||||||
|  | Summary: Userspace configuration daemon required for some iSCSI hardware | ||||||
|  | Group: System Environment/Daemons | ||||||
|  | License: BSD | ||||||
|  | Requires: %{name} = %{version}-%{release} | ||||||
|  | 
 | ||||||
|  | %description iscsiuio | ||||||
|  | The iscsiuio configuration daemon provides network configuration help | ||||||
|  | for some iSCSI offload hardware. | ||||||
|  | 
 | ||||||
|  | %package devel | ||||||
|  | Summary: Development files for %{name} | ||||||
|  | Group: Development/Libraries | ||||||
|  | Requires: %{name} = %{version}-%{release} | ||||||
|  | 
 | ||||||
|  | %description devel | ||||||
|  | The %{name}-devel package contains libraries and header files for | ||||||
|  | developing applications that use %{name}. | ||||||
|  | 
 | ||||||
|  | %if %{with python2} | ||||||
|  | %package -n python2-%{name} | ||||||
|  | %{?python_provide:%python_provide python2-%{name}} | ||||||
|  | Summary: Python %{python2_version} bindings to %{name} | ||||||
|  | Group: Development/Libraries | ||||||
|  | 
 | ||||||
|  | BuildRequires: python2-devel | ||||||
|  | BuildRequires: python2-setuptools | ||||||
|  | 
 | ||||||
|  | %description -n python2-%{name} | ||||||
|  | The %{name}-python2 package contains Python %{python2_version} bindings to the | ||||||
|  | libiscsi interface for interacting with %{name} | ||||||
|  | %endif # with python2 | ||||||
|  | 
 | ||||||
|  | %package -n python3-%{name} | ||||||
|  | %{?python_provide:%python_provide python3-%{name}} | ||||||
|  | Summary: Python %{python3_version} bindings to %{name} | ||||||
|  | Group: Development/Libraries | ||||||
|  | 
 | ||||||
|  | BuildRequires: python3-devel | ||||||
|  | BuildRequires: python3-setuptools | ||||||
|  | 
 | ||||||
|  | %description -n python3-%{name} | ||||||
|  | The %{name}-python3 package contains Python %{python3_version} bindings to the | ||||||
|  | libiscsi interface for interacting with %{name} | ||||||
|  | 
 | ||||||
|  | %prep | ||||||
|  | %autosetup -p1 -n open-iscsi-%{commit0} | ||||||
|  | 
 | ||||||
|  | # change exec_prefix, there's no easy way to override | ||||||
|  | %{__sed} -i -e 's|^exec_prefix = /$|exec_prefix = %{_exec_prefix}|' Makefile | ||||||
|  | 
 | ||||||
|  | %build | ||||||
|  | 
 | ||||||
|  | # configure sub-packages from here | ||||||
|  | # letting the top level Makefile do it will lose setting from rpm | ||||||
|  | cd iscsiuio | ||||||
|  | autoreconf --install | ||||||
|  | %{configure} | ||||||
|  | cd .. | ||||||
|  | 
 | ||||||
|  | %{__make} OPTFLAGS="%{optflags} %{?__global_ldflags} -DUSE_KMOD -lkmod" | ||||||
|  | pushd libiscsi | ||||||
|  | %if %{with python2} | ||||||
|  | %py2_build | ||||||
|  | %endif # with python2 | ||||||
|  | %py3_build | ||||||
|  | touch -r libiscsi.doxy html/* | ||||||
|  | popd | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | %install | ||||||
|  | %{__make} DESTDIR=%{?buildroot} install_programs install_doc install_etc install_libopeniscsiusr | ||||||
|  | # upstream makefile doesn't get everything the way we like it | ||||||
|  | #rm $RPM_BUILD_ROOT%{_sbindir}/iscsi_discovery | ||||||
|  | rm $RPM_BUILD_ROOT%{_mandir}/man8/iscsi_discovery.8 | ||||||
|  | rm $RPM_BUILD_ROOT%{_mandir}/man8/iscsi_fw_login.8 | ||||||
|  | %{__install} -pm 755 usr/iscsistart $RPM_BUILD_ROOT%{_sbindir} | ||||||
|  | %{__install} -pm 644 doc/iscsistart.8 $RPM_BUILD_ROOT%{_mandir}/man8 | ||||||
|  | %{__install} -pm 644 doc/iscsi-iname.8 $RPM_BUILD_ROOT%{_mandir}/man8 | ||||||
|  | %{__install} -d $RPM_BUILD_ROOT%{_sysconfdir}/logrotate.d | ||||||
|  | %{__install} -pm 644 iscsiuio/iscsiuiolog $RPM_BUILD_ROOT%{_sysconfdir}/logrotate.d | ||||||
|  | 
 | ||||||
|  | %{__install} -d $RPM_BUILD_ROOT%{_sharedstatedir}/iscsi | ||||||
|  | %{__install} -d $RPM_BUILD_ROOT%{_sharedstatedir}/iscsi/nodes | ||||||
|  | %{__install} -d $RPM_BUILD_ROOT%{_sharedstatedir}/iscsi/send_targets | ||||||
|  | %{__install} -d $RPM_BUILD_ROOT%{_sharedstatedir}/iscsi/static | ||||||
|  | %{__install} -d $RPM_BUILD_ROOT%{_sharedstatedir}/iscsi/isns | ||||||
|  | %{__install} -d $RPM_BUILD_ROOT%{_sharedstatedir}/iscsi/slp | ||||||
|  | %{__install} -d $RPM_BUILD_ROOT%{_sharedstatedir}/iscsi/ifaces | ||||||
|  | 
 | ||||||
|  | # for %%ghost | ||||||
|  | %{__install} -d $RPM_BUILD_ROOT/var/lock/iscsi | ||||||
|  | touch $RPM_BUILD_ROOT/var/lock/iscsi/lock | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | %{__install} -d $RPM_BUILD_ROOT%{_unitdir} | ||||||
|  | %{__install} -pm 644 etc/systemd/iscsi.service $RPM_BUILD_ROOT%{_unitdir} | ||||||
|  | %{__install} -pm 644 etc/systemd/iscsi-shutdown.service $RPM_BUILD_ROOT%{_unitdir} | ||||||
|  | %{__install} -pm 644 etc/systemd/iscsid.service $RPM_BUILD_ROOT%{_unitdir} | ||||||
|  | %{__install} -pm 644 etc/systemd/iscsid.socket $RPM_BUILD_ROOT%{_unitdir} | ||||||
|  | %{__install} -pm 644 etc/systemd/iscsiuio.service $RPM_BUILD_ROOT%{_unitdir} | ||||||
|  | %{__install} -pm 644 etc/systemd/iscsiuio.socket $RPM_BUILD_ROOT%{_unitdir} | ||||||
|  | 
 | ||||||
|  | %{__install} -d $RPM_BUILD_ROOT%{_libexecdir} | ||||||
|  | %{__install} -pm 755 etc/systemd/iscsi-mark-root-nodes $RPM_BUILD_ROOT%{_libexecdir} | ||||||
|  | 
 | ||||||
|  | %{__install} -d $RPM_BUILD_ROOT%{_sysconfdir}/NetworkManager/dispatcher.d | ||||||
|  | %{__install} -pm 755 %{SOURCE4} $RPM_BUILD_ROOT%{_sysconfdir}/NetworkManager/dispatcher.d | ||||||
|  | 
 | ||||||
|  | %{__install} -d $RPM_BUILD_ROOT%{_tmpfilesdir} | ||||||
|  | %{__install} -pm 644 %{SOURCE5} $RPM_BUILD_ROOT%{_tmpfilesdir}/iscsi.conf | ||||||
|  | 
 | ||||||
|  | %{__install} -d $RPM_BUILD_ROOT%{_libdir} | ||||||
|  | %{__install} -pm 755 libiscsi/libiscsi.so.0 $RPM_BUILD_ROOT%{_libdir} | ||||||
|  | %{__ln_s}    libiscsi.so.0 $RPM_BUILD_ROOT%{_libdir}/libiscsi.so | ||||||
|  | %{__install} -d $RPM_BUILD_ROOT%{_includedir} | ||||||
|  | %{__install} -pm 644 libiscsi/libiscsi.h $RPM_BUILD_ROOT%{_includedir} | ||||||
|  | 
 | ||||||
|  | %if %{with python2} | ||||||
|  | %{__install} -d $RPM_BUILD_ROOT%{python2_sitearch} | ||||||
|  | %endif # with python2 | ||||||
|  | %{__install} -d $RPM_BUILD_ROOT%{python3_sitearch} | ||||||
|  | pushd libiscsi | ||||||
|  | %if %{with python2} | ||||||
|  | %py2_install | ||||||
|  | %endif # with python2 | ||||||
|  | %py3_install | ||||||
|  | popd | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | %post | ||||||
|  | /sbin/ldconfig | ||||||
|  | 
 | ||||||
|  | %systemd_post iscsi.service iscsi-shutdown.service iscsid.service iscsid.socket | ||||||
|  | 
 | ||||||
|  | if [ $1 -eq 1 ]; then | ||||||
|  | 	if [ ! -f %{_sysconfdir}/iscsi/initiatorname.iscsi ]; then | ||||||
|  | 		echo "InitiatorName=`/usr/sbin/iscsi-iname`" > %{_sysconfdir}/iscsi/initiatorname.iscsi | ||||||
|  | 	fi | ||||||
|  | 	# enable socket activation and persistant session startup by default | ||||||
|  | 	/bin/systemctl enable iscsi.service >/dev/null 2>&1 || : | ||||||
|  | 	/bin/systemctl enable iscsid.socket >/dev/null 2>&1 || : | ||||||
|  | fi | ||||||
|  | 
 | ||||||
|  | %post iscsiuio | ||||||
|  | %systemd_post iscsiuio.service iscsiuio.socket | ||||||
|  | 
 | ||||||
|  | if [ $1 -eq 1 ]; then | ||||||
|  | 	/bin/systemctl enable iscsiuio.socket >/dev/null 2>&1 || : | ||||||
|  | fi | ||||||
|  | 
 | ||||||
|  | %preun | ||||||
|  | %systemd_preun iscsi.service iscsi-shutdown.service iscsid.service iscsiuio.service iscsid.socket iscsiuio.socket | ||||||
|  | 
 | ||||||
|  | %preun iscsiuio | ||||||
|  | %systemd_preun iscsiuio.service iscsiuio.socket | ||||||
|  | 
 | ||||||
|  | %postun | ||||||
|  | /sbin/ldconfig | ||||||
|  | %systemd_postun | ||||||
|  | 
 | ||||||
|  | %postun iscsiuio | ||||||
|  | %systemd_postun | ||||||
|  | 
 | ||||||
|  | %triggerun -- iscsi-initiator-utils < 6.2.0.873-25 | ||||||
|  | # prior to 6.2.0.873-24 iscsi.service was missing a Wants=remote-fs-pre.target | ||||||
|  | # this forces remote-fs-pre.target active if needed for a clean shutdown/reboot | ||||||
|  | # after upgrading this package | ||||||
|  | if [ $1 -gt 0 ]; then | ||||||
|  |     /usr/bin/systemctl -q is-active iscsi.service | ||||||
|  |     if [ $? -eq 0 ]; then | ||||||
|  |         /usr/bin/systemctl -q is-active remote-fs-pre.target | ||||||
|  |         if [ $? -ne 0 ]; then | ||||||
|  |             SRC=`/usr/bin/systemctl show --property FragmentPath remote-fs-pre.target | cut -d= -f2` | ||||||
|  |             DST=/run/systemd/system/remote-fs-pre.target | ||||||
|  |             if [ $SRC != $DST ]; then | ||||||
|  |                 cp $SRC $DST | ||||||
|  |             fi | ||||||
|  |             sed -i 's/RefuseManualStart=yes/RefuseManualStart=no/' $DST | ||||||
|  |             /usr/bin/systemctl daemon-reload >/dev/null 2>&1 || : | ||||||
|  |             /usr/bin/systemctl start remote-fs-pre.target >/dev/null 2>&1 || : | ||||||
|  |         fi | ||||||
|  |     fi | ||||||
|  | fi | ||||||
|  | # added in 6.2.0.873-25 | ||||||
|  | if [ $1 -gt 0 ]; then | ||||||
|  |     systemctl start iscsi-shutdown.service >/dev/null 2>&1 || : | ||||||
|  | fi | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | %files | ||||||
|  | %doc README | ||||||
|  | %dir %{_sharedstatedir}/iscsi | ||||||
|  | %dir %{_sharedstatedir}/iscsi/nodes | ||||||
|  | %dir %{_sharedstatedir}/iscsi/isns | ||||||
|  | %dir %{_sharedstatedir}/iscsi/static | ||||||
|  | %dir %{_sharedstatedir}/iscsi/slp | ||||||
|  | %dir %{_sharedstatedir}/iscsi/ifaces | ||||||
|  | %dir %{_sharedstatedir}/iscsi/send_targets | ||||||
|  | %ghost %{_var}/lock/iscsi | ||||||
|  | %ghost %{_var}/lock/iscsi/lock | ||||||
|  | %{_unitdir}/iscsi.service | ||||||
|  | %{_unitdir}/iscsi-shutdown.service | ||||||
|  | %{_unitdir}/iscsid.service | ||||||
|  | %{_unitdir}/iscsid.socket | ||||||
|  | %{_libexecdir}/iscsi-mark-root-nodes | ||||||
|  | %{_sysconfdir}/NetworkManager/dispatcher.d/04-iscsi | ||||||
|  | %{_tmpfilesdir}/iscsi.conf | ||||||
|  | %dir %{_sysconfdir}/iscsi | ||||||
|  | %attr(0600,root,root) %config(noreplace) %{_sysconfdir}/iscsi/iscsid.conf | ||||||
|  | %{_sbindir}/iscsi-iname | ||||||
|  | %{_sbindir}/iscsiadm | ||||||
|  | %{_sbindir}/iscsid | ||||||
|  | %{_sbindir}/iscsistart | ||||||
|  | %{_libdir}/libiscsi.so.0 | ||||||
|  | %{_mandir}/man8/iscsi-iname.8.gz | ||||||
|  | %{_mandir}/man8/iscsiadm.8.gz | ||||||
|  | %{_mandir}/man8/iscsid.8.gz | ||||||
|  | %{_mandir}/man8/iscsistart.8.gz | ||||||
|  | # until we decide to setup libopeniscsiusr as a subpkg for real | ||||||
|  | %{_libdir}/libopeniscsiusr.so.* | ||||||
|  | %exclude %{_libdir}/libopeniscsiusr.so | ||||||
|  | %exclude %{_includedir}/libopeniscsiusr.h | ||||||
|  | %exclude %{_includedir}/libopeniscsiusr_common.h | ||||||
|  | %exclude %{_includedir}/libopeniscsiusr_iface.h | ||||||
|  | %exclude %{_includedir}/libopeniscsiusr_session.h | ||||||
|  | %exclude %{_libdir}/pkgconfig/libopeniscsiusr.pc | ||||||
|  | 
 | ||||||
|  | # %files -n libopeniscsiusr | ||||||
|  | # %{_libdir}/libopeniscsiusr.so.* | ||||||
|  | # | ||||||
|  | # %files -n libopeniscsiusr-devel | ||||||
|  | # %{_libdir}/libopeniscsiusr.so | ||||||
|  | # %{_includedir}/libopeniscsiusr.h | ||||||
|  | # %{_includedir}/libopeniscsiusr_common.h | ||||||
|  | # %{_includedir}/libopeniscsiusr_iface.h | ||||||
|  | # %{_includedir}/libopeniscsiusr_session.h | ||||||
|  | # %{_libdir}/pkgconfig/libopeniscsiusr.pc | ||||||
|  | 
 | ||||||
|  | %files iscsiuio | ||||||
|  | %{_sbindir}/iscsiuio | ||||||
|  | %{_unitdir}/iscsiuio.service | ||||||
|  | %{_unitdir}/iscsiuio.socket | ||||||
|  | %config(noreplace) %{_sysconfdir}/logrotate.d/iscsiuiolog | ||||||
|  | %{_mandir}/man8/iscsiuio.8.gz | ||||||
|  | 
 | ||||||
|  | %files devel | ||||||
|  | %doc libiscsi/html | ||||||
|  | %{_libdir}/libiscsi.so | ||||||
|  | %{_includedir}/libiscsi.h | ||||||
|  | 
 | ||||||
|  | %if %{with python2} | ||||||
|  | %files -n python2-%{name} | ||||||
|  | %{python2_sitearch}/* | ||||||
|  | %endif # with python2 | ||||||
|  | 
 | ||||||
|  | %files -n python3-%{name} | ||||||
|  | %{python3_sitearch}/* | ||||||
|  | 
 | ||||||
|  | %changelog | ||||||
|  | * Wed Jun 05 2019 Chris Leech <cleech@redhat.com> - 6.2.0.877-1.gitf71581b | ||||||
|  | - fix Covscan reported issues from upstream patches | ||||||
|  | 
 | ||||||
|  | * Tue Jun 04 2019 Chris Leech <cleech@redhat.com> - 6.2.0.877-0.gitf71581b | ||||||
|  | - 1665317 update to latest upstream for iscsiuio enhancements | ||||||
|  | 
 | ||||||
|  | * Thu Feb 21 2019 Chris Leech <cleech@redhat.com> - 6.2.0.876-7.gitf3c8e90 | ||||||
|  | - 1647826: fix sysfs and output format regressions in libopeniscsi code | ||||||
|  | 
 | ||||||
|  | * Thu Jan 03 2019 Chris Leech <cleech@redhat.com> - 6.2.0.876-6.gitf3c8e90 | ||||||
|  | - 1650402: fix missing space in node display output | ||||||
|  | 
 | ||||||
|  | * Tue Jul 10 2018 Chris Leech <cleech@redhat.com> - 6.2.0.876-5.gitf3c8e90 | ||||||
|  | - iscsiuio: add mutex to protect netlink buffer for pass-through xmit | ||||||
|  | - iscsid: get gateway information from sysfs when recovering sessions | ||||||
|  | - enabled MaxOustandingR2T negotiation during login | ||||||
|  | 
 | ||||||
|  | * Mon Jun 25 2018 Adam Williamson <awilliam@redhat.com> - 6.2.0.876-4.git4ef9261 | ||||||
|  | - Rebuilt for Python 3.7, again | ||||||
|  | 
 | ||||||
|  | * Mon Jun 25 2018 Adam Williamson <awilliam@redhat.com> - 6.2.0.876-3.git4ef9261 | ||||||
|  | - Link libiscsi against libopeniscsiusr (bz #1594946) (python 3.6 build) | ||||||
|  | 
 | ||||||
|  | * Wed Jun 20 2018 Miro Hrončok <mhroncok@redhat.com> - 6.2.0.876-2.git4ef9261 | ||||||
|  | - Rebuilt for Python 3.7 | ||||||
|  | 
 | ||||||
|  | * Tue Jun 19 2018 Chris Leech <cleech@redhat.com> - 6.2.0.876-1.git4ef9261 | ||||||
|  | - pull in post 2.0.876 tagged fixes from upstream git | ||||||
|  | - minimal packaging of libopeniscsiusr (internal use only, no dev package yet) | ||||||
|  | 
 | ||||||
|  | * Tue Jun 19 2018 Chris Leech <cleech@redhat.com> - 6.2.0.876-1.git24580ad | ||||||
|  | - rebase to upstream 2.0.876 | ||||||
|  | 
 | ||||||
|  | * Tue Jun 19 2018 Miro Hrončok <mhroncok@redhat.com> - 6.2.0.874-10.git86e8892 | ||||||
|  | - Rebuilt for Python 3.7 | ||||||
|  | 
 | ||||||
|  | * Mon May 28 2018 Charalampos Stratakis <cstratak@redhat.com> - 6.2.0.874-10.git86e8892 | ||||||
|  | - Conditionalize the python2 subpackage | ||||||
|  | 
 | ||||||
|  | * Wed Feb 07 2018 Fedora Release Engineering <releng@fedoraproject.org> - 6.2.0.874-9.git86e8892 | ||||||
|  | - Rebuilt for https://fedoraproject.org/wiki/Fedora_28_Mass_Rebuild | ||||||
|  | 
 | ||||||
|  | * Fri Jan 05 2018 Iryna Shcherbina <ishcherb@redhat.com> - 6.2.0.874-8.git86e8892 | ||||||
|  | - Update Python 2 dependency declarations to new packaging standards | ||||||
|  |   (See https://fedoraproject.org/wiki/FinalizingFedoraSwitchtoPython3) | ||||||
|  | 
 | ||||||
|  | * Sat Aug 19 2017 Zbigniew Jędrzejewski-Szmek <zbyszek@in.waw.pl> - 6.2.0.874-7.git86e8892 | ||||||
|  | - Python 2 binary package renamed to python2-iscsi-initiator-utils | ||||||
|  |   See https://fedoraproject.org/wiki/FinalizingFedoraSwitchtoPython3 | ||||||
|  | 
 | ||||||
|  | * Wed Aug 02 2017 Fedora Release Engineering <releng@fedoraproject.org> - 6.2.0.874-6.git86e8892 | ||||||
|  | - Rebuilt for https://fedoraproject.org/wiki/Fedora_27_Binutils_Mass_Rebuild | ||||||
|  | 
 | ||||||
|  | * Wed Jul 26 2017 Fedora Release Engineering <releng@fedoraproject.org> - 6.2.0.874-5.git86e8892 | ||||||
|  | - Rebuilt for https://fedoraproject.org/wiki/Fedora_27_Mass_Rebuild | ||||||
|  | 
 | ||||||
|  | * Wed Apr 12 2017 Chris Leech <cleech@redhat.com> - 6.2.0.874-4.git86e8892 | ||||||
|  | - rebuild to use shared libisns | ||||||
|  | 
 | ||||||
|  | * Tue Feb 28 2017 Chris Leech <cleech@redhat.com> - 6.2.0.874-3.git86e8892 | ||||||
|  | - libiscsi: fix discovery command timeout regression | ||||||
|  | - libiscsi: fix format security build errors | ||||||
|  | 
 | ||||||
|  | * Thu Feb 16 2017 Chris Leech <cleech@redhat.com> - 6.2.0.874-2.git86e8892 | ||||||
|  | - fix regression with iscsiadm discoverydb commands having a 0 timeout | ||||||
|  | 
 | ||||||
|  | * Thu Feb 09 2017 Chris Leech <cleech@redhat.com> - 6.2.0.874-1 | ||||||
|  | - update to 2.0.874 | ||||||
|  | 
 | ||||||
|  | * Mon Dec 12 2016 Charalampos Stratakis <cstratak@redhat.com> - 6.2.0.873-35.git4c1f2d9 | ||||||
|  | - Rebuild for Python 3.6 | ||||||
|  | 
 | ||||||
|  | * Tue Jul 19 2016 Fedora Release Engineering <rel-eng@lists.fedoraproject.org> - 6.2.0.873-34.git4c1f2d9 | ||||||
|  | - https://fedoraproject.org/wiki/Changes/Automatic_Provides_for_Python_RPM_Packages | ||||||
|  | 
 | ||||||
|  | * Fri Feb 19 2016 Chris Leech <cleech@redhat.com> - 6.2.0.873-33.git4c1f2d9 | ||||||
|  | - sync with upstream | ||||||
|  | - sysfs handling changes to speed up operations over large number of sessions | ||||||
|  | 
 | ||||||
|  | * Thu Feb 04 2016 Fedora Release Engineering <releng@fedoraproject.org> - 6.2.0.873-32.git4c9d6f9 | ||||||
|  | - Rebuilt for https://fedoraproject.org/wiki/Fedora_24_Mass_Rebuild | ||||||
|  | 
 | ||||||
|  | * Wed Feb  3 2016 Michael Schwendt <mschwendt@fedoraproject.org> - 6.2.0.873-31.git4c9d6f9 | ||||||
|  | - BuildRequires: isns-utils-static for -lisns (bz #1291913) | ||||||
|  | 
 | ||||||
|  | * Tue Nov 03 2015 Robert Kuska <rkuska@redhat.com> - 6.2.0.873-30.git4c9d6f9 | ||||||
|  | - Rebuilt for Python3.5 rebuild | ||||||
|  | 
 | ||||||
|  | * Tue Oct 06 2015 Chris Leech <cleech@redhat.com> - 6.2.0.873-29.git4c9d6f9 | ||||||
|  | - rebase with upstream, change Source0 url to github | ||||||
|  | - build with external isns-utils | ||||||
|  | 
 | ||||||
|  | * Mon Oct 05 2015 Chris Leech <cleech@redhat.com> - 6.2.0.873-28.git6aa2c9b | ||||||
|  | - fixed broken multiple trigger scripts, removed old pre-systemd migration triggers | ||||||
|  | - added libiscsi session API patch (bz #1262279) | ||||||
|  | 
 | ||||||
|  | * Wed Jun 17 2015 Fedora Release Engineering <rel-eng@lists.fedoraproject.org> - 6.2.0.873-27.git6aa2c9b | ||||||
|  | - Rebuilt for https://fedoraproject.org/wiki/Fedora_23_Mass_Rebuild | ||||||
|  | 
 | ||||||
|  | * Wed Jun 10 2015 Chris Leech <cleech@redhat.com> - 6.2.0.873-26.git6aa2c9b | ||||||
|  | - rebase to upstream snapshot | ||||||
|  | - add patch to improve GIL lock performance in libiscsi | ||||||
|  | - Split Python 2 and Python 3 bindings out into subpackages | ||||||
|  | 
 | ||||||
|  | * Wed Jan 28 2015 Chris Leech <cleech@redhat.com> - 6.2.0.873-25.gitc9d830b | ||||||
|  | - split out session logout on shutdown to a separate service | ||||||
|  | - 985321 roll up libiscsi patches, update python bindings to support python3 | ||||||
|  | - scriptlets were never split out properly for the iscsiuio subpackage | ||||||
|  | - fix regression in network interface binding | ||||||
|  | - created iscsi-shutdown.service to ensure that session cleanup happens | ||||||
|  | - Add --with-slp=no | ||||||
|  | - segfault from unexpected netlink event during discovery | ||||||
|  | - inhibit strict aliasing optimizations in iscsiuio, rpmdiff error | ||||||
|  | 
 | ||||||
|  | * Thu Oct 23 2014 Chris Leech <cleech@redhat.com> - 6.2.0.873-24.gitc9d830b | ||||||
|  | - sync with upstream v2.0.873-84-gc9d830b | ||||||
|  | - ignore iscsiadm return in iscsi.service | ||||||
|  | - make sure systemd order against remote mounts is correct | ||||||
|  | - add discovery as a valid mode in iscsiadm.8 | ||||||
|  | - make sure to pass --with-security=no to isns configure | ||||||
|  | 
 | ||||||
|  | * Sat Aug 16 2014 Fedora Release Engineering <rel-eng@lists.fedoraproject.org> - 6.2.0.873-23 | ||||||
|  | - Rebuilt for https://fedoraproject.org/wiki/Fedora_21_22_Mass_Rebuild | ||||||
|  | 
 | ||||||
|  | * Sat Jun 07 2014 Fedora Release Engineering <rel-eng@lists.fedoraproject.org> - 6.2.0.873-22 | ||||||
|  | - Rebuilt for https://fedoraproject.org/wiki/Fedora_21_Mass_Rebuild | ||||||
|  | 
 | ||||||
|  | * Mon Apr 14 2014 Chris Leech <cleech@redhat.com> - 6.2.0.873-21 | ||||||
|  | - boot session handling improvements | ||||||
|  | - split out iscsiuio into a seperate sub-package | ||||||
|  | - sync with new upstream additions | ||||||
|  | - revert change to return code when calling login_portal for sessions | ||||||
|  |   that already exist, as it impacts users scripting around iscsiadm | ||||||
|  | 
 | ||||||
|  | * Tue Dec 10 2013 Chris Leech <cleech@redhat.com> - 6.2.0.873-17 | ||||||
|  | - fix regression in glob use, inappropriate error code escape | ||||||
|  | - clean up dead node links from discovery when reusing tpgt | ||||||
|  | 
 | ||||||
|  | * Mon Nov 25 2013 Chris Leech <cleech@redhat.com> - 6.2.0.873-16 | ||||||
|  | - fix iscsiuio socket activation | ||||||
|  | - have systemd start socket units on iscsiadm use, if not already listening | ||||||
|  | 
 | ||||||
|  | * Sun Sep 15 2013 Chris Leech <cleech@redhat.com> - 6.2.0.873-15 | ||||||
|  | - move /sbin to /usr/sbin | ||||||
|  | - use rpm macros in install rules | ||||||
|  | 
 | ||||||
|  | * Fri Sep 13 2013 Chris Leech <cleech@redhat.com> - 6.2.0.873-14 | ||||||
|  | - fix iscsiuio hardened build and other compiler flags | ||||||
|  | 
 | ||||||
|  | * Fri Aug 23 2013 Andy Grover <agrover@redhat.com> - 6.2.0.873-13 | ||||||
|  | - Fix patch 0041 to check session != NULL before calling iscsi_sysfs_read_boot() | ||||||
|  | 
 | ||||||
|  | * Tue Aug 20 2013 Chris Leech <cleech@redhat.com> - 6.2.0.873-12 | ||||||
|  | - fix regression in last build, database records can't be accessed | ||||||
|  | 
 | ||||||
|  | * Mon Aug 19 2013 Chris Leech <cleech@redhat.com> - 6.2.0.873-11 | ||||||
|  | - iscsi boot related fixes | ||||||
|  |   make sure iscsid gets started if there are any boot sessions running | ||||||
|  |   add reload target to fix double session problem when restarting from NM | ||||||
|  |   don't rely on session list passed from initrd, never got fully implemented | ||||||
|  |   remove patches related to running iscsid from initrd, possible to revisit later | ||||||
|  | 
 | ||||||
|  | * Sun Aug 18 2013 Chris Leech <cleech@redhat.com> - 6.2.0.873-10 | ||||||
|  | - sync with upstream git, minor context fixes after rebase of out-of-tree patches | ||||||
|  | - iscsiuio is merged upstream, remove old source archive and patches | ||||||
|  | - spec cleanups to fix rpmlint issues | ||||||
|  | 
 | ||||||
|  | * Sun Aug  4 2013 Peter Robinson <pbrobinson@fedoraproject.org> 6.2.0.873-9 | ||||||
|  | - Fix FTBFS, cleanup spec | ||||||
|  | 
 | ||||||
|  | * Sat Aug 03 2013 Fedora Release Engineering <rel-eng@lists.fedoraproject.org> - 6.2.0.873-8 | ||||||
|  | - Rebuilt for https://fedoraproject.org/wiki/Fedora_20_Mass_Rebuild | ||||||
|  | 
 | ||||||
|  | * Tue Jun 11 2013 Chris Leech <cleech@redhat.com> - 6.2.0.873-7 | ||||||
|  | - Use the systemd tmpfiles service to recreate lockfiles in /var/lock | ||||||
|  | - 955167 build as a position independent executable | ||||||
|  | - 894576 fix order of setuid/setgid and drop additional groups | ||||||
|  | 
 | ||||||
|  | * Tue May 28 2013 Chris Leech <cleech@redhat.com> - 6.2.0.873-6 | ||||||
|  | - Don't have iscsiadm scan for autostart record if node db is empty (bug #951951) | ||||||
|  | 
 | ||||||
|  | * Tue Apr 30 2013 Orion Poplawski <orion@cora.nwra.com> - 6.2.0.873-5 | ||||||
|  | - Fix typo in NM dispatcher script (bug #917058) | ||||||
|  | 
 | ||||||
|  | * Thu Feb 21 2013 Chris Leech <cleech@redhat.com> - 6.2.0.873-4 | ||||||
|  | - build with libkmod support, instead of calling out to modprobe | ||||||
|  | - enable socket activation by default | ||||||
|  | 
 | ||||||
|  | * Thu Jan 24 2013 Kalev Lember <kalevlember@gmail.com> - 6.2.0.873-3 | ||||||
|  | - Fix the postun script to not use ldconfig as the interpreter | ||||||
|  | 
 | ||||||
|  | * Wed Jan 23 2013 Chris Leech <cleech@redhat.com> - 6.2.0.873-2 | ||||||
|  | - package iscsi_mark_root_nodes script, it's being referenced by the unit files | ||||||
|  | 
 | ||||||
|  | * Tue Jan 22 2013 Chris Leech <cleech@redhat.com> - 6.2.0.873-1 | ||||||
|  | - rebase to new upstream code | ||||||
|  | - systemd conversion | ||||||
|  | - 565245 Fix multilib issues caused by timestamp in doxygen footers | ||||||
|  | 
 | ||||||
|  | * Thu Jul 19 2012 Fedora Release Engineering <rel-eng@lists.fedoraproject.org> - 6.2.0.872-19 | ||||||
|  | - Rebuilt for https://fedoraproject.org/wiki/Fedora_18_Mass_Rebuild | ||||||
|  | 
 | ||||||
|  | * Tue Feb 14 2012 Mike Christie <mchristi@redhat.com> 6.2.0.872.18 | ||||||
|  | - 789683 Fix boot slow down when the iscsi service is started | ||||||
|  |   (regression added in 6.2.0.872.16 when the nm wait was added). | ||||||
|  | 
 | ||||||
|  | * Mon Feb 6 2012 Mike Christie <mchristi@redhat.com> 6.2.0.872.17 | ||||||
|  | - 786174 Change iscsid/iscsi service startup, so it always starts | ||||||
|  |   when called. | ||||||
|  | 
 | ||||||
|  | * Sat Feb 4 2012 Mike Christie <mchristi@redhat.com> 6.2.0.872.16 | ||||||
|  | - 747479 Fix iscsidevs handling of network requirement | ||||||
|  | 
 | ||||||
|  | * Fri Jan 13 2012 Fedora Release Engineering <rel-eng@lists.fedoraproject.org> - 6.2.0.872-15 | ||||||
|  | - Rebuilt for https://fedoraproject.org/wiki/Fedora_17_Mass_Rebuild | ||||||
|  | 
 | ||||||
|  | * Wed Nov 30 2011 Mike Christie <mcrhsit@redhat.com> 6.2.0.872.14 | ||||||
|  | - Fix version string to reflect fedora and not rhel. | ||||||
|  | 
 | ||||||
|  | * Tue Oct 18 2011 Mike Christie <mcrhsit@redhat.com> 6.2.0.872.13 | ||||||
|  | - Update iscsi tools. | ||||||
|  | 
 | ||||||
|  | * Sat Apr 30 2011 Hans de Goede <hdegoede@redhat.com> - 6.2.0.872-12 | ||||||
|  | - Change iscsi init scripts to check for networking being actually up, rather | ||||||
|  |   then for NetworkManager being started (#692230) | ||||||
|  | 
 | ||||||
|  | * Tue Apr 26 2011 Hans de Goede <hdegoede@redhat.com> - 6.2.0.872-11 | ||||||
|  | - Fix iscsid autostarting when upgrading from an older version | ||||||
|  |   (add iscsid.startup key to iscsid.conf on upgrade) | ||||||
|  | - Fix printing of [ OK ] when successfully stopping iscsid | ||||||
|  | - systemd related fixes: | ||||||
|  |  - Add Should-Start/Stop tgtd to iscsi init script to fix (re)boot from | ||||||
|  |    hanging when using locally hosted targets | ||||||
|  |  - %%ghost /var/lock/iscsi and contents (#656605) | ||||||
|  | 
 | ||||||
|  | * Mon Apr 25 2011 Mike Christie <mchristi@redhat.com> 6.2.0.872-10 | ||||||
|  | - Fix iscsi init scripts check for networking being up (#692230) | ||||||
|  | 
 | ||||||
|  | * Wed Feb 09 2011 Fedora Release Engineering <rel-eng@lists.fedoraproject.org> - 6.2.0.872-9 | ||||||
|  | - Rebuilt for https://fedoraproject.org/wiki/Fedora_15_Mass_Rebuild | ||||||
		Loading…
	
		Reference in New Issue
	
	Block a user