]> git.sesse.net Git - rdpsrv/blobdiff - rdp.c
Reduce small block size to 32x32, and parametrize (#defines instead of hardcoding)
[rdpsrv] / rdp.c
diff --git a/rdp.c b/rdp.c
index bcb1bd8c05f445b20b0441ce02d0a040e765603a..dc32fc298085a954b25c1bbd9f81ee33a69d1479 100644 (file)
--- a/rdp.c
+++ b/rdp.c
@@ -152,10 +152,13 @@ void rdp_send_bitmap_update(unsigned x, unsigned y, unsigned width, unsigned hei
 {
        STREAM s;
 
-       int length = 10*2 + width*height*3 + 5;
+       int length = 10*2 + width*height*3 + 5 + 3;
 
        s = rdp5_init(length, 1);
 
+       out_uint8(s, 3); // ??
+       out_uint16_le(s, 0); // length
+       
        out_uint8(s, 1); // process bitmap update
        out_uint16_le(s, 10*2 + width*height*3 + 2); // RDP5 chunk length
        out_uint16_le(s, 10*2 + width*height*3);     // part length
@@ -287,7 +290,7 @@ rdp_get_logon_info(STREAM s)
 }
 
 /* Send a control PDU */
-static void
+void
 rdp_send_control(uint16 action)
 {
        STREAM s;
@@ -303,15 +306,15 @@ rdp_send_control(uint16 action)
 }
 
 /* Send a synchronisation PDU */
-static void
-rdp_send_synchronise(void)
+void
+rdp_send_synchronise(uint16 id)
 {
        STREAM s;
 
        s = rdp_init_data(4);
 
        out_uint16_le(s, 1);    /* type */
-       out_uint16_le(s, 1002);
+       out_uint16_le(s, id);
 
        s_mark_end(s);
        rdp_send_data(s, RDP_DATA_PDU_SYNCHRONISE);