hdr.width = htons(fb->curmode.xres);
hdr.height = htons(fb->curmode.yres);
hdr.enctype = htonl(0);
- tcp_write(pcb, &hdr, sizeof(hdr), 0);
- tcp_output(pcb);
+ tcp_write(pcb, &hdr, sizeof(hdr), TCP_WRITE_FLAG_COPY);
state->update_pos = 0;
state->send_state = SST_SENDING;
/* FALL THROUGH */
case SST_SENDING:
-
while (1) {
+ unsigned char mbuf[8192 /* XXX magic */];
+
left = state->frame_bytes - state->update_pos;
if (left == 0) {
state->send_state = SST_IDLE;
break;
}
+
+ if (left > 8192)
+ left = 8192;
- if (left > tcp_mss(pcb)) {
- sndlength = tcp_mss(pcb);
- } else {
- sndlength = left;
- }
-
+ memcpy(mbuf, fb->fbaddr + state->update_pos, left); /* It's OK if it becomes smaller later. */
+
+ sndlength = left;
do {
- err = tcp_write(pcb, fb->fbaddr + state->update_pos, sndlength, 0);
- if (err == ERR_MEM) {
- outputf("RFB: ERR_MEM sending %d", sndlength);
+ err = tcp_write(pcb, mbuf, sndlength, TCP_WRITE_FLAG_COPY /* This is my memory on the stack, thank you very much. */);
+ if (err == ERR_MEM) /* Back down until lwip says we've got space. */
sndlength /= 2;
- }
} while (err == ERR_MEM && sndlength > 1);
- if (err == ERR_OK) {
- outputf("RFB: attempting send %d", sndlength);
- } else {
- outputf("RFB: send error %d", err);
- break;
- }
-
- if (tcp_output(pcb) != ERR_OK) {
- outputf("RFB: tcp_output has had enough");
+ if (err != ERR_OK) {
+ /* We'll just give up for now and come back when we have space later. */
+ //outputf("RFB: send error %d", err);
break;
}
break;
}
+
+ if (tcp_output(pcb) != ERR_OK)
+ {
+ outputf("RFB: tcp_output bailed in send_fsm?");
+ }
}
static err_t rfb_sent(void *arg, struct tcp_pcb *pcb, uint16_t len) {
state->state = ST_MAIN;
outputf("RFB: Sending server info", state->version);
- tcp_write(pcb, &server_info, sizeof(server_info), 0);
+ tcp_write(pcb, &server_info, sizeof(server_info), TCP_WRITE_FLAG_COPY);
tcp_output(pcb);
return OK;
case OK:
outputf("RFB FSM: ok");
- /* Might as well send now... */
+ /* Kick off a send. */
if (state->send_state == SST_IDLE
&& state->update_requested) {
send_fsm(pcb, state);