From d38b0dbf5bb85063ff38418a35d1ae0928f2908e Mon Sep 17 00:00:00 2001 From: Marko Mikulicic Date: Thu, 17 Mar 2016 13:06:04 +0100 Subject: [PATCH] Add command to extract build info from metadata This will allow to recreate the metadata after patching the FS. PUBLISHED_FROM=dae228bbf49d71f383e4dc52316cf98aba3914f5 --- docs/design-concept/events.md | 4 +++ docs/design-concept/intro.md | 24 ++++++++++++++ docs/design-concept/items.json | 6 ++++ docs/design-concept/memory-buffers.md | 20 ++++++++++++ docs/img/mbuf.png | Bin 0 -> 73349 bytes docs/items.json | 6 ++++ docs/usage-example/intro.md | 44 ++++++++++++++++++++++++++ docs/usage-example/items.json | 5 +++ 8 files changed, 109 insertions(+) create mode 100644 docs/design-concept/events.md create mode 100644 docs/design-concept/intro.md create mode 100644 docs/design-concept/items.json create mode 100644 docs/design-concept/memory-buffers.md create mode 100644 docs/img/mbuf.png create mode 100644 docs/items.json create mode 100644 docs/usage-example/intro.md create mode 100644 docs/usage-example/items.json diff --git a/docs/design-concept/events.md b/docs/design-concept/events.md new file mode 100644 index 00000000..da02fac8 --- /dev/null +++ b/docs/design-concept/events.md @@ -0,0 +1,4 @@ +--- +title: Events +--- + diff --git a/docs/design-concept/intro.md b/docs/design-concept/intro.md new file mode 100644 index 00000000..3c5a41b7 --- /dev/null +++ b/docs/design-concept/intro.md @@ -0,0 +1,24 @@ +--- +title: Design Concept +--- + +Mongoose is a multi-protocol networking library that implements non-blocking, +asyncronous IO and provides event-based API. It has three basic data structures: + +- [`struct mg_mgr`](#TODO) is an event manager that holds all active + connections +- [`struct mg_connection`](#TODO) describes a connection +- [`struct mbuf`](#TODO) describes data buffer (received or sent data) + +Connections could be either *listening*, *outbound* or *inbound*. Outbound +connections are created by [`mg_connect()`](#TODO) call. Listening connections +are created by [`mg_bind()`](#TODO) call. Inbound connections are those +accepted by a listening connection. Each connection is described by [`struct +mg_connection`](#TODO) structure, which has a number of fields like socket, +event handler function, send/receive buffer, flags, et cetera. + +Mongoose usage pattern is to declare and initialize event manager, create +connections and create an event loop by calling [`mg_mgr_poll()`](#TODO) in a +loop. [`mg_mgr_poll()`](#TODO) iterates over all sockets, accepts new +connections, sends and receives data, closes connections, and calls event +handler functions for the respective events. diff --git a/docs/design-concept/items.json b/docs/design-concept/items.json new file mode 100644 index 00000000..50ffece2 --- /dev/null +++ b/docs/design-concept/items.json @@ -0,0 +1,6 @@ +{ + "items": [ + { "type": "markdown", "name": "intro.md" }, + { "type": "markdown", "name": "memory-buffers.md" } + ] +} diff --git a/docs/design-concept/memory-buffers.md b/docs/design-concept/memory-buffers.md new file mode 100644 index 00000000..6cb41548 --- /dev/null +++ b/docs/design-concept/memory-buffers.md @@ -0,0 +1,20 @@ +--- +title: Memory buffers +--- + +Each connection has send and receive buffer, +[`struct mg_connection::send_mbuf`](#TODO) +and +[`struct mg_connection::recv_mbuf`](#ODO) respectively. +When data arrives, +Mongoose appends received data to the `recv_mbuf` and +triggers `MG_EV_RECV` event. User may send data back by calling one of the +output functions, like [`mg_send()`](#TODO) or +[`mg_printf()`](#TODO). Output functions append data to the +`send_mbuf`. When Mongoose +successfully writes data to the socket, it discards data from +[`mg_connection::send_mbuf`](#TODO) and +sends `MG_EV_SEND` event. When connection is closed, `MG_EV_CLOSE` event is sent. + +![](../../static/img/mongoose/mbuf.png) + diff --git a/docs/img/mbuf.png b/docs/img/mbuf.png new file mode 100644 index 0000000000000000000000000000000000000000..a162abc3d6ce0df95ad9fa725cc54337b1ceb64f GIT binary patch literal 73349 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 lKn2WE5&!=recv_mbuf; + + switch (ev) { + case MG_EV_RECV: + // This event handler implements simple TCP echo server + mg_send(nc, io->buf, io->len); // Echo received data back + mbuf_remove(io, io->len); // Discard data from recv buffer + break; + default: + break; + } +} + +int main(void) { + struct mg_mgr mgr; + + mg_mgr_init(&mgr, NULL); // Initialize event manager object + + // Note that many connections can be added to a single event manager + // Connections can be created at any point, e.g. in event handler function + mg_bind(&mgr, "1234", ev_handler); // Create listening connection and add it to the event manager + + for (;;) { // Start infinite event loop + mg_mgr_poll(&mgr, 1000); + } + + mg_mgr_free(&mgr); + return 0; +} +``` + diff --git a/docs/usage-example/items.json b/docs/usage-example/items.json new file mode 100644 index 00000000..bc7e70d8 --- /dev/null +++ b/docs/usage-example/items.json @@ -0,0 +1,5 @@ +{ + "items": [ + { "type": "markdown", "name": "intro.md" } + ] +}