tu58fs - PDP-11 file sharing with TU58 tape emulator
Jörg Hoppe
j_hoppe at t-online.de
Tue Jan 24 01:33:09 CST 2017
Hmmm, anyone out there who understands FreeBSD termios(4) .
Can't believe that FreeBSD has no baudrate > 38400 !
Joerg
> On Fri, Jan 20, 2017 at 8:51 PM, Jörg Hoppe <j_hoppe at t-online.de> wrote:
>> If you like to have a look (and play beta tester):
>>
>> Docs on http://retrocmp.com/tools/tu58fs
>> C sources and makefile on https://github.com/j-hoppe/tu58fs
> FWIW, It doesn't compile on FreeBSD (yes, I do not know if it is supposed to)
> tingo at kg-core1$ gmake
> cc -I. -c -UWINCOMM -ggdb3 -O0 -m64 main.c -o freebsd-amd64/main.o
> cc -I. -c -UWINCOMM -ggdb3 -O0 -m64 getopt2.c -o freebsd-amd64/getopt2.o
> getopt2.c:228:20: warning: using the result of an assignment as a
> condition without parentheses [-Wparentheses]
> for (i = 0; odesc = _this->option_descrs[i]; i++)
> ~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~
> getopt2.c:228:20: note: place parentheses around the assignment to
> silence this warning
> for (i = 0; odesc = _this->option_descrs[i]; i++)
> ^
> ( )
> getopt2.c:228:20: note: use '==' to turn this assignment into an
> equality comparison
> for (i = 0; odesc = _this->option_descrs[i]; i++)
> ^
> ==
> getopt2.c:364:21: warning: using the result of an assignment as a
> condition without parentheses [-Wparentheses]
> for (i = 0; odesc = _this->option_descrs[i]; i++)
> ~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~
> getopt2.c:364:21: note: place parentheses around the assignment to
> silence this warning
> for (i = 0; odesc = _this->option_descrs[i]; i++)
> ^
> ( )
> getopt2.c:364:21: note: use '==' to turn this assignment into an
> equality comparison
> for (i = 0; odesc = _this->option_descrs[i]; i++)
> ^
> ==
> getopt2.c:439:20: warning: using the result of an assignment as a
> condition without parentheses [-Wparentheses]
> for (i = 0; odesc = _this->option_descrs[i]; i++)
> ~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~
> getopt2.c:439:20: note: place parentheses around the assignment to
> silence this warning
> for (i = 0; odesc = _this->option_descrs[i]; i++)
> ^
> ( )
> getopt2.c:439:20: note: use '==' to turn this assignment into an
> equality comparison
> for (i = 0; odesc = _this->option_descrs[i]; i++)
> ^
> ==
> getopt2.c:646:16: warning: using the result of an assignment as a
> condition without parentheses [-Wparentheses]
> for (i = 0; s = odesc->fix_args[i]; i++) {
> ~~^~~~~~~~~~~~~~~~~~~~
> getopt2.c:646:16: note: place parentheses around the assignment to
> silence this warning
> for (i = 0; s = odesc->fix_args[i]; i++) {
> ^
> ( )
> getopt2.c:646:16: note: use '==' to turn this assignment into an
> equality comparison
> for (i = 0; s = odesc->fix_args[i]; i++) {
> ^
> ==
> getopt2.c:651:16: warning: using the result of an assignment as a
> condition without parentheses [-Wparentheses]
> for (i = 0; s = odesc->var_args[i]; i++) {
> ~~^~~~~~~~~~~~~~~~~~~~
> getopt2.c:651:16: note: place parentheses around the assignment to
> silence this warning
> for (i = 0; s = odesc->var_args[i]; i++) {
> ^
> ( )
> getopt2.c:651:16: note: use '==' to turn this assignment into an
> equality comparison
> for (i = 0; s = odesc->var_args[i]; i++) {
> ^
> ==
> getopt2.c:751:20: warning: using the result of an assignment as a
> condition without parentheses [-Wparentheses]
> for (i = 0; odesc = _this->option_descrs[i]; i++) {
> ~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~
> getopt2.c:751:20: note: place parentheses around the assignment to
> silence this warning
> for (i = 0; odesc = _this->option_descrs[i]; i++) {
> ^
> ( )
> getopt2.c:751:20: note: use '==' to turn this assignment into an
> equality comparison
> for (i = 0; odesc = _this->option_descrs[i]; i++) {
> ^
> ==
> getopt2.c:754:26: warning: the value of the size argument in 'strncat'
> is too large, might lead to a buffer overflow [-Wstrncat-size]
> strncat(linebuff, " ", sizeof(linebuff));
> ^~~~~~~~~~~~~~~~
> getopt2.c:754:26: note: change the argument to be the free space in
> the destination buffer minus the terminating null byte
> strncat(linebuff, " ", sizeof(linebuff));
> ^~~~~~~~~~~~~~~~
> sizeof(linebuff) - strlen(linebuff) - 1
> getopt2.c:760:26: warning: the value of the size argument in 'strncat'
> is too large, might lead to a buffer overflow [-Wstrncat-size]
> strncat(linebuff, " ", sizeof(linebuff));
> ^~~~~~~~~~~~~~~~
> getopt2.c:760:26: note: change the argument to be the free space in
> the destination buffer minus the terminating null byte
> strncat(linebuff, " ", sizeof(linebuff));
> ^~~~~~~~~~~~~~~~
> sizeof(linebuff) - strlen(linebuff) - 1
> getopt2.c:774:20: warning: using the result of an assignment as a
> condition without parentheses [-Wparentheses]
> for (i = 0; odesc = _this->option_descrs[i]; i++)
> ~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~
> getopt2.c:774:20: note: place parentheses around the assignment to
> silence this warning
> for (i = 0; odesc = _this->option_descrs[i]; i++)
> ^
> ( )
> getopt2.c:774:20: note: use '==' to turn this assignment into an
> equality comparison
> for (i = 0; odesc = _this->option_descrs[i]; i++)
> ^
> ==
> 9 warnings generated.
> cc -I. -c -UWINCOMM -ggdb3 -O0 -m64 tu58drive.c -o freebsd-amd64/tu58drive.o
> cc -I. -c -UWINCOMM -ggdb3 -O0 -m64 image.c -o freebsd-amd64/image.o
> image.c:99:9: warning: expression result unused [-Wunused-value]
> _this->blocksize;
> ~~~~~ ^~~~~~~~~
> image.c:240:1: warning: control may reach end of non-void function
> [-Wreturn-type]
> }
> ^
> image.c:294:11: warning: using the result of an assignment as a
> condition without parentheses [-Wparentheses]
> if (res = hostdir_load(_this->hostdir,
> _this->autosizing, allowcreate, &filecreated)) {
>
> ~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
> image.c:294:11: note: place parentheses around the assignment to
> silence this warning
> if (res = hostdir_load(_this->hostdir,
> _this->autosizing, allowcreate, &filecreated)) {
> ^
> (
> )
> image.c:294:11: note: use '==' to turn this assignment into an
> equality comparison
> if (res = hostdir_load(_this->hostdir,
> _this->autosizing, allowcreate, &filecreated)) {
> ^
> ==
> image.c:301:11: warning: using the result of an assignment as a
> condition without parentheses [-Wparentheses]
> if (res = image_hostfile_open(_this, allowcreate,
> &filecreated)) {
> ~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
> image.c:301:11: note: place parentheses around the assignment to
> silence this warning
> if (res = image_hostfile_open(_this, allowcreate,
> &filecreated)) {
> ^
> ( )
> image.c:301:11: note: use '==' to turn this assignment into an
> equality comparison
> if (res = image_hostfile_open(_this, allowcreate,
> &filecreated)) {
> ^
> ==
> image.c:469:11: warning: using the result of an assignment as a
> condition without parentheses [-Wparentheses]
> if (res = hostdir_save(_this->hostdir)) {
> ~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
> image.c:469:11: note: place parentheses around the assignment to
> silence this warning
> if (res = hostdir_save(_this->hostdir)) {
> ^
> ( )
> image.c:469:11: note: use '==' to turn this assignment into an
> equality comparison
> if (res = hostdir_save(_this->hostdir)) {
> ^
> ==
> image.c:474:11: warning: using the result of an assignment as a
> condition without parentheses [-Wparentheses]
> if (res = image_hostfile_save(_this)) {
> ~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~
> image.c:474:11: note: place parentheses around the assignment to
> silence this warning
> if (res = image_hostfile_save(_this)) {
> ^
> ( )
> image.c:474:11: note: use '==' to turn this assignment into an
> equality comparison
> if (res = image_hostfile_save(_this)) {
> ^
> ==
> image.c:502:1: warning: control may reach end of non-void function
> [-Wreturn-type]
> }
> ^
> 7 warnings generated.
> cc -I. -c -UWINCOMM -ggdb3 -O0 -m64 serial.c -o freebsd-amd64/serial.o
> serial.c:443:44: error: use of undeclared identifier 'B3000000'
> static int32_t baudlist[] = { 3000000, B3000000,
> ^
> serial.c:444:16: error: use of undeclared identifier 'B2500000'
> 2500000, B2500000,
> ^
> serial.c:445:16: error: use of undeclared identifier 'B2000000'
> 2000000, B2000000,
> ^
> serial.c:446:16: error: use of undeclared identifier 'B1500000'
> 1500000, B1500000,
> ^
> serial.c:447:16: error: use of undeclared identifier 'B1152000'
> 1152000, B1152000,
> ^
> serial.c:448:16: error: use of undeclared identifier 'B1000000'
> 1000000, B1000000,
> ^
> serial.c:450:16: error: use of undeclared identifier 'B576000'
> 576000, B576000,
> ^
> serial.c:451:16: error: use of undeclared identifier 'B500000'
> 500000, B500000,
> ^
> serial.c:571:10: error: use of undeclared identifier 'IUCLC'
> IUCLC | IXANY | PARMRK | IGNPAR );
> ^
> serial.c:575:33: error: use of undeclared identifier 'OLCUC'
> line.c_oflag &= ~( OPOST | OLCUC | OCRNL | ONLCR | ONOCR |
> ^
> serial.c:576:19: error: use of undeclared identifier 'OFILL'
> ONLRET | OFILL | CRDLY | NLDLY | BSDLY |
> ^
> serial.c:576:27: error: use of undeclared identifier 'CRDLY'
> ONLRET | OFILL | CRDLY | NLDLY | BSDLY |
> ^
> serial.c:576:35: error: use of undeclared identifier 'NLDLY'
> ONLRET | OFILL | CRDLY | NLDLY | BSDLY |
> ^
> serial.c:576:43: error: use of undeclared identifier 'BSDLY'
> ONLRET | OFILL | CRDLY | NLDLY | BSDLY |
> ^
> serial.c:577:19: error: use of undeclared identifier 'VTDLY'
> TABDLY | VTDLY | FFDLY | OFDEL );
> ^
> serial.c:577:27: error: use of undeclared identifier 'FFDLY'
> TABDLY | VTDLY | FFDLY | OFDEL );
> ^
> serial.c:577:35: error: use of undeclared identifier 'OFDEL'
> TABDLY | VTDLY | FFDLY | OFDEL );
> ^
> serial.c:581:24: error: use of undeclared identifier 'CBAUD'
> line.c_cflag &= ~( CBAUD | CSIZE | CSTOPB | PARENB | PARODD |
> ^
> 18 errors generated.
> gmake: *** [makefile:63: freebsd-amd64/serial.o] Error 1
> The only change I made was OBJDIR= in the makefile.
>
> This on
> tingo at kg-core1$ uname -a
> FreeBSD kg-core1.kg4.no 10.3-STABLE FreeBSD 10.3-STABLE #0 r310083:
> Wed Dec 14 21:00:13 CET 2016
> root at kg-core1.kg4.no:/usr/obj/usr/src/sys/GENERIC amd64
>
> HTH
More information about the cctech
mailing list