summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--libxrdp/Makefile1
-rw-r--r--libxrdp/xrdp_rdp.c68
2 files changed, 68 insertions, 1 deletions
diff --git a/libxrdp/Makefile b/libxrdp/Makefile
index 19393919..6986766d 100644
--- a/libxrdp/Makefile
+++ b/libxrdp/Makefile
@@ -14,6 +14,7 @@ DEFINES = -DXRDP_CFG_FILE=\"$(CFGDIR)/xrdp.ini\" \
-DXRDP_KEY_FILE=\"$(CFGDIR)/rsakeys.ini\"
CFLAGS = -Wall -O2 -I../common -fPIC $(DEFINES)
+#CFLAGS += -DXRDP_DEBUG
C_OS_FLAGS = $(CFLAGS) -c
LDFLAGS = -shared
LIBS = -ldl
diff --git a/libxrdp/xrdp_rdp.c b/libxrdp/xrdp_rdp.c
index c84e6673..7d9d376f 100644
--- a/libxrdp/xrdp_rdp.c
+++ b/libxrdp/xrdp_rdp.c
@@ -107,6 +107,13 @@ xrdp_rdp_create(struct xrdp_session* session, int sck)
self->sec_layer = xrdp_sec_create(self, sck);
/* read ini settings */
xrdp_rdp_read_config(&self->client_info);
+ /* deafult 8 bit color bitmap cache entries and size */
+ self->client_info.cache1_entries = 600;
+ self->client_info.cache1_size = 256;
+ self->client_info.cache2_entries = 300;
+ self->client_info.cache2_size = 1024;
+ self->client_info.cache3_entries = 262;
+ self->client_info.cache3_size = 4096;
return self;
}
@@ -495,6 +502,12 @@ xrdp_process_capset_bmpcache(struct xrdp_rdp* self, struct stream* s,
in_uint16_le(s, self->client_info.cache2_size);
in_uint16_le(s, self->client_info.cache3_entries);
in_uint16_le(s, self->client_info.cache3_size);
+ DEBUG(("cache1 entries %d size %d\r\n", self->client_info.cache1_entries,
+ self->client_info.cache1_size));
+ DEBUG(("cache2 entries %d size %d\r\n", self->client_info.cache2_entries,
+ self->client_info.cache2_size));
+ DEBUG(("cache3 entries %d size %d\r\n", self->client_info.cache3_entries,
+ self->client_info.cache3_size));
return 0;
}
@@ -525,6 +538,7 @@ xrdp_rdp_process_confirm_active(struct xrdp_rdp* self, struct stream* s)
int len;
char* p;
+ DEBUG(("in xrdp_rdp_process_confirm_active\r\n"));
in_uint8s(s, 4); /* rdp_shareid */
in_uint8s(s, 2); /* userid */
in_uint16_le(s, source_len); /* sizeof RDP_SOURCE */
@@ -540,20 +554,70 @@ xrdp_rdp_process_confirm_active(struct xrdp_rdp* self, struct stream* s)
switch (type)
{
case RDP_CAPSET_GENERAL: /* 1 */
+ DEBUG(("RDP_CAPSET_GENERAL\r\n"));
xrdp_process_capset_general(self, s, len);
break;
+ case RDP_CAPSET_BITMAP: /* 2 */
+ DEBUG(("RDP_CAPSET_BITMAP\r\n"));
+ break;
case RDP_CAPSET_ORDER: /* 3 */
+ DEBUG(("RDP_CAPSET_ORDER\r\n"));
xrdp_process_capset_order(self, s, len);
break;
case RDP_CAPSET_BMPCACHE: /* 4 */
+ DEBUG(("RDP_CAPSET_BMPCACHE\r\n"));
xrdp_process_capset_bmpcache(self, s, len);
break;
+ case RDP_CAPSET_CONTROL: /* 5 */
+ DEBUG(("RDP_CAPSET_CONTROL\r\n"));
+ break;
+ case RDP_CAPSET_ACTIVATE: /* 7 */
+ DEBUG(("RDP_CAPSET_ACTIVATE\r\n"));
+ break;
case RDP_CAPSET_POINTER: /* 8 */
+ DEBUG(("RDP_CAPSET_POINTER\r\n"));
xrdp_process_capset_pointercache(self, s, len);
break;
+ case RDP_CAPSET_SHARE: /* 9 */
+ DEBUG(("RDP_CAPSET_SHARE\r\n"));
+ break;
+ case RDP_CAPSET_COLCACHE: /* 10 */
+ DEBUG(("RDP_CAPSET_COLCACHE\r\n"));
+ break;
+ case 12: /* 12 */
+ DEBUG(("--12\r\n"));
+ break;
+ case 13: /* 13 */
+ DEBUG(("--13\r\n"));
+ break;
+ case 14: /* 14 */
+ DEBUG(("--14\r\n"));
+ break;
+ case 15: /* 15 */
+ DEBUG(("--15\r\n"));
+ break;
+ case 16: /* 16 */
+ DEBUG(("--16\r\n"));
+ break;
+ case 17: /* 17 */
+ DEBUG(("--16\r\n"));
+ break;
+ case RDP_CAPSET_BMPCACHE2: /* 19 */
+ DEBUG(("RDP_CAPSET_BMPCACHE2\r\n"));
+ break;
+ case 20: /* 20 */
+ DEBUG(("--20\r\n"));
+ break;
+ case 21: /* 21 */
+ DEBUG(("--21\r\n"));
+ break;
+ default:
+ g_printf("unknown in xrdp_rdp_process_confirm_active %d\r\n", type);
+ break;
}
s->p = p + len;
}
+ DEBUG(("out xrdp_rdp_process_confirm_active\r\n"));
return 0;
}
@@ -579,7 +643,7 @@ xrdp_rdp_process_data_input(struct xrdp_rdp* self, struct stream* s)
in_uint16_le(s, num_events);
in_uint8s(s, 2); /* pad */
- DEBUG(("xrdp_rdp_process_data_input %d events\r\n", num_events));
+ DEBUG(("in xrdp_rdp_process_data_input %d events\r\n", num_events));
for (index = 0; index < num_events; index++)
{
in_uint32_le(s, time);
@@ -595,10 +659,12 @@ param2 %d time %d\r\n", msg_type, device_flags, param1, param2, time));
RDP_INPUT_SYNCHRONIZE - 0
RDP_INPUT_SCANCODE - 4
RDP_INPUT_MOUSE - 0x8001 */
+ /* call to xrdp_wm.c : callback */
self->session->callback(self->session->id, msg_type, param1, param2,
device_flags, time);
}
}
+ DEBUG(("out xrdp_rdp_process_data_input\r\n"));
return 0;
}