From 20777fef17150f0d65487ce385c5484d9b6d4e2d Mon Sep 17 00:00:00 2001 From: Bruce Allen Date: Tue, 28 Dec 2004 19:44:44 +0000 Subject: [PATCH] Added some details about how to link a shared library object and how to communicate data between worker and graphics threads in that situation. svn path=/trunk/boinc/; revision=4955 --- doc/graphics.php | 37 ++++++++++++++++++++++++++++++++++--- 1 file changed, 34 insertions(+), 3 deletions(-) diff --git a/doc/graphics.php b/doc/graphics.php index d2e901493f..34e17dc2ad 100644 --- a/doc/graphics.php +++ b/doc/graphics.php @@ -109,7 +109,8 @@ int boinc_init_options_graphics_lib( ) // for compound apps -where worker() is as above. +where worker() is as above, and argv0 is the name of the +executable as passed in the second argument of main() as argv[0]. The main program must be linked with libboinc_graphics_lib.a

@@ -119,9 +120,39 @@ It must be linked with libboinc_graphics_impl.a, with your rendering and input-handling functions, and (dynamically) with glut and opengl. +

+You must bundle the main program and the shared library together as a +multi-file application version. +

-You must bundle the main program and the shared library together -as a multi-file application version. +A typical linking line in building the main program might look like +this:
g++ -pthread -o einstein_4.01_i686-pc-linux-gnu app1.o +app2.o -lboinc_zip -lboinc_api -lboinc -lboinc_graphics_lib -ldl +-lm
+where app1.o and app2.o contain the definitions of main() and worker(). + +

+A typical linking line in building the shared library might +look like this:
g++ -pthread -o +einstein_4.01_i686-pc-linux-gnu.so -shared -fPIC app_graphics1.o +app_graphics2.o -lboinc_graphics_impl -lboinc -lglut -lGLU -lGL -lX11 +-lXmu -ldl -lm
+where app_graphics1.o and app_graphics2.o contain the definitions +of app_graphics_init(), app_graphics_render(), etc. + +

In order to communicate data between the worker thread and the +graphics thread, the worker() function can call functions from within +the shared library. To do this, it makes use of the global variable +graphics_lib_handle. If NULL, this means that the host lacks graphics +capabilities. If not NULL, the worker can use +

+communications_function_hook = dlsym(graphics_lib_handle,\"communications_function\");
+
+to resolve pointers to functions which are defined in the graphics +code app_graphicsN.o. In turn, such functions can modify data used by +the graphics code. + +

Separate-program structure