On 6/11/24 6:05 PM, jor...@apache.org wrote:
> Author: jorton
> Date: Tue Jun 11 16:05:22 2024
> New Revision: 1918258
> 
> URL: http://svn.apache.org/viewvc?rev=1918258&view=rev
> Log:
> * file_io/unix/pipe.c (file_pipe_create): Use pipe2(,O_NONBLOCK) by
>   default unless APR_FULL_BLOCK was used; unconditionally set the
>   blocking state later. Saves two syscalls per invocation for both
>   APR_READ_BLOCK and APR_WRITE_BLOCK, no [intended] functional change.

I guess it is me being blind , but how do we save two syscalls for the
APR_READ_BLOCK and APR_WRITE_BLOCK case each? With the code before the patch
we started with a blocking pipe and needed to set one end of the pipe to non 
blocking.
Now we start with a non blocking pipe and need to set the other end to blocking.
Where did I get lost and miss the point?

Regards

RĂ¼diger

> 
> Github: closes #56
> 
> Modified:
>     apr/apr/trunk/file_io/unix/pipe.c
> 
> Modified: apr/apr/trunk/file_io/unix/pipe.c
> URL: 
> http://svn.apache.org/viewvc/apr/apr/trunk/file_io/unix/pipe.c?rev=1918258&r1=1918257&r2=1918258&view=diff
> ==============================================================================
> --- apr/apr/trunk/file_io/unix/pipe.c (original)
> +++ apr/apr/trunk/file_io/unix/pipe.c Tue Jun 11 16:05:22 2024
> @@ -186,7 +186,10 @@ static apr_status_t file_pipe_create(apr
>      apr_interval_time_t fd_timeout;
>  
>  #ifdef HAVE_PIPE2
> -    if (blocking == APR_FULL_NONBLOCK) {
> +    /* If pipe2() is available, use O_NONBLOCK by default unless
> +     * APR_FULL_BLOCK is requested, then set the individual pipe state
> +     * as desired later - changing the state uses two syscalls. */
> +    if (blocking != APR_FULL_BLOCK) {
>          if (pipe2(filedes, O_NONBLOCK) == -1) {
>              return errno;
>          }
> @@ -239,21 +242,14 @@ static apr_status_t file_pipe_create(apr
>      apr_pool_cleanup_register((*out)->pool, (void *)(*out), 
> apr_unix_file_cleanup,
>                           apr_pool_cleanup_null);
>  
> -    switch (blocking) {
> -    case APR_FULL_BLOCK:
> -        break;
> -    case APR_READ_BLOCK:
> -        apr_file_pipe_timeout_set(*out, 0);
> -        break;
> -    case APR_WRITE_BLOCK:
> -        apr_file_pipe_timeout_set(*in, 0);
> -        break;
> -    default:
> -        /* These are noops for the pipe2() case */
> -        apr_file_pipe_timeout_set(*out, 0);
> -        apr_file_pipe_timeout_set(*in, 0);
> -        break;
> -    }
> +    /* Set each pipe to the desired O_NONBLOCK state, which may be a
> +     * noop depending on whether the pipe2() or pipe() case was
> +     * used. (timeout of -1 == blocking) */
> +    apr_file_pipe_timeout_set(*in, (blocking == APR_FULL_BLOCK
> +                                    || blocking == APR_READ_BLOCK) ? -1 : 0);
> +    apr_file_pipe_timeout_set(*out, (blocking == APR_FULL_BLOCK
> +                                     || blocking == APR_WRITE_BLOCK) ? -1 : 
> 0);
> +
>      return APR_SUCCESS;
>  }
>  
> 
> 
> 

Reply via email to