Change priority update scheme

This commit is contained in:
Tatsuhiro Tsujikawa 2013-07-23 21:33:28 +09:00
parent 3c9e31da87
commit 65cb559431
1 changed files with 30 additions and 39 deletions

View File

@ -581,9 +581,8 @@ static int nghttp2_session_predicate_syn_reply_send(nghttp2_session *session,
} }
/* /*
* This function checks HEADERS, which is neither stream-opening nor * This function checks frames belongs to the stream |stream_id| can
* first response header, with the stream ID |stream_id| can be sent * be sent.
* at this time.
* *
* This function returns 0 if it succeeds, or one of the following * This function returns 0 if it succeeds, or one of the following
* negative error codes: * negative error codes:
@ -599,8 +598,8 @@ static int nghttp2_session_predicate_syn_reply_send(nghttp2_session *session,
* The state of the stream is not valid (e.g., if the local peer * The state of the stream is not valid (e.g., if the local peer
* is receiving side and SYN_REPLY has not been sent). * is receiving side and SYN_REPLY has not been sent).
*/ */
static int nghttp2_session_predicate_headers_send(nghttp2_session *session, static int nghttp2_session_predicate_stream_frame_send
int32_t stream_id) (nghttp2_session* session, int32_t stream_id)
{ {
nghttp2_stream *stream = nghttp2_session_get_stream(session, stream_id); nghttp2_stream *stream = nghttp2_session_get_stream(session, stream_id);
int r; int r;
@ -625,38 +624,25 @@ static int nghttp2_session_predicate_headers_send(nghttp2_session *session,
} }
} }
/*
* This function checks HEADERS, which is neither stream-opening nor
* first response header, with the stream ID |stream_id| can be sent
* at this time.
*/
static int nghttp2_session_predicate_headers_send(nghttp2_session *session,
int32_t stream_id)
{
return nghttp2_session_predicate_stream_frame_send(session, stream_id);
}
/* /*
* This function checks PRIORITY frame with stream ID |stream_id| can * This function checks PRIORITY frame with stream ID |stream_id| can
* be sent at this time. * be sent at this time.
*
* This function returns 0 if it is succeeds, or one of the following
* negative error codes:
*
* NGHTTP2_ERR_STREAM_CLOSED
* The stream is already closed or does not exist.
* NGHTTP2_ERR_STREAM_SHUT_WR
* The transmission is not allowed for this stream (e.g., a frame
* with END_STREAM flag set has already sent)
* NGHTTP2_ERR_STREAM_CLOSING
* RST_STREAM was queued for this stream.
*/ */
static int nghttp2_session_predicate_priority_send static int nghttp2_session_predicate_priority_send
(nghttp2_session *session, int32_t stream_id) (nghttp2_session *session, int32_t stream_id)
{ {
nghttp2_stream *stream = nghttp2_session_get_stream(session, stream_id); return nghttp2_session_predicate_stream_frame_send(session, stream_id);
int r;
r = nghttp2_predicate_stream_for_send(stream);
if(r != 0) {
return r;
}
/* The spec is not clear if the receiving side can issue PRIORITY
and the other side should do when receiving it. We just send
PRIORITY if requested. */
if(stream->state != NGHTTP2_STREAM_CLOSING) {
return 0;
} else {
return NGHTTP2_ERR_STREAM_CLOSING;
}
} }
/* /*
@ -1133,15 +1119,17 @@ static int nghttp2_session_after_frame_sent(nghttp2_session *session)
} }
break; break;
} }
case NGHTTP2_PRIORITY: { case NGHTTP2_PRIORITY:
nghttp2_stream *stream = nghttp2_session_get_stream(session, // TODO Update priority of the stream if the stream is initiated
frame->hd.stream_id); // by the local endpoint. The spec is not detailed about this.
if(stream) { if(nghttp2_session_is_my_stream_id(session, frame->hd.stream_id)) {
// Just update priority for the stream for now. nghttp2_stream *stream;
stream->pri = frame->priority.pri; stream = nghttp2_session_get_stream(session, frame->hd.stream_id);
if(stream) {
stream->pri = frame->priority.pri;
}
} }
break; break;
}
case NGHTTP2_RST_STREAM: case NGHTTP2_RST_STREAM:
nghttp2_session_close_stream(session, frame->hd.stream_id, nghttp2_session_close_stream(session, frame->hd.stream_id,
frame->rst_stream.error_code); frame->rst_stream.error_code);
@ -1636,8 +1624,11 @@ int nghttp2_session_on_priority_received(nghttp2_session *session,
stream = nghttp2_session_get_stream(session, frame->hd.stream_id); stream = nghttp2_session_get_stream(session, frame->hd.stream_id);
if(stream) { if(stream) {
if((stream->shut_flags & NGHTTP2_SHUT_RD) == 0) { if((stream->shut_flags & NGHTTP2_SHUT_RD) == 0) {
// Just update priority anyway for now // Update the priority of the stream if the stream is initiated
stream->pri = frame->priority.pri; // by the remote endpoint.
if(!nghttp2_session_is_my_stream_id(session, frame->hd.stream_id)) {
stream->pri = frame->priority.pri;
}
nghttp2_session_call_on_frame_received(session, frame); nghttp2_session_call_on_frame_received(session, frame);
} else { } else {
return nghttp2_session_handle_invalid_stream(session, frame, return nghttp2_session_handle_invalid_stream(session, frame,