All of lore.kernel.org
 help / color / mirror / Atom feed
From: "Philippe Mathieu-Daudé" <f4bug@amsat.org>
To: "Alex Bennée" <alex.bennee@linaro.org>, qemu-devel@nongnu.org
Cc: fam@euphon.net, berrange@redhat.com,
	Robert Foley <robert.foley@linaro.org>,
	richard.henderson@linaro.org, cota@braap.org,
	Cleber Rosa <crosa@redhat.com>, John Snow <jsnow@redhat.com>,
	aurelien@aurel32.net, Eduardo Habkost <ehabkost@redhat.com>
Subject: Re: [PATCH v3 14/16] python/qemu: Cleanup changes to ConsoleSocket
Date: Fri, 24 Jul 2020 09:25:10 +0200	[thread overview]
Message-ID: <f92eef51-ba19-1be1-c70a-3715587ff44a@amsat.org> (raw)
In-Reply-To: <20200724064509.331-15-alex.bennee@linaro.org>

+John who requested the changes.

On 7/24/20 8:45 AM, Alex Bennée wrote:
> From: Robert Foley <robert.foley@linaro.org>
> 
> The changes to console_socket.py and machine.py are to
> cleanup for pylint and flake8.
> 
> Signed-off-by: Robert Foley <robert.foley@linaro.org>
> Reviewed-by: Alex Bennée <alex.bennee@linaro.org>
> Signed-off-by: Alex Bennée <alex.bennee@linaro.org>
> Message-Id: <20200717203041.9867-2-robert.foley@linaro.org>
> ---
>  python/qemu/console_socket.py | 57 ++++++++++++++++++-----------------
>  python/qemu/machine.py        |  7 +++--
>  python/qemu/pylintrc          |  2 +-
>  3 files changed, 34 insertions(+), 32 deletions(-)
> 
> diff --git a/python/qemu/console_socket.py b/python/qemu/console_socket.py
> index 830cb7c6282..09986bc2152 100644
> --- a/python/qemu/console_socket.py
> +++ b/python/qemu/console_socket.py
> @@ -1,12 +1,9 @@
> -#!/usr/bin/env python3
> -#
> -# This python module implements a ConsoleSocket object which is
> -# designed always drain the socket itself, and place
> -# the bytes into a in memory buffer for later processing.
> -#
> -# Optionally a file path can be passed in and we will also
> -# dump the characters to this file for debug.
> -#
> +"""
> +QEMU Console Socket Module:
> +
> +This python module implements a ConsoleSocket object,
> +which can drain a socket and optionally dump the bytes to file.
> +"""
>  # Copyright 2020 Linaro
>  #
>  # Authors:
> @@ -15,20 +12,27 @@
>  # This code is licensed under the GPL version 2 or later.  See
>  # the COPYING file in the top-level directory.
>  #
> +
>  import asyncore
>  import socket
>  import threading
> -import io
> -import os
> -import sys
>  from collections import deque
>  import time
> -import traceback
> +
>  
>  class ConsoleSocket(asyncore.dispatcher):
> +    """
> +    ConsoleSocket represents a socket attached to a char device.
>  
> +    Drains the socket and places the bytes into an in memory buffer
> +    for later processing.
> +
> +    Optionally a file path can be passed in and we will also
> +    dump the characters to this file for debugging purposes.
> +    """
>      def __init__(self, address, file=None):
>          self._recv_timeout_sec = 300
> +        self._sleep_time = 0.5
>          self._buffer = deque()
>          self._asyncore_thread = None
>          self._sock = socket.socket(socket.AF_UNIX, socket.SOCK_STREAM)
> @@ -70,31 +74,28 @@ class ConsoleSocket(asyncore.dispatcher):
>  
>      def handle_read(self):
>          """process arriving characters into in memory _buffer"""
> -        try:
> -            data = asyncore.dispatcher.recv(self, 1)
> -            # latin1 is needed since there are some chars
> -            # we are receiving that cannot be encoded to utf-8
> -            # such as 0xe2, 0x80, 0xA6.
> -            string = data.decode("latin1")
> -        except:
> -            print("Exception seen.")
> -            traceback.print_exc()
> -            return
> +        data = asyncore.dispatcher.recv(self, 1)

A bit more than the commit description, but I don't mind.

Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org>

> +        # latin1 is needed since there are some chars
> +        # we are receiving that cannot be encoded to utf-8
> +        # such as 0xe2, 0x80, 0xA6.
> +        string = data.decode("latin1")
>          if self._logfile:
>              self._logfile.write("{}".format(string))
>              self._logfile.flush()
>          for c in string:
>              self._buffer.extend(c)
>  
> -    def recv(self, n=1, sleep_delay_s=0.1):
> -        """Return chars from in memory buffer"""
> +    def recv(self, buffer_size=1):
> +        """Return chars from in memory buffer.
> +           Maintains the same API as socket.socket.recv.
> +        """
>          start_time = time.time()
> -        while len(self._buffer) < n:
> -            time.sleep(sleep_delay_s)
> +        while len(self._buffer) < buffer_size:
> +            time.sleep(self._sleep_time)
>              elapsed_sec = time.time() - start_time
>              if elapsed_sec > self._recv_timeout_sec:
>                  raise socket.timeout
> -        chars = ''.join([self._buffer.popleft() for i in range(n)])
> +        chars = ''.join([self._buffer.popleft() for i in range(buffer_size)])
>          # We choose to use latin1 to remain consistent with
>          # handle_read() and give back the same data as the user would
>          # receive if they were reading directly from the
> diff --git a/python/qemu/machine.py b/python/qemu/machine.py
> index 80c4d4a8b6e..9956360a792 100644
> --- a/python/qemu/machine.py
> +++ b/python/qemu/machine.py
> @@ -27,7 +27,7 @@ import socket
>  import tempfile
>  from typing import Optional, Type
>  from types import TracebackType
> -from qemu.console_socket import ConsoleSocket
> +from . import console_socket
>  
>  from . import qmp
>  
> @@ -674,8 +674,9 @@ class QEMUMachine:
>          """
>          if self._console_socket is None:
>              if self._drain_console:
> -                self._console_socket = ConsoleSocket(self._console_address,
> -                                                    file=self._console_log_path)
> +                self._console_socket = console_socket.ConsoleSocket(
> +                    self._console_address,
> +                    file=self._console_log_path)
>              else:
>                  self._console_socket = socket.socket(socket.AF_UNIX,
>                                                       socket.SOCK_STREAM)
> diff --git a/python/qemu/pylintrc b/python/qemu/pylintrc
> index 5d6ae7367d8..3f69205000d 100644
> --- a/python/qemu/pylintrc
> +++ b/python/qemu/pylintrc
> @@ -33,7 +33,7 @@ good-names=i,
>             Run,
>             _,
>             fd,
> -
> +           c,
>  [VARIABLES]
>  
>  [STRING]
> 


  reply	other threads:[~2020-07-24  7:26 UTC|newest]

Thread overview: 24+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2020-07-24  6:44 [PATCH v3 00/16] candidate fixes for 5.1-rc1 (testing, semihosting, OOM tcg, x86 fpu) Alex Bennée
2020-07-24  6:44 ` [PATCH v3 01/16] shippable: add one more qemu to registry url Alex Bennée
2020-07-24  6:44 ` [PATCH v3 02/16] semihosting: defer connect_chardevs a little more to use serialx Alex Bennée
2020-07-24  6:44 ` [PATCH v3 03/16] semihosting: don't send the trailing '\0' Alex Bennée
2020-07-24  6:44 ` [PATCH v3 04/16] util: add qemu_get_host_physmem utility function Alex Bennée
2020-07-24  6:44 ` [PATCH v3 05/16] util/oslib-win32: add qemu_get_host_physmem implementation Alex Bennée
2020-07-24  6:51   ` Stefan Weil
2020-07-24  6:44 ` [PATCH v3 06/16] accel/tcg: better handle memory constrained systems Alex Bennée
2020-07-24 13:41   ` Robert Foley
2020-07-24 18:22   ` Richard Henderson
2020-07-24  6:45 ` [PATCH v3 07/16] target/i386: floatx80: avoid compound literals in static initializers Alex Bennée
2020-07-24 18:23   ` Richard Henderson
2020-07-24  6:45 ` [PATCH v3 08/16] linux-user: don't use MAP_FIXED in pgd_find_hole_fallback Alex Bennée
2020-07-24  6:45 ` [PATCH v3 09/16] tests/docker: fix update command due to python3 str/bytes distinction Alex Bennée
2020-07-24  6:45 ` [PATCH v3 10/16] tests/docker: fix binfmt_misc image building Alex Bennée
2020-07-24  6:45 ` [PATCH v3 11/16] tests/docker: add support for DEB_KEYRING Alex Bennée
2020-07-24  6:45 ` [PATCH v3 12/16] linux-user: fix clock_nanosleep() Alex Bennée
2020-07-24 18:24   ` Richard Henderson
2020-07-24  6:45 ` [PATCH v3 13/16] linux-user, ppc: fix clock_nanosleep() for linux-user-ppc Alex Bennée
2020-07-24 18:24   ` [PATCH v3 13/16] linux-user,ppc: " Richard Henderson
2020-07-24  6:45 ` [PATCH v3 14/16] python/qemu: Cleanup changes to ConsoleSocket Alex Bennée
2020-07-24  7:25   ` Philippe Mathieu-Daudé [this message]
2020-07-24  6:45 ` [PATCH v3 15/16] python/qemu: Change ConsoleSocket to optionally drain socket Alex Bennée
2020-07-24  6:45 ` [PATCH v3 16/16] tests/vm: add shutdown timeout in basevm.py Alex Bennée

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=f92eef51-ba19-1be1-c70a-3715587ff44a@amsat.org \
    --to=f4bug@amsat.org \
    --cc=alex.bennee@linaro.org \
    --cc=aurelien@aurel32.net \
    --cc=berrange@redhat.com \
    --cc=cota@braap.org \
    --cc=crosa@redhat.com \
    --cc=ehabkost@redhat.com \
    --cc=fam@euphon.net \
    --cc=jsnow@redhat.com \
    --cc=qemu-devel@nongnu.org \
    --cc=richard.henderson@linaro.org \
    --cc=robert.foley@linaro.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.