mirror of
https://github.com/apache/nuttx.git
synced 2025-01-13 08:38:38 +08:00
VNC: Add basic message receipt logic
This commit is contained in:
parent
c767686b3d
commit
3ca5a94515
4 changed files with 66 additions and 2 deletions
|
@ -7,6 +7,7 @@ menuconfig VNCSERVER
|
|||
bool "VNC server"
|
||||
default n
|
||||
depends on NET_TCP && !NX_LCDDRIVER && EXPERIMENTAL
|
||||
select NET_TCP_READAHEAD
|
||||
---help---
|
||||
Enable support for a VNC Remote Frame Buffer (RFB) server.
|
||||
|
||||
|
|
|
@ -109,7 +109,7 @@ int vnc_negotiate(FAR struct vnc_session_s *session)
|
|||
/* Receive the echo of the protocol string */
|
||||
|
||||
nrecvd = psock_recv(&session->connect, session->inbuf, len, 0);
|
||||
if (nrecvd <= 0)
|
||||
if (nrecvd < 0)
|
||||
{
|
||||
errcode = get_errno();
|
||||
gdbg("ERROR: Receive protocol confirmation failed: %d\n", errcode);
|
||||
|
|
|
@ -39,7 +39,12 @@
|
|||
|
||||
#include <nuttx/config.h>
|
||||
|
||||
#include <assert.h>
|
||||
#include <errno.h>
|
||||
#include <debug.h>
|
||||
|
||||
#include <nuttx/net/net.h>
|
||||
#include <nuttx/video/rfb.h>
|
||||
|
||||
#include "vnc_server.h"
|
||||
|
||||
|
@ -67,6 +72,64 @@
|
|||
|
||||
int vnc_receiver(FAR struct vnc_session_s *session)
|
||||
{
|
||||
ssize_t nrecvd;
|
||||
int errcode;
|
||||
|
||||
/* Loop until the client disconnects or an unhandled error occurs */
|
||||
|
||||
for (; ; )
|
||||
{
|
||||
/* Set up to read one byte which should be the message type of the
|
||||
* next Client-to-Server message. We will block here until the message
|
||||
* is received.
|
||||
*/
|
||||
|
||||
nrecvd = psock_recv(&session->connect, session->inbuf, 1, 0);
|
||||
if (nrecvd < 0)
|
||||
{
|
||||
errcode = get_errno();
|
||||
gdbg("ERROR: Receive byte failed: %d\n", errcode);
|
||||
DEBUGASSERT(errcode > 0);
|
||||
return -errcode;
|
||||
}
|
||||
|
||||
DEBUGASSERT(nrecvd == 1);
|
||||
|
||||
/* The single byte received should be the message type. Handle the
|
||||
* message according to this message type.
|
||||
*/
|
||||
|
||||
switch (session->inbuf[0])
|
||||
{
|
||||
case RFB_SETPIXELFMT_MSG: /* SetPixelFormat */
|
||||
#warning Missing logic
|
||||
break;
|
||||
|
||||
case RFB_SETENCODINGS_MSG: /* SetEncodings */
|
||||
#warning Missing logic
|
||||
break;
|
||||
|
||||
case RFB_FBUPDATEREQ_MSG: /* FramebufferUpdateRequest */
|
||||
#warning Missing logic
|
||||
break;
|
||||
|
||||
case RFB_KEYEVENT_MSG: /* KeyEvent */
|
||||
#warning Missing logic
|
||||
break;
|
||||
|
||||
case RFB_POINTEREVENT_MSG: /* PointerEvent */
|
||||
#warning Missing logic
|
||||
break;
|
||||
|
||||
case RFB_CLIENTCUTTEXT_MSG: /* ClientCutText */
|
||||
#warning Missing logic
|
||||
break;
|
||||
|
||||
default:
|
||||
gdbg("ERROR: Unsynchronized, msgtype=%d\n", session->inbuf[0]);
|
||||
return -EPROTO;
|
||||
}
|
||||
}
|
||||
|
||||
return -ENOSYS;
|
||||
}
|
||||
|
|
|
@ -261,7 +261,7 @@ static inline void recvfrom_newtcpdata(FAR struct net_driver_s *dev,
|
|||
|
||||
size_t recvlen = recvfrom_newdata(dev, pstate);
|
||||
|
||||
/* If there is more data left in the packet that we could not buffer, than
|
||||
/* If there is more data left in the packet that we could not buffer, then
|
||||
* add it to the read-ahead buffers.
|
||||
*/
|
||||
|
||||
|
|
Loading…
Reference in a new issue