Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 184005
b: refs/heads/master
c: 69a6a0b
h: refs/heads/master
i:
  184003: e518edc
v: v3
  • Loading branch information
Gerrit Renker authored and David S. Miller committed Feb 12, 2010
1 parent fa851ef commit 68bb902
Show file tree
Hide file tree
Showing 3 changed files with 9 additions and 8 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: 7455a76f170f794498d26081a5f15b797ef1a2aa
refs/heads/master: 69a6a0b38a139ccceef32222108caca8a9b0b795
6 changes: 4 additions & 2 deletions trunk/Documentation/networking/dccp.txt
Original file line number Diff line number Diff line change
Expand Up @@ -58,8 +58,10 @@ DCCP_SOCKOPT_GET_CUR_MPS is read-only and retrieves the current maximum packet
size (application payload size) in bytes, see RFC 4340, section 14.

DCCP_SOCKOPT_AVAILABLE_CCIDS is also read-only and returns the list of CCIDs
supported by the endpoint (see include/linux/dccp.h for symbolic constants).
The caller needs to provide a sufficiently large (> 2) array of type uint8_t.
supported by the endpoint. The option value is an array of type uint8_t whose
size is passed as option length. The minimum array size is 4 elements, the
value returned in the optlen argument always reflects the true number of
built-in CCIDs.

DCCP_SOCKOPT_CCID is write-only and sets both the TX and RX CCIDs at the same
time, combining the operation of the next two socket options. This option is
Expand Down
9 changes: 4 additions & 5 deletions trunk/net/dccp/ccid.c
Original file line number Diff line number Diff line change
Expand Up @@ -63,14 +63,13 @@ int ccid_getsockopt_builtin_ccids(struct sock *sk, int len,
u8 *ccid_array, array_len;
int err = 0;

if (len < ARRAY_SIZE(ccids))
return -EINVAL;

if (ccid_get_builtin_ccids(&ccid_array, &array_len))
return -ENOBUFS;

if (put_user(array_len, optlen) ||
copy_to_user(optval, ccid_array, array_len))
if (put_user(array_len, optlen))
err = -EFAULT;
else if (len > 0 && copy_to_user(optval, ccid_array,
len > array_len ? array_len : len))
err = -EFAULT;

kfree(ccid_array);
Expand Down

0 comments on commit 68bb902

Please sign in to comment.