r4757: added the ability of the clisocket level of libcli to handle async
authorAndrew Tridgell <tridge@samba.org>
Sat, 15 Jan 2005 10:38:12 +0000 (10:38 +0000)
committerGerald (Jerry) Carter <jerry@samba.org>
Wed, 10 Oct 2007 18:08:50 +0000 (13:08 -0500)
commit468f8ebbfdbdf37c757fdc4863626aa9946a8870
treee12934036a721cd2a542307a68939b7dad9ec93a
parentd2f76c3671df0b0232982e2fbfd5c049c9fb674f
r4757: added the ability of the clisocket level of libcli to handle async
socket connections. This was complicated by a few factors:

 - it meant moving the event context from clitransport to clisocket,
   so lots of structures changed

 - we need to asynchronously handle connection to lists of port
   numbers, not just one port number. The code internally tries each
   port in the list in turn, without ever blocking

 - the man page on how connect() is supposed to work asynchronously
   doesn't work in practice (now why doesn't this surprise me?). The
   getsockopt() for SOL_ERROR is supposed to retrieve the error, but
   in fact the next (unrelated) connect() call on the same socket also
   gets an error, though not the right error. To work around this I
   need to tear down the whole socket between each attempted port. I
   hate posix.

Note that clisocket.c still does a blocking name resolution call in
smbcli_sock_connect_byname(). That will be fixed when we add the async
NBT resolution code.

Also note that I arranged things so that every SMB connection is now
async internally, so using plain smbclient or smbtorture tests all the
async features of this new code.
source/libcli/raw/clisocket.c
source/libcli/raw/clitransport.c
source/libcli/raw/libcliraw.h
source/libcli/raw/rawrequest.c
source/libcli/util/errormap.c
source/librpc/rpc/dcerpc_smb.c
source/ntvfs/cifs/vfs_cifs.c
source/torture/torture.c