Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
raspberrypi-kernel
提交
974f7bc5
R
raspberrypi-kernel
项目概览
openeuler
/
raspberrypi-kernel
通知
13
Star
1
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
R
raspberrypi-kernel
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
974f7bc5
编写于
10月 28, 2005
作者:
A
Arnaldo Carvalho de Melo
浏览文件
操作
浏览文件
下载
差异文件
Merge master.kernel.org:/pub/scm/linux/kernel/git/sridhar/lksctp-2.6
上级
89fbb69c
64a0c1c8
变更
4
隐藏空白更改
内联
并排
Showing
4 changed file
with
64 addition
and
42 deletion
+64
-42
include/net/sctp/user.h
include/net/sctp/user.h
+4
-4
net/sctp/sm_make_chunk.c
net/sctp/sm_make_chunk.c
+1
-1
net/sctp/socket.c
net/sctp/socket.c
+56
-34
net/sctp/ulpevent.c
net/sctp/ulpevent.c
+3
-3
未找到文件。
include/net/sctp/user.h
浏览文件 @
974f7bc5
...
@@ -171,10 +171,10 @@ struct sctp_sndrcvinfo {
...
@@ -171,10 +171,10 @@ struct sctp_sndrcvinfo {
*/
*/
enum
sctp_sinfo_flags
{
enum
sctp_sinfo_flags
{
MSG
_UNORDERED
=
1
,
/* Send/receive message unordered. */
SCTP
_UNORDERED
=
1
,
/* Send/receive message unordered. */
MSG
_ADDR_OVER
=
2
,
/* Override the primary destination. */
SCTP
_ADDR_OVER
=
2
,
/* Override the primary destination. */
MSG
_ABORT
=
4
,
/* Send an ABORT message to the peer. */
SCTP
_ABORT
=
4
,
/* Send an ABORT message to the peer. */
/* MSG_EOF is already defined per socket.h */
SCTP_EOF
=
MSG_FIN
,
/* Initiate graceful shutdown process. */
};
};
...
...
net/sctp/sm_make_chunk.c
浏览文件 @
974f7bc5
...
@@ -554,7 +554,7 @@ struct sctp_chunk *sctp_make_datafrag_empty(struct sctp_association *asoc,
...
@@ -554,7 +554,7 @@ struct sctp_chunk *sctp_make_datafrag_empty(struct sctp_association *asoc,
dp
.
ppid
=
sinfo
->
sinfo_ppid
;
dp
.
ppid
=
sinfo
->
sinfo_ppid
;
/* Set the flags for an unordered send. */
/* Set the flags for an unordered send. */
if
(
sinfo
->
sinfo_flags
&
MSG
_UNORDERED
)
{
if
(
sinfo
->
sinfo_flags
&
SCTP
_UNORDERED
)
{
flags
|=
SCTP_DATA_UNORDERED
;
flags
|=
SCTP_DATA_UNORDERED
;
dp
.
ssn
=
0
;
dp
.
ssn
=
0
;
}
else
}
else
...
...
net/sctp/socket.c
浏览文件 @
974f7bc5
...
@@ -1010,6 +1010,19 @@ static int __sctp_connect(struct sock* sk,
...
@@ -1010,6 +1010,19 @@ static int __sctp_connect(struct sock* sk,
err
=
-
EAGAIN
;
err
=
-
EAGAIN
;
goto
out_free
;
goto
out_free
;
}
}
}
else
{
/*
* If an unprivileged user inherits a 1-many
* style socket with open associations on a
* privileged port, it MAY be permitted to
* accept new associations, but it SHOULD NOT
* be permitted to open new associations.
*/
if
(
ep
->
base
.
bind_addr
.
port
<
PROT_SOCK
&&
!
capable
(
CAP_NET_BIND_SERVICE
))
{
err
=
-
EACCES
;
goto
out_free
;
}
}
}
scope
=
sctp_scope
(
&
to
);
scope
=
sctp_scope
(
&
to
);
...
@@ -1389,27 +1402,27 @@ SCTP_STATIC int sctp_sendmsg(struct kiocb *iocb, struct sock *sk,
...
@@ -1389,27 +1402,27 @@ SCTP_STATIC int sctp_sendmsg(struct kiocb *iocb, struct sock *sk,
SCTP_DEBUG_PRINTK
(
"msg_len: %zu, sinfo_flags: 0x%x
\n
"
,
SCTP_DEBUG_PRINTK
(
"msg_len: %zu, sinfo_flags: 0x%x
\n
"
,
msg_len
,
sinfo_flags
);
msg_len
,
sinfo_flags
);
/*
MSG_EOF or MSG
_ABORT cannot be set on a TCP-style socket. */
/*
SCTP_EOF or SCTP
_ABORT cannot be set on a TCP-style socket. */
if
(
sctp_style
(
sk
,
TCP
)
&&
(
sinfo_flags
&
(
MSG_EOF
|
MSG
_ABORT
)))
{
if
(
sctp_style
(
sk
,
TCP
)
&&
(
sinfo_flags
&
(
SCTP_EOF
|
SCTP
_ABORT
)))
{
err
=
-
EINVAL
;
err
=
-
EINVAL
;
goto
out_nounlock
;
goto
out_nounlock
;
}
}
/* If
MSG
_EOF is set, no data can be sent. Disallow sending zero
/* If
SCTP
_EOF is set, no data can be sent. Disallow sending zero
* length messages when
MSG_EOF|MSG
_ABORT is not set.
* length messages when
SCTP_EOF|SCTP
_ABORT is not set.
* If
MSG
_ABORT is set, the message length could be non zero with
* If
SCTP
_ABORT is set, the message length could be non zero with
* the msg_iov set to the user abort reason.
* the msg_iov set to the user abort reason.
*/
*/
if
(((
sinfo_flags
&
MSG
_EOF
)
&&
(
msg_len
>
0
))
||
if
(((
sinfo_flags
&
SCTP
_EOF
)
&&
(
msg_len
>
0
))
||
(
!
(
sinfo_flags
&
(
MSG_EOF
|
MSG
_ABORT
))
&&
(
msg_len
==
0
)))
{
(
!
(
sinfo_flags
&
(
SCTP_EOF
|
SCTP
_ABORT
))
&&
(
msg_len
==
0
)))
{
err
=
-
EINVAL
;
err
=
-
EINVAL
;
goto
out_nounlock
;
goto
out_nounlock
;
}
}
/* If
MSG
_ADDR_OVER is set, there must be an address
/* If
SCTP
_ADDR_OVER is set, there must be an address
* specified in msg_name.
* specified in msg_name.
*/
*/
if
((
sinfo_flags
&
MSG
_ADDR_OVER
)
&&
(
!
msg
->
msg_name
))
{
if
((
sinfo_flags
&
SCTP
_ADDR_OVER
)
&&
(
!
msg
->
msg_name
))
{
err
=
-
EINVAL
;
err
=
-
EINVAL
;
goto
out_nounlock
;
goto
out_nounlock
;
}
}
...
@@ -1458,14 +1471,14 @@ SCTP_STATIC int sctp_sendmsg(struct kiocb *iocb, struct sock *sk,
...
@@ -1458,14 +1471,14 @@ SCTP_STATIC int sctp_sendmsg(struct kiocb *iocb, struct sock *sk,
goto
out_unlock
;
goto
out_unlock
;
}
}
if
(
sinfo_flags
&
MSG
_EOF
)
{
if
(
sinfo_flags
&
SCTP
_EOF
)
{
SCTP_DEBUG_PRINTK
(
"Shutting down association: %p
\n
"
,
SCTP_DEBUG_PRINTK
(
"Shutting down association: %p
\n
"
,
asoc
);
asoc
);
sctp_primitive_SHUTDOWN
(
asoc
,
NULL
);
sctp_primitive_SHUTDOWN
(
asoc
,
NULL
);
err
=
0
;
err
=
0
;
goto
out_unlock
;
goto
out_unlock
;
}
}
if
(
sinfo_flags
&
MSG
_ABORT
)
{
if
(
sinfo_flags
&
SCTP
_ABORT
)
{
SCTP_DEBUG_PRINTK
(
"Aborting association: %p
\n
"
,
asoc
);
SCTP_DEBUG_PRINTK
(
"Aborting association: %p
\n
"
,
asoc
);
sctp_primitive_ABORT
(
asoc
,
msg
);
sctp_primitive_ABORT
(
asoc
,
msg
);
err
=
0
;
err
=
0
;
...
@@ -1477,7 +1490,7 @@ SCTP_STATIC int sctp_sendmsg(struct kiocb *iocb, struct sock *sk,
...
@@ -1477,7 +1490,7 @@ SCTP_STATIC int sctp_sendmsg(struct kiocb *iocb, struct sock *sk,
if
(
!
asoc
)
{
if
(
!
asoc
)
{
SCTP_DEBUG_PRINTK
(
"There is no association yet.
\n
"
);
SCTP_DEBUG_PRINTK
(
"There is no association yet.
\n
"
);
if
(
sinfo_flags
&
(
MSG_EOF
|
MSG
_ABORT
))
{
if
(
sinfo_flags
&
(
SCTP_EOF
|
SCTP
_ABORT
))
{
err
=
-
EINVAL
;
err
=
-
EINVAL
;
goto
out_unlock
;
goto
out_unlock
;
}
}
...
@@ -1515,6 +1528,19 @@ SCTP_STATIC int sctp_sendmsg(struct kiocb *iocb, struct sock *sk,
...
@@ -1515,6 +1528,19 @@ SCTP_STATIC int sctp_sendmsg(struct kiocb *iocb, struct sock *sk,
err
=
-
EAGAIN
;
err
=
-
EAGAIN
;
goto
out_unlock
;
goto
out_unlock
;
}
}
}
else
{
/*
* If an unprivileged user inherits a one-to-many
* style socket with open associations on a privileged
* port, it MAY be permitted to accept new associations,
* but it SHOULD NOT be permitted to open new
* associations.
*/
if
(
ep
->
base
.
bind_addr
.
port
<
PROT_SOCK
&&
!
capable
(
CAP_NET_BIND_SERVICE
))
{
err
=
-
EACCES
;
goto
out_unlock
;
}
}
}
scope
=
sctp_scope
(
&
to
);
scope
=
sctp_scope
(
&
to
);
...
@@ -1611,10 +1637,10 @@ SCTP_STATIC int sctp_sendmsg(struct kiocb *iocb, struct sock *sk,
...
@@ -1611,10 +1637,10 @@ SCTP_STATIC int sctp_sendmsg(struct kiocb *iocb, struct sock *sk,
/* If an address is passed with the sendto/sendmsg call, it is used
/* If an address is passed with the sendto/sendmsg call, it is used
* to override the primary destination address in the TCP model, or
* to override the primary destination address in the TCP model, or
* when
MSG
_ADDR_OVER flag is set in the UDP model.
* when
SCTP
_ADDR_OVER flag is set in the UDP model.
*/
*/
if
((
sctp_style
(
sk
,
TCP
)
&&
msg_name
)
||
if
((
sctp_style
(
sk
,
TCP
)
&&
msg_name
)
||
(
sinfo_flags
&
MSG
_ADDR_OVER
))
{
(
sinfo_flags
&
SCTP
_ADDR_OVER
))
{
chunk_tp
=
sctp_assoc_lookup_paddr
(
asoc
,
&
to
);
chunk_tp
=
sctp_assoc_lookup_paddr
(
asoc
,
&
to
);
if
(
!
chunk_tp
)
{
if
(
!
chunk_tp
)
{
err
=
-
EINVAL
;
err
=
-
EINVAL
;
...
@@ -2306,16 +2332,14 @@ static int sctp_setsockopt_maxseg(struct sock *sk, char __user *optval, int optl
...
@@ -2306,16 +2332,14 @@ static int sctp_setsockopt_maxseg(struct sock *sk, char __user *optval, int optl
return
-
EINVAL
;
return
-
EINVAL
;
if
(
get_user
(
val
,
(
int
__user
*
)
optval
))
if
(
get_user
(
val
,
(
int
__user
*
)
optval
))
return
-
EFAULT
;
return
-
EFAULT
;
if
((
val
<
8
)
||
(
val
>
SCTP_MAX_CHUNK_LEN
))
if
((
val
!=
0
)
&&
((
val
<
8
)
||
(
val
>
SCTP_MAX_CHUNK_LEN
)
))
return
-
EINVAL
;
return
-
EINVAL
;
sp
->
user_frag
=
val
;
sp
->
user_frag
=
val
;
if
(
val
)
{
/* Update the frag_point of the existing associations. */
/* Update the frag_point of the existing associations. */
list_for_each
(
pos
,
&
(
sp
->
ep
->
asocs
))
{
list_for_each
(
pos
,
&
(
sp
->
ep
->
asocs
))
{
asoc
=
list_entry
(
pos
,
struct
sctp_association
,
asocs
);
asoc
=
list_entry
(
pos
,
struct
sctp_association
,
asocs
);
asoc
->
frag_point
=
sctp_frag_point
(
sp
,
asoc
->
pmtu
);
asoc
->
frag_point
=
sctp_frag_point
(
sp
,
asoc
->
pmtu
);
}
}
}
return
0
;
return
0
;
...
@@ -2384,14 +2408,14 @@ static int sctp_setsockopt_peer_primary_addr(struct sock *sk, char __user *optva
...
@@ -2384,14 +2408,14 @@ static int sctp_setsockopt_peer_primary_addr(struct sock *sk, char __user *optva
static
int
sctp_setsockopt_adaption_layer
(
struct
sock
*
sk
,
char
__user
*
optval
,
static
int
sctp_setsockopt_adaption_layer
(
struct
sock
*
sk
,
char
__user
*
optval
,
int
optlen
)
int
optlen
)
{
{
__u32
val
;
struct
sctp_setadaption
adaption
;
if
(
optlen
<
sizeof
(
__u32
))
if
(
optlen
!=
sizeof
(
struct
sctp_setadaption
))
return
-
EINVAL
;
return
-
EINVAL
;
if
(
copy_from_user
(
&
val
,
optval
,
sizeof
(
__u32
)))
if
(
copy_from_user
(
&
adaption
,
optval
,
optlen
))
return
-
EFAULT
;
return
-
EFAULT
;
sctp_sk
(
sk
)
->
adaption_ind
=
val
;
sctp_sk
(
sk
)
->
adaption_ind
=
adaption
.
ssb_adaption_ind
;
return
0
;
return
0
;
}
}
...
@@ -3672,17 +3696,15 @@ static int sctp_getsockopt_primary_addr(struct sock *sk, int len,
...
@@ -3672,17 +3696,15 @@ static int sctp_getsockopt_primary_addr(struct sock *sk, int len,
static
int
sctp_getsockopt_adaption_layer
(
struct
sock
*
sk
,
int
len
,
static
int
sctp_getsockopt_adaption_layer
(
struct
sock
*
sk
,
int
len
,
char
__user
*
optval
,
int
__user
*
optlen
)
char
__user
*
optval
,
int
__user
*
optlen
)
{
{
__u32
val
;
struct
sctp_setadaption
adaption
;
if
(
len
<
sizeof
(
__u32
))
if
(
len
!=
sizeof
(
struct
sctp_setadaption
))
return
-
EINVAL
;
return
-
EINVAL
;
len
=
sizeof
(
__u32
);
adaption
.
ssb_adaption_ind
=
sctp_sk
(
sk
)
->
adaption_ind
;
val
=
sctp_sk
(
sk
)
->
adaption_ind
;
if
(
copy_to_user
(
optval
,
&
adaption
,
len
))
if
(
put_user
(
len
,
optlen
))
return
-
EFAULT
;
if
(
copy_to_user
(
optval
,
&
val
,
len
))
return
-
EFAULT
;
return
-
EFAULT
;
return
0
;
return
0
;
}
}
...
@@ -4640,8 +4662,8 @@ SCTP_STATIC int sctp_msghdr_parse(const struct msghdr *msg,
...
@@ -4640,8 +4662,8 @@ SCTP_STATIC int sctp_msghdr_parse(const struct msghdr *msg,
/* Minimally, validate the sinfo_flags. */
/* Minimally, validate the sinfo_flags. */
if
(
cmsgs
->
info
->
sinfo_flags
&
if
(
cmsgs
->
info
->
sinfo_flags
&
~
(
MSG_UNORDERED
|
MSG
_ADDR_OVER
|
~
(
SCTP_UNORDERED
|
SCTP
_ADDR_OVER
|
MSG_ABORT
|
MSG
_EOF
))
SCTP_ABORT
|
SCTP
_EOF
))
return
-
EINVAL
;
return
-
EINVAL
;
break
;
break
;
...
...
net/sctp/ulpevent.c
浏览文件 @
974f7bc5
...
@@ -698,7 +698,7 @@ struct sctp_ulpevent *sctp_ulpevent_make_rcvmsg(struct sctp_association *asoc,
...
@@ -698,7 +698,7 @@ struct sctp_ulpevent *sctp_ulpevent_make_rcvmsg(struct sctp_association *asoc,
event
->
ssn
=
ntohs
(
chunk
->
subh
.
data_hdr
->
ssn
);
event
->
ssn
=
ntohs
(
chunk
->
subh
.
data_hdr
->
ssn
);
event
->
ppid
=
chunk
->
subh
.
data_hdr
->
ppid
;
event
->
ppid
=
chunk
->
subh
.
data_hdr
->
ppid
;
if
(
chunk
->
chunk_hdr
->
flags
&
SCTP_DATA_UNORDERED
)
{
if
(
chunk
->
chunk_hdr
->
flags
&
SCTP_DATA_UNORDERED
)
{
event
->
flags
|=
MSG
_UNORDERED
;
event
->
flags
|=
SCTP
_UNORDERED
;
event
->
cumtsn
=
sctp_tsnmap_get_ctsn
(
&
asoc
->
peer
.
tsn_map
);
event
->
cumtsn
=
sctp_tsnmap_get_ctsn
(
&
asoc
->
peer
.
tsn_map
);
}
}
event
->
tsn
=
ntohl
(
chunk
->
subh
.
data_hdr
->
tsn
);
event
->
tsn
=
ntohl
(
chunk
->
subh
.
data_hdr
->
tsn
);
...
@@ -824,7 +824,7 @@ void sctp_ulpevent_read_sndrcvinfo(const struct sctp_ulpevent *event,
...
@@ -824,7 +824,7 @@ void sctp_ulpevent_read_sndrcvinfo(const struct sctp_ulpevent *event,
*
*
* recvmsg() flags:
* recvmsg() flags:
*
*
*
MSG
_UNORDERED - This flag is present when the message was sent
*
SCTP
_UNORDERED - This flag is present when the message was sent
* non-ordered.
* non-ordered.
*/
*/
sinfo
.
sinfo_flags
=
event
->
flags
;
sinfo
.
sinfo_flags
=
event
->
flags
;
...
@@ -839,7 +839,7 @@ void sctp_ulpevent_read_sndrcvinfo(const struct sctp_ulpevent *event,
...
@@ -839,7 +839,7 @@ void sctp_ulpevent_read_sndrcvinfo(const struct sctp_ulpevent *event,
* This field will hold the current cumulative TSN as
* This field will hold the current cumulative TSN as
* known by the underlying SCTP layer. Note this field is
* known by the underlying SCTP layer. Note this field is
* ignored when sending and only valid for a receive
* ignored when sending and only valid for a receive
* operation when sinfo_flags are set to
MSG
_UNORDERED.
* operation when sinfo_flags are set to
SCTP
_UNORDERED.
*/
*/
sinfo
.
sinfo_cumtsn
=
event
->
cumtsn
;
sinfo
.
sinfo_cumtsn
=
event
->
cumtsn
;
/* sinfo_assoc_id: sizeof (sctp_assoc_t)
/* sinfo_assoc_id: sizeof (sctp_assoc_t)
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录