[PATCH] wpa_cli: Don't buffer stdout.

Ben Greear greearb at candelatech.com
Fri Jun 9 06:27:23 PDT 2017



On 06/09/2017 05:46 AM, Slava Monich wrote:
> On 08/06/17 23:21, greearb at candelatech.com wrote:
>> From: Ben Greear <greearb at candelatech.com>
>>
>> I am trying to read from a wpa_cli process using a perl script,
>> and it appears that wpa_cli was buffering output and so my script
>> would not see events properly.  This patch apepars to fix it.
>>
>> Signed-off-by: Ben Greear <greearb at candelatech.com>
>
> Another way to fix this problem is to allocate a pty (pseudo terminal) and connect the output of the child process to that, to turn on line buffering in the stdio library [1]. Don't know how to do that from perl though...
>
> It's a bit more complicated but once you learn how to do that, you no longer need to modify the program you are spawning in order to pull the output from it line by line.
>
> [1]: http://rachid.koucha.free.fr/tech_corner/pty_pdip.html

My fix seems a whole lot simpler than what you propose, but thanks for the suggestion!

Thanks,
Ben

>
> Cheers,
> -Slava
>
>
>> ---
>>   wpa_supplicant/wpa_cli.c | 5 +++++
>>   1 file changed, 5 insertions(+)
>>
>> diff --git a/wpa_supplicant/wpa_cli.c b/wpa_supplicant/wpa_cli.c
>> index 4cdc4fb..510f385 100644
>> --- a/wpa_supplicant/wpa_cli.c
>> +++ b/wpa_supplicant/wpa_cli.c
>> @@ -4410,6 +4410,11 @@ int main(int argc, char *argv[])
>>           }
>>       }
>>   +    /* Don't buffer stdout, we need to see events immediately as they
>> +     * happen.
>> +     */
>> +    setbuf(stdout, NULL);
>> +
>>       interactive = (argc == optind) && (action_file == NULL);
>>         if (interactive)
>

-- 
Ben Greear <greearb at candelatech.com>
Candela Technologies Inc  http://www.candelatech.com



More information about the Hostap mailing list