Merge branch 'sched/urgent' into sched/core, to avoid conflicts
Signed-off-by: Ingo Molnar <mingo@kernel.org>
This commit is contained in:
@@ -41,7 +41,7 @@ static ssize_t version_show(struct kobject *kobj, struct kobj_attribute *attr,
|
||||
return snprintf(buf, PAGE_SIZE, "%u\n", O2NM_API_VERSION);
|
||||
}
|
||||
static struct kobj_attribute attr_version =
|
||||
__ATTR(interface_revision, S_IFREG | S_IRUGO, version_show, NULL);
|
||||
__ATTR(interface_revision, S_IRUGO, version_show, NULL);
|
||||
|
||||
static struct attribute *o2cb_attrs[] = {
|
||||
&attr_version.attr,
|
||||
|
@@ -137,7 +137,7 @@ static int o2net_sys_err_translations[O2NET_ERR_MAX] =
|
||||
static void o2net_sc_connect_completed(struct work_struct *work);
|
||||
static void o2net_rx_until_empty(struct work_struct *work);
|
||||
static void o2net_shutdown_sc(struct work_struct *work);
|
||||
static void o2net_listen_data_ready(struct sock *sk, int bytes);
|
||||
static void o2net_listen_data_ready(struct sock *sk);
|
||||
static void o2net_sc_send_keep_req(struct work_struct *work);
|
||||
static void o2net_idle_timer(unsigned long data);
|
||||
static void o2net_sc_postpone_idle(struct o2net_sock_container *sc);
|
||||
@@ -262,17 +262,17 @@ static void o2net_update_recv_stats(struct o2net_sock_container *sc)
|
||||
|
||||
#endif /* CONFIG_OCFS2_FS_STATS */
|
||||
|
||||
static inline int o2net_reconnect_delay(void)
|
||||
static inline unsigned int o2net_reconnect_delay(void)
|
||||
{
|
||||
return o2nm_single_cluster->cl_reconnect_delay_ms;
|
||||
}
|
||||
|
||||
static inline int o2net_keepalive_delay(void)
|
||||
static inline unsigned int o2net_keepalive_delay(void)
|
||||
{
|
||||
return o2nm_single_cluster->cl_keepalive_delay_ms;
|
||||
}
|
||||
|
||||
static inline int o2net_idle_timeout(void)
|
||||
static inline unsigned int o2net_idle_timeout(void)
|
||||
{
|
||||
return o2nm_single_cluster->cl_idle_timeout_ms;
|
||||
}
|
||||
@@ -597,9 +597,9 @@ static void o2net_set_nn_state(struct o2net_node *nn,
|
||||
}
|
||||
|
||||
/* see o2net_register_callbacks() */
|
||||
static void o2net_data_ready(struct sock *sk, int bytes)
|
||||
static void o2net_data_ready(struct sock *sk)
|
||||
{
|
||||
void (*ready)(struct sock *sk, int bytes);
|
||||
void (*ready)(struct sock *sk);
|
||||
|
||||
read_lock(&sk->sk_callback_lock);
|
||||
if (sk->sk_user_data) {
|
||||
@@ -613,7 +613,7 @@ static void o2net_data_ready(struct sock *sk, int bytes)
|
||||
}
|
||||
read_unlock(&sk->sk_callback_lock);
|
||||
|
||||
ready(sk, bytes);
|
||||
ready(sk);
|
||||
}
|
||||
|
||||
/* see o2net_register_callbacks() */
|
||||
@@ -916,57 +916,30 @@ static struct o2net_msg_handler *o2net_handler_get(u32 msg_type, u32 key)
|
||||
|
||||
static int o2net_recv_tcp_msg(struct socket *sock, void *data, size_t len)
|
||||
{
|
||||
int ret;
|
||||
mm_segment_t oldfs;
|
||||
struct kvec vec = {
|
||||
.iov_len = len,
|
||||
.iov_base = data,
|
||||
};
|
||||
struct msghdr msg = {
|
||||
.msg_iovlen = 1,
|
||||
.msg_iov = (struct iovec *)&vec,
|
||||
.msg_flags = MSG_DONTWAIT,
|
||||
};
|
||||
|
||||
oldfs = get_fs();
|
||||
set_fs(get_ds());
|
||||
ret = sock_recvmsg(sock, &msg, len, msg.msg_flags);
|
||||
set_fs(oldfs);
|
||||
|
||||
return ret;
|
||||
struct kvec vec = { .iov_len = len, .iov_base = data, };
|
||||
struct msghdr msg = { .msg_flags = MSG_DONTWAIT, };
|
||||
return kernel_recvmsg(sock, &msg, &vec, 1, len, msg.msg_flags);
|
||||
}
|
||||
|
||||
static int o2net_send_tcp_msg(struct socket *sock, struct kvec *vec,
|
||||
size_t veclen, size_t total)
|
||||
{
|
||||
int ret;
|
||||
mm_segment_t oldfs;
|
||||
struct msghdr msg = {
|
||||
.msg_iov = (struct iovec *)vec,
|
||||
.msg_iovlen = veclen,
|
||||
};
|
||||
struct msghdr msg;
|
||||
|
||||
if (sock == NULL) {
|
||||
ret = -EINVAL;
|
||||
goto out;
|
||||
}
|
||||
|
||||
oldfs = get_fs();
|
||||
set_fs(get_ds());
|
||||
ret = sock_sendmsg(sock, &msg, total);
|
||||
set_fs(oldfs);
|
||||
if (ret != total) {
|
||||
mlog(ML_ERROR, "sendmsg returned %d instead of %zu\n", ret,
|
||||
total);
|
||||
if (ret >= 0)
|
||||
ret = -EPIPE; /* should be smarter, I bet */
|
||||
goto out;
|
||||
}
|
||||
|
||||
ret = 0;
|
||||
ret = kernel_sendmsg(sock, &msg, vec, veclen, total);
|
||||
if (likely(ret == total))
|
||||
return 0;
|
||||
mlog(ML_ERROR, "sendmsg returned %d instead of %zu\n", ret, total);
|
||||
if (ret >= 0)
|
||||
ret = -EPIPE; /* should be smarter, I bet */
|
||||
out:
|
||||
if (ret < 0)
|
||||
mlog(0, "returning error: %d\n", ret);
|
||||
mlog(0, "returning error: %d\n", ret);
|
||||
return ret;
|
||||
}
|
||||
|
||||
@@ -1953,9 +1926,9 @@ static void o2net_accept_many(struct work_struct *work)
|
||||
cond_resched();
|
||||
}
|
||||
|
||||
static void o2net_listen_data_ready(struct sock *sk, int bytes)
|
||||
static void o2net_listen_data_ready(struct sock *sk)
|
||||
{
|
||||
void (*ready)(struct sock *sk, int bytes);
|
||||
void (*ready)(struct sock *sk);
|
||||
|
||||
read_lock(&sk->sk_callback_lock);
|
||||
ready = sk->sk_user_data;
|
||||
@@ -1964,18 +1937,29 @@ static void o2net_listen_data_ready(struct sock *sk, int bytes)
|
||||
goto out;
|
||||
}
|
||||
|
||||
/* ->sk_data_ready is also called for a newly established child socket
|
||||
* before it has been accepted and the acceptor has set up their
|
||||
* data_ready.. we only want to queue listen work for our listening
|
||||
* socket */
|
||||
/* This callback may called twice when a new connection
|
||||
* is being established as a child socket inherits everything
|
||||
* from a parent LISTEN socket, including the data_ready cb of
|
||||
* the parent. This leads to a hazard. In o2net_accept_one()
|
||||
* we are still initializing the child socket but have not
|
||||
* changed the inherited data_ready callback yet when
|
||||
* data starts arriving.
|
||||
* We avoid this hazard by checking the state.
|
||||
* For the listening socket, the state will be TCP_LISTEN; for the new
|
||||
* socket, will be TCP_ESTABLISHED. Also, in this case,
|
||||
* sk->sk_user_data is not a valid function pointer.
|
||||
*/
|
||||
|
||||
if (sk->sk_state == TCP_LISTEN) {
|
||||
mlog(ML_TCP, "bytes: %d\n", bytes);
|
||||
queue_work(o2net_wq, &o2net_listen_work);
|
||||
} else {
|
||||
ready = NULL;
|
||||
}
|
||||
|
||||
out:
|
||||
read_unlock(&sk->sk_callback_lock);
|
||||
ready(sk, bytes);
|
||||
if (ready != NULL)
|
||||
ready(sk);
|
||||
}
|
||||
|
||||
static int o2net_open_listening_sock(__be32 addr, __be16 port)
|
||||
|
@@ -165,7 +165,7 @@ struct o2net_sock_container {
|
||||
|
||||
/* original handlers for the sockets */
|
||||
void (*sc_state_change)(struct sock *sk);
|
||||
void (*sc_data_ready)(struct sock *sk, int bytes);
|
||||
void (*sc_data_ready)(struct sock *sk);
|
||||
|
||||
u32 sc_msg_key;
|
||||
u16 sc_msg_type;
|
||||
|
Reference in New Issue
Block a user