On Sat, Apr 9, 2016 at 11:16 PM, Jamal Hadi Salim <jhs@xxxxxxxxxxxx> wrote: > Appreciate these patches. Finally some love for sctp. > Small comment below: > > > On 16-04-09 12:53 AM, Xin Long wrote: >> >> sctp_diag will dump some important details of sctp's assoc or ep, we use >> sctp_info to describe them, sctp_get_sctp_info to get them, and export >> it to sctp_diag.ko. >> >> Signed-off-by: Xin Long <lucien.xin@xxxxxxxxx> >> --- >> include/linux/sctp.h | 65 +++++++++++++++++++++++++++++++++++++ >> include/net/sctp/sctp.h | 3 ++ >> net/sctp/socket.c | 86 >> +++++++++++++++++++++++++++++++++++++++++++++++++ >> 3 files changed, 154 insertions(+) >> >> diff --git a/include/linux/sctp.h b/include/linux/sctp.h >> index a9414fd..a448ebc 100644 >> --- a/include/linux/sctp.h >> +++ b/include/linux/sctp.h >> @@ -705,4 +705,69 @@ typedef struct sctp_auth_chunk { >> sctp_authhdr_t auth_hdr; >> } __packed sctp_auth_chunk_t; >> >> +struct sctp_info { >> + __u32 sctpi_tag; >> + __u32 sctpi_state; >> + __u32 sctpi_rwnd; >> + __u16 sctpi_unackdata; >> + __u16 sctpi_penddata; >> + __u16 sctpi_instrms; >> + __u16 sctpi_outstrms; >> + __u32 sctpi_fragmentation_point; >> + __u32 sctpi_inqueue; >> + __u32 sctpi_outqueue; >> + __u32 sctpi_overall_error; >> + __u32 sctpi_max_burst; >> + __u32 sctpi_maxseg; >> + __u32 sctpi_peer_rwnd; >> + __u32 sctpi_peer_tag; >> + __u8 sctpi_peer_capable; >> + __u8 sctpi_peer_sack; >> + >> + /* assoc status info */ >> + __u64 sctpi_isacks; >> + __u64 sctpi_osacks; >> + __u64 sctpi_opackets; >> + __u64 sctpi_ipackets; >> + __u64 sctpi_rtxchunks; >> + __u64 sctpi_outofseqtsns; >> + __u64 sctpi_idupchunks; >> + __u64 sctpi_gapcnt; >> + __u64 sctpi_ouodchunks; >> + __u64 sctpi_iuodchunks; >> + __u64 sctpi_oodchunks; >> + __u64 sctpi_iodchunks; >> + __u64 sctpi_octrlchunks; >> + __u64 sctpi_ictrlchunks; >> + >> + /* primary transport info */ >> + struct sockaddr_storage sctpi_p_address; >> + __s32 sctpi_p_state; >> + __u32 sctpi_p_cwnd; >> + __u32 sctpi_p_srtt; >> + __u32 sctpi_p_rto; >> + __u32 sctpi_p_hbinterval; >> + __u32 sctpi_p_pathmaxrxt; >> + __u32 sctpi_p_sackdelay; >> + __u32 sctpi_p_sackfreq; >> + __u32 sctpi_p_ssthresh; >> + __u32 sctpi_p_partial_bytes_acked; >> + __u32 sctpi_p_flight_size; >> + __u16 sctpi_p_error; >> + >> + /* sctp sock info */ >> + __u32 sctpi_s_autoclose; >> + __u32 sctpi_s_adaptation_ind; >> + __u32 sctpi_s_pd_point; >> + __u8 sctpi_s_nodelay; >> + __u8 sctpi_s_disable_fragments; >> + __u8 sctpi_s_v4mapped; >> + __u8 sctpi_s_frag_interleave; >> +}; >> + > > > > Can you double check to make sure this is 32 bit aligned > (no holes) maybe in your case 64 bit aligned? > Sticking + __u16 sctpi_p_error in there seems > to kill it. yes, I will check this structure all. > > Also, any plans to do the netlink events and destroy features? yeah, maybe after this one, we will do it. but for destroy feature, do you have any idea to test, cause ss of iproute seems cannot cover it, even .dump_one, neither. do we have to write code to test them? netlink events? sorry, what's that for? I didn't see it in tcp_diag. > > cheers, > jamal -- To unsubscribe from this list: send the line "unsubscribe linux-sctp" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html