[Spice-devel] [PATCH spice-server 00/15] A bunch of stream cleanups

Frediano Ziglio fziglio at redhat.com
Mon Nov 6 17:30:36 UTC 2017


> 
> Jonathon Jongsma writes:
> 
> > I sent two of these patches earlier (one ACKed by Frediano), but decided
> > to do a little more cleanup here. There are a couple of basic issues
> > related to the Stream stuff:
> >  1. The word Stream is used in a couple of ways within the spice-server
> >     codebase. The first is a generic data stream between the client and
> >     server (RedStream). The second is a portion of the display that is
> >     encoded as a video stream. To prevent confusion, this series renamed
> >     Stream to VideoStream to make it more explicit.
> >  2. the stream.[ch] files contain a hodgepodge of functions and types
> >     related to video streaming. But some of them are the realm of the
> >     display channel and some are the realm of the channel client. This
> >     series attempts to clean that up a little bit by moving some
> >     channel-client-specific stuff to dcc*.[ch] and some channel-specific
> >     stuff to display-channel.[ch]. It doesn't fully solve the issue, but
> >     I think it helps.
> 
> +1
> 
> >
> > Jonathon Jongsma (15):
> >   Use standard "Red" namespace
> >   RedStream: make some functions static
> >   Move stream agent manipulation to dcc
> >   Stream: store channel in stream
> >   Move RedStreamClipItem to dcc.c
> >   Move dcc_update-streams_max_latency to dcc.c
> >   Move StreamCreateDestroyItem to dcc
> >   Move dcc_create_stream() to dcc
> >   Factor out dcc_stream_stop()
> >   Factor out dcc_attach_stream()
> >   Rename Stream to VideoStream
> >   Rename VideoStream methods
> >   Rename StreamAgent to VideoStreamAgent
> >   Move display_channel_init_video_streams()
> >   Move display_channel_create_video_stream()
> 
> For the series:
> 
> Reviewed-by: Christophe de Dinechin <dinechin at redhat.com>
> 

We had a quick discussion on the streaming part.
Currently DisplayChannel is split in 4 C files:
- display-channel.c
- dcc.c
- dcc-send.c
- stream.c
All other channels are implemented with one or 2 (Channel+ChannelClient)
files.
The rationale between dcc and dcc-send is mainly dcc-send should contain
just client part sending (for instance marshalling) messages. This as
DisplayChannel messages are more complicate and copious compared to other
channels.
But we didn't find a clear rationale on what should be put inside stream.c.
For instance should marshalling of stream_data message be in dcc-send or
stream? Or why Stream and StreamAgent are in the same file if they are
related to Channel and ChannelClient, respectively.

I agree on the rename Stream -> VideoStream.

Frediano

> 
> >
> >  server/Makefile.am                     |   8 +-
> >  server/common-graphics-channel.c       |   4 +-
> >  server/cursor-channel-client.c         |   2 +-
> >  server/cursor-channel-client.h         |   4 +-
> >  server/cursor-channel.c                |   2 +-
> >  server/cursor-channel.h                |   2 +-
> >  server/dcc-private.h                   |   4 +-
> >  server/dcc-send.c                      |  20 +-
> >  server/dcc.c                           | 372 ++++++++++++-
> >  server/dcc.h                           |  32 +-
> >  server/display-channel-private.h       |   8 +-
> >  server/display-channel.c               | 134 ++++-
> >  server/display-channel.h               |  10 +-
> >  server/inputs-channel-client.c         |   2 +-
> >  server/inputs-channel-client.h         |   2 +-
> >  server/inputs-channel.c                |   6 +-
> >  server/main-channel-client.c           |   2 +-
> >  server/main-channel-client.h           |   2 +-
> >  server/main-channel.c                  |   2 +-
> >  server/main-channel.h                  |   2 +-
> >  server/red-channel-client.c            |  28 +-
> >  server/red-channel-client.h            |   4 +-
> >  server/red-channel.c                   |   6 +-
> >  server/red-channel.h                   |   6 +-
> >  server/red-qxl.c                       |   4 +-
> >  server/{reds-stream.c => red-stream.c} | 284 +++++-----
> >  server/red-stream.h                    |  90 ++++
> >  server/red-worker.c                    |   5 +-
> >  server/red-worker.h                    |   4 +-
> >  server/reds-private.h                  |   2 +-
> >  server/reds-stream.h                   |  93 ----
> >  server/reds.c                          | 158 +++---
> >  server/smartcard-channel-client.c      |   2 +-
> >  server/smartcard-channel-client.h      |   2 +-
> >  server/smartcard.c                     |   2 +-
> >  server/sound.c                         |  10 +-
> >  server/spicevmc.c                      |  12 +-
> >  server/stream-channel.c                |   6 +-
> >  server/stream.c                        | 955
> >  ---------------------------------
> >  server/tests/test-channel.c            |   6 +-
> >  server/tests/test-stream.c             |  24 +-
> >  server/video-stream.c                  | 544 +++++++++++++++++++
> >  server/{stream.h => video-stream.h}    |  60 +--
> >  43 files changed, 1478 insertions(+), 1449 deletions(-)
> >  rename server/{reds-stream.c => red-stream.c} (74%)
> >  create mode 100644 server/red-stream.h
> >  delete mode 100644 server/reds-stream.h
> >  delete mode 100644 server/stream.c
> >  create mode 100644 server/video-stream.c
> >  rename server/{stream.h => video-stream.h} (72%)
> 


More information about the Spice-devel mailing list