GNO + Marinetti = MariGNOtti
Go to file
2012-05-13 19:47:28 -04:00
driver.c accept/listen support. 2012-05-13 19:46:49 -04:00
maccept.c accept/listen support. 2012-05-13 19:46:49 -04:00
main.c stack size. 2012-05-11 22:46:42 -04:00 accept/listen support. 2012-05-13 19:46:49 -04:00
marignotti.h accept/listen support. 2012-05-13 19:46:49 -04:00
mattach.c UDP support (socket, read, write) 2012-05-12 19:44:10 -04:00
mconnect.c udp connect -- just set the destination port & address. 2012-05-12 19:48:06 -04:00
mdetach.c remove any pending selects when closing the socket. 2012-05-12 01:28:46 -04:00
mgetsockname.c debugging for getsockname 2012-05-13 19:45:14 -04:00
mgetsockopt.c SO_TYPE 2012-05-12 01:25:36 -04:00
mioctl.c ioctl(2) 2012-05-06 17:41:45 -04:00
mlisten.c accept/listen support. 2012-05-13 19:46:49 -04:00
mread.c read/write oob. 2012-05-13 19:46:25 -04:00
mselect.c add comments. 2012-05-13 19:47:02 -04:00
msetsockopt.c remove duplicate label 2012-05-07 22:43:51 -04:00
mshutdown.c shutdown(2) 2012-05-06 17:41:38 -04:00
mwrite.c check shut_rd/shut_wr for read/write. 2012-05-13 19:45:51 -04:00
net.h initial version (it even works) 2012-04-12 00:51:12 -04:00
README.text update the read me text 2012-05-12 20:29:32 -04:00
resolve.conf /etc/ files missing from gnome. 2012-05-13 19:47:28 -04:00
s16debug.c debug updates 2012-05-12 19:42:54 -04:00
s16debug.h debug updates 2012-05-12 19:42:54 -04:00
services /etc/ files missing from gnome. 2012-05-13 19:47:28 -04:00
table.c accept/listen support. 2012-05-13 19:46:49 -04:00


MariGNOtti is a network driver for GNO/ME 2.0.6.  It provides a translation layer between BSD sockets and Marinetti. Think of it as a replacement for GSTCP.


1. copy the marignotti, ftp, sic, and whois executables to your /usr/local/bin directory.

ftp is an update of the gno 2.0.6 ftp (it adds passive ftp support).

whois is an updated version (from FreeBSD 9.0).  The gno 2.0.6 version is from FreeBSD 2.1.

sic is a very simple irc client. 
sic -h -p 6667 -n myname
(a bunch of messages)
:j << join a room

2. copy the services file to /etc/services (if it does not exist).
3. edit and copy the resolve.conf file to /etc/resolve.conf (if it does not exist). This file is your DNS server

4. If you don't have a DNS server, edit /etc/hosts to include your favorite sites.


Run marignotti in the background (marignotti &).  To quit, bring it to the foreground (fg) and hit control-C.

If you're using the Sweet-16 emulator and started Sweet 16 from the terminal (/Applications/, marignotti -d will print some debugging information to the console.  marignotti -dd will enable extra debugging information (including the contents of reads and writes).

What it does:

While marignotti is running in the background, it translates BSD socket calls into Marinetti tool calls.  It also handles blocking IO, socket options, select, etc.  


BSD sockets are, by default, blocking whereas everything Marinetti does (other than the inital network connection) is non-blocking.  To handle blocking behavior, each socket has a semaphore.  The main thread performs all the polling and uses the semaphore to signal the other threads when they can proceed.


socket -- only support for PF_UNIX, SOCK_STREAM, and SOCK_DGRAM.

connect -- but non-blocking connects are not yet supported.

bind -- currently a no-op since the old whois(1) used it.

read/recv/recvfrom -- supports blocking, non-blocking, timeouts, and RCVLOWAT.  The address parameter of recvfrom is not supported.  OOB is not supported.

write/send/sendto -- does not support SNDLOWAT, OOB, or the address parameter of sendto.

close -- does not support SOLINGER type functionality.

shutdown -- sets flags but the flags are not completely implemented.

ioctl(2) -- support for FIONREAD (bytes available to read) and FIONBIO (set/clear non-blocking).

getsockopt(2) -- support for SO_OOBINLINE, SO_SNDLOWAT, SO_RCVLOWAT, SO_SNDTIMEO, SO_RCVTIMEO. SNDLOWAT and SNDTIMEO set flags but don't have any other effect.  OOBINLINE will only be supported when true.


Not (yet) supported:

- OOB (out of band) data (and will never be supported).
- raw sockets (SOCK_RAW)
- TCP servers (listen/accept).  Should be simple, though.
- UDP servers