Update a document, a README, and some comments.

This commit is contained in:
Gregory Nutt 2017-10-17 06:25:46 -06:00
parent 5b385f4d4d
commit 5d6ecfa3ca
4 changed files with 237 additions and 112 deletions

View file

@ -12,7 +12,7 @@
<h1><big><font color="#3c34ec">
<i>NX Graphics Subsystem</i>
</font></big></h1>
<p>Last Updated: October 15, 2017</p>
<p>Last Updated: October 17, 2017</p>
</td>
</tr>
</table>
@ -90,40 +90,47 @@
<ul>
<i>2.3.1 <a href="#nxppdefs">Pre-Processor Definitions</a></i><br>
<i>2.3.2 <a href="#nxtypes">NX Types</a></i><br>
<i>2.3.3 <a href="#nxtypes">NX Server Callbacks</a></i>
<i>2.3.3 <a href="#startingnx">Starting the NX Server</a></i>
<p>
<ul>
<i>2.3.3.1 <a href="#nxcbredraw"><code>redraw()</code></a></i><br>
<i>2.3.3.2 <a href="#nxcbposition"><code>position()</code></a></i><br>
<i>2.3.3.3 <a href="#nxcbmousein"><code>mousein()</code></a></i><br>
<i>2.3.3.4 <a href="#nxcbkbdin"><code>kbdin()</code></a></i>
<i>2.3.3.1 <a href="#nxstart"><code>nx_start()</code></a></i><br>
<i>2.3.3.2 <a href="#boardctl"><code>boardctl()</code></a></i><br>
</ul>
<p>
<i>2.3.4 <a href="#nxruninstance"><code>nx_runinstance()</code> (and <code>nx_run()<code> macro)</a></i><br>
<i>2.3.5 <a href="#nxconnectinstance"><code>nx_connectinstance()</code> (and <code>nx_connect()</code> macro)</a></i><br>
<i>2.3.6 <a href="#nxdisconnect"><code>nx_disconnect()</code></a></i><br>
<i>2.3.7 <a href="#nxeventhandler"><code>nx_eventhandler()</code></a></i><br>
<i>2.3.8 <a href="#nxeventnotify"><code>nx_eventnotify()</code></a></i><br>
<i>2.3.9 <a href="#nxopenwindow"><code>nx_openwindow()</code></a></i><br>
<i>2.3.10 <a href="#nxclosewindow"><code>nx_closewindow()</code></a></i><br>
<i>2.3.11 <a href="#nxrequestbkgd"><code>nx_requestbkgd()</code></a></i><br>
<i>2.3.12 <a href="#nxreleasebkgd"><code>nx_releasebkgd()</code></a></i><br>
<i>2.3.13 <a href="#nxgetposition"><code>nx_getposition()</code></a></i><br>
<i>2.3.14 <a href="#nxsetposition"><code>nx_setposition()</code></a></i><br>
<i>2.3.15 <a href="#nxsetsize"><code>nx_setsize()</code></a></i><br>
<i>2.3.16 <a href="#nxraise"><code>nx_raise()</code></a></i><br>
<i>2.3.17 <a href="#nxlower"><code>nx_lower()</code></a></i><br>
<i>2.3.18 <a href="#nxfill"><code>nx_fill()</code></a></i><br>
<i>2.3.19 <a href="#nxgetrectangle"><code>nx_getrectangle()</code></a></i><br>
<i>2.3.20 <a href="#nxfilltrapezoid"><code>nx_filltrapezoid()</code></a></i><br>
<i>2.3.21 <a href="#nxdrawline"><code>nx_drawline()</code></a></i><br>
<i>2.3.22 <a href="#nxdrawcircle"><code>nx_drawcircle()</code></a></i><br>
<i>2.3.23 <a href="#nxfillcircle"><code>nx_fillcircle()</code></a></i><br>
<i>2.3.24 <a href="#nxglrgb2yuv"><code>nx_setbgcolor()</code></a></i><br>
<i>2.3.25 <a href="#nxmove"><code>nx_move()</code></a></i><br>
<i>2.3.26 <a href="#nxbitmap"><code>nx_bitmap()</code></a></i><br>
<i>2.3.27 <a href="#nxkbdin"><code>nx_kbdin()</code></a></i><br>
<i>2.3.28 <a href="#nxmousein"><code>nx_mousein()</code></a></i><br>
<i>2.3.4 <a href="#nxcallbacks">NX Server Callbacks</a></i>
<p>
<ul>
<i>2.3.4.1 <a href="#nxcbredraw"><code>redraw()</code></a></i><br>
<i>2.3.4.2 <a href="#nxcbposition"><code>position()</code></a></i><br>
<i>2.3.4.3 <a href="#nxcbmousein"><code>mousein()</code></a></i><br>
<i>2.3.4.4 <a href="#nxcbkbdin"><code>kbdin()</code></a></i>
</ul>
<p>
<i>2.3.5 <a href="#nxruninstance"><code>nx_runinstance()</code> (and <code>nx_run()<code> macro)</a></i><br>
<i>2.3.6 <a href="#nxconnectinstance"><code>nx_connectinstance()</code> (and <code>nx_connect()</code> macro)</a></i><br>
<i>2.3.7 <a href="#nxdisconnect"><code>nx_disconnect()</code></a></i><br>
<i>2.3.8 <a href="#nxeventhandler"><code>nx_eventhandler()</code></a></i><br>
<i>2.3.9 <a href="#nxeventnotify"><code>nx_eventnotify()</code></a></i><br>
<i>2.3.10 <a href="#nxopenwindow"><code>nx_openwindow()</code></a></i><br>
<i>2.3.11 <a href="#nxclosewindow"><code>nx_closewindow()</code></a></i><br>
<i>2.3.12 <a href="#nxrequestbkgd"><code>nx_requestbkgd()</code></a></i><br>
<i>2.3.13 <a href="#nxreleasebkgd"><code>nx_releasebkgd()</code></a></i><br>
<i>2.3.14 <a href="#nxgetposition"><code>nx_getposition()</code></a></i><br>
<i>2.3.15 <a href="#nxsetposition"><code>nx_setposition()</code></a></i><br>
<i>2.3.16 <a href="#nxsetsize"><code>nx_setsize()</code></a></i><br>
<i>2.3.17 <a href="#nxraise"><code>nx_raise()</code></a></i><br>
<i>2.3.18 <a href="#nxlower"><code>nx_lower()</code></a></i><br>
<i>2.3.19 <a href="#nxfill"><code>nx_fill()</code></a></i><br>
<i>2.3.20 <a href="#nxgetrectangle"><code>nx_getrectangle()</code></a></i><br>
<i>2.3.21 <a href="#nxfilltrapezoid"><code>nx_filltrapezoid()</code></a></i><br>
<i>2.3.22 <a href="#nxdrawline"><code>nx_drawline()</code></a></i><br>
<i>2.3.23 <a href="#nxdrawcircle"><code>nx_drawcircle()</code></a></i><br>
<i>2.3.24 <a href="#nxfillcircle"><code>nx_fillcircle()</code></a></i><br>
<i>2.3.25 <a href="#nxglrgb2yuv"><code>nx_setbgcolor()</code></a></i><br>
<i>2.3.26 <a href="#nxmove"><code>nx_move()</code></a></i><br>
<i>2.3.27 <a href="#nxbitmap"><code>nx_bitmap()</code></a></i><br>
<i>2.3.28 <a href="#nxkbdin"><code>nx_kbdin()</code></a></i><br>
<i>2.3.29 <a href="#nxmousein"><code>nx_mousein()</code></a></i><br>
</ul>
</p>
</td>
@ -921,9 +928,94 @@ struct nx_callback_s
};
</pre></ul>
<h3>2.3.3 <a name="nxtypes">NX Server Callbacks</a></h3>
<h3>2.3.3 <a name="startingnx">Starting the NX Server</a></h3>
<p>
The <i>NX Server</i> is a kernel daemon that receives and serializes graphic commands.
Before you can use the NX graphics system, you must first start this daemon.
There are two ways that this can be done:
</p>
<ol>
<li>
<p>
The NX server may be started in your board startup logic by simply calling the function <code> nx_start()</code>.
The board startup logic usually resides the the <code>configs/<i>board</i>/src</code> directory.
The boar board startup logic can run automatically during the early system if <code>CONFIG_BOARD_INITIALIZE</code> is defined in the configuration.
Or, the board startup logic can execute under control of the application by calling the <code>boardctl(BOARDIOC_INIT, arg)</code> OS interface.
</p>
<p>
The board initialization logic will run in either case and the simple call to <code>nx_start()</code> will start the NX server.
</p>
</li>
<li>
The NX server may also be started later by the application via the <code>boardctl(BOARDIOC_NX_START, arg)</code>
</li>
</ol>
<h4>2.3.3.1 <a name="nxcbredraw"><code>redraw()</code></a></h4>
<h4>2.3.3.1 <a name="nxstart"><code>nx_start()</code></a></h4>
<p><b>Function Prototype:</b></p>
<ul><pre>
#include &lt;nuttx/nx/nx.h&gt;
int nx_start(void);
</pre></ul>
<p>
<b>Description:</b>
<code>nx_start()</code> provides a wrapper function to simplify and standardize the starting of the NX server.
</p>
<p>
<b>Input Parameters:</b>
None
</p>
<p>
<b>Returned Value:</b>
Zero (<code>OK</code>) is returned on success.
This indicates that the NX server has been successfully started, is running, and waiting to accept connections from NX clients.
</p>
<p>
A negated <code>errno</code> value is returned on failure.
The <code>errno</code> value indicates the nature of the failure.
</p>
<h4>2.3.3.1 <a name="boardctl"><code>boardctl()</code></a></h4>
<p><b>Function Prototype:</b></p>
<ul><pre>
#include &lt;sys/boardctl.h&gt;
</pre></ul>
<p>
<b>Description:</b>
<code>boardctl()</code> is a generic NuttX interface that among many of it functions, may also be used to start the NX server.
</p>
In a small embedded system, there will typically be a much greater interaction between application and low-level board features.
The canonically correct to implement such interactions is by implementing a character driver and performing the interactions via low level <code>ioctl()</code> calls.
This, however, may not be practical in many cases and will lead to &quot;correct&quot; but awkward implementations.
</p>
<p>
<code>boardctl()</code> is non-standard OS interface to alleviate the problem.
It basically circumvents the normal device driver ioctl interlace and allows the application to perform direction IOCTL-like calls to the board-specific logic.
In it is especially useful for setting up board operational and test configurations.
</p>
<p>
When called with the <code>cmd</code> of <code>BOARDIOC_NX_START</code>, then the <code>boardctl()</code> will call <code>nx_start</code> indirectly on behalf of the appication.
In this case the <code>arg</code> parameter is ignored.
</p>
<p>
<b>Input Parameters:</b>
<ul><dl>
<dt><code>cmd</code>
<dd> Identifies the board command to be executed
<dt><code>arg</code>
<dd>The argument that accompanies the command. The nature of the argument is determined by the specific command.
</dl></ul>
</p>
<p>
<b>Returned Value:</b>
On success zero (<code>OK</code) is returned; -1 (<code>ERROR</code>) is returned on failure with the <code>errno</code> variable to to indicate the nature of the failure.
</p>
<h3>2.3.4 <a name="nxcallbacks">NX Server Callbacks</a></h3>
<h4>2.3.4.1 <a name="nxcbredraw"><code>redraw()</code></a></h4>
<p><b>Callback Function Prototype:</b></p>
<ul><pre>
void redraw(NXWINDOW hwnd, FAR const struct nxgl_rect_s *rect,
@ -952,7 +1044,7 @@ void redraw(NXWINDOW hwnd, FAR const struct nxgl_rect_s *rect,
<b>Returned Value:</b> None
</p>
<h4>2.3.3.2 <a name="nxcbposition"><code>position()</code></a></h4>
<h4>2.3.4.2 <a name="nxcbposition"><code>position()</code></a></h4>
<p><b>Callback Function Prototype:</b></p>
<ul><pre>
void position(NXWINDOW hwnd, FAR const struct nxgl_size_s *size,
@ -986,7 +1078,7 @@ void position(NXWINDOW hwnd, FAR const struct nxgl_size_s *size,
<b>Returned Value:</b> None
</p>
<h4>2.3.3.3 <a name="nxcbmousein"><code>mousein()</code></a></h4>
<h4>2.3.4.3 <a name="nxcbmousein"><code>mousein()</code></a></h4>
<p><b>Callback Function Prototype:</b></p>
<ul><pre>
#ifdef CONFIG_NX_XYINPUT
@ -1016,7 +1108,7 @@ void mousein(NXWINDOW hwnd, FAR const struct nxgl_point_s *pos,
<b>Returned Value:</b> None
</p>
<h4>2.3.3.4 <a name="nxcbkbdin"><code>kbdin()</code></a></h4>
<h4>2.3.4.4 <a name="nxcbkbdin"><code>kbdin()</code></a></h4>
<p><b>Callback Function Prototype:</b></p>
<ul><pre>
#ifdef CONFIG_NX_KBD
@ -1045,7 +1137,7 @@ void (*kbdin)(NXWINDOW hwnd, uint8_t nch, FAR const uint8_t *ch, FAR void *arg);
<b>Returned Value:</b> None
</p>
<h3>2.3.4 <a name="nxruninstance"><code>nx_runinstance()</code> (and <code>nx_run()</code> macro)</a></h3>
<h3>2.3.5 <a name="nxruninstance"><code>nx_runinstance()</code> (and <code>nx_run()</code> macro)</a></h3>
<p><b>Function Prototype:</b></p>
<ul><pre>
#include &lt;nuttx/nx/nxglib.h&gt;
@ -1082,7 +1174,7 @@ int nx_runinstance(FAR const char *mqname, FAR struct fb_vtable_s *fb);
return <code>ERROR</code> and <code>errno</code> will be set appropriately.
</p>
<h3>2.3.5 <a name="nxconnectinstance"><code>nx_connectinstance()</code> (and <code>nx_connect()</code> macro)</a></h3>
<h3>2.3.6 <a name="nxconnectinstance"><code>nx_connectinstance()</code> (and <code>nx_connect()</code> macro)</a></h3>
<p><b>Function Prototype:</b></p>
<ul><pre>
#include &lt;nuttx/nx/nxglib.h&gt;
@ -1131,7 +1223,7 @@ NXHANDLE nx_connectinstance(FAR const char *svrmqname);
Failure: NULL is returned and <code>errno</code> is set appropriately.
</ul>
<h3>2.3.6 <a name="nxdisconnect"><code>nx_disconnect()</code></a></h3>
<h3>2.3.7 <a name="nxdisconnect"><code>nx_disconnect()</code></a></h3>
<p><b>Function Prototype:</b></p>
<ul><pre>
#include &lt;nuttx/nx/nxglib.h&gt;
@ -1155,7 +1247,7 @@ void nx_disconnect(NXHANDLE handle);
<b>Returned Value:</b> None.
</p>
<h3>2.3.7 <a name="nxeventhandler"><code>nx_eventhandler()</code></a></h3>
<h3>2.3.8 <a name="nxeventhandler"><code>nx_eventhandler()</code></a></h3>
<p><b>Function Prototype:</b></p>
<ul><pre>
#include &lt;nuttx/nx/nxglib.h&gt;
@ -1199,7 +1291,7 @@ int nx_eventhandler(NXHANDLE handle);
</li>
</ul>
<h3>2.3.8 <a name="nxeventnotify"><code>nx_eventnotify()</code></a></h3>
<h3>2.3.9 <a name="nxeventnotify"><code>nx_eventnotify()</code></a></h3>
<p><b>Function Prototype:</b></p>
<ul><pre>
#include &lt;nuttx/nx/nxglib.h&gt;
@ -1245,7 +1337,7 @@ int nx_eventnotify(NXHANDLE handle, int signo);
<code>ERROR</code> on failure with <code>errno</code> set appropriately
</p>
<h3>2.3.9 <a name="nxopenwindow"><code>nx_openwindow()</code></a></h3>
<h3>2.3.10 <a name="nxopenwindow"><code>nx_openwindow()</code></a></h3>
<p><b>Function Prototype:</b></p>
<ul><pre>
#include &lt;nuttx/nx/nxglib.h&gt;
@ -1277,7 +1369,7 @@ NXWINDOW nx_openwindow(NXHANDLE handle,
Failure: NULL is returned and <code>errno</code> is set appropriately.
</ul>
<h3>2.3.10 <a name="nxclosewindow"><code>nx_closewindow()</code></a></h3>
<h3>2.3.11 <a name="nxclosewindow"><code>nx_closewindow()</code></a></h3>
<p><b>Function Prototype:</b></p>
<ul><pre>
#include &lt;nuttx/nx/nxglib.h&gt;
@ -1305,7 +1397,7 @@ int nx_closewindow(NXWINDOW hwnd);
<code>ERROR</code> on failure with <code>errno</code> set appropriately
</p>
<h3>2.3.11 <a name="nxrequestbkgd"><code>nx_requestbkgd()</code></a></h3>
<h3>2.3.12 <a name="nxrequestbkgd"><code>nx_requestbkgd()</code></a></h3>
<p><b>Function Prototype:</b></p>
<ul><pre>
#include &lt;nuttx/nx/nxglib.h&gt;
@ -1375,7 +1467,7 @@ int nx_requestbkgd(NXHANDLE handle,
<code>ERROR</code> on failure with <code>errno</code> set appropriately
</p>
<h3>2.3.12 <a name="nxreleasebkgd"><code>nx_releasebkgd()</code></a></h3>
<h3>2.3.13 <a name="nxreleasebkgd"><code>nx_releasebkgd()</code></a></h3>
<p><b>Function Prototype:</b></p>
<ul><pre>
#include &lt;nuttx/nx/nxglib.h&gt;
@ -1405,7 +1497,7 @@ int nx_releasebkgd(NXWINDOW hwnd);
<code>ERROR</code> on failure with <code>errno</code> set appropriately
</p>
<h3>2.3.13 <a name="nxgetposition"><code>nx_getposition()</code></a></h3>
<h3>2.3.14 <a name="nxgetposition"><code>nx_getposition()</code></a></h3>
<p><b>Function Prototype:</b></p>
<ul><pre>
#include &lt;nuttx/nx/nxglib.h&gt;
@ -1433,7 +1525,7 @@ int nx_getposition(NXWINDOW hwnd);
<code>ERROR</code> on failure with <code>errno</code> set appropriately
</p>
<h3>2.3.14 <a name="nxsetposition"><code>nx_setposition()</code></a></h3>
<h3>2.3.15 <a name="nxsetposition"><code>nx_setposition()</code></a></h3>
<p><b>Function Prototype:</b></p>
<ul><pre>
#include &lt;nuttx/nx/nxglib.h&gt;
@ -1462,7 +1554,7 @@ int nx_setposition(NXWINDOW hwnd, FAR struct nxgl_point_s *pos);
<code>ERROR</code> on failure with <code>errno</code> set appropriately
</p>
<h3>2.3.15 <a name="nxsetsize"><code>nx_setsize()</code></a></h3>
<h3>2.3.16 <a name="nxsetsize"><code>nx_setsize()</code></a></h3>
<p><b>Function Prototype:</b></p>
<ul><pre>
#include &lt;nuttx/nx/nxglib.h&gt;
@ -1490,7 +1582,7 @@ int nx_setsize(NXWINDOW hwnd, FAR struct nxgl_size_s *size);
<code>ERROR</code> on failure with <code>errno</code> set appropriately
</p>
<h3>2.3.16 <a name="nxraise"><code>nx_raise()</code></a></h3>
<h3>2.3.17 <a name="nxraise"><code>nx_raise()</code></a></h3>
<p><b>Function Prototype:</b></p>
<ul><pre>
#include &lt;nuttx/nx/nxglib.h&gt;
@ -1518,7 +1610,7 @@ int nx_raise(NXWINDOW hwnd);
<code>ERROR</code> on failure with <code>errno</code> set appropriately
</p>
<h3>2.3.17 <a name="nxlower"><code>nx_lower()</code></a></h3>
<h3>2.3.18 <a name="nxlower"><code>nx_lower()</code></a></h3>
<p><b>Function Prototype:</b></p>
<ul><pre>
#include &lt;nuttx/nx/nxglib.h&gt;
@ -1546,7 +1638,7 @@ int nx_lower(NXWINDOW hwnd);
<code>ERROR</code> on failure with <code>errno</code> set appropriately
</p>
<h3>2.3.18 <a name="nxfill"><code>nx_fill()</code></a></h3>
<h3>2.3.19 <a name="nxfill"><code>nx_fill()</code></a></h3>
<p><b>Function Prototype:</b></p>
<ul><pre>
#include &lt;nuttx/nx/nxglib.h&gt;
@ -1577,7 +1669,7 @@ int nx_fill(NXWINDOW hwnd, FAR const struct nxgl_rect_s *rect,
<code>ERROR</code> on failure with <code>errno</code> set appropriately
</p>
<h3>2.3.19 <a name="nxgetrectangle"><code>nx_getrectangle()</code></a></h3>
<h3>2.3.20 <a name="nxgetrectangle"><code>nx_getrectangle()</code></a></h3>
<p><b>Function Prototype:</b></p>
<ul><pre>
#include &lt;nuttx/nx/nxglib.h&gt;
@ -1617,7 +1709,7 @@ void nx_getrectangle(NXWINDOW hwnd, FAR const struct nxgl_rect_s *rect,
<code>ERROR</code> on failure with <code>errno</code> set appropriately
</p>
<h3>2.3.20 <a name="nxfilltrapezoid"><code>nx_filltrapezoid()</code></a></h3>
<h3>2.3.21 <a name="nxfilltrapezoid"><code>nx_filltrapezoid()</code></a></h3>
<p><b>Function Prototype:</b></p>
<ul><pre>
#include &lt;nuttx/nx/nxglib.h&gt;
@ -1651,7 +1743,7 @@ int nx_filltrapezoid(NXWINDOW hwnd, FAR const struct nxgl_rect_s *clip,
<code>ERROR</code> on failure with <code>errno</code> set appropriately
</p>
<h3>2.3.21 <a name="nxdrawline"><code>nx_drawline()</code></a></h3>
<h3>2.3.22 <a name="nxdrawline"><code>nx_drawline()</code></a></h3>
<p><b>Function Prototype:</b></p>
<ul><pre>
#include &lt;nuttx/nx/nxglib.h&gt;
@ -1699,7 +1791,7 @@ int nx_drawline(NXWINDOW hwnd, FAR struct nxgl_vector_s *vector,
<code>ERROR</code> on failure with <code>errno</code> set appropriately
</p>
<h3>2.3.22 <a name="nxdrawcircle"><code>nx_drawcircle()</code></a></h3>
<h3>2.3.23 <a name="nxdrawcircle"><code>nx_drawcircle()</code></a></h3>
<p><b>Function Prototype:</b></p>
<ul><pre>
#include &lt;nuttx/nx/nxglib.h&gt;
@ -1735,7 +1827,7 @@ int nx_drawcircle(NXWINDOW hwnd, FAR const struct nxgl_point_s *center,
<code>ERROR</code> on failure with <code>errno</code> set appropriately
</p>
<h3>2.3.23 <a name="nxfillcircle"><code>nx_fillcircle()</code></a></h3>
<h3>2.3.24 <a name="nxfillcircle"><code>nx_fillcircle()</code></a></h3>
<p><b>Function Prototype:</b></p>
<ul><pre>
#include &lt;nuttx/nx/nxglib.h&gt;
@ -1768,7 +1860,7 @@ int nx_fillcircle(NXWINDOW hwnd, FAR const struct nxgl_point_s *center,
<code>ERROR</code> on failure with <code>errno</code> set appropriately
</p>
<h3>2.3.24 <a name="nxglrgb2yuv"><code>nx_setbgcolor()</code></a></h3>
<h3>2.3.25 <a name="nxglrgb2yuv"><code>nx_setbgcolor()</code></a></h3>
<p><b>Function Prototype:</b></p>
<ul><pre>
#include &lt;nuttx/nx/nxglib.h&gt;
@ -1796,7 +1888,7 @@ int nx_setbgcolor(NXHANDLE handle,
<code>ERROR</code> on failure with <code>errno</code> set appropriately
</p>
<h3>2.3.25 <a name="nxmove"><code>nx_move()</code></a></h3>
<h3>2.3.26 <a name="nxmove"><code>nx_move()</code></a></h3>
<p><b>Function Prototype:</b></p>
<ul><pre>
#include &lt;nuttx/nx/nxglib.h&gt;
@ -1827,7 +1919,7 @@ int nx_move(NXWINDOW hwnd, FAR const struct nxgl_rect_s *rect,
<code>ERROR</code> on failure with <code>errno</code> set appropriately
</p>
<h3>2.3.26 <a name="nxbitmap"><code>nx_bitmap()</code></a></h3>
<h3>2.3.27 <a name="nxbitmap"><code>nx_bitmap()</code></a></h3>
<p><b>Function Prototype:</b></p>
<ul><pre>
#include &lt;nuttx/nx/nxglib.h&gt;
@ -1869,7 +1961,7 @@ int nx_bitmap(NXWINDOW hwnd, FAR const struct nxgl_rect_s *dest,
<code>ERROR</code> on failure with <code>errno</code> set appropriately
</p>
<h3>2.3.27 <a name="nxkbdin"><code>nx_kbdin()</code></a></h3>
<h3>2.3.28 <a name="nxkbdin"><code>nx_kbdin()</code></a></h3>
<p><b>Function Prototype:</b></p>
<ul><pre>
#include &lt;nuttx/nx/nxglib.h&gt;
@ -1892,7 +1984,7 @@ int nx_kbdin(NXHANDLE handle, uint8_t nch, FAR const uint8_t *ch);
<code>ERROR</code> on failure with <code>errno</code> set appropriately
</p>
<h3>2.3.28 <a name="nxmousein"><code>nx_mousein()</code></a></h3>
<h3>2.3.29 <a name="nxmousein"><code>nx_mousein()</code></a></h3>
<p><b>Function Prototype:</b></p>
<ul><pre>
#include &lt;nuttx/nx/nxglib.h&gt;

View file

@ -12,6 +12,7 @@ Contents
- 64-bit Issues
- Compiler differences
- Stack Size Issues
- Symbol Collisions
- Networking Issues
- X11 Issues
- Cygwin64 Issues
@ -24,20 +25,21 @@ Overview
Description
-----------
This README file describes the contents of the build configurations available
for the NuttX "sim" target. The sim target is a NuttX port that runs as a
user-space program under Linux or Cygwin. It is a very "low fidelity" embedded
system simulation: This environment does not support any kind of asynchronous
events -- there are nothing like interrupts in this context. Therefore, there
can be no pre-empting events.
This README file describes the contents of the build configurations
available for the NuttX "sim" target. The sim target is a NuttX port that
runs as a user-space program under Linux or Cygwin. It is a very "low
fidelity" embedded system simulation: This environment does not support
any kind of asynchronous events -- there are nothing like interrupts in this
context. Therefore, there can be no pre-empting events.
Fake Interrupts
---------------
In order to get timed behavior, the system timer "interrupt handler" is called
from the sim target's IDLE loop. The IDLE runs whenever there is no other task
running. So, for example, if a task calls sleep(), then that task will suspend
wanting for the time to elapse. If nothing else is available to run, then the
IDLE loop runs and the timer increments, eventually re-awakening the sleeping task.
In order to get timed behavior, the system timer "interrupt handler" is
called from the sim target's IDLE loop. The IDLE runs whenever there is no
other task running. So, for example, if a task calls sleep(), then that
task will suspend wanting for the time to elapse. If nothing else is
available to run, then the IDLE loop runs and the timer increments,
eventually re-awakening the sleeping task.
Context switching is based on logic similar to setjmp() and longjmp().
@ -47,14 +49,16 @@ application that I know of.
Timing Fidelity
---------------
NOTE: In order to facility fast testing, the sim target's IDLE loop, by default,
calls the system "interrupt handler" as fast as possible. As a result, there
really are no noticeable delays when a task sleeps. However, the task really does
sleep -- but the time scale is wrong. If you want behavior that is closer to
normal timing, then you can define CONFIG_SIM_WALLTIME=y in your configuration
file. This configuration setting will cause the sim target's IDLE loop to delay
on each call so that the system "timer interrupt" is called at a rate approximately
correct for the system timer tick rate. With this definition in the configuration,
NOTE: In order to facility fast testing, the sim target's IDLE loop, by
default, calls the system "interrupt handler" as fast as possible. As a
result, there really are no noticeable delays when a task sleeps. However,
the task really does sleep -- but the time scale is wrong. If you want
behavior that is closer to normal timing, then you can define
CONFIG_SIM_WALLTIME=y in your configuration file. This configuration
setting will cause the sim target's IDLE loop to delay on each call so that
the system "timer interrupt" is called at a rate approximately correct for
the system timer tick rate. With this definition in the configuration,
sleep() behavior is more or less normal.
Debugging
@ -141,44 +145,83 @@ steps for increasing the stack size in that case:
vi builtin_list.h # Edit this file and increase the stack size of the add-on
rm .built *.o # This will force the builtin apps logic to rebuild
Symbol Collisions
-----------------
The simulation build is a two pass build:
1. On the first pass, an intermediate, partially relocatable object is
created called nuttx.rel. This includes all of the files that are part
of the NuttX "domain."
2. On the second pass, the files are are in the host OS domain are build
and then linked with nuttx.rel to generate the simulation program.
NuttX is a POSIX compliant RTOS and is normally build on a POSIX compliant
host environment (like Linux or Cygwin). As a result, the same symbols are
exported by both the NuttX doman and the host domain. How can we keep them
separate?
This is done using the special file nuttx-name.dat. This file just contains
a list of original function names and a new function name. For example
the NuttX printf() will get the new name NXprintf().
This nuttx-names.dat file is used by the objcopy program between pass1 and
pass2 to rename all of the symbols in the nuttx.rel object so that they do
not collide with names provided by the host OS in the host PC domain.
Occasionally, as you test new functionality, you will find that you need to
add more names to the nuttx-names.dat file. If there is a missing name
mapping in nuttx-name.dat, the symptoms may be very obscure and difficult to
debug. What happens in this case is that when logic in nuttx.rel intended
to call the NuttX domain function, it instead calls into the host OS
function of the same name.
Often you can survive such events. For example, it really should not matter
which version of strlen() you call. Other times, it can cause subtle,
mysterious errors. Usually, however, callng the wrong function in the wrong
OS results in a fatal crash.
Networking Issues
-----------------
I never did get networking to work on the sim target. It tries to use the tap device
(/dev/net/tun) to emulate an Ethernet NIC, but I never got it correctly integrated
with the NuttX networking (I probably should try using raw sockets instead).
I never did get networking to work on the sim target. It tries to use the
tap device (/dev/net/tun) to emulate an Ethernet NIC, but I never got it
correctly integrated with the NuttX networking (I probably should try using
raw sockets instead).
Update: Max Holtzberg reports to me that the tap device actually does work properly,
but not in an NSH configuration because of stdio operations freeze the simulation.
Update: Max Holtzberg reports to me that the tap device actually does work
properly, but not in an NSH configuration because of stdio operations freeze
the simulation.
REVISIT: This may not long be an issue even with NSH because of the recent redesign
of how the stdio devices are handled in the simulation (they should no longer freeze
the simulation).
REVISIT: This may not long be an issue even with NSH because of the recent
redesign of how the stdio devices are handled in the simulation (they should
no longer freeze the simulation).
X11 Issues
----------
There is an X11-based framebuffer driver that you can use exercise the NuttX graphics
subsystem on the simulator (see the sim/nx11 configuration below). This may require a
lot of tinkering to get working, depending upon where your X11 installation stores
libraries and header files and how it names libraries.
There is an X11-based framebuffer driver that you can use exercise the NuttX
graphics subsystem on the simulator (see the sim/nx11 configuration below).
This may require a lot of tinkering to get working, depending upon where
your X11 installation stores libraries and header files and how it names
libraries.
For example, on UBuntu 9.09, I had to do the following to get a clean build:
For example, on Ubuntu 9.09, I had to do the following to get a clean build:
cd /usr/lib/
sudo ln -s libXext.so.6.4.0 libXext.so
(I also get a segmentation fault at the conclusion of the NX test -- that will need
to get looked into as well).
(I also get a segmentation fault at the conclusion of the NX test -- that
will need to get looked into as well).
The X11 examples builds on Cygwin, but does not run. The last time I tried it,
XOpenDisplay() aborted the program. UPDATE: This was caused by the small stack
size and can be fixed by increasing the size of the NuttX stack that calls into
X11. See the discussion "Stack Size Issues" above.
The X11 examples builds on Cygwin, but does not run. The last time I tried
it, XOpenDisplay() aborted the program. UPDATE: This was caused by the
small stack size and can be fixed by increasing the size of the NuttX stack
that calls into X11. See the discussion "Stack Size Issues" above.
Cygwin64 Issues
---------------
There are some additional issues using the simulator with Cygwin64. Below is the
summary of the changes that I had to make to get the simulator working in that
environment:
There are some additional issues using the simulator with Cygwin64. Below
is the summary of the changes that I had to make to get the simulator
working in that environment:
CONFIG_HOST_X86_64=y
CONFIG_SIM_M32=n

View file

@ -159,11 +159,6 @@ int nx_server(int argc, char *argv[])
* nx_start() provides a wrapper function to simplify and standardize the
* starting of the NX server.
*
* NOTE: Currently, many applications include logic to start the NX
* server from application initialization logic. That, of course, cannot
* work in the NuttX kernel build because the resources required by the
* NX server are private to the kernel mode logic.
*
* nx_start() can be called (indirectly) from applications via the
* boardctl() interface with the BOARDIOC_NX_START command.
*

View file

@ -276,11 +276,6 @@ int nx_runinstance(FAR const char *mqname, FAR NX_DRIVERTYPE *dev);
* nx_start() provides a wrapper function to simplify and standardize the
* starting of the NX server.
*
* NOTE: Currently, many applications include logic to start the NX
* server from application initialization logic. That, of course, cannot
* work in the NuttX kernel build because the resources required by the
* NX server are private to the kernel mode logic.
*
* nx_start() can be called (indirectly) from applications via the
* boardctl() interface with the BOARDIOC_NX_START command.
*