Merge git://git.kernel.org/pub/scm/linux/kernel/git/davem/net
Conflicts: drivers/net/bonding/bond_alb.c drivers/net/ethernet/altera/altera_msgdma.c drivers/net/ethernet/altera/altera_sgdma.c net/ipv6/xfrm6_output.c Several cases of overlapping changes. The xfrm6_output.c has a bug fix which overlaps the renaming of skb->local_df to skb->ignore_df. In the Altera TSE driver cases, the register access cleanups in net-next overlapped with bug fixes done in net. Similarly a bug fix to send ALB packets in the bonding driver using the right source address overlaps with cleanups in net-next. Signed-off-by: David S. Miller <davem@davemloft.net>
这个提交包含在:
@@ -28,6 +28,7 @@
|
||||
#include <target/target_core_base.h>
|
||||
#include <target/target_core_fabric.h>
|
||||
#include <target/iscsi/iscsi_transport.h>
|
||||
#include <linux/semaphore.h>
|
||||
|
||||
#include "isert_proto.h"
|
||||
#include "ib_isert.h"
|
||||
@@ -561,7 +562,15 @@ isert_connect_request(struct rdma_cm_id *cma_id, struct rdma_cm_event *event)
|
||||
struct isert_device *device;
|
||||
struct ib_device *ib_dev = cma_id->device;
|
||||
int ret = 0;
|
||||
u8 pi_support = np->tpg_np->tpg->tpg_attrib.t10_pi;
|
||||
u8 pi_support;
|
||||
|
||||
spin_lock_bh(&np->np_thread_lock);
|
||||
if (!np->enabled) {
|
||||
spin_unlock_bh(&np->np_thread_lock);
|
||||
pr_debug("iscsi_np is not enabled, reject connect request\n");
|
||||
return rdma_reject(cma_id, NULL, 0);
|
||||
}
|
||||
spin_unlock_bh(&np->np_thread_lock);
|
||||
|
||||
pr_debug("Entering isert_connect_request cma_id: %p, context: %p\n",
|
||||
cma_id, cma_id->context);
|
||||
@@ -652,6 +661,7 @@ isert_connect_request(struct rdma_cm_id *cma_id, struct rdma_cm_event *event)
|
||||
goto out_mr;
|
||||
}
|
||||
|
||||
pi_support = np->tpg_np->tpg->tpg_attrib.t10_pi;
|
||||
if (pi_support && !device->pi_capable) {
|
||||
pr_err("Protection information requested but not supported\n");
|
||||
ret = -EINVAL;
|
||||
@@ -663,11 +673,11 @@ isert_connect_request(struct rdma_cm_id *cma_id, struct rdma_cm_event *event)
|
||||
goto out_conn_dev;
|
||||
|
||||
mutex_lock(&isert_np->np_accept_mutex);
|
||||
list_add_tail(&isert_np->np_accept_list, &isert_conn->conn_accept_node);
|
||||
list_add_tail(&isert_conn->conn_accept_node, &isert_np->np_accept_list);
|
||||
mutex_unlock(&isert_np->np_accept_mutex);
|
||||
|
||||
pr_debug("isert_connect_request() waking up np_accept_wq: %p\n", np);
|
||||
wake_up(&isert_np->np_accept_wq);
|
||||
pr_debug("isert_connect_request() up np_sem np: %p\n", np);
|
||||
up(&isert_np->np_sem);
|
||||
return 0;
|
||||
|
||||
out_conn_dev:
|
||||
@@ -2999,7 +3009,7 @@ isert_setup_np(struct iscsi_np *np,
|
||||
pr_err("Unable to allocate struct isert_np\n");
|
||||
return -ENOMEM;
|
||||
}
|
||||
init_waitqueue_head(&isert_np->np_accept_wq);
|
||||
sema_init(&isert_np->np_sem, 0);
|
||||
mutex_init(&isert_np->np_accept_mutex);
|
||||
INIT_LIST_HEAD(&isert_np->np_accept_list);
|
||||
init_completion(&isert_np->np_login_comp);
|
||||
@@ -3047,18 +3057,6 @@ out:
|
||||
return ret;
|
||||
}
|
||||
|
||||
static int
|
||||
isert_check_accept_queue(struct isert_np *isert_np)
|
||||
{
|
||||
int empty;
|
||||
|
||||
mutex_lock(&isert_np->np_accept_mutex);
|
||||
empty = list_empty(&isert_np->np_accept_list);
|
||||
mutex_unlock(&isert_np->np_accept_mutex);
|
||||
|
||||
return empty;
|
||||
}
|
||||
|
||||
static int
|
||||
isert_rdma_accept(struct isert_conn *isert_conn)
|
||||
{
|
||||
@@ -3151,16 +3149,14 @@ isert_accept_np(struct iscsi_np *np, struct iscsi_conn *conn)
|
||||
int max_accept = 0, ret;
|
||||
|
||||
accept_wait:
|
||||
ret = wait_event_interruptible(isert_np->np_accept_wq,
|
||||
!isert_check_accept_queue(isert_np) ||
|
||||
np->np_thread_state == ISCSI_NP_THREAD_RESET);
|
||||
ret = down_interruptible(&isert_np->np_sem);
|
||||
if (max_accept > 5)
|
||||
return -ENODEV;
|
||||
|
||||
spin_lock_bh(&np->np_thread_lock);
|
||||
if (np->np_thread_state == ISCSI_NP_THREAD_RESET) {
|
||||
spin_unlock_bh(&np->np_thread_lock);
|
||||
pr_err("ISCSI_NP_THREAD_RESET for isert_accept_np\n");
|
||||
pr_debug("ISCSI_NP_THREAD_RESET for isert_accept_np\n");
|
||||
return -ENODEV;
|
||||
}
|
||||
spin_unlock_bh(&np->np_thread_lock);
|
||||
|
@@ -182,7 +182,7 @@ struct isert_device {
|
||||
};
|
||||
|
||||
struct isert_np {
|
||||
wait_queue_head_t np_accept_wq;
|
||||
struct semaphore np_sem;
|
||||
struct rdma_cm_id *np_cm_id;
|
||||
struct mutex np_accept_mutex;
|
||||
struct list_head np_accept_list;
|
||||
|
在新工单中引用
屏蔽一个用户