diff --git a/gtests/net/packetdrill/lexer.l b/gtests/net/packetdrill/lexer.l index 1f7ed9d5064590e085dc2c59e8cfae27fa5ac099..fdb44cee35561ae2acb22dda80adef64199016f9 100644 --- a/gtests/net/packetdrill/lexer.l +++ b/gtests/net/packetdrill/lexer.l @@ -245,6 +245,16 @@ spp_ipv6_flowlabel return SPP_IPV6_FLOWLABEL_; /* avoid name clash */ spp_dscp return SPP_DSCP_; /* avoid name clash */ se_type return SE_TYPE; se_on return SE_ON; +sctp_data_io_event return _SCTP_DATA_IO_EVENT_; +sctp_association_event return _SCTP_ASSOCIATION_EVENT_; +sctp_address_event return _SCTP_ADDRESS_EVENT_; +sctp_send_failure_event return _SCTP_SEND_FAILURE_EVENT_; +sctp_peer_error_event return _SCTP_PEER_ERROR_EVENT_; +sctp_shutdown_event return _SCTP_SHUTDOWN_EVENT_; +sctp_partial_delivery_event return _SCTP_PARTIAL_DELIVERY_EVENT_; +sctp_adaptation_layer_event return _SCTP_ADAPTATION_LAYER_EVENT_; +sctp_authentication_event return _SCTP_AUTHENTICATION_EVENT_; +sctp_sender_dry_event return _SCTP_SENDER_DRY_EVENT_; snd_sid return SND_SID; snd_flags return SND_FLAGS; snd_ppid return SND_PPID; diff --git a/gtests/net/packetdrill/parser.y b/gtests/net/packetdrill/parser.y index 9fac14bf21998dc08c0e7aba9042eebb0d8f6a00..344826a81c11729b3bc2c8455968157078dfd886 100644 --- a/gtests/net/packetdrill/parser.y +++ b/gtests/net/packetdrill/parser.y @@ -548,6 +548,10 @@ static struct tcp_option *new_tcp_fast_open_option(const char *cookie_string, %token <reserved> NXT_SID NXT_FLAGS NXT_PPID NXT_LENGTH %token <reserved> RECVV_RCVINFO RECVV_NXTINFO %token <reserved> SSE_TYPE SSE_FLAGS SSE_LENGTH +%token <rexerved> _SCTP_DATA_IO_EVENT_ _SCTP_ASSOCIATION_EVENT_ _SCTP_ADDRESS_EVENT_ +%token <reserved> _SCTP_SEND_FAILURE_EVENT_ _SCTP_PEER_ERROR_EVENT_ _SCTP_SHUTDOWN_EVENT_ +%token <reserved> _SCTP_PARTIAL_DELIVERY_EVENT_ _SCTP_ADAPTATION_LAYER_EVENT_ +%token <reserved> _SCTP_AUTHENTICATION_EVENT_ _SCTP_SENDER_DRY_EVENT_ %token <floating> FLOAT %token <integer> INTEGER HEX_INTEGER %token <string> WORD STRING BACK_QUOTED CODE IPV4_ADDR IPV6_ADDR @@ -604,6 +608,7 @@ static struct tcp_option *new_tcp_fast_open_option(const char *cookie_string, %type <expression> sctp_rcvinfo rcv_sid rcv_ssn rcv_flags rcv_ppid rcv_tsn rcv_cumtsn rcv_context %type <expression> sctp_nxtinfo nxt_sid nxt_flags nxt_ppid nxt_length sctp_recvv_rn %type <expression> sctp_shutdown_event sse_type sse_flags sse_length +%type <expression> sctp_event_subscribe %type <errno_info> opt_errno %type <chunk_list> sctp_chunk_list_spec %type <chunk_list_item> sctp_chunk_spec @@ -2461,6 +2466,9 @@ expression | sctp_event { $$ = $1; } +| sctp_event_subscribe { + $$ = $1; +} | sctp_sndinfo { $$ = $1; } @@ -3116,6 +3124,57 @@ sctp_event } ; +sctp_event_subscribe +: '{' _SCTP_DATA_IO_EVENT_ '=' INTEGER ',' _SCTP_ASSOCIATION_EVENT_ '=' INTEGER ',' + _SCTP_ADDRESS_EVENT_ '=' INTEGER ',' _SCTP_SEND_FAILURE_EVENT_ '=' INTEGER ',' + _SCTP_PEER_ERROR_EVENT_ '=' INTEGER ',' _SCTP_SHUTDOWN_EVENT_ '=' INTEGER ',' + _SCTP_PARTIAL_DELIVERY_EVENT_ '=' INTEGER ',' _SCTP_ADAPTATION_LAYER_EVENT_ '=' INTEGER ',' + _SCTP_AUTHENTICATION_EVENT_ '=' INTEGER ',' _SCTP_SENDER_DRY_EVENT_ '=' INTEGER '}' { + $$ = new_expression(EXPR_SCTP_EVENT_SUBSCRIBE); + $$->value.sctp_event_subscribe = calloc(1, sizeof(struct sctp_event_subscribe_expr)); + if (!is_valid_u8($4)) { + semantic_error("sctp_data_io_event out of range"); + } + $$->value.sctp_event_subscribe->sctp_data_io_event = new_integer_expression($4, "%hhu"); + if (!is_valid_u8($8)) { + semantic_error("sctp_association_event out of range"); + } + $$->value.sctp_event_subscribe->sctp_association_event = new_integer_expression($8, "%hhu"); + if (!is_valid_u8($12)) { + semantic_error("sctp_address_event out of range"); + } + $$->value.sctp_event_subscribe->sctp_address_event = new_integer_expression($12, "%hhu"); + if (!is_valid_u8($16)) { + semantic_error("sctp_send_failure_event out of range"); + } + $$->value.sctp_event_subscribe->sctp_send_failure_event = new_integer_expression($16, "%hhu"); + if (!is_valid_u8($20)) { + semantic_error("sctp_peer_error_event out of range"); + } + $$->value.sctp_event_subscribe->sctp_peer_error_event = new_integer_expression($20, "%hhu"); + if (!is_valid_u8($24)) { + semantic_error("sctp_shutdown_event out of range"); + } + $$->value.sctp_event_subscribe->sctp_shutdown_event = new_integer_expression($24, "%hhu"); + if (!is_valid_u8($28)) { + semantic_error("sctp_partial_delivery_event out of range"); + } + $$->value.sctp_event_subscribe->sctp_partial_delivery_event = new_integer_expression($28, "%hhu"); + if (!is_valid_u8($32)) { + semantic_error("sctp_adaptation_layer_event out of range"); + } + $$->value.sctp_event_subscribe->sctp_adaptation_layer_event = new_integer_expression($32, "%hhu"); + if (!is_valid_u8($36)) { + semantic_error("sctp_authentication_event out of range"); + } + $$->value.sctp_event_subscribe->sctp_authentication_event = new_integer_expression($36, "%hhu"); + if (!is_valid_u8($40)) { + semantic_error("sctp_sender_dry_event out of range"); + } + $$->value.sctp_event_subscribe->sctp_sender_dry_event = new_integer_expression($40, "%hhu"); +} +; + snd_sid : SND_SID '=' INTEGER { if (!is_valid_u16($3)) { diff --git a/gtests/net/packetdrill/run_system_call.c b/gtests/net/packetdrill/run_system_call.c index 38c85117fb77a1ee57104a35574fa701353a0275..fcd2e89fbbd9043847e90ff8744df10fe988dafa 100644 --- a/gtests/net/packetdrill/run_system_call.c +++ b/gtests/net/packetdrill/run_system_call.c @@ -2318,6 +2318,135 @@ static int check_sctp_event(struct sctp_event_expr *expr, } #endif +#ifdef SCTP_EVENT +static int check_sctp_event_subscribe(struct sctp_event_subscribe_expr *expr, + struct sctp_event_subscribe *sctp_events, + char **error) +{ + if (expr->sctp_data_io_event->type != EXPR_ELLIPSIS) { + u8 sctp_data_io_event; + + if (get_u8(expr->sctp_data_io_event, &sctp_data_io_event, error)) { + return STATUS_ERR; + } + if (sctp_events->sctp_data_io_event != sctp_data_io_event) { + asprintf(error, "sctp_event_subscribe.sctp_data_io_event: expected: %hhu actual: %hhu", + sctp_data_io_event, sctp_events->sctp_data_io_event); + return STATUS_ERR; + } + } + if (expr->sctp_association_event->type != EXPR_ELLIPSIS) { + u8 sctp_association_event; + + if (get_u8(expr->sctp_association_event, &sctp_association_event, error)) { + return STATUS_ERR; + } + if (sctp_events->sctp_association_event != sctp_association_event) { + asprintf(error, "sctp_event_subscribe.sctp_association_event: expected: %hhu actual: %hhu", + sctp_association_event, sctp_events->sctp_association_event); + return STATUS_ERR; + } + } + if (expr->sctp_address_event->type != EXPR_ELLIPSIS) { + u8 sctp_address_event; + + if (get_u8(expr->sctp_address_event, &sctp_address_event, error)) { + return STATUS_ERR; + } + if (sctp_events->sctp_address_event != sctp_address_event) { + asprintf(error, "sctp_event_subscribe.sctp_address_event: expected: %hhu actual: %hhu", + sctp_address_event, sctp_events->sctp_address_event); + return STATUS_ERR; + } + } + if (expr->sctp_send_failure_event->type != EXPR_ELLIPSIS) { + u8 sctp_send_failure_event; + + if (get_u8(expr->sctp_send_failure_event, &sctp_send_failure_event, error)) { + return STATUS_ERR; + } + if (sctp_events->sctp_send_failure_event != sctp_send_failure_event) { + asprintf(error, "sctp_event_subscribe.sctp_send_failure_event: expected: %hhu actual: %hhu", + sctp_send_failure_event, sctp_events->sctp_send_failure_event); + return STATUS_ERR; + } + } + if (expr->sctp_peer_error_event->type != EXPR_ELLIPSIS) { + u8 sctp_peer_error_event; + + if (get_u8(expr->sctp_peer_error_event, &sctp_peer_error_event, error)) { + return STATUS_ERR; + } + if (sctp_events->sctp_peer_error_event != sctp_peer_error_event) { + asprintf(error, "sctp_event_subscribe.sctp_peer_error_event: expected: %hhu actual: %hhu", + sctp_peer_error_event, sctp_events->sctp_peer_error_event); + return STATUS_ERR; + } + } + if (expr->sctp_shutdown_event->type != EXPR_ELLIPSIS) { + u8 sctp_shutdown_event; + + if (get_u8(expr->sctp_shutdown_event, &sctp_shutdown_event, error)) { + return STATUS_ERR; + } + if (sctp_events->sctp_shutdown_event != sctp_shutdown_event) { + asprintf(error, "sctp_event_subscribe.sctp_shutdown_event: expected: %hhu actual: %hhu", + sctp_shutdown_event, sctp_events->sctp_shutdown_event); + return STATUS_ERR; + } + } + if (expr->sctp_partial_delivery_event->type != EXPR_ELLIPSIS) { + u8 sctp_partial_delivery_event; + + if (get_u8(expr->sctp_partial_delivery_event, &sctp_partial_delivery_event, error)) { + return STATUS_ERR; + } + if (sctp_events->sctp_partial_delivery_event != sctp_partial_delivery_event) { + asprintf(error, "sctp_event_subscribe.sctp_partial_delivery_event: expected: %hhu actual: %hhu", + sctp_partial_delivery_event, sctp_events->sctp_partial_delivery_event); + return STATUS_ERR; + } + } + if (expr->sctp_adaptation_layer_event->type != EXPR_ELLIPSIS) { + u8 sctp_adaptation_layer_event; + + if (get_u8(expr->sctp_adaptation_layer_event, &sctp_adaptation_layer_event, error)) { + return STATUS_ERR; + } + if (sctp_events->sctp_adaptation_layer_event != sctp_adaptation_layer_event) { + asprintf(error, "sctp_event_subscribe.sctp_adaptation_layer_event: expected: %hhu actual: %hhu", + sctp_adaptation_layer_event, sctp_events->sctp_adaptation_layer_event); + return STATUS_ERR; + } + } + if (expr->sctp_authentication_event->type != EXPR_ELLIPSIS) { + u8 sctp_authentication_event; + + if (get_u8(expr->sctp_authentication_event, &sctp_authentication_event, error)) { + return STATUS_ERR; + } + if (sctp_events->sctp_authentication_event != sctp_authentication_event) { + asprintf(error, "sctp_event_subscribe.sctp_authentication_event: expected: %hhu actual: %hhu", + sctp_authentication_event, sctp_events->sctp_authentication_event); + return STATUS_ERR; + } + } + if (expr->sctp_sender_dry_event->type != EXPR_ELLIPSIS) { + u8 sctp_sender_dry_event; + + if (get_u8(expr->sctp_sender_dry_event, &sctp_sender_dry_event, error)) { + return STATUS_ERR; + } + if (sctp_events->sctp_sender_dry_event != sctp_sender_dry_event) { + asprintf(error, "sctp_event_subscribe.sctp_sender_dry_event: expected: %hhu actual: %hhu", + sctp_sender_dry_event, sctp_events->sctp_sender_dry_event); + return STATUS_ERR; + } + } + + return STATUS_OK; +} +#endif #ifdef SCTP_DEFAULT_SNDINFO static int check_sctp_sndinfo(struct sctp_sndinfo_expr *expr, struct sctp_sndinfo *sctp_sndinfo, @@ -2529,6 +2658,12 @@ static int syscall_getsockopt(struct state *state, struct syscall_spec *syscall, } break; #endif +#ifdef SCTP_EVENTS + case EXPR_SCTP_EVENT_SUBSCRIBE: + live_optval = malloc(sizeof(struct sctp_event_subscribe)); + live_optlen = sizeof(struct sctp_event_subscribe); + break; +#endif #ifdef SCTP_DEFAULT_SNDINFO case EXPR_SCTP_SNDINFO: live_optval = malloc(sizeof(struct sctp_sndinfo)); @@ -2623,6 +2758,11 @@ static int syscall_getsockopt(struct state *state, struct syscall_spec *syscall, result = check_sctp_event(val_expression->value.sctp_event, live_optval, error); break; #endif +#ifdef SCTP_EVENTS + case EXPR_SCTP_EVENT_SUBSCRIBE: + result = check_sctp_event_subscribe(val_expression->value.sctp_event_subscribe, live_optval, error); + break; +#endif #ifdef SCTP_DEFAULT_SNDINFO case EXPR_SCTP_SNDINFO: result = check_sctp_sndinfo(val_expression->value.sctp_sndinfo, live_optval, error); @@ -2683,6 +2823,9 @@ static int syscall_setsockopt(struct state *state, struct syscall_spec *syscall, #ifdef SCTP_EVENT struct sctp_event event; #endif +#ifdef SCTP_EVENTS + struct sctp_event_subscribe event_subscribe; +#endif #ifdef SCTP_DEFAULT_SNDINFO struct sctp_sndinfo sndinfo; #endif @@ -2696,7 +2839,6 @@ static int syscall_setsockopt(struct state *state, struct syscall_spec *syscall, u8 spp_dscp; #endif #endif - if (check_arg_count(args, 5, error)) return STATUS_ERR; if (s32_arg(args, 0, &script_fd, error)) @@ -2863,6 +3005,51 @@ static int syscall_setsockopt(struct state *state, struct syscall_spec *syscall, optval = &event; break; #endif +#ifdef SCTP_EVENTS + case EXPR_SCTP_EVENT_SUBSCRIBE: + if (get_u8(val_expression->value.sctp_event_subscribe->sctp_data_io_event, + &event_subscribe.sctp_data_io_event, error)) { + return STATUS_ERR; + } + if (get_u8(val_expression->value.sctp_event_subscribe->sctp_association_event, + &event_subscribe.sctp_association_event, error)) { + return STATUS_ERR; + } + if (get_u8(val_expression->value.sctp_event_subscribe->sctp_address_event, + &event_subscribe.sctp_address_event, error)) { + return STATUS_ERR; + } + if (get_u8(val_expression->value.sctp_event_subscribe->sctp_send_failure_event, + &event_subscribe.sctp_send_failure_event, error)) { + return STATUS_ERR; + } + if (get_u8(val_expression->value.sctp_event_subscribe->sctp_peer_error_event, + &event_subscribe.sctp_peer_error_event, error)) { + return STATUS_ERR; + } + if (get_u8(val_expression->value.sctp_event_subscribe->sctp_shutdown_event, + &event_subscribe.sctp_shutdown_event, error)) { + return STATUS_ERR; + } + if (get_u8(val_expression->value.sctp_event_subscribe->sctp_partial_delivery_event, + &event_subscribe.sctp_partial_delivery_event, error)) { + return STATUS_ERR; + } + if (get_u8(val_expression->value.sctp_event_subscribe->sctp_adaptation_layer_event, + &event_subscribe.sctp_adaptation_layer_event, error)) { + return STATUS_ERR; + } + if (get_u8(val_expression->value.sctp_event_subscribe->sctp_authentication_event, + &event_subscribe.sctp_authentication_event, error)) { + return STATUS_ERR; + } + if (get_u8(val_expression->value.sctp_event_subscribe->sctp_sender_dry_event, + &event_subscribe.sctp_sender_dry_event, error)) { + return STATUS_ERR; + } + optval = &event_subscribe; + break; +#endif #ifdef SCTP_DEFAULT_SNDINFO case EXPR_SCTP_SNDINFO: sndinfo.snd_assoc_id = 0; @@ -3761,6 +3948,9 @@ static int check_sctp_notification(struct iovec *iov, case EXPR_ELLIPSIS: break; default: + asprintf(error, "Bad type for iov_base. Can't check type %s", + expression_type_to_string(script_iov_base->type)); + return STATUS_ERR; break; } i++; diff --git a/gtests/net/packetdrill/script.c b/gtests/net/packetdrill/script.c index eaeea6aedce6d6657596cd72edb0d81541e7666d..9f162ddf5f8eee300a0f0ac97c1719674728af61 100644 --- a/gtests/net/packetdrill/script.c +++ b/gtests/net/packetdrill/script.c @@ -76,6 +76,7 @@ struct expression_type_entry expression_type_table[] = { { EXPR_SCTP_STREAM_VALUE, "sctp_stream_value"}, { EXPR_SCTP_ASSOCPARAMS, "sctp_assocparams"}, { EXPR_SCTP_EVENT, "sctp_event" }, + { EXPR_SCTP_EVENT_SUBSCRIBE, "sctp_event_subscribe"}, { EXPR_SCTP_SNDINFO, "sctp_sndinfo" }, { EXPR_SCTP_SETADAPTATION, "sctp_setadaptation"}, { EXPR_SCTP_SNDRCVINFO, "sctp_sndrcvinfo" }, @@ -366,6 +367,18 @@ void free_expression(struct expression *expression) free_expression(expression->value.sctp_event->se_type); free_expression(expression->value.sctp_event->se_on); break; + case EXPR_SCTP_EVENT_SUBSCRIBE: + free_expression(expression->value.sctp_event_subscribe->sctp_data_io_event); + free_expression(expression->value.sctp_event_subscribe->sctp_association_event); + free_expression(expression->value.sctp_event_subscribe->sctp_address_event); + free_expression(expression->value.sctp_event_subscribe->sctp_send_failure_event); + free_expression(expression->value.sctp_event_subscribe->sctp_peer_error_event); + free_expression(expression->value.sctp_event_subscribe->sctp_shutdown_event); + free_expression(expression->value.sctp_event_subscribe->sctp_partial_delivery_event); + free_expression(expression->value.sctp_event_subscribe->sctp_adaptation_layer_event); + free_expression(expression->value.sctp_event_subscribe->sctp_authentication_event); + free_expression(expression->value.sctp_event_subscribe->sctp_sender_dry_event); + break; case EXPR_SCTP_SNDINFO: free_expression(expression->value.sctp_sndinfo->snd_sid); free_expression(expression->value.sctp_sndinfo->snd_flags); @@ -924,6 +937,66 @@ static int evaluate_sctp_event_expression(struct expression *in, return STATUS_OK; } +static int evaluate_sctp_event_subscribe_expression(struct expression *in, + struct expression *out, + char **error) +{ + struct sctp_event_subscribe_expr *in_event; + struct sctp_event_subscribe_expr *out_event; + + assert(in->type == EXPR_SCTP_EVENT_SUBSCRIBE); + assert(in->value.sctp_event_subscribe); + assert(out->type == EXPR_SCTP_EVENT_SUBSCRIBE); + + out->value.sctp_event_subscribe = calloc(1, sizeof(struct sctp_event_subscribe_expr)); + + in_event = in->value.sctp_event_subscribe; + out_event = out->value.sctp_event_subscribe; + + if (evaluate(in_event->sctp_data_io_event, + &out_event->sctp_data_io_event, + error)) + return STATUS_ERR; + if (evaluate(in_event->sctp_association_event, + &out_event->sctp_association_event, + error)) + return STATUS_ERR; + if (evaluate(in_event->sctp_address_event, + &out_event->sctp_address_event, + error)) + return STATUS_ERR; + if (evaluate(in_event->sctp_send_failure_event, + &out_event->sctp_send_failure_event, + error)) + return STATUS_ERR; + if (evaluate(in_event->sctp_peer_error_event, + &out_event->sctp_peer_error_event, + error)) + return STATUS_ERR; + if (evaluate(in_event->sctp_shutdown_event, + &out_event->sctp_shutdown_event, + error)) + return STATUS_ERR; + if (evaluate(in_event->sctp_partial_delivery_event, + &out_event->sctp_partial_delivery_event, + error)) + return STATUS_ERR; + if (evaluate(in_event->sctp_adaptation_layer_event, + &out_event->sctp_adaptation_layer_event, + error)) + return STATUS_ERR; + if (evaluate(in_event->sctp_authentication_event, + &out_event->sctp_authentication_event, + error)) + return STATUS_ERR; + if (evaluate(in_event->sctp_sender_dry_event, + &out_event->sctp_sender_dry_event, + error)) + return STATUS_ERR; + + return STATUS_OK; +} + static int evaluate_sctp_accocparams_expression(struct expression *in, struct expression *out, char **error) @@ -1360,6 +1433,9 @@ static int evaluate(struct expression *in, case EXPR_SCTP_EVENT: result = evaluate_sctp_event_expression(in, out, error); break; + case EXPR_SCTP_EVENT_SUBSCRIBE: + result = evaluate_sctp_event_subscribe_expression(in, out, error); + break; case EXPR_SCTP_SNDINFO: result = evaluate_sctp_sndinfo_expression(in, out, error); break; diff --git a/gtests/net/packetdrill/script.h b/gtests/net/packetdrill/script.h index effbd57118eae1592ffc4c1ae51cac61037947f0..95ca7231b944ca261927844a5aef633c0b0ffff8 100644 --- a/gtests/net/packetdrill/script.h +++ b/gtests/net/packetdrill/script.h @@ -56,6 +56,7 @@ enum expression_t { EXPR_SCTP_PEER_ADDR_PARAMS, /* struct for sctp_paddrparams for SCTP_PEER_ADDR_PARAMS */ EXPR_SCTP_ASSOCPARAMS, /* struct sctp_assocparams for SCTP_ASSOCINFO */ EXPR_SCTP_EVENT, /* struct sctp_event for SCTP_EVENT */ + EXPR_SCTP_EVENT_SUBSCRIBE,/* struct sctp_event_subscribe for SCTP_EVENTS */ EXPR_SCTP_SNDINFO, /* struct sctp_sndinfo for SCTP_DEFAULT_SNDINFO */ EXPR_SCTP_SETADAPTATION, /* struct sctp_setadaptation for SCTP_ADATTATION_LAYER */ EXPR_SCTP_SNDRCVINFO, /* struct sctp_sndrcvinfo for syscall sctp_recvmsg */ @@ -95,6 +96,7 @@ struct expression { struct sctp_stream_value_expr *sctp_stream_value; struct sctp_assocparams_expr *sctp_assocparams; struct sctp_event_expr *sctp_event; + struct sctp_event_subscribe_expr *sctp_event_subscribe; struct sctp_sndinfo_expr *sctp_sndinfo; struct sctp_setadaptation_expr *sctp_setadaptation; struct sctp_sndrcvinfo_expr *sctp_sndrcvinfo; @@ -232,6 +234,20 @@ struct sctp_event_expr { struct expression *se_on; }; +/* Parse tree for sctp_event_subscribe struct in [gs]etsockopt syscall. */ +struct sctp_event_subscribe_expr { + struct expression *sctp_data_io_event; + struct expression *sctp_association_event; + struct expression *sctp_address_event; + struct expression *sctp_send_failure_event; + struct expression *sctp_peer_error_event; + struct expression *sctp_shutdown_event; + struct expression *sctp_partial_delivery_event; + struct expression *sctp_adaptation_layer_event; + struct expression *sctp_authentication_event; + struct expression *sctp_sender_dry_event; +}; + /* Parse tree for sctp_sndinfo struct in [gs]etsockopt syscall. */ struct sctp_sndinfo_expr { struct expression *snd_sid; diff --git a/gtests/net/packetdrill/symbols_freebsd.c b/gtests/net/packetdrill/symbols_freebsd.c index 284e156cd32a93f6df81bf10e15037c7d78eb383..8f8bd758060100cac0c0075508e1b80ab12ed73d 100644 --- a/gtests/net/packetdrill/symbols_freebsd.c +++ b/gtests/net/packetdrill/symbols_freebsd.c @@ -89,6 +89,7 @@ struct int_symbol platform_symbols_table[] = { { SCTP_MAX_BURST, "SCTP_MAX_BURST" }, { SCTP_PEER_ADDR_PARAMS, "SCTP_PEER_ADDR_PARAMS" }, { SCTP_EVENT, "SCTP_EVENT" }, + { SCTP_EVENTS, "SCTP_EVENTS" }, { SCTP_DEFAULT_SNDINFO, "SCTP_DEFAULT_SNDINFO" }, { SCTP_STATUS, "SCTP_STATUS" }, { SCTP_GET_PEER_ADDR_INFO, "SCTP_GET_PEER_ADDR_INFO" }, diff --git a/gtests/net/packetdrill/symbols_linux.c b/gtests/net/packetdrill/symbols_linux.c index 464f2141f87f9ed843c69d1c309d0808eb39d1cc..049ba2356fc6857b2c48ffc2df03a654808f2d5d 100644 --- a/gtests/net/packetdrill/symbols_linux.c +++ b/gtests/net/packetdrill/symbols_linux.c @@ -112,6 +112,9 @@ struct int_symbol platform_symbols_table[] = { #endif #if 0 { SCTP_EVENT, "SCTP_EVENT" }, +#endif +#ifdef SCTP_EVENTS + { SCTP_EVENTS, "SCTP_EVENTS" }, #endif { SCTP_PEER_ADDR_PARAMS, "SCTP_PEER_ADDR_PARAMS" }, { SCTP_STATUS, "SCTP_STATUS" }, diff --git a/gtests/net/packetdrill/tests/bsd/sctp/sctp_get_socket_options.pkt b/gtests/net/packetdrill/tests/bsd/sctp/sctp_get_socket_options.pkt index 1c5977792ac854e857f3733b7803f8826aaa9c57..2b9f57a45ab668a1797af277c6744b7bd6fe6933 100644 --- a/gtests/net/packetdrill/tests/bsd/sctp/sctp_get_socket_options.pkt +++ b/gtests/net/packetdrill/tests/bsd/sctp/sctp_get_socket_options.pkt @@ -115,16 +115,24 @@ sasoc_cookie_life=...}, [20]) = 0 +0 setsockopt(3, IPPROTO_SCTP, SCTP_EVENT, {se_type=SCTP_SHUTDOWN_EVENT, se_on=1}, 8) = 0 +0 getsockopt(3, IPPROTO_SCTP, SCTP_EVENT, {se_type=SCTP_SHUTDOWN_EVENT, se_on=1}, [8]) = 0 -+0 setsockopt(3, IPPROTO_SCTP, SCTP_DEFAULT_SNDINFO, {snd_sid=0, snd_flags=0, snd_ppid=1, snd_context=1}, 16) = 0 -+0 getsockopt(3, IPPROTO_SCTP, SCTP_DEFAULT_SNDINFO, {snd_sid=0, snd_flags=0, snd_ppid=1, snd_context=1}, [16]) = 0 -+0 setsockopt(3, IPPROTO_SCTP, SCTP_DEFAULT_SNDINFO, {snd_sid=0, snd_flags=SCTP_UNORDERED, snd_ppid=2, snd_context=2}, 16) = 0 -+0 getsockopt(3, IPPROTO_SCTP, SCTP_DEFAULT_SNDINFO, {snd_sid=0, snd_flags=SCTP_UNORDERED, snd_ppid=2, snd_context=2}, [16]) = 0 -+0 getsockopt(3, IPPROTO_SCTP, SCTP_DEFAULT_SNDINFO, {snd_sid=0, snd_flags=SCTP_UNORDERED, snd_ppid=2, snd_context=...}, [16]) = 0 ++0 setsockopt(3, IPPROTO_SCTP, SCTP_DEFAULT_SNDINFO, {snd_sid=0, snd_flags=0, snd_ppid=htonl(1), snd_context=1}, 16) = 0 ++0 getsockopt(3, IPPROTO_SCTP, SCTP_DEFAULT_SNDINFO, {snd_sid=0, snd_flags=0, snd_ppid=htonl(1), snd_context=1}, [16]) = 0 ++0 setsockopt(3, IPPROTO_SCTP, SCTP_DEFAULT_SNDINFO, {snd_sid=0, snd_flags=SCTP_UNORDERED, snd_ppid=htonl(2), snd_context=2}, 16) = 0 ++0 getsockopt(3, IPPROTO_SCTP, SCTP_DEFAULT_SNDINFO, {snd_sid=0, snd_flags=SCTP_UNORDERED, snd_ppid=htonl(2), snd_context=2}, [16]) = 0 ++0 getsockopt(3, IPPROTO_SCTP, SCTP_DEFAULT_SNDINFO, {snd_sid=0, snd_flags=SCTP_UNORDERED, snd_ppid=htonl(2), snd_context=...}, [16]) = 0 +0 getsockopt(3, IPPROTO_SCTP, SCTP_DEFAULT_SNDINFO, {snd_sid=0, snd_flags=SCTP_UNORDERED, snd_ppid=..., snd_context=2}, [16]) = 0 -+0 getsockopt(3, IPPROTO_SCTP, SCTP_DEFAULT_SNDINFO, {snd_sid=0, snd_flags=..., snd_ppid=2, snd_context=2}, [16]) = 0 -+0 getsockopt(3, IPPROTO_SCTP, SCTP_DEFAULT_SNDINFO, {snd_sid=..., snd_flags=SCTP_UNORDERED, snd_ppid=2, snd_context=2}, [16]) = 0 ++0 getsockopt(3, IPPROTO_SCTP, SCTP_DEFAULT_SNDINFO, {snd_sid=0, snd_flags=..., snd_ppid=htonl(2), snd_context=2}, [16]) = 0 ++0 getsockopt(3, IPPROTO_SCTP, SCTP_DEFAULT_SNDINFO, {snd_sid=..., snd_flags=SCTP_UNORDERED, snd_ppid=htonl(2), snd_context=2}, [16]) = 0 +0 setsockopt(3, IPPROTO_SCTP, SCTP_ADAPTATION_LAYER, {ssb_adaptation_ind=2}, 4) = 0 +0 getsockopt(3, IPPROTO_SCTP, SCTP_ADAPTATION_LAYER, {ssb_adaptation_ind=2}, [4]) = 0 ++0 setsockopt(3, IPPROTO_SCTP, SCTP_EVENTS, {sctp_data_io_event=1, sctp_association_event=1, sctp_address_event=0, sctp_send_failure_event=1, +sctp_peer_error_event=0, sctp_shutdown_event=1, sctp_partial_delivery_event=0, sctp_adaptation_layer_event=0, sctp_authentication_event=0, +sctp_sender_dry_event=0}, 11) = 0 + ++0 getsockopt(3, IPPROTO_SCTP, SCTP_EVENTS, {sctp_data_io_event=1, sctp_association_event=1, sctp_address_event=0, sctp_send_failure_event=1, +sctp_peer_error_event=0, sctp_shutdown_event=1, sctp_partial_delivery_event=0, sctp_adaptation_layer_event=0, sctp_authentication_event=0, +sctp_sender_dry_event=0}, [11]) = 0 + +0 close(3) = 0 diff --git a/gtests/net/packetdrill/tests/bsd/sctp/sctp_socket_options.pkt b/gtests/net/packetdrill/tests/bsd/sctp/sctp_socket_options.pkt index 4fab681e2a1c615bf8af2793620f9873cbb1c59c..af811a60bd4158cad8ed03642210684a2fde792f 100644 --- a/gtests/net/packetdrill/tests/bsd/sctp/sctp_socket_options.pkt +++ b/gtests/net/packetdrill/tests/bsd/sctp/sctp_socket_options.pkt @@ -45,4 +45,8 @@ +0 setsockopt(3, IPPROTO_SCTP, SCTP_PEER_ADDR_PARAMS, {spp_address={sa_family=AF_INET, sin_port=htons(8080), sin_addr=inet_addr("192.0.2.1")}, spp_hbinterval=30000, spp_pathmaxrxt=100, spp_pathmtu=1468, spp_flags=0, spp_ipv6_flowlabel=0, spp_dscp=0}, 152) = 0 ++0 setsockopt(3, IPPROTO_SCTP, SCTP_EVENTS, {sctp_data_io_event=1, sctp_association_event=0, sctp_address_event=0, sctp_send_failure_event=0, +sctp_peer_error_event=0, sctp_shutdown_event=0, sctp_partial_delivery_event=0, sctp_adaptation_layer_event=0, sctp_authentication_event=0, +sctp_sender_dry_event=0}, 11) = 0 + +0 close(3) = 0