summaryrefslogtreecommitdiffstats
path: root/src/net
diff options
context:
space:
mode:
authorMichael Brown2006-06-19 17:46:58 +0200
committerMichael Brown2006-06-19 17:46:58 +0200
commit3a660f9b2580432477e0804e7d94fc01854c481a (patch)
treeb62400baa9ef7a771196534f2a7cdb6c31305ce3 /src/net
parentPlaceholder (diff)
downloadipxe-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.c16
-rw-r--r--src/net/tcp/hello.c17
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;
}