lp 4626 src/decNumber/decNumber.c uLong *lp; // .. lp 4737 src/decNumber/decNumber.c for (lp=zacc; lp<zacc+iacc; lp++) *lp=0; lp 4758 src/decNumber/decNumber.c lp=zacc+(rip-zrhi); // where to add the lhs lp 4759 src/decNumber/decNumber.c for (lip=zlhi; lip<=lmsi; lip++, lp++) { // over each item in lhs lp 4760 src/decNumber/decNumber.c *lp+=(uLong)(*lip)*(*rip); // [this should in-line] lp 4766 src/decNumber/decNumber.c for (lp=zacc; lp<zacc+iacc; lp++) { lp 4767 src/decNumber/decNumber.c if (*lp<FASTBASE) continue; // it fits lp 4768 src/decNumber/decNumber.c lcarry=*lp/FASTBASE; // top part [slow divide] lp 4776 src/decNumber/decNumber.c *(lp+2)+=carry2; // add to item+2 lp 4777 src/decNumber/decNumber.c *lp-=((uLong)FASTBASE*FASTBASE*carry2); // [slow] lp 4780 src/decNumber/decNumber.c *(lp+1)+=carry; // add to item above [inline] lp 4781 src/decNumber/decNumber.c *lp-=((uLong)FASTBASE*carry); // [inline] lp 4791 src/decNumber/decNumber.c for (lp=zacc, up=acc; lp<zacc+iacc; lp++) { lp 4792 src/decNumber/decNumber.c uInt item=(uInt)*lp; // decapitate to uInt lp 1578 src/dps8/dps8_console.c uint lp = (uint)narrow_char; lp 1581 src/dps8/dps8_console.c if (lp == 060 /* + */ || lp == 075 /* = */) { // POLTS lp 1585 src/dps8/dps8_console.c if (lp == 0) lp 1586 src/dps8/dps8_console.c lp = 1; lp 1587 src/dps8/dps8_console.c if (lp >= 16) { lp 1591 src/dps8/dps8_console.c for (uint i = 0; i < lp; i ++) { lp 400 src/simh/sim_console.c TMLN *lp; lp 423 src/simh/sim_console.c lp = &sim_rem_con_tmxr.ldsc[i]; lp 424 src/simh/sim_console.c if (!lp->conn) lp 429 src/simh/sim_console.c tmxr_fconns (st, lp, i); lp 450 src/simh/sim_console.c TMLN *lp = &sim_rem_con_tmxr.ldsc[c]; lp 454 src/simh/sim_console.c lp->rcve = 1; /* rcv enabled */ lp 465 src/simh/sim_console.c tmxr_linemsgf (lp, "%s Remote Console\r\n" lp 472 src/simh/sim_console.c tmxr_send_buffered_data (lp); /* flush buffered data */ lp 594 src/simh/sim_console.c static void _sim_rem_log_out (TMLN *lp) lp 605 src/simh/sim_console.c tmxr_linemsgf (lp, "%s", cbuf); lp 606 src/simh/sim_console.c if (!tmxr_input_pending_ln (lp)) { lp 608 src/simh/sim_console.c unwritten = tmxr_send_buffered_data (lp); lp 609 src/simh/sim_console.c if (unwritten == lp->txbsz) lp 611 src/simh/sim_console.c } while (unwritten == lp->txbsz); lp 652 src/simh/sim_console.c TMLN *lp; lp 668 src/simh/sim_console.c lp = &sim_rem_con_tmxr.ldsc[i]; lp 669 src/simh/sim_console.c if (!lp->conn) lp 672 src/simh/sim_console.c tmxr_linemsgf (lp, "\nMaster Mode Session\r\n"); lp 673 src/simh/sim_console.c tmxr_send_buffered_data (lp); /* flush any buffered data */ lp 685 src/simh/sim_console.c _sim_rem_log_out (lp); lp 698 src/simh/sim_console.c tmxr_linemsgf (lpj, "\nRemote Master Console(%s) Entering Commands\n", lp->ipad); lp 701 src/simh/sim_console.c lp = &sim_rem_con_tmxr.ldsc[i]; lp 705 src/simh/sim_console.c c = tmxr_getc_ln (lp); lp 716 src/simh/sim_console.c _sim_rem_log_out (lp); lp 722 src/simh/sim_console.c (unsigned long)i, lp->ipad); lp 725 src/simh/sim_console.c lp = &sim_rem_con_tmxr.ldsc[i]; lp 727 src/simh/sim_console.c tmxr_linemsg (lp, "\r\nSimulator paused.\r\n"); lp 729 src/simh/sim_console.c tmxr_linemsgf (lp, "Simulation will resume automatically if input is not received in %lu seconds\n", lp 731 src/simh/sim_console.c tmxr_linemsgf (lp, "\r\n"); lp 732 src/simh/sim_console.c tmxr_send_buffered_data (lp); /* flush any buffered data */ lp 741 src/simh/sim_console.c tmxr_linemsgf (lp, "\r\nGoodbye\r\n"); lp 742 src/simh/sim_console.c tmxr_send_buffered_data (lp); /* flush any buffered data */ lp 743 src/simh/sim_console.c tmxr_reset_ln (lp); lp 749 src/simh/sim_console.c tmxr_linemsgf (lp, "\r\n%s", sim_prompt); lp 751 src/simh/sim_console.c tmxr_linemsgf (lp, "\r\n%s", sim_is_running ? "SIM> " : "sim> "); lp 753 src/simh/sim_console.c if (!tmxr_input_pending_ln (lp)) lp 754 src/simh/sim_console.c tmxr_send_buffered_data (lp); /* flush any buffered data */ lp 766 src/simh/sim_console.c tmxr_linemsg (lp, "sim> "); lp 768 src/simh/sim_console.c tmxr_linemsg (lp, sim_prompt); lp 769 src/simh/sim_console.c tmxr_send_buffered_data (lp); /* flush any buffered data */ lp 773 src/simh/sim_console.c c = tmxr_getc_ln (lp); lp 775 src/simh/sim_console.c tmxr_send_buffered_data (lp); /* flush any buffered data */ lp 780 src/simh/sim_console.c tmxr_linemsg (lp, "\b \b"); lp 788 src/simh/sim_console.c tmxr_linemsgf (lp, "%s\n", sim_rem_buf[i]); lp 794 src/simh/sim_console.c if (!lp->conn) { /* if connection lost? */ lp 809 src/simh/sim_console.c tmxr_linemsg (lp, "\b \b"); lp 816 src/simh/sim_console.c tmxr_linemsg (lp, "\b \b"); lp 825 src/simh/sim_console.c tmxr_linemsg (lp, "\r\n"); lp 833 src/simh/sim_console.c (unsigned long)tmxr_input_pending_ln (lp), sim_rem_buf[i]); lp 839 src/simh/sim_console.c tmxr_linemsg (lp, "\b \b"); lp 848 src/simh/sim_console.c tmxr_linemsgf (lp, "%s\n", sim_rem_buf[i]); lp 854 src/simh/sim_console.c tmxr_putc_ln (lp, c); lp 866 src/simh/sim_console.c if ((!got_command) && (sim_rem_single_mode[i]) && (tmxr_input_pending_ln (lp))) { lp 867 src/simh/sim_console.c c = tmxr_getc_ln (lp); lp 871 src/simh/sim_console.c if (!tmxr_input_pending_ln (lp)) lp 872 src/simh/sim_console.c tmxr_send_buffered_data (lp); /* flush any buffered data */ lp 876 src/simh/sim_console.c sim_printf ("Remote Console Command from %s> %s\r\n", lp->ipad, sim_rem_buf[i]); lp 880 src/simh/sim_console.c tmxr_linemsgf (lp, "\nLine too long. Ignored. Continuing Simulator execution\n"); lp 881 src/simh/sim_console.c tmxr_send_buffered_data (lp); /* try to flush any buffered data */ lp 972 src/simh/sim_console.c _sim_rem_log_out (lp); lp 994 src/simh/sim_console.c tmxr_linemsg (lp, "Simulator Running..."); lp 995 src/simh/sim_console.c tmxr_send_buffered_data (lp); lp 1012 src/simh/sim_console.c tmxr_linemsgf (lp, "%s", "sim> "); lp 1014 src/simh/sim_console.c tmxr_linemsgf (lp, "%s", sim_prompt); lp 1015 src/simh/sim_console.c tmxr_send_buffered_data (lp); lp 1027 src/simh/sim_console.c tmxr_linemsgf (lp, "\r\nGoodbye\r\n"); lp 1028 src/simh/sim_console.c tmxr_send_buffered_data (lp); /* flush any buffered data */ lp 1029 src/simh/sim_console.c tmxr_reset_ln (lp); lp 1045 src/simh/sim_console.c lp = &sim_rem_con_tmxr.ldsc[0]; lp 1046 src/simh/sim_console.c tmxr_linemsgf (lp, "Non Master Mode Session..."); /* report transition */ lp 1047 src/simh/sim_console.c tmxr_send_buffered_data (lp); /* flush any buffered data */ lp 240 src/simh/sim_tmxr.c static void tmxr_init_line (TMLN *lp) lp 242 src/simh/sim_tmxr.c lp->tsta = 0; /* init telnet state */ lp 243 src/simh/sim_tmxr.c lp->xmte = 1; /* enable transmit */ lp 244 src/simh/sim_tmxr.c lp->dstb = 0; /* default bin mode */ lp 245 src/simh/sim_tmxr.c lp->rxbpr = lp->rxbpi = lp->rxcnt = lp->rxpcnt = 0; /* init receive indexes */ lp 246 src/simh/sim_tmxr.c if (!lp->txbfd || lp->notelnet) /* if not buffered telnet */ lp 247 src/simh/sim_tmxr.c lp->txbpr = lp->txbpi = lp->txcnt = lp->txpcnt = 0; /* init transmit indexes */ lp 248 src/simh/sim_tmxr.c lp->txdrp = 0; lp 249 src/simh/sim_tmxr.c tmxr_set_get_modem_bits (lp, 0, 0, NULL); lp 250 src/simh/sim_tmxr.c if ((!lp->mp->buffered) && (!lp->txbfd)) { lp 251 src/simh/sim_tmxr.c lp->txbfd = 0; //-V1048 lp 252 src/simh/sim_tmxr.c lp->txbsz = TMXR_MAXBUF; lp 253 src/simh/sim_tmxr.c lp->txb = (char *)realloc (lp->txb, lp->txbsz); lp 254 src/simh/sim_tmxr.c if (!lp->txb) lp 266 src/simh/sim_tmxr.c lp->rxbsz = TMXR_MAXBUF; lp 267 src/simh/sim_tmxr.c lp->rxb = (char *)realloc(lp->rxb, lp->rxbsz); lp 268 src/simh/sim_tmxr.c if (!lp->rxb) lp 280 src/simh/sim_tmxr.c lp->rbr = (char *)realloc(lp->rbr, lp->rxbsz); lp 281 src/simh/sim_tmxr.c if (!lp->rbr) lp 294 src/simh/sim_tmxr.c if (lp->loopback) { lp 295 src/simh/sim_tmxr.c lp->lpbsz = lp->rxbsz; lp 296 src/simh/sim_tmxr.c lp->lpb = (char *)realloc(lp->lpb, lp->lpbsz); lp 297 src/simh/sim_tmxr.c if (!lp->lpb) lp 309 src/simh/sim_tmxr.c lp->lpbcnt = lp->lpbpi = lp->lpbpr = 0; lp 311 src/simh/sim_tmxr.c if (lp->rxpb) { lp 312 src/simh/sim_tmxr.c lp->rxpboffset = lp->rxpbsize = 0; lp 313 src/simh/sim_tmxr.c FREE (lp->rxpb); lp 314 src/simh/sim_tmxr.c lp->rxpb = NULL; lp 316 src/simh/sim_tmxr.c if (lp->txpb) { lp 317 src/simh/sim_tmxr.c lp->txpbsize = lp->txppsize = lp->txppoffset = 0; lp 318 src/simh/sim_tmxr.c FREE (lp->txpb); lp 319 src/simh/sim_tmxr.c lp->txpb = NULL; lp 321 src/simh/sim_tmxr.c (void)memset (lp->rbr, 0, lp->rxbsz); /* clear break status array */ lp 338 src/simh/sim_tmxr.c static void tmxr_report_connection (TMXR *mp, TMLN *lp) lp 346 src/simh/sim_tmxr.c if ((!lp->notelnet) || (sim_switches & SWMASK ('V'))) { lp 354 src/simh/sim_tmxr.c (void)sprintf (lmsg, ", line %d", (int)(lp-mp->ldsc));/* report the line number */ lp 361 src/simh/sim_tmxr.c lp->txbpi = 0; /* init buf pointers */ lp 362 src/simh/sim_tmxr.c lp->txbpr = (int32)(lp->txbsz - strlen (msgbuf)); lp 363 src/simh/sim_tmxr.c lp->rxcnt = lp->txcnt = lp->txdrp = 0; /* init counters */ lp 364 src/simh/sim_tmxr.c lp->rxpcnt = lp->txpcnt = 0; lp 367 src/simh/sim_tmxr.c if (lp->txcnt > lp->txbsz) lp 368 src/simh/sim_tmxr.c lp->txbpr = (lp->txbpi + 1) % lp->txbsz; lp 370 src/simh/sim_tmxr.c lp->txbpr = (int32)(lp->txbsz - strlen (msgbuf)); lp 372 src/simh/sim_tmxr.c psave = lp->txbpi; /* save insertion pointer */ lp 373 src/simh/sim_tmxr.c lp->txbpi = lp->txbpr; /* insert connection message */ lp 374 src/simh/sim_tmxr.c tmxr_linemsg (lp, msgbuf); /* beginning of buffer */ lp 375 src/simh/sim_tmxr.c lp->txbpi = psave; /* restore insertion pointer */ lp 377 src/simh/sim_tmxr.c unwritten = tmxr_send_buffered_data (lp); /* send the message */ lp 380 src/simh/sim_tmxr.c lp->xmte = 1; /* re-enable transmission if paused */ lp 382 src/simh/sim_tmxr.c lp->txcnt -= (int32)strlen (msgbuf); /* adjust statistics */ lp 396 src/simh/sim_tmxr.c static void tmxr_report_disconnection (TMLN *lp) lp 398 src/simh/sim_tmxr.c if (lp->notelnet) lp 400 src/simh/sim_tmxr.c tmxr_linemsgf (lp, "\r\nDisconnected from the %s simulator\r\n\n", sim_name);/* report disconnection */ lp 404 src/simh/sim_tmxr.c static int32 loop_write_ex (TMLN *lp, char *buf, int32 length, t_bool prefix_datagram) lp 407 src/simh/sim_tmxr.c int32 loopfree = lp->lpbsz - lp->lpbcnt; lp 409 src/simh/sim_tmxr.c if (lp->datagram && prefix_datagram) { lp 412 src/simh/sim_tmxr.c loop_write_ex (lp, (char *)&length, sizeof(length), FALSE); lp 417 src/simh/sim_tmxr.c loopfree = lp->lpbsz - lp->lpbcnt; lp 422 src/simh/sim_tmxr.c if (lp->lpbpi >= lp->lpbpr) lp 423 src/simh/sim_tmxr.c chunksize = lp->lpbsz - lp->lpbpi; lp 425 src/simh/sim_tmxr.c chunksize = lp->lpbpr - lp->lpbpi; lp 428 src/simh/sim_tmxr.c memcpy (&lp->lpb[lp->lpbpi], buf, chunksize); lp 432 src/simh/sim_tmxr.c lp->lpbpi = (lp->lpbpi + chunksize) % lp->lpbsz; lp 434 src/simh/sim_tmxr.c lp->lpbcnt += written; lp 438 src/simh/sim_tmxr.c static int32 loop_write (TMLN *lp, char *buf, int32 length) lp 440 src/simh/sim_tmxr.c return loop_write_ex (lp, buf, length, TRUE); lp 443 src/simh/sim_tmxr.c static int32 loop_read_ex (TMLN *lp, char *buf, int32 bufsize) lp 449 src/simh/sim_tmxr.c int32 loopused = lp->lpbcnt; lp 455 src/simh/sim_tmxr.c if (lp->lpbpi > lp->lpbpr) lp 456 src/simh/sim_tmxr.c chunksize = lp->lpbpi - lp->lpbpr; lp 458 src/simh/sim_tmxr.c chunksize = lp->lpbsz - lp->lpbpr; lp 461 src/simh/sim_tmxr.c memcpy (buf, &lp->lpb[lp->lpbpr], chunksize); lp 465 src/simh/sim_tmxr.c lp->lpbpr = (lp->lpbpr + chunksize) % lp->lpbsz; lp 467 src/simh/sim_tmxr.c lp->lpbcnt -= bytesread; lp 471 src/simh/sim_tmxr.c static int32 loop_read (TMLN *lp, char *buf, int32 bufsize) lp 473 src/simh/sim_tmxr.c if (lp->datagram) { lp 476 src/simh/sim_tmxr.c if (lp->lpbcnt < (int32)sizeof(pktsize)) lp 478 src/simh/sim_tmxr.c if ((sizeof(pktsize) != loop_read_ex (lp, (char *)&pktsize, sizeof(pktsize))) || lp 483 src/simh/sim_tmxr.c return loop_read_ex (lp, buf, bufsize); lp 494 src/simh/sim_tmxr.c static int32 tmxr_read (TMLN *lp, int32 length) lp 496 src/simh/sim_tmxr.c int32 i = lp->rxbpi; lp 498 src/simh/sim_tmxr.c if (lp->loopback) lp 499 src/simh/sim_tmxr.c return loop_read (lp, &(lp->rxb[i]), length); lp 501 src/simh/sim_tmxr.c return sim_read_sock (lp->sock, &(lp->rxb[i]), length); lp 511 src/simh/sim_tmxr.c static int32 tmxr_write (TMLN *lp, int32 length) lp 514 src/simh/sim_tmxr.c int32 i = lp->txbpr; lp 516 src/simh/sim_tmxr.c if (lp->loopback) lp 517 src/simh/sim_tmxr.c return loop_write (lp, &(lp->txb[i]), length); lp 519 src/simh/sim_tmxr.c written = sim_write_sock (lp->sock, &(lp->txb[i]), length); lp 522 src/simh/sim_tmxr.c if (lp->datagram) lp 537 src/simh/sim_tmxr.c static void tmxr_rmvrc (TMLN *lp, int32 p) lp 539 src/simh/sim_tmxr.c for ( ; p < lp->rxbpi; p++) { /* work from "p" through end of buffer */ lp 540 src/simh/sim_tmxr.c lp->rxb[p] = lp->rxb[p + 1]; /* slide following character down */ lp 541 src/simh/sim_tmxr.c lp->rbr[p] = lp->rbr[p + 1]; /* adjust break status too */ lp 544 src/simh/sim_tmxr.c lp->rbr[p] = 0; /* clear potential break from vacated slot */ lp 545 src/simh/sim_tmxr.c lp->rxbpi = lp->rxbpi - 1; /* drop buffer insert index */ lp 598 src/simh/sim_tmxr.c TMLN *lp = NULL; lp 605 src/simh/sim_tmxr.c lp = tmxr_find_ldsc (uptr, mp->lines, mp); /* determine line from unit */ lp 607 src/simh/sim_tmxr.c if (lp == NULL) /* invalid line number? */ lp 618 src/simh/sim_tmxr.c lp = mp->ldsc + (int32) ln; /* use as index to determine line */ lp 624 src/simh/sim_tmxr.c return lp; /* return pointer to line descriptor */ lp 671 src/simh/sim_tmxr.c TMLN *lp; lp 688 src/simh/sim_tmxr.c lp = mp->ldsc + i; lp 690 src/simh/sim_tmxr.c lptr = tmxr_line_attach_string(lp); lp 722 src/simh/sim_tmxr.c char *tmxr_line_attach_string(TMLN *lp) lp 730 src/simh/sim_tmxr.c if (lp->destination || lp->port || lp->txlogname) { lp 731 src/simh/sim_tmxr.c if ((lp->mp->lines > 1) || (lp->port)) lp 732 src/simh/sim_tmxr.c (void)sprintf (growstring(&tptr, 32), "Line=%d", (int)(lp-lp->mp->ldsc)); lp 733 src/simh/sim_tmxr.c if (lp->modem_control != lp->mp->modem_control) lp 734 src/simh/sim_tmxr.c (void)sprintf (growstring(&tptr, 32), ",%s", lp->modem_control ? "Modem" : "NoModem"); lp 735 src/simh/sim_tmxr.c if (lp->txbfd && (lp->txbsz != lp->mp->buffered)) lp 736 src/simh/sim_tmxr.c (void)sprintf (growstring(&tptr, 32), ",Buffered=%d", lp->txbsz); lp 737 src/simh/sim_tmxr.c if (!lp->txbfd && (lp->mp->buffered > 0)) lp 739 src/simh/sim_tmxr.c if (lp->mp->datagram != lp->datagram) lp 740 src/simh/sim_tmxr.c (void)sprintf (growstring(&tptr, 8), ",%s", lp->datagram ? "UDP" : "TCP"); lp 741 src/simh/sim_tmxr.c if (lp->mp->packet != lp->packet) lp 743 src/simh/sim_tmxr.c if (lp->port) lp 744 src/simh/sim_tmxr.c (void)sprintf (growstring(&tptr, 32 + strlen (lp->port)), ",%s%s", lp 745 src/simh/sim_tmxr.c lp->port, ((lp->mp->notelnet != lp->notelnet) && \ lp 746 src/simh/sim_tmxr.c (!lp->datagram)) ? (lp->notelnet ? ";notelnet" : ";telnet") : ""); lp 747 src/simh/sim_tmxr.c if (lp->destination) { lp 748 src/simh/sim_tmxr.c (void)sprintf (growstring(&tptr, 25 + strlen (lp->destination)), lp 749 src/simh/sim_tmxr.c ",Connect=%s%s", lp->destination, lp 750 src/simh/sim_tmxr.c ((lp->mp->notelnet != lp->notelnet) && \ lp 751 src/simh/sim_tmxr.c (!lp->datagram)) ? (lp->notelnet ? ";notelnet" : ";telnet") : ""); lp 753 src/simh/sim_tmxr.c if (lp->txlogname) lp 754 src/simh/sim_tmxr.c (void)sprintf (growstring(&tptr, 12 + strlen (lp->txlogname)), ",Log=%s", lp->txlogname); lp 755 src/simh/sim_tmxr.c if (lp->loopback) lp 801 src/simh/sim_tmxr.c TMLN *lp = NULL; lp 810 src/simh/sim_tmxr.c (void)lp; lp 921 src/simh/sim_tmxr.c lp = mp->ldsc + i; /* get pointer to line descriptor */ lp 922 src/simh/sim_tmxr.c if ((lp->conn == FALSE) && /* is the line available? */ lp 923 src/simh/sim_tmxr.c (lp->destination == NULL) && lp 924 src/simh/sim_tmxr.c (lp->master == 0) && lp 925 src/simh/sim_tmxr.c (lp->ser_connect_pending == FALSE) && lp 926 src/simh/sim_tmxr.c (lp->modem_control ? ((lp->modembits & TMXR_MDM_DTR) != 0) : TRUE)) lp 934 src/simh/sim_tmxr.c lp = mp->ldsc + j; /* get pointer to line descriptor */ lp 935 src/simh/sim_tmxr.c if ((lp->conn == FALSE) && /* is the line available? */ lp 936 src/simh/sim_tmxr.c (lp->destination == NULL) && lp 937 src/simh/sim_tmxr.c (lp->master == 0) && lp 938 src/simh/sim_tmxr.c (lp->ser_connect_pending == FALSE) && lp 939 src/simh/sim_tmxr.c ((lp->modembits & TMXR_MDM_DTR) == 0)) { lp 941 src/simh/sim_tmxr.c tmxr_set_get_modem_bits (lp, TMXR_MDM_RNG, 0, NULL); lp 959 src/simh/sim_tmxr.c for (ln = 0; ln < lp->mp->lines; ln++) { lp 960 src/simh/sim_tmxr.c TMLN *tlp = lp->mp->ldsc + ln; lp 979 src/simh/sim_tmxr.c lp = mp->ldsc + i; /* get line desc */ lp 980 src/simh/sim_tmxr.c lp->conn = TRUE; /* record connection */ lp 981 src/simh/sim_tmxr.c lp->sock = newsock; /* save socket */ lp 982 src/simh/sim_tmxr.c lp->ipad = address; /* ip address */ lp 983 src/simh/sim_tmxr.c tmxr_init_line (lp); /* init line */ lp 984 src/simh/sim_tmxr.c lp->notelnet = mp->notelnet; /* apply mux default telnet setting */ lp 985 src/simh/sim_tmxr.c if (!lp->notelnet) { lp 987 src/simh/sim_tmxr.c lp->telnet_sent_opts = (uint8 *)realloc (lp->telnet_sent_opts, 256); lp 988 src/simh/sim_tmxr.c if (!lp->telnet_sent_opts) lp 1000 src/simh/sim_tmxr.c (void)memset (lp->telnet_sent_opts, 0, 256); lp 1002 src/simh/sim_tmxr.c tmxr_report_connection (mp, lp); lp 1003 src/simh/sim_tmxr.c lp->cnms = sim_os_msec (); /* time of connection */ lp 1012 src/simh/sim_tmxr.c lp = mp->ldsc + i; /* get pointer to line descriptor */ lp 1014 src/simh/sim_tmxr.c if (lp->ser_connect_pending) { lp 1015 src/simh/sim_tmxr.c lp->ser_connect_pending = FALSE; lp 1016 src/simh/sim_tmxr.c lp->conn = TRUE; lp 1022 src/simh/sim_tmxr.c if (lp->loopback) lp 1037 src/simh/sim_tmxr.c if (lp->connecting) { /* connecting? */ lp 1040 src/simh/sim_tmxr.c switch (sim_check_conn(lp->connecting, FALSE)) lp 1043 src/simh/sim_tmxr.c lp->conn = TRUE; /* record connection */ lp 1044 src/simh/sim_tmxr.c lp->sock = lp->connecting; /* it now looks normal */ lp 1045 src/simh/sim_tmxr.c lp->connecting = 0; lp 1047 src/simh/sim_tmxr.c if (lp->destination != NULL) lp 1048 src/simh/sim_tmxr.c lpdlen = 1+strlen (lp->destination); lp 1049 src/simh/sim_tmxr.c lp->ipad = (char *)realloc (lp->ipad, lpdlen); lp 1050 src/simh/sim_tmxr.c if (!lp->ipad) lp 1062 src/simh/sim_tmxr.c if (lp->destination != NULL) lp 1063 src/simh/sim_tmxr.c (void)strcpy (lp->ipad, lp->destination); lp 1064 src/simh/sim_tmxr.c lp->cnms = sim_os_msec (); lp 1065 src/simh/sim_tmxr.c sim_getnames_sock (lp->sock, &sockname, &peername); lp 1066 src/simh/sim_tmxr.c if (lp->destination) lp 1069 src/simh/sim_tmxr.c lp->destination, sockname, peername); lp 1075 src/simh/sim_tmxr.c lp->destination); lp 1076 src/simh/sim_tmxr.c tmxr_reset_ln (lp); /* retry */ lp 1082 src/simh/sim_tmxr.c if (lp->master) { /* Check for a pending Telnet/tcp connection */ lp 1083 src/simh/sim_tmxr.c while (INVALID_SOCKET != (newsock = sim_accept_conn_ex (lp->master, &address, lp 1084 src/simh/sim_tmxr.c (lp->packet ? SIM_SOCK_OPT_NODELAY : 0)))) {/* got a live one? */ lp 1094 src/simh/sim_tmxr.c if (lp->destination) { /* Virtual Null Modem Cable? */ lp 1097 src/simh/sim_tmxr.c if (sim_parse_addr (lp->destination, host, sizeof(host), NULL, NULL, 0, NULL, address)) { lp 1105 src/simh/sim_tmxr.c if (lp->connecting) { lp 1107 src/simh/sim_tmxr.c lp->destination); lp 1108 src/simh/sim_tmxr.c sim_close_sock (lp->connecting); /* abort our as yet unconnnected socket */ lp 1109 src/simh/sim_tmxr.c lp->connecting = 0; lp 1112 src/simh/sim_tmxr.c if (lp->conn == FALSE) { /* is the line available? */ lp 1113 src/simh/sim_tmxr.c if ((!lp->modem_control) || (lp->modembits & TMXR_MDM_DTR)) { lp 1114 src/simh/sim_tmxr.c lp->conn = TRUE; /* record connection */ lp 1115 src/simh/sim_tmxr.c lp->sock = newsock; /* save socket */ lp 1116 src/simh/sim_tmxr.c lp->ipad = address; /* ip address */ lp 1117 src/simh/sim_tmxr.c tmxr_init_line (lp); /* init line */ lp 1118 src/simh/sim_tmxr.c if (!lp->notelnet) { lp 1120 src/simh/sim_tmxr.c lp->telnet_sent_opts = (uint8 *)realloc (lp->telnet_sent_opts, 256); lp 1121 src/simh/sim_tmxr.c if (!lp->telnet_sent_opts) lp 1133 src/simh/sim_tmxr.c (void)memset (lp->telnet_sent_opts, 0, 256); lp 1135 src/simh/sim_tmxr.c tmxr_report_connection (mp, lp); lp 1136 src/simh/sim_tmxr.c lp->cnms = sim_os_msec (); /* time of connection */ lp 1157 src/simh/sim_tmxr.c if (lp->destination && (!lp->sock) && (!lp->connecting) && lp 1158 src/simh/sim_tmxr.c (!lp->modem_control || (lp->modembits & TMXR_MDM_DTR))) { lp 1159 src/simh/sim_tmxr.c snprintf (msg, sizeof(msg)-1, "tmxr_poll_conn() - establishing outgoing connection to: %s", lp->destination); lp 1160 src/simh/sim_tmxr.c lp->connecting = sim_connect_sock_ex (lp->datagram ? lp->port : NULL, lp 1161 src/simh/sim_tmxr.c lp->destination, "localhost", NULL, lp 1162 src/simh/sim_tmxr.c (lp->datagram ? SIM_SOCK_OPT_DATAGRAM : 0) | lp 1163 src/simh/sim_tmxr.c (lp->mp->packet ? SIM_SOCK_OPT_NODELAY : 0) | lp 1174 src/simh/sim_tmxr.c static t_stat tmxr_reset_ln_ex (TMLN *lp, t_bool closeserial) lp 1178 src/simh/sim_tmxr.c if (lp->txlog) lp 1179 src/simh/sim_tmxr.c (void)fflush (lp->txlog); /* flush log */ lp 1181 src/simh/sim_tmxr.c tmxr_send_buffered_data (lp); /* send any buffered data */ lp 1185 src/simh/sim_tmxr.c if (lp->sock) { lp 1186 src/simh/sim_tmxr.c sim_close_sock (lp->sock); /* close socket */ lp 1187 src/simh/sim_tmxr.c FREE (lp->telnet_sent_opts); lp 1188 src/simh/sim_tmxr.c lp->telnet_sent_opts = NULL; lp 1189 src/simh/sim_tmxr.c lp->sock = 0; lp 1190 src/simh/sim_tmxr.c lp->conn = FALSE; lp 1191 src/simh/sim_tmxr.c lp->cnms = 0; lp 1192 src/simh/sim_tmxr.c lp->xmte = 1; lp 1194 src/simh/sim_tmxr.c FREE(lp->ipad); lp 1195 src/simh/sim_tmxr.c lp->ipad = NULL; lp 1196 src/simh/sim_tmxr.c if ((lp->destination) lp 1198 src/simh/sim_tmxr.c if (lp->connecting) { lp 1199 src/simh/sim_tmxr.c sim_close_sock (lp->connecting); lp 1200 src/simh/sim_tmxr.c lp->connecting = 0; lp 1202 src/simh/sim_tmxr.c if ((!lp->modem_control) || (lp->modembits & TMXR_MDM_DTR)) { lp 1203 src/simh/sim_tmxr.c snprintf (msg, sizeof(msg)-1, "tmxr_reset_ln_ex() - connecting to %s", lp->destination); lp 1204 src/simh/sim_tmxr.c lp->connecting = sim_connect_sock_ex (lp->datagram ? lp->port : NULL, lp 1205 src/simh/sim_tmxr.c lp->destination, "localhost", NULL, lp 1206 src/simh/sim_tmxr.c (lp->datagram ? SIM_SOCK_OPT_DATAGRAM : 0) | lp 1207 src/simh/sim_tmxr.c (lp->packet ? SIM_SOCK_OPT_NODELAY : 0) | lp 1211 src/simh/sim_tmxr.c tmxr_init_line (lp); /* initialize line state */ lp 1215 src/simh/sim_tmxr.c t_stat tmxr_close_ln (TMLN *lp) lp 1217 src/simh/sim_tmxr.c return tmxr_reset_ln_ex (lp, TRUE); lp 1220 src/simh/sim_tmxr.c t_stat tmxr_reset_ln (TMLN *lp) lp 1222 src/simh/sim_tmxr.c return tmxr_reset_ln_ex (lp, FALSE); lp 1237 src/simh/sim_tmxr.c t_stat tmxr_set_get_modem_bits (TMLN *lp, int32 bits_to_set, int32 bits_to_clear, int32 *incoming_bits) lp 1246 src/simh/sim_tmxr.c before_modem_bits = lp->modembits; lp 1247 src/simh/sim_tmxr.c lp->modembits |= bits_to_set; lp 1248 src/simh/sim_tmxr.c lp->modembits &= ~(bits_to_clear | TMXR_MDM_INCOMING); lp 1249 src/simh/sim_tmxr.c if ((lp->sock) || (lp->loopback)) { lp 1250 src/simh/sim_tmxr.c if (lp->modembits & TMXR_MDM_DTR) { lp 1252 src/simh/sim_tmxr.c if (lp->modembits & TMXR_MDM_RTS) lp 1254 src/simh/sim_tmxr.c if (lp->halfduplex) { lp 1267 src/simh/sim_tmxr.c ((lp->modembits & TMXR_MDM_DTR) != 0) && lp 1268 src/simh/sim_tmxr.c (lp->conn == FALSE) && /* Not connected */ lp 1269 src/simh/sim_tmxr.c (lp->modembits & TMXR_MDM_RNG)) { /* and Ring Signal Present */ lp 1270 src/simh/sim_tmxr.c if ((lp->destination == NULL) && lp 1271 src/simh/sim_tmxr.c (lp->master == 0) && lp 1272 src/simh/sim_tmxr.c (lp->mp && (lp->mp->ring_sock))) { lp 1275 src/simh/sim_tmxr.c lp->conn = TRUE; /* record connection */ lp 1276 src/simh/sim_tmxr.c lp->sock = lp->mp->ring_sock; /* save socket */ lp 1277 src/simh/sim_tmxr.c lp->mp->ring_sock = INVALID_SOCKET; lp 1278 src/simh/sim_tmxr.c lp->ipad = lp->mp->ring_ipad; /* ip address */ lp 1279 src/simh/sim_tmxr.c lp->mp->ring_ipad = NULL; lp 1280 src/simh/sim_tmxr.c lp->mp->ring_start_time = 0; lp 1281 src/simh/sim_tmxr.c tmxr_init_line (lp); /* init line */ lp 1282 src/simh/sim_tmxr.c lp->notelnet = lp->mp->notelnet; /* apply mux default telnet setting */ lp 1283 src/simh/sim_tmxr.c if (!lp->notelnet) { lp 1284 src/simh/sim_tmxr.c sim_write_sock (lp->sock, (char *)mantra, sizeof(mantra)); lp 1285 src/simh/sim_tmxr.c lp->telnet_sent_opts = (uint8 *)realloc (lp->telnet_sent_opts, 256); lp 1286 src/simh/sim_tmxr.c if (!lp->telnet_sent_opts) lp 1298 src/simh/sim_tmxr.c (void)memset (lp->telnet_sent_opts, 0, 256); lp 1300 src/simh/sim_tmxr.c tmxr_report_connection (lp->mp, lp); lp 1301 src/simh/sim_tmxr.c lp->cnms = sim_os_msec (); /* time of connection */ lp 1302 src/simh/sim_tmxr.c lp->modembits &= ~TMXR_MDM_RNG; /* turn off ring on this line*/ lp 1304 src/simh/sim_tmxr.c for (ln = 0; ln < lp->mp->lines; ln++) { lp 1305 src/simh/sim_tmxr.c TMLN *tlp = lp->mp->ldsc + ln; lp 1312 src/simh/sim_tmxr.c if ((lp->master) || (lp->mp && lp->mp->master) || lp 1313 src/simh/sim_tmxr.c (lp->port && lp->destination)) lp 1318 src/simh/sim_tmxr.c lp->modembits |= incoming_state; lp 1319 src/simh/sim_tmxr.c dptr = (lp->dptr ? lp->dptr : (lp->mp ? lp->mp->dptr : NULL)); lp 1326 src/simh/sim_tmxr.c *incoming_bits = lp->modembits; lp 1327 src/simh/sim_tmxr.c if (lp->mp && lp->modem_control) { /* This API ONLY works on modem_control enabled multiplexer lines */ lp 1329 src/simh/sim_tmxr.c if (lp->loopback) { lp 1330 src/simh/sim_tmxr.c if ((lp->modembits ^ before_modem_bits) & TMXR_MDM_DTR) { /* DTR changed? */ lp 1331 src/simh/sim_tmxr.c lp->ser_connect_pending = (lp->modembits & TMXR_MDM_DTR); lp 1332 src/simh/sim_tmxr.c lp->conn = !(lp->modembits & TMXR_MDM_DTR); lp 1336 src/simh/sim_tmxr.c if ((lp->sock) || (lp->connecting)) { lp 1338 src/simh/sim_tmxr.c if (lp->sock) lp 1339 src/simh/sim_tmxr.c tmxr_report_disconnection (lp); /* report closure */ lp 1340 src/simh/sim_tmxr.c tmxr_reset_ln (lp); lp 1344 src/simh/sim_tmxr.c if ((lp->destination) && /* Virtual Null Modem Cable */ lp 1350 src/simh/sim_tmxr.c lp->destination); lp 1351 src/simh/sim_tmxr.c lp->connecting = sim_connect_sock_ex (lp->datagram ? lp->port : NULL, lp->destination, "localhost", NULL, lp 1352 src/simh/sim_tmxr.c (lp->datagram ? SIM_SOCK_OPT_DATAGRAM : 0) | lp 1353 src/simh/sim_tmxr.c (lp->packet ? SIM_SOCK_OPT_NODELAY : 0) | lp 1360 src/simh/sim_tmxr.c if ((lp->sock) || (lp->connecting)) { lp 1362 src/simh/sim_tmxr.c if (lp->sock) lp 1363 src/simh/sim_tmxr.c tmxr_report_disconnection (lp); /* report closure */ lp 1364 src/simh/sim_tmxr.c tmxr_reset_ln (lp); lp 1379 src/simh/sim_tmxr.c t_stat tmxr_set_line_loopback (TMLN *lp, t_bool enable_loopback) lp 1381 src/simh/sim_tmxr.c if (lp->loopback == (enable_loopback != FALSE)) lp 1383 src/simh/sim_tmxr.c lp->loopback = (enable_loopback != FALSE); lp 1384 src/simh/sim_tmxr.c if (lp->loopback) { lp 1385 src/simh/sim_tmxr.c lp->lpbsz = lp->rxbsz; lp 1386 src/simh/sim_tmxr.c lp->lpb = (char *)realloc(lp->lpb, lp->lpbsz); lp 1387 src/simh/sim_tmxr.c if (!lp->lpb) lp 1399 src/simh/sim_tmxr.c lp->lpbcnt = lp->lpbpi = lp->lpbpr = 0; lp 1400 src/simh/sim_tmxr.c if (!lp->conn) lp 1401 src/simh/sim_tmxr.c lp->ser_connect_pending = TRUE; lp 1404 src/simh/sim_tmxr.c FREE (lp->lpb); lp 1405 src/simh/sim_tmxr.c lp->lpb = NULL; lp 1406 src/simh/sim_tmxr.c lp->lpbsz = 0; lp 1411 src/simh/sim_tmxr.c t_bool tmxr_get_line_loopback (TMLN *lp) lp 1413 src/simh/sim_tmxr.c return (lp->loopback != FALSE); lp 1430 src/simh/sim_tmxr.c t_stat tmxr_set_line_halfduplex (TMLN *lp, t_bool enable_halfduplex) lp 1432 src/simh/sim_tmxr.c if (lp->halfduplex == (enable_halfduplex != FALSE)) lp 1434 src/simh/sim_tmxr.c lp->halfduplex = (enable_halfduplex != FALSE); lp 1438 src/simh/sim_tmxr.c t_bool tmxr_get_line_halfduplex (TMLN *lp) lp 1440 src/simh/sim_tmxr.c return (lp->halfduplex != FALSE); lp 1457 src/simh/sim_tmxr.c int32 tmxr_input_pending_ln (TMLN *lp) lp 1459 src/simh/sim_tmxr.c return (lp->rxbpi - lp->rxbpr); lp 1462 src/simh/sim_tmxr.c int32 tmxr_getc_ln (TMLN *lp) lp 1468 src/simh/sim_tmxr.c if ((lp->conn && lp->rcve) && /* conn & enb & */ lp 1469 src/simh/sim_tmxr.c ((!lp->rxbps) || /* (!rate limited || enough time passed)? */ lp 1470 src/simh/sim_tmxr.c (sim_gtime () >= lp->rxnexttime))) { lp 1471 src/simh/sim_tmxr.c if (!sim_send_poll_data (&lp->send, &val)) { /* injected input characters available? */ lp 1472 src/simh/sim_tmxr.c j = lp->rxbpi - lp->rxbpr; /* # input chrs */ lp 1474 src/simh/sim_tmxr.c tmp = lp->rxb[lp->rxbpr]; /* get char */ lp 1476 src/simh/sim_tmxr.c if (lp->rbr[lp->rxbpr]) { /* break? */ lp 1477 src/simh/sim_tmxr.c lp->rbr[lp->rxbpr] = 0; /* clear status */ lp 1480 src/simh/sim_tmxr.c lp->rxbpr = lp->rxbpr + 1; /* adv pointer */ lp 1484 src/simh/sim_tmxr.c if (lp->rxbpi == lp->rxbpr) /* empty? zero ptrs */ lp 1485 src/simh/sim_tmxr.c lp->rxbpi = lp->rxbpr = 0; lp 1486 src/simh/sim_tmxr.c if (lp->rxbps) { lp 1488 src/simh/sim_tmxr.c lp->rxnexttime = floor (sim_gtime () + ((lp->rxdelta * sim_timer_inst_per_sec ())/lp->rxbpsfactor)); lp 1512 src/simh/sim_tmxr.c t_stat tmxr_get_packet_ln (TMLN *lp, const uint8 **pbuf, size_t *psize) lp 1514 src/simh/sim_tmxr.c return tmxr_get_packet_ln_ex (lp, pbuf, psize, 0); lp 1517 src/simh/sim_tmxr.c t_stat tmxr_get_packet_ln_ex (TMLN *lp, const uint8 **pbuf, size_t *psize, uint8 frame_byte) lp 1523 src/simh/sim_tmxr.c while (TMXR_VALID & (c = tmxr_getc_ln (lp))) { lp 1524 src/simh/sim_tmxr.c if (lp->rxpboffset + 3 > lp->rxpbsize) { lp 1525 src/simh/sim_tmxr.c lp->rxpbsize += 512; lp 1526 src/simh/sim_tmxr.c lp->rxpb = (uint8 *)realloc (lp->rxpb, lp->rxpbsize); lp 1527 src/simh/sim_tmxr.c if (!lp->rxpb) lp 1540 src/simh/sim_tmxr.c if ((lp->rxpboffset == 0) && (fc_size) && (c != frame_byte)) { lp 1543 src/simh/sim_tmxr.c if ((lp->datagram) && (lp->rxpboffset == fc_size)) { lp 1548 src/simh/sim_tmxr.c lp->rxpb[lp->rxpboffset++] = (uint8)(((1 + lp->rxbpi - lp->rxbpr) >> 8) & 0xFF); lp 1549 src/simh/sim_tmxr.c lp->rxpb[lp->rxpboffset++] = (uint8)((1 + lp->rxbpi - lp->rxbpr) & 0xFF); lp 1551 src/simh/sim_tmxr.c lp->rxpb[lp->rxpboffset++] = c & 0xFF; lp 1552 src/simh/sim_tmxr.c if (lp->rxpboffset >= (2 + fc_size)) { lp 1553 src/simh/sim_tmxr.c pktsize = (lp->rxpb[0+fc_size] << 8) | lp->rxpb[1+fc_size]; lp 1554 src/simh/sim_tmxr.c if (pktsize == (lp->rxpboffset - 2)) { lp 1555 src/simh/sim_tmxr.c ++lp->rxpcnt; lp 1556 src/simh/sim_tmxr.c *pbuf = &lp->rxpb[2+fc_size]; lp 1558 src/simh/sim_tmxr.c lp->rxpboffset = 0; lp 1565 src/simh/sim_tmxr.c if (lp->conn) lp 1580 src/simh/sim_tmxr.c TMLN *lp; lp 1583 src/simh/sim_tmxr.c lp = mp->ldsc + i; /* get line desc */ lp 1584 src/simh/sim_tmxr.c if (!(lp->sock lp 1585 src/simh/sim_tmxr.c || lp->loopback) || lp 1586 src/simh/sim_tmxr.c !(lp->rcve)) /* skip if not connected */ lp 1590 src/simh/sim_tmxr.c if (lp->rxbpi == 0) /* need input? */ lp 1591 src/simh/sim_tmxr.c nbytes = tmxr_read (lp, /* yes, read */ lp 1592 src/simh/sim_tmxr.c lp->rxbsz - TMXR_GUARD); /* leave spc for Telnet cruft */ lp 1593 src/simh/sim_tmxr.c else if (lp->tsta) /* in Telnet seq? */ lp 1594 src/simh/sim_tmxr.c nbytes = tmxr_read (lp, /* yes, read to end */ lp 1595 src/simh/sim_tmxr.c lp->rxbsz - lp->rxbpi); lp 1598 src/simh/sim_tmxr.c if (!lp->datagram) { /* ignore errors reading UDP sockets */ lp 1599 src/simh/sim_tmxr.c if (!lp->txbfd || lp->notelnet) lp 1600 src/simh/sim_tmxr.c lp->txbpi = lp->txbpr = 0; /* Drop the data we already know we can't send */ lp 1601 src/simh/sim_tmxr.c tmxr_close_ln (lp); /* disconnect line */ lp 1607 src/simh/sim_tmxr.c j = lp->rxbpi; /* start of data */ lp 1608 src/simh/sim_tmxr.c lp->rxbpi = lp->rxbpi + nbytes; /* adv pointers */ lp 1609 src/simh/sim_tmxr.c lp->rxcnt = lp->rxcnt + nbytes; lp 1613 src/simh/sim_tmxr.c if (!lp->notelnet) { /* Are we looking for telnet interpretation? */ lp 1614 src/simh/sim_tmxr.c for (; j < lp->rxbpi; ) { /* loop thru char */ lp 1615 src/simh/sim_tmxr.c u_char tmp = (u_char)lp->rxb[j]; /* get char */ lp 1616 src/simh/sim_tmxr.c switch (lp->tsta) { /* case tlnt state */ lp 1620 src/simh/sim_tmxr.c lp->tsta = TNS_IAC; /* change state */ lp 1621 src/simh/sim_tmxr.c tmxr_rmvrc (lp, j); /* remove char */ lp 1624 src/simh/sim_tmxr.c if ((tmp == TN_CR) && lp->dstb) /* CR, no bin */ lp 1625 src/simh/sim_tmxr.c lp->tsta = TNS_CRPAD; /* skip pad char */ lp 1631 src/simh/sim_tmxr.c lp->tsta = TNS_NORM; /* treat as normal */ lp 1636 src/simh/sim_tmxr.c lp->tsta = TNS_NORM; /* treat as normal */ lp 1637 src/simh/sim_tmxr.c lp->rxb[j] = 0; /* char is null */ lp 1638 src/simh/sim_tmxr.c lp->rbr[j] = 1; /* flag break */ lp 1644 src/simh/sim_tmxr.c lp->tsta = TNS_WILL; lp 1647 src/simh/sim_tmxr.c lp->tsta = TNS_WONT; lp 1650 src/simh/sim_tmxr.c lp->tsta = TNS_DO; lp 1653 src/simh/sim_tmxr.c lp->tsta = TNS_SKIP; /* IAC + other */ lp 1659 src/simh/sim_tmxr.c lp->tsta = TNS_NORM; //-V1037 /* ignore */ lp 1664 src/simh/sim_tmxr.c lp->tsta = TNS_NORM; //-V1037 /* ignore */ lp 1667 src/simh/sim_tmxr.c tmxr_rmvrc (lp, j); /* remove char */ lp 1705 src/simh/sim_tmxr.c if (0 == (lp->telnet_sent_opts[tmp] & TNOS_DONT)) { lp 1706 src/simh/sim_tmxr.c lp->notelnet = TRUE; /* Temporarily disable so */ lp 1707 src/simh/sim_tmxr.c tmxr_putc_ln (lp, TN_IAC); /* IAC gets injected bare */ lp 1708 src/simh/sim_tmxr.c lp->notelnet = FALSE; lp 1709 src/simh/sim_tmxr.c tmxr_putc_ln (lp, TN_DONT); lp 1710 src/simh/sim_tmxr.c tmxr_putc_ln (lp, tmp); lp 1711 src/simh/sim_tmxr.c lp->telnet_sent_opts[tmp] |= TNOS_DONT;/* Record DONT sent */ lp 1717 src/simh/sim_tmxr.c if (lp->tsta == TNS_WILL) { lp 1718 src/simh/sim_tmxr.c lp->dstb = 0; lp 1721 src/simh/sim_tmxr.c lp->dstb = 1; lp 1724 src/simh/sim_tmxr.c tmxr_rmvrc (lp, j); /* remove it */ lp 1725 src/simh/sim_tmxr.c lp->tsta = TNS_NORM; /* next normal */ lp 1743 src/simh/sim_tmxr.c lp->tsta = TNS_NORM; /* next normal */ lp 1746 src/simh/sim_tmxr.c tmxr_rmvrc (lp, j); /* remove it */ lp 1784 src/simh/sim_tmxr.c if (0 == (lp->telnet_sent_opts[tmp] & TNOS_WONT)) { lp 1785 src/simh/sim_tmxr.c lp->notelnet = TRUE; /* Temporarily disable so */ lp 1786 src/simh/sim_tmxr.c tmxr_putc_ln (lp, TN_IAC); /* IAC gets injected bare */ lp 1787 src/simh/sim_tmxr.c lp->notelnet = FALSE; lp 1788 src/simh/sim_tmxr.c tmxr_putc_ln (lp, TN_WONT); lp 1789 src/simh/sim_tmxr.c tmxr_putc_ln (lp, tmp); lp 1790 src/simh/sim_tmxr.c lp->telnet_sent_opts[tmp] |= TNOS_WONT;/* Record WONT sent */ lp 1795 src/simh/sim_tmxr.c tmxr_rmvrc (lp, j); /* remove char */ lp 1796 src/simh/sim_tmxr.c lp->tsta = TNS_NORM; /* next normal */ lp 1804 src/simh/sim_tmxr.c lp = mp->ldsc + i; /* get line desc */ lp 1805 src/simh/sim_tmxr.c if (lp->rxbpi == lp->rxbpr) /* if buf empty, */ lp 1806 src/simh/sim_tmxr.c lp->rxbpi = lp->rxbpr = 0; /* reset pointers */ lp 1813 src/simh/sim_tmxr.c int32 tmxr_rqln_bare (const TMLN *lp, t_bool speed) lp 1815 src/simh/sim_tmxr.c if ((speed) && (lp->rxbps)) { /* consider speed and rate limiting? */ lp 1816 src/simh/sim_tmxr.c if (sim_gtime () < lp->rxnexttime) /* too soon? */ lp 1819 src/simh/sim_tmxr.c return (lp->rxbpi - lp->rxbpr + ((lp->rxbpi < lp->rxbpr)? lp->rxbsz : 0)) ? 1 : 0; lp 1821 src/simh/sim_tmxr.c return (lp->rxbpi - lp->rxbpr + ((lp->rxbpi < lp->rxbpr)? lp->rxbsz: 0)); lp 1824 src/simh/sim_tmxr.c int32 tmxr_rqln (const TMLN *lp) lp 1826 src/simh/sim_tmxr.c return tmxr_rqln_bare (lp, TRUE); lp 1842 src/simh/sim_tmxr.c t_stat tmxr_putc_ln (TMLN *lp, int32 chr) lp 1844 src/simh/sim_tmxr.c if ((lp->conn == FALSE) && /* no conn & not buffered telnet? */ lp 1845 src/simh/sim_tmxr.c (!lp->txbfd || lp->notelnet)) { lp 1846 src/simh/sim_tmxr.c ++lp->txdrp; /* lost */ lp 1850 src/simh/sim_tmxr.c #define TXBUF_AVAIL(lp) (lp->txbsz - tmxr_tqln (lp)) lp 1852 src/simh/sim_tmxr.c #define TXBUF_CHAR(lp, c) { \ lp 1853 src/simh/sim_tmxr.c lp->txb[lp->txbpi++] = (char)(c); \ lp 1854 src/simh/sim_tmxr.c lp->txbpi %= lp->txbsz; \ lp 1855 src/simh/sim_tmxr.c if (lp->txbpi == lp->txbpr) \ lp 1856 src/simh/sim_tmxr.c lp->txbpr = (1+lp->txbpr)%lp->txbsz, ++lp->txdrp; \ lp 1859 src/simh/sim_tmxr.c if ((lp->txbfd && !lp->notelnet) || (TXBUF_AVAIL(lp) > 1)) {/* room for char (+ IAC)? */ lp 1860 src/simh/sim_tmxr.c if ((TN_IAC == (u_char) chr) && (!lp->notelnet)) /* char == IAC in telnet session? */ lp 1861 src/simh/sim_tmxr.c TXBUF_CHAR (lp, TN_IAC); /* stuff extra IAC char */ lp 1862 src/simh/sim_tmxr.c TXBUF_CHAR (lp, chr); /* buffer char & adv pointer */ lp 1863 src/simh/sim_tmxr.c if ((!lp->txbfd) && ((unsigned long int)TXBUF_AVAIL (lp) <= TMXR_GUARD)) /* near full? */ lp 1864 src/simh/sim_tmxr.c lp->xmte = 0; /* disable line */ lp 1865 src/simh/sim_tmxr.c if (lp->txlog) /* log if available */ lp 1866 src/simh/sim_tmxr.c fputc (chr, lp->txlog); lp 1867 src/simh/sim_tmxr.c sim_exp_check (&lp->expect, chr); /* process expect rules as needed */ lp 1870 src/simh/sim_tmxr.c ++lp->txdrp; lp->xmte = 0; /* no room, dsbl line */ lp 1891 src/simh/sim_tmxr.c t_stat tmxr_put_packet_ln (TMLN *lp, const uint8 *buf, size_t size) lp 1893 src/simh/sim_tmxr.c return tmxr_put_packet_ln_ex (lp, buf, size, 0); lp 1896 src/simh/sim_tmxr.c t_stat tmxr_put_packet_ln_ex (TMLN *lp, const uint8 *buf, size_t size, uint8 frame_byte) lp 1900 src/simh/sim_tmxr.c size_t pktlen_size = (lp->datagram ? 0 : 2); lp 1902 src/simh/sim_tmxr.c if ((!lp->conn) && (!lp->loopback)) lp 1904 src/simh/sim_tmxr.c if (lp->txppoffset < lp->txppsize) { lp 1907 src/simh/sim_tmxr.c if (lp->txpbsize < size + pktlen_size + fc_size) { lp 1908 src/simh/sim_tmxr.c lp->txpbsize = size + pktlen_size + fc_size; lp 1909 src/simh/sim_tmxr.c lp->txpb = (uint8 *)realloc (lp->txpb, lp->txpbsize); lp 1910 src/simh/sim_tmxr.c if (!lp->txpb) lp 1923 src/simh/sim_tmxr.c lp->txpb[0] = frame_byte; lp 1924 src/simh/sim_tmxr.c if (!lp->datagram) { lp 1925 src/simh/sim_tmxr.c lp->txpb[0+fc_size] = (size >> 8) & 0xFF; lp 1926 src/simh/sim_tmxr.c lp->txpb[1+fc_size] = size & 0xFF; lp 1928 src/simh/sim_tmxr.c memcpy (lp->txpb + pktlen_size + fc_size, buf, size); lp 1929 src/simh/sim_tmxr.c lp->txppsize = size + pktlen_size + fc_size; lp 1930 src/simh/sim_tmxr.c lp->txppoffset = 0; lp 1931 src/simh/sim_tmxr.c ++lp->txpcnt; lp 1932 src/simh/sim_tmxr.c while ((lp->txppoffset < lp->txppsize) && lp 1933 src/simh/sim_tmxr.c (SCPE_OK == (r = tmxr_putc_ln (lp, lp->txpb[lp->txppoffset])))) lp 1934 src/simh/sim_tmxr.c ++lp->txppoffset; lp 1936 src/simh/sim_tmxr.c tmxr_send_buffered_data (lp); lp 1937 src/simh/sim_tmxr.c return (lp->conn || lp->loopback) ? SCPE_OK : SCPE_LOST; lp 1951 src/simh/sim_tmxr.c TMLN *lp; lp 1954 src/simh/sim_tmxr.c lp = mp->ldsc + i; /* get line desc */ lp 1955 src/simh/sim_tmxr.c if (!lp->conn) /* skip if !conn */ lp 1957 src/simh/sim_tmxr.c nbytes = tmxr_send_buffered_data (lp); /* buffered bytes */ lp 1959 src/simh/sim_tmxr.c lp->xmte = 1; /* enable line transmit */ lp 1973 src/simh/sim_tmxr.c int32 tmxr_send_buffered_data (TMLN *lp) lp 1978 src/simh/sim_tmxr.c nbytes = tmxr_tqln(lp); /* avail bytes */ lp 1980 src/simh/sim_tmxr.c if (lp->txbpr < lp->txbpi) /* no wrap? */ lp 1981 src/simh/sim_tmxr.c sbytes = tmxr_write (lp, nbytes); /* write all data */ lp 1983 src/simh/sim_tmxr.c sbytes = tmxr_write (lp, lp->txbsz - lp->txbpr);/* write to end buf */ lp 1985 src/simh/sim_tmxr.c lp->txbpr = (lp->txbpr + sbytes); /* update remove ptr */ lp 1986 src/simh/sim_tmxr.c if (lp->txbpr >= lp->txbsz) /* wrap? */ lp 1987 src/simh/sim_tmxr.c lp->txbpr = 0; lp 1988 src/simh/sim_tmxr.c lp->txcnt = lp->txcnt + sbytes; /* update counts */ lp 1990 src/simh/sim_tmxr.c if ((nbytes == 0) && (lp->datagram)) /* if Empty buffer on datagram line */ lp 1991 src/simh/sim_tmxr.c lp->txbpi = lp->txbpr = 0; /* Start next packet at beginning of buffer */ lp 1994 src/simh/sim_tmxr.c lp->txbpi = lp->txbpr = 0; /* Drop the data we already know we can't send */ lp 1995 src/simh/sim_tmxr.c lp->rxpboffset = lp->txppoffset = lp->txppsize = 0;/* Drop the data we already know we can't send */ lp 1996 src/simh/sim_tmxr.c tmxr_close_ln (lp); /* close line/port on error */ lp 1999 src/simh/sim_tmxr.c if (nbytes && (lp->txbpr == 0)) { /* more data and wrap? */ lp 2000 src/simh/sim_tmxr.c sbytes = tmxr_write (lp, nbytes); lp 2002 src/simh/sim_tmxr.c lp->txbpr = (lp->txbpr + sbytes); /* update remove ptr */ lp 2003 src/simh/sim_tmxr.c if (lp->txbpr >= lp->txbsz) /* wrap? */ lp 2004 src/simh/sim_tmxr.c lp->txbpr = 0; lp 2005 src/simh/sim_tmxr.c lp->txcnt = lp->txcnt + sbytes; /* update counts */ lp 2010 src/simh/sim_tmxr.c while ((lp->txppoffset < lp->txppsize) && /* buffered packet data? */ lp 2011 src/simh/sim_tmxr.c (lp->txbsz > nbytes) && /* and room in xmt buffer */ lp 2012 src/simh/sim_tmxr.c (SCPE_OK == (r = tmxr_putc_ln (lp, lp->txpb[lp->txppoffset])))) lp 2013 src/simh/sim_tmxr.c ++lp->txppoffset; lp 2015 src/simh/sim_tmxr.c if ((nbytes == 0) && (tmxr_tqln(lp) > 0)) lp 2016 src/simh/sim_tmxr.c return tmxr_send_buffered_data (lp); lp 2017 src/simh/sim_tmxr.c return tmxr_tqln(lp) + tmxr_tpqln(lp); lp 2022 src/simh/sim_tmxr.c int32 tmxr_tqln (const TMLN *lp) lp 2024 src/simh/sim_tmxr.c return (lp->txbpi - lp->txbpr + ((lp->txbpi < lp->txbpr)? lp->txbsz: 0)); lp 2029 src/simh/sim_tmxr.c int32 tmxr_tpqln (const TMLN *lp) lp 2031 src/simh/sim_tmxr.c return (lp->txppsize - lp->txppoffset); lp 2036 src/simh/sim_tmxr.c t_bool tmxr_tpbusyln (const TMLN *lp) lp 2038 src/simh/sim_tmxr.c return (0 != (lp->txppsize - lp->txppoffset)); lp 2041 src/simh/sim_tmxr.c static void _mux_detach_line (TMLN *lp, t_bool close_listener, t_bool close_connecting) lp 2043 src/simh/sim_tmxr.c if (close_listener && lp->master) { lp 2044 src/simh/sim_tmxr.c sim_close_sock (lp->master); lp 2045 src/simh/sim_tmxr.c lp->master = 0; lp 2046 src/simh/sim_tmxr.c FREE (lp->port); lp 2047 src/simh/sim_tmxr.c lp->port = NULL; lp 2049 src/simh/sim_tmxr.c if (lp->sock) { /* if existing tcp, drop it */ lp 2050 src/simh/sim_tmxr.c tmxr_report_disconnection (lp); /* report disconnection */ lp 2051 src/simh/sim_tmxr.c tmxr_reset_ln (lp); lp 2054 src/simh/sim_tmxr.c FREE (lp->destination); lp 2055 src/simh/sim_tmxr.c lp->destination = NULL; lp 2056 src/simh/sim_tmxr.c if (lp->connecting) { /* if existing outgoing tcp, drop it */ lp 2057 src/simh/sim_tmxr.c lp->sock = lp->connecting; lp 2058 src/simh/sim_tmxr.c lp->connecting = 0; lp 2059 src/simh/sim_tmxr.c tmxr_reset_ln (lp); lp 2062 src/simh/sim_tmxr.c tmxr_set_line_loopback (lp, FALSE); lp 2065 src/simh/sim_tmxr.c t_stat tmxr_detach_ln (TMLN *lp) lp 2069 src/simh/sim_tmxr.c _mux_detach_line (lp, TRUE, TRUE); lp 2070 src/simh/sim_tmxr.c if (lp->mp) { lp 2071 src/simh/sim_tmxr.c if (lp->uptr) lp 2072 src/simh/sim_tmxr.c uptr = lp->uptr; lp 2074 src/simh/sim_tmxr.c uptr = lp->mp->uptr; lp 2078 src/simh/sim_tmxr.c uptr->filename = tmxr_mux_attach_string (uptr->filename, lp->mp); lp 2081 src/simh/sim_tmxr.c tmxr_detach (lp->mp, uptr); lp 2132 src/simh/sim_tmxr.c t_stat tmxr_set_line_speed (TMLN *lp, CONST char *speed) lp 2142 src/simh/sim_tmxr.c if (lp == NULL) lp 2144 src/simh/sim_tmxr.c lp->rxbps = (uint32)strtotv (speed, &cptr, 10); lp 2149 src/simh/sim_tmxr.c lp->rxbpsfactor = TMXR_RX_BPS_UNIT_SCALE * rxbpsfactor; lp 2151 src/simh/sim_tmxr.c lp->rxdelta = _tmln_speed_delta (speed); lp 2152 src/simh/sim_tmxr.c lp->rxnexttime = 0.0; lp 2153 src/simh/sim_tmxr.c uptr = lp->uptr; lp 2154 src/simh/sim_tmxr.c if ((!uptr) && (lp->mp)) lp 2155 src/simh/sim_tmxr.c uptr = lp->mp->uptr; lp 2157 src/simh/sim_tmxr.c uptr->wait = lp->rxdelta; lp 2158 src/simh/sim_tmxr.c if (lp->rxbpsfactor == 0.0) lp 2159 src/simh/sim_tmxr.c lp->rxbpsfactor = TMXR_RX_BPS_UNIT_SCALE; lp 2160 src/simh/sim_tmxr.c lp->txbps = lp->rxbps; lp 2161 src/simh/sim_tmxr.c lp->txdelta = lp->rxdelta; lp 2162 src/simh/sim_tmxr.c lp->txnexttime = lp->rxnexttime; lp 2182 src/simh/sim_tmxr.c TMLN *lp = NULL; lp 2188 src/simh/sim_tmxr.c lp = mp->ldsc + i; lp 2189 src/simh/sim_tmxr.c lp->mp = mp; /* set the back pointer */ lp 2190 src/simh/sim_tmxr.c lp->modem_control = mp->modem_control; lp 2191 src/simh/sim_tmxr.c if (lp->rxbpsfactor == 0.0) lp 2192 src/simh/sim_tmxr.c lp->rxbpsfactor = TMXR_RX_BPS_UNIT_SCALE; lp 2404 src/simh/sim_tmxr.c lp = mp->ldsc + i; lp 2405 src/simh/sim_tmxr.c sim_close_logfile (&lp->txlogref); lp 2406 src/simh/sim_tmxr.c lp->txlog = NULL; lp 2407 src/simh/sim_tmxr.c lp->txlogname = (char *)realloc(lp->txlogname, CBUFSIZE); lp 2408 src/simh/sim_tmxr.c if (!lp->txlogname) lp 2421 src/simh/sim_tmxr.c (void)sprintf(lp->txlogname, "%s_%d", mp->logfiletmpl, i); lp 2423 src/simh/sim_tmxr.c (void)strcpy (lp->txlogname, mp->logfiletmpl); lp 2424 src/simh/sim_tmxr.c r = sim_open_logfile (lp->txlogname, TRUE, &lp->txlog, &lp->txlogref); lp 2426 src/simh/sim_tmxr.c setvbuf (lp->txlog, NULL, _IOFBF, 65536); lp 2428 src/simh/sim_tmxr.c FREE (lp->txlogname); lp 2429 src/simh/sim_tmxr.c lp->txlogname = NULL; lp 2436 src/simh/sim_tmxr.c lp = mp->ldsc + i; lp 2438 src/simh/sim_tmxr.c lp->txbsz = mp->buffered; lp 2439 src/simh/sim_tmxr.c lp->txbfd = 1; lp 2440 src/simh/sim_tmxr.c lp->rxbsz = mp->buffered; lp 2443 src/simh/sim_tmxr.c lp->txbsz = TMXR_MAXBUF; lp 2444 src/simh/sim_tmxr.c lp->txbfd = 0; lp 2445 src/simh/sim_tmxr.c lp->rxbsz = TMXR_MAXBUF; lp 2447 src/simh/sim_tmxr.c lp->txbpi = lp->txbpr = 0; lp 2448 src/simh/sim_tmxr.c lp->txb = (char *)realloc(lp->txb, lp->txbsz); lp 2449 src/simh/sim_tmxr.c if (!lp->txb) lp 2461 src/simh/sim_tmxr.c lp->rxb = (char *)realloc(lp->rxb, lp->rxbsz); lp 2462 src/simh/sim_tmxr.c if (!lp->rxb) lp 2474 src/simh/sim_tmxr.c lp->rbr = (char *)realloc(lp->rbr, lp->rxbsz); lp 2475 src/simh/sim_tmxr.c if (!lp->rbr) lp 2491 src/simh/sim_tmxr.c lp = mp->ldsc + i; lp 2492 src/simh/sim_tmxr.c FREE(lp->txlogname); lp 2493 src/simh/sim_tmxr.c lp->txlogname = NULL; lp 2494 src/simh/sim_tmxr.c if (lp->txlog) { lp 2495 src/simh/sim_tmxr.c sim_close_logfile (&lp->txlogref); lp 2496 src/simh/sim_tmxr.c lp->txlog = NULL; lp 2534 src/simh/sim_tmxr.c lp = mp->ldsc + i; lp 2535 src/simh/sim_tmxr.c lp->mp = mp; /* set the back pointer */ lp 2536 src/simh/sim_tmxr.c lp->packet = mp->packet; lp 2538 src/simh/sim_tmxr.c tmxr_set_line_speed (lp, speed); lp 2539 src/simh/sim_tmxr.c tmxr_init_line (lp); /* initialize line state */ lp 2540 src/simh/sim_tmxr.c lp->sock = 0; /* clear the socket */ lp 2548 src/simh/sim_tmxr.c lp = mp->ldsc + i; lp 2549 src/simh/sim_tmxr.c tmxr_set_line_loopback (lp, loopback); lp 2551 src/simh/sim_tmxr.c tmxr_set_line_speed (lp, speed); lp 2557 src/simh/sim_tmxr.c lp = &mp->ldsc[0]; lp 2558 src/simh/sim_tmxr.c lp->datagram = datagram; lp 2561 src/simh/sim_tmxr.c lp->port = (char *)realloc (lp->port, 1 + strlen (listen)); lp 2562 src/simh/sim_tmxr.c if (!lp->port) lp 2574 src/simh/sim_tmxr.c (void)strcpy (lp->port, listen); /* save port */ lp 2579 src/simh/sim_tmxr.c lp->packet = packet; lp 2585 src/simh/sim_tmxr.c _mux_detach_line (lp, FALSE, TRUE); lp 2586 src/simh/sim_tmxr.c lp->destination = (char *)malloc(1+strlen(hostport)); lp 2587 src/simh/sim_tmxr.c if (!lp->destination) lp 2599 src/simh/sim_tmxr.c (void)strcpy (lp->destination, hostport); lp 2600 src/simh/sim_tmxr.c lp->mp = mp; lp 2601 src/simh/sim_tmxr.c if (!lp->modem_control || (lp->modembits & TMXR_MDM_DTR)) { lp 2602 src/simh/sim_tmxr.c lp->connecting = sock; lp 2603 src/simh/sim_tmxr.c lp->ipad = (char *)malloc (1 + strlen (lp->destination)); lp 2604 src/simh/sim_tmxr.c if (!lp->ipad) lp 2616 src/simh/sim_tmxr.c (void)strcpy (lp->ipad, lp->destination); lp 2620 src/simh/sim_tmxr.c lp->notelnet = notelnet; lp 2621 src/simh/sim_tmxr.c tmxr_init_line (lp); /* init the line state */ lp 2623 src/simh/sim_tmxr.c tmxr_set_line_speed (lp, speed); lp 2633 src/simh/sim_tmxr.c lp = &mp->ldsc[line]; lp 2634 src/simh/sim_tmxr.c lp->mp = mp; lp 2636 src/simh/sim_tmxr.c sim_close_logfile (&lp->txlogref); lp 2637 src/simh/sim_tmxr.c lp->txlog = NULL; lp 2638 src/simh/sim_tmxr.c lp->txlogname = (char *)realloc (lp->txlogname, 1 + strlen (logfiletmpl)); lp 2639 src/simh/sim_tmxr.c if (!lp->txlogname) lp 2651 src/simh/sim_tmxr.c (void)strcpy (lp->txlogname, logfiletmpl); lp 2652 src/simh/sim_tmxr.c r = sim_open_logfile (lp->txlogname, TRUE, &lp->txlog, &lp->txlogref); lp 2654 src/simh/sim_tmxr.c setvbuf(lp->txlog, NULL, _IOFBF, 65536); lp 2656 src/simh/sim_tmxr.c FREE (lp->txlogname); lp 2657 src/simh/sim_tmxr.c lp->txlogname = NULL; lp 2662 src/simh/sim_tmxr.c lp->rxbsz = lp->txbsz = TMXR_MAXBUF; lp 2663 src/simh/sim_tmxr.c lp->txbfd = 0; lp 2666 src/simh/sim_tmxr.c lp->rxbsz = lp->txbsz = atoi(buffered); lp 2667 src/simh/sim_tmxr.c lp->txbfd = 1; lp 2669 src/simh/sim_tmxr.c lp->txbpi = lp->txbpr = 0; lp 2670 src/simh/sim_tmxr.c lp->txb = (char *)realloc (lp->txb, lp->txbsz); lp 2671 src/simh/sim_tmxr.c if (!lp->txb) lp 2683 src/simh/sim_tmxr.c lp->rxb = (char *)realloc (lp->rxb, lp->rxbsz); lp 2684 src/simh/sim_tmxr.c if (!lp->rxb) lp 2696 src/simh/sim_tmxr.c lp->rbr = (char *)realloc (lp->rbr, lp->rxbsz); lp 2697 src/simh/sim_tmxr.c if (!lp->rbr) lp 2709 src/simh/sim_tmxr.c lp->packet = packet; lp 2711 src/simh/sim_tmxr.c FREE(lp->txlogname); lp 2712 src/simh/sim_tmxr.c lp->txlogname = NULL; lp 2713 src/simh/sim_tmxr.c if (lp->txlog) { lp 2714 src/simh/sim_tmxr.c sim_close_logfile (&lp->txlogref); lp 2715 src/simh/sim_tmxr.c lp->txlog = NULL; lp 2726 src/simh/sim_tmxr.c _mux_detach_line (lp, TRUE, FALSE); lp 2728 src/simh/sim_tmxr.c lp->port = (char *)realloc (lp->port, 1 + strlen (listen)); lp 2729 src/simh/sim_tmxr.c if (!lp->port) lp 2741 src/simh/sim_tmxr.c (void)strcpy (lp->port, listen); /* save port */ lp 2742 src/simh/sim_tmxr.c lp->master = sock; /* save master socket */ lp 2744 src/simh/sim_tmxr.c lp->notelnet = listennotelnet; lp 2746 src/simh/sim_tmxr.c lp->notelnet = mp->notelnet; lp 2749 src/simh/sim_tmxr.c lp->datagram = datagram; lp 2752 src/simh/sim_tmxr.c lp->port = (char *)realloc (lp->port, 1 + strlen (listen)); lp 2753 src/simh/sim_tmxr.c if (!lp->port) lp 2765 src/simh/sim_tmxr.c (void)strcpy (lp->port, listen); /* save port */ lp 2773 src/simh/sim_tmxr.c _mux_detach_line (lp, FALSE, TRUE); lp 2774 src/simh/sim_tmxr.c lp->destination = (char *)malloc(1+strlen(hostport)); lp 2775 src/simh/sim_tmxr.c if (!lp->destination) lp 2787 src/simh/sim_tmxr.c (void)strcpy (lp->destination, hostport); lp 2788 src/simh/sim_tmxr.c if (!lp->modem_control || (lp->modembits & TMXR_MDM_DTR)) { lp 2789 src/simh/sim_tmxr.c lp->connecting = sock; lp 2790 src/simh/sim_tmxr.c lp->ipad = (char *)malloc (1 + strlen (lp->destination)); lp 2791 src/simh/sim_tmxr.c if (!lp->ipad) lp 2803 src/simh/sim_tmxr.c (void)strcpy (lp->ipad, lp->destination); lp 2807 src/simh/sim_tmxr.c lp->notelnet = notelnet; lp 2808 src/simh/sim_tmxr.c tmxr_init_line (lp); /* init the line state */ lp 2817 src/simh/sim_tmxr.c if (lp != NULL) { lp 2818 src/simh/sim_tmxr.c tmxr_set_line_loopback (lp, loopback); lp 2822 src/simh/sim_tmxr.c if (lp != NULL) lp->modem_control = modem_control; lp 2825 src/simh/sim_tmxr.c tmxr_set_line_speed (lp, speed); lp 3047 src/simh/sim_tmxr.c TMLN *lp; lp 3085 src/simh/sim_tmxr.c lp = mp->ldsc + j; lp 3087 src/simh/sim_tmxr.c if (lp->dptr && (mp->dptr != lp->dptr)) lp 3088 src/simh/sim_tmxr.c fprintf (st, "Device: %s ", sim_dname(lp->dptr)); lp 3090 src/simh/sim_tmxr.c if (mp->notelnet != lp->notelnet) lp 3091 src/simh/sim_tmxr.c fprintf (st, " - %stelnet", lp->notelnet ? "no" : ""); lp 3092 src/simh/sim_tmxr.c if (lp->uptr && (lp->uptr != lp->mp->uptr)) lp 3093 src/simh/sim_tmxr.c fprintf (st, " - Unit: %s", sim_uname (lp->uptr)); lp 3094 src/simh/sim_tmxr.c if (mp->modem_control != lp->modem_control) lp 3095 src/simh/sim_tmxr.c fprintf(st, ", ModemControl=%s", lp->modem_control ? "enabled" : "disabled"); lp 3096 src/simh/sim_tmxr.c if (lp->loopback) lp 3098 src/simh/sim_tmxr.c if (lp->rxbps) { lp 3099 src/simh/sim_tmxr.c fprintf(st, ", Speed=%lu", (unsigned long)lp->rxbps); lp 3100 src/simh/sim_tmxr.c if (lp->rxbpsfactor != TMXR_RX_BPS_UNIT_SCALE) lp 3101 src/simh/sim_tmxr.c fprintf(st, "*%.0f", lp->rxbpsfactor/TMXR_RX_BPS_UNIT_SCALE); lp 3106 src/simh/sim_tmxr.c if ((!lp->sock) && (!lp->connecting) lp 3107 src/simh/sim_tmxr.c && (!lp->master)) { lp 3108 src/simh/sim_tmxr.c if (lp->modem_control) lp 3109 src/simh/sim_tmxr.c tmxr_fconns (st, lp, -1); lp 3112 src/simh/sim_tmxr.c tmxr_fconns (st, lp, -1); lp 3113 src/simh/sim_tmxr.c tmxr_fstats (st, lp, -1); lp 3130 src/simh/sim_tmxr.c TMLN *lp; lp 3133 src/simh/sim_tmxr.c lp = mp->ldsc + i; lp 3135 src/simh/sim_tmxr.c if (!lp->destination && lp->sock) { /* not serial and is connected? */ lp 3136 src/simh/sim_tmxr.c tmxr_report_disconnection (lp); /* report disconnection */ lp 3137 src/simh/sim_tmxr.c tmxr_reset_ln (lp); /* disconnect line */ lp 3140 src/simh/sim_tmxr.c if (lp->sock) { lp 3141 src/simh/sim_tmxr.c tmxr_report_disconnection (lp); /* report disconnection */ lp 3142 src/simh/sim_tmxr.c tmxr_reset_ln (lp); lp 3144 src/simh/sim_tmxr.c FREE (lp->destination); lp 3145 src/simh/sim_tmxr.c lp->destination = NULL; lp 3146 src/simh/sim_tmxr.c if (lp->connecting) { lp 3147 src/simh/sim_tmxr.c lp->sock = lp->connecting; lp 3148 src/simh/sim_tmxr.c lp->connecting = 0; lp 3149 src/simh/sim_tmxr.c tmxr_reset_ln (lp); lp 3151 src/simh/sim_tmxr.c lp->conn = FALSE; lp 3153 src/simh/sim_tmxr.c if (lp->master) { lp 3154 src/simh/sim_tmxr.c sim_close_sock (lp->master); /* close master socket */ lp 3155 src/simh/sim_tmxr.c lp->master = 0; lp 3156 src/simh/sim_tmxr.c FREE (lp->port); lp 3157 src/simh/sim_tmxr.c lp->port = NULL; lp 3159 src/simh/sim_tmxr.c lp->txbfd = 0; lp 3160 src/simh/sim_tmxr.c FREE (lp->txb); lp 3161 src/simh/sim_tmxr.c lp->txb = NULL; lp 3162 src/simh/sim_tmxr.c FREE (lp->rxb); lp 3163 src/simh/sim_tmxr.c lp->rxb = NULL; lp 3164 src/simh/sim_tmxr.c FREE (lp->rbr); lp 3165 src/simh/sim_tmxr.c lp->rbr = NULL; lp 3166 src/simh/sim_tmxr.c lp->modembits = 0; lp 3449 src/simh/sim_tmxr.c void tmxr_linemsg (TMLN *lp, const char *msg) lp 3452 src/simh/sim_tmxr.c while (SCPE_STALL == tmxr_putc_ln (lp, (int32)(*msg))) lp 3453 src/simh/sim_tmxr.c if (lp->txbsz == tmxr_send_buffered_data (lp)) lp 3462 src/simh/sim_tmxr.c void tmxr_linemsgf (TMLN *lp, const char *fmt, ...) lp 3467 src/simh/sim_tmxr.c tmxr_linemsgvf (lp, fmt, arglist); lp 3471 src/simh/sim_tmxr.c void tmxr_linemsgvf (TMLN *lp, const char *fmt, va_list arglist) lp 3515 src/simh/sim_tmxr.c while (SCPE_STALL == tmxr_putc_ln (lp, '\r')) lp 3516 src/simh/sim_tmxr.c if (lp->txbsz == tmxr_send_buffered_data (lp)) lp 3519 src/simh/sim_tmxr.c while (SCPE_STALL == tmxr_putc_ln (lp, buf[i])) lp 3520 src/simh/sim_tmxr.c if (lp->txbsz == tmxr_send_buffered_data (lp)) lp 3530 src/simh/sim_tmxr.c void tmxr_fconns (FILE *st, const TMLN *lp, int32 ln) lp 3538 src/simh/sim_tmxr.c if ((lp->sock) || (lp->connecting)) { /* tcp connection? */ lp 3539 src/simh/sim_tmxr.c if (lp->destination) /* remote connection? */ lp 3540 src/simh/sim_tmxr.c if (lp->datagram) lp 3541 src/simh/sim_tmxr.c fprintf (st, "Datagram Connection from %s to remote port %s\n", lp->port, lp->destination);/* print port name */ lp 3543 src/simh/sim_tmxr.c fprintf (st, "Connection to remote port %s\n", lp->destination);/* print port name */ lp 3545 src/simh/sim_tmxr.c fprintf (st, "Connection from IP address %s\n", lp->ipad); lp 3548 src/simh/sim_tmxr.c if (lp->destination) /* remote connection? */ lp 3549 src/simh/sim_tmxr.c fprintf (st, "Connecting to remote port %s\n", lp->destination);/* print port name */ lp 3550 src/simh/sim_tmxr.c if (lp->sock) { lp 3553 src/simh/sim_tmxr.c sim_getnames_sock (lp->sock, &sockname, &peername); lp 3559 src/simh/sim_tmxr.c if ((lp->port) && (!lp->datagram)) lp 3560 src/simh/sim_tmxr.c fprintf (st, "Listening on port %s\n", lp->port); /* print port name */ lp 3561 src/simh/sim_tmxr.c if (lp->cnms) { lp 3562 src/simh/sim_tmxr.c tctime = (sim_os_msec () - lp->cnms) / 1000; lp 3567 src/simh/sim_tmxr.c fprintf (st, " %s %02d:%02d:%02d\n", lp->connecting ? "Connecting for" : "Connected", hr, mn, sc); lp 3572 src/simh/sim_tmxr.c if (lp->modem_control) { lp 3573 src/simh/sim_tmxr.c fprintf (st, " Modem Bits: %s%s%s%s%s%s\n", (lp->modembits & TMXR_MDM_DTR) ? "DTR " : "", lp 3574 src/simh/sim_tmxr.c (lp->modembits & TMXR_MDM_RTS) ? "RTS " : "", lp 3575 src/simh/sim_tmxr.c (lp->modembits & TMXR_MDM_DCD) ? "DCD " : "", lp 3576 src/simh/sim_tmxr.c (lp->modembits & TMXR_MDM_RNG) ? "RNG " : "", lp 3577 src/simh/sim_tmxr.c (lp->modembits & TMXR_MDM_CTS) ? "CTS " : "", lp 3578 src/simh/sim_tmxr.c (lp->modembits & TMXR_MDM_DSR) ? "DSR " : ""); lp 3582 src/simh/sim_tmxr.c (lp->sock) && (!lp->datagram)) lp 3583 src/simh/sim_tmxr.c fprintf (st, " %s\n", (lp->notelnet) ? "Telnet disabled (RAW data)" : "Telnet protocol"); lp 3584 src/simh/sim_tmxr.c if (lp->send.buffer) lp 3585 src/simh/sim_tmxr.c sim_show_send_input (st, &lp->send); lp 3586 src/simh/sim_tmxr.c if (lp->expect.buf) lp 3587 src/simh/sim_tmxr.c sim_exp_showall (st, &lp->expect); lp 3588 src/simh/sim_tmxr.c if (lp->txlog) lp 3589 src/simh/sim_tmxr.c fprintf (st, " Logging to %s\n", lp->txlogname); lp 3595 src/simh/sim_tmxr.c void tmxr_fstats (FILE *st, const TMLN *lp, int32 ln) lp 3602 src/simh/sim_tmxr.c if ((!lp->sock) && (!lp->connecting) lp 3608 src/simh/sim_tmxr.c fprintf (st, " input (%s)", (lp->rcve? enab: dsab)); lp 3609 src/simh/sim_tmxr.c if (lp->rxcnt) lp 3610 src/simh/sim_tmxr.c fprintf (st, " queued/total = %d/%d", tmxr_rqln (lp), lp->rxcnt); lp 3611 src/simh/sim_tmxr.c if (lp->rxpcnt) lp 3612 src/simh/sim_tmxr.c fprintf (st, " packets = %d", lp->rxpcnt); lp 3613 src/simh/sim_tmxr.c fprintf (st, "\n output (%s)", (lp->xmte? enab: dsab)); lp 3614 src/simh/sim_tmxr.c if (lp->txcnt || lp->txbpi) lp 3615 src/simh/sim_tmxr.c fprintf (st, " queued/total = %d/%d", tmxr_tqln (lp), lp->txcnt); lp 3616 src/simh/sim_tmxr.c if (lp->txpcnt || tmxr_tpqln (lp)) lp 3618 src/simh/sim_tmxr.c tmxr_tpqln (lp), lp->txpcnt); lp 3621 src/simh/sim_tmxr.c if (lp->txbfd) lp 3622 src/simh/sim_tmxr.c fprintf (st, " output buffer size = %d\n", lp->txbsz); lp 3623 src/simh/sim_tmxr.c if (lp->txcnt || lp->txbpi) lp 3625 src/simh/sim_tmxr.c ((lp->txcnt > 0) && (lp->txcnt > lp->txbsz)) ? lp->txbsz : lp->txbpi); lp 3626 src/simh/sim_tmxr.c if (lp->txdrp) lp 3627 src/simh/sim_tmxr.c fprintf (st, " dropped = %d\n", lp->txdrp); lp 3660 src/simh/sim_tmxr.c TMLN *lp; lp 3666 src/simh/sim_tmxr.c lp = tmxr_get_ldsc (uptr, cptr, mp, &status); /* get referenced line */ lp 3668 src/simh/sim_tmxr.c if (lp == NULL) /* bad line number? */ lp 3671 src/simh/sim_tmxr.c if ((lp->sock) lp 3673 src/simh/sim_tmxr.c if (!lp->notelnet) lp 3674 src/simh/sim_tmxr.c tmxr_linemsg (lp, "\r\nOperator disconnected line\r\n\n");/* report closure */ lp 3675 src/simh/sim_tmxr.c tmxr_reset_ln_ex (lp, (sim_switches & SWMASK ('C'))); /* drop the line */ lp 3686 src/simh/sim_tmxr.c TMLN *lp; lp 3691 src/simh/sim_tmxr.c lp = tmxr_find_ldsc (uptr, val, mp); /* find line desc */ lp 3692 src/simh/sim_tmxr.c if (lp == NULL) lp 3694 src/simh/sim_tmxr.c if (lp->txlog) /* close existing log */ lp 3696 src/simh/sim_tmxr.c lp->txlogname = (char *) calloc (CBUFSIZE, sizeof (char)); /* alloc namebuf */ lp 3697 src/simh/sim_tmxr.c if (lp->txlogname == NULL) /* can't? */ lp 3699 src/simh/sim_tmxr.c strncpy (lp->txlogname, cptr, CBUFSIZE-1); /* save file name */ lp 3700 src/simh/sim_tmxr.c r = sim_open_logfile (cptr, TRUE, &lp->txlog, &lp->txlogref); /* open log */ lp 3702 src/simh/sim_tmxr.c FREE (lp->txlogname); /* free buffer */ lp 3705 src/simh/sim_tmxr.c if (lp->txlog == NULL) { /* error? */ lp 3706 src/simh/sim_tmxr.c FREE (lp->txlogname); /* free buffer */ lp 3710 src/simh/sim_tmxr.c lp->mp->uptr->filename = tmxr_mux_attach_string (lp->mp->uptr->filename, lp->mp); lp 3719 src/simh/sim_tmxr.c TMLN *lp; lp 3723 src/simh/sim_tmxr.c lp = tmxr_find_ldsc (uptr, val, mp); /* find line desc */ lp 3724 src/simh/sim_tmxr.c if (lp == NULL) lp 3726 src/simh/sim_tmxr.c if (lp->txlog) { /* logging? */ lp 3727 src/simh/sim_tmxr.c sim_close_logfile (&lp->txlogref); /* close log */ lp 3728 src/simh/sim_tmxr.c FREE (lp->txlogname); /* free namebuf */ lp 3729 src/simh/sim_tmxr.c lp->txlog = NULL; lp 3730 src/simh/sim_tmxr.c lp->txlogname = NULL; lp 3733 src/simh/sim_tmxr.c lp->mp->uptr->filename = tmxr_mux_attach_string (lp->mp->uptr->filename, lp->mp); lp 3742 src/simh/sim_tmxr.c TMLN *lp; lp 3744 src/simh/sim_tmxr.c lp = tmxr_find_ldsc (uptr, val, mp); /* find line desc */ lp 3745 src/simh/sim_tmxr.c if (lp == NULL) lp 3747 src/simh/sim_tmxr.c if (lp->txlog) lp 3748 src/simh/sim_tmxr.c fprintf (st, "logging to %s", lp->txlogname); lp 218 src/simh/sim_tmxr.h t_stat tmxr_reset_ln (TMLN *lp); lp 219 src/simh/sim_tmxr.h t_stat tmxr_detach_ln (TMLN *lp); lp 220 src/simh/sim_tmxr.h int32 tmxr_input_pending_ln (TMLN *lp); lp 221 src/simh/sim_tmxr.h int32 tmxr_getc_ln (TMLN *lp); lp 222 src/simh/sim_tmxr.h t_stat tmxr_get_packet_ln (TMLN *lp, const uint8 **pbuf, size_t *psize); lp 223 src/simh/sim_tmxr.h t_stat tmxr_get_packet_ln_ex (TMLN *lp, const uint8 **pbuf, size_t *psize, uint8 frame_byte); lp 225 src/simh/sim_tmxr.h t_stat tmxr_putc_ln (TMLN *lp, int32 chr); lp 226 src/simh/sim_tmxr.h t_stat tmxr_put_packet_ln (TMLN *lp, const uint8 *buf, size_t size); lp 227 src/simh/sim_tmxr.h t_stat tmxr_put_packet_ln_ex (TMLN *lp, const uint8 *buf, size_t size, uint8 frame_byte); lp 229 src/simh/sim_tmxr.h int32 tmxr_send_buffered_data (TMLN *lp); lp 235 src/simh/sim_tmxr.h char *tmxr_line_attach_string(TMLN *lp); lp 236 src/simh/sim_tmxr.h t_stat tmxr_set_get_modem_bits (TMLN *lp, int32 bits_to_set, int32 bits_to_clear, int32 *incoming_bits); lp 237 src/simh/sim_tmxr.h t_stat tmxr_set_line_loopback (TMLN *lp, t_bool enable_loopback); lp 238 src/simh/sim_tmxr.h t_bool tmxr_get_line_loopback (TMLN *lp); lp 239 src/simh/sim_tmxr.h t_stat tmxr_set_line_halfduplex (TMLN *lp, t_bool enable_loopback); lp 240 src/simh/sim_tmxr.h t_bool tmxr_get_line_halfduplex (TMLN *lp); lp 241 src/simh/sim_tmxr.h t_stat tmxr_set_line_speed (TMLN *lp, CONST char *speed); lp 247 src/simh/sim_tmxr.h void tmxr_linemsg (TMLN *lp, const char *msg); lp 248 src/simh/sim_tmxr.h void tmxr_linemsgf (TMLN *lp, const char *fmt, ...); lp 249 src/simh/sim_tmxr.h void tmxr_linemsgvf (TMLN *lp, const char *fmt, va_list args); lp 250 src/simh/sim_tmxr.h void tmxr_fconns (FILE *st, const TMLN *lp, int32 ln); lp 251 src/simh/sim_tmxr.h void tmxr_fstats (FILE *st, const TMLN *lp, int32 ln); lp 256 src/simh/sim_tmxr.h int32 tmxr_rqln (const TMLN *lp); lp 257 src/simh/sim_tmxr.h int32 tmxr_tqln (const TMLN *lp); lp 258 src/simh/sim_tmxr.h int32 tmxr_tpqln (const TMLN *lp); lp 259 src/simh/sim_tmxr.h t_bool tmxr_tpbusyln (const TMLN *lp); lp 275 src/simh/sim_tmxr.h void _tmxr_debug (uint32 dbits, TMLN *lp, const char *msg, char *buf, int bufsize); lp 277 src/simh/sim_tmxr.h # define tmxr_debug(dbits, lp, msg, buf, bufsize) \ lp 278 src/simh/sim_tmxr.h do { if (sim_deb && (lp)->mp && (lp)->mp->dptr && ((dbits) & (lp)->mp->dptr->dctrl)) \ lp 279 src/simh/sim_tmxr.h _tmxr_debug (dbits, lp, msg, buf, bufsize); } while (0) lp 281 src/simh/sim_tmxr.h # define tmxr_debug_msg(dbits, lp, msg) \ lp 282 src/simh/sim_tmxr.h do { if (sim_deb && (lp)->mp && (lp)->mp->dptr && ((dbits) & (lp)->mp->dptr->dctrl)) \ lp 283 src/simh/sim_tmxr.h sim_debug (dbits, (lp)->mp->dptr, "%s", msg); } while (0) lp 285 src/simh/sim_tmxr.h # define tmxr_debug_return(lp, val) \ lp 286 src/simh/sim_tmxr.h do { if (sim_deb && (val) && (lp)->mp && (lp)->mp->dptr && (TMXR_DBG_RET & (lp)->mp->dptr->dctrl)) \ lp 287 src/simh/sim_tmxr.h { if ((lp)->rxbps) sim_debug (TMXR_DBG_RET, (lp)->mp->dptr, "Ln%d: 0x%x - Next after: %.0f\n", \ lp 288 src/simh/sim_tmxr.h (int)((lp)-(lp)->mp->ldsc), val, (lp)->rxnexttime); \ lp 289 src/simh/sim_tmxr.h else sim_debug (TMXR_DBG_RET, (lp)->mp->dptr, "Ln%d: 0x%x\n", (int)((lp)-(lp)->mp->ldsc), val); \ lp 296 src/simh/sim_tmxr.h # define tmxr_debug_trace_line(lp, msg) \ lp 297 src/simh/sim_tmxr.h do { if (sim_deb && (lp)->mp && (lp)->mp->dptr && (TMXR_DBG_TRC & (lp)->mp->dptr->dctrl)) \ lp 298 src/simh/sim_tmxr.h sim_debug (TMXR_DBG_TRC, (lp)->mp->dptr, "Ln%d:%s\n", (int)((lp)-(lp)->mp->ldsc), (msg)); } while (0) lp 304 src/simh/sim_tmxr.h # define tmxr_debug_connect_line(lp, msg) \ lp 305 src/simh/sim_tmxr.h do { if (sim_deb && (lp)->mp && (lp)->mp->dptr && (TMXR_DBG_CON & (lp)->mp->dptr->dctrl)) \ lp 306 src/simh/sim_tmxr.h sim_debug (TMXR_DBG_CON, (lp)->mp->dptr, "Ln%d:%s\n", (int)((lp)-(lp)->mp->ldsc), (msg)); } while (0)