diff options
| author | Michael Brown | 2006-06-19 17:46:58 +0200 |
|---|---|---|
| committer | Michael Brown | 2006-06-19 17:46:58 +0200 |
| commit | 3a660f9b2580432477e0804e7d94fc01854c481a (patch) | |
| tree | b62400baa9ef7a771196534f2a7cdb6c31305ce3 /src/net | |
| parent | Placeholder (diff) | |
| download | ipxe-3a660f9b2580432477e0804e7d94fc01854c481a.tar.gz ipxe-3a660f9b2580432477e0804e7d94fc01854c481a.tar.xz ipxe-3a660f9b2580432477e0804e7d94fc01854c481a.zip | |
Update ftp.c and hello.c to use the generic async_operations API.
Diffstat (limited to 'src/net')
| -rw-r--r-- | src/net/tcp/ftp.c | 16 | ||||
| -rw-r--r-- | src/net/tcp/hello.c | 17 |
2 files changed, 18 insertions, 15 deletions
diff --git a/src/net/tcp/ftp.c b/src/net/tcp/ftp.c index b0f9fef92..71a53ccf5 100644 --- a/src/net/tcp/ftp.c +++ b/src/net/tcp/ftp.c @@ -4,6 +4,7 @@ #include <vsprintf.h> #include <assert.h> #include <errno.h> +#include <gpxe/async.h> #include <gpxe/ftp.h> /** @file @@ -70,13 +71,13 @@ static inline struct ftp_request * tcp_to_ftp ( struct tcp_connection *conn ) { * Mark FTP request as complete * * @v ftp FTP request - * @v complete Completion indicator + * @v rc Return status code * */ -static void ftp_complete ( struct ftp_request *ftp, int complete ) { - ftp->complete = complete; +static void ftp_done ( struct ftp_request *ftp, int rc ) { tcp_close ( &ftp->tcp_data ); tcp_close ( &ftp->tcp ); + async_done ( &ftp->aop, rc ); } /** @@ -145,7 +146,7 @@ static void ftp_reply ( struct ftp_request *ftp ) { err: /* Flag protocol error and close connections */ - ftp_complete ( ftp, -EPROTO ); + ftp_done ( ftp, -EPROTO ); } /** @@ -248,7 +249,7 @@ static void ftp_senddata ( struct tcp_connection *conn, static void ftp_closed ( struct tcp_connection *conn, int status ) { struct ftp_request *ftp = tcp_to_ftp ( conn ); - ftp_complete ( ftp, status ? status : 1 ); + ftp_done ( ftp, status ); } /** FTP control channel operations */ @@ -291,7 +292,7 @@ static void ftp_data_closed ( struct tcp_connection *conn, int status ) { struct ftp_request *ftp = tcp_to_ftp_data ( conn ); if ( status ) - ftp_complete ( ftp, status ); + ftp_done ( ftp, status ); } /** @@ -327,10 +328,11 @@ static struct tcp_operations ftp_data_tcp_operations = { * * @v ftp FTP request */ -void ftp_connect ( struct ftp_request *ftp ) { +struct async_operation * ftp_get ( struct ftp_request *ftp ) { ftp->tcp.tcp_op = &ftp_tcp_operations; ftp->tcp_data.tcp_op = &ftp_data_tcp_operations; ftp->recvbuf = ftp->status_text; ftp->recvsize = sizeof ( ftp->status_text ) - 1; tcp_connect ( &ftp->tcp ); + return &ftp->aop; } diff --git a/src/net/tcp/hello.c b/src/net/tcp/hello.c index baaf8c76e..d74e52f9f 100644 --- a/src/net/tcp/hello.c +++ b/src/net/tcp/hello.c @@ -2,6 +2,7 @@ #include <string.h> #include <vsprintf.h> #include <assert.h> +#include <gpxe/async.h> #include <gpxe/hello.h> /** @file @@ -13,7 +14,8 @@ * message (hello_request::message). Any data received from the * server will be passed to the callback function, * hello_request::callback(), and once the connection has been closed, - * hello_request::complete will be set to a non-zero value. + * the asynchronous operation associated with the request will be + * marked as complete. * * To use this code, do something like: * @@ -31,10 +33,7 @@ * hello.sin.sin_addr.s_addr = ... server IP address ... * hello.sin.sin_port = ... server port ... * - * hello_connect ( &hello ); - * while ( ! hello.completed ) { - * run_tcpip(); - * } + * rc = async_wait ( say_hello ( &hello ) ); * * @endcode * @@ -52,7 +51,7 @@ tcp_to_hello ( struct tcp_connection *conn ) { static void hello_closed ( struct tcp_connection *conn, int status ) { struct hello_request *hello = tcp_to_hello ( conn ); - hello->complete = ( status ? status : 1 ); + async_done ( &hello->aop, status ); } static void hello_connected ( struct tcp_connection *conn ) { @@ -92,7 +91,8 @@ static void hello_newdata ( struct tcp_connection *conn, void *data, hello->callback ( data, len ); } -static void hello_senddata ( struct tcp_connection *conn ) { +static void hello_senddata ( struct tcp_connection *conn, + void *buf __unused, size_t len __unused ) { struct hello_request *hello = tcp_to_hello ( conn ); tcp_send ( conn, hello->message, hello->remaining ); @@ -111,7 +111,8 @@ static struct tcp_operations hello_tcp_operations = { * * @v hello "Hello world" request */ -void hello_connect ( struct hello_request *hello ) { +struct async_operation * say_hello ( struct hello_request *hello ) { hello->tcp.tcp_op = &hello_tcp_operations; tcp_connect ( &hello->tcp ); + return &hello->aop; } |
