dl

package module
v0.0.0-...-1b01514 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Dec 22, 2015 License: MPL-2.0 Imports: 9 Imported by: 23

README

dl

Runtime dynamic library loader (dlopen / dlsym) for Go (golang)

To install dl run the following command:

    go get github.com/rainycape/dl

GoDoc

Documentation

Overview

Package dl implements dynamic of shared libraries, like dlopen() and dlsym() in C.

This package supports the following type mapping between Go and C.

Go		    -   C
(u)int	    -   (unsigned) long
(u)int8	    -   uint8_t / int8_t
(u)int16	    -   uint16_t / int16_t
(u)int32	    -   (unsigned) int
(u)int64	    -   uint64_t / int64_t
float32	    -	float
float64	    -	double
string	    -   char * (read only)
[]byte	    -   char * (readwrite)
slices	    -   pointer to first argument
uintptr	    -   void *
unsafe.Pointer  -	void *

No struct types are supported at this time.

Retrieving variable symbols

Symbols pointing to variables might be retrieved either as values or pointers. Given a C library which declares a symbol as:

int my_int = 8;

It might be retrieved as a value, returning a copy with:

 var myInt int32
 if err := lib.Sym("my_int", &myInt); err != nil {
	handle_error...
 }

Alternatively, a pointer to the variable might be obtained as:

 var myInt *int32
 if err := lib.Sym("my_int", &myInt); err != nil {
	handle_error...
 }

Note that changing the value via the pointer will change the symbol in the loaded library, while changing the value obtained without the pointer will not, since a copy is made at lookup time.

Retrieving function symbols

This package also supports dynamically loading functions from libraries. To do so you must declare a function variable which matches the signature of the C function. Note that type mismatches will likely result in crashes, so use this feature with extreme care. Argument and return types must be of one of the supported types. See the examples in this package for the complete code.

 var printf func(string, ...interface{}) int32
 if err := lib.Sym("printf", &printf); err != nil {
	handle_error...
 }
 printf("this string uses C format: %d\n", 7)

Functions retrieved from a symbol can be used as standard Go functions.

Overhead

Typically, calling functions via this package rather than using cgo directly takes around 500ns more per call, due to reflection overhead. Future versions might adopt a JIT strategy which should make it as fast as cgo.

Index

Examples

Constants

View Source
const (
	// dlopen() flags. See man dlopen.
	RTLD_LAZY     = int(C.RTLD_LAZY)
	RTLD_NOW      = int(C.RTLD_NOW)
	RTLD_GLOBAL   = int(C.RTLD_GLOBAL)
	RTLD_LOCAL    = int(C.RTLD_LOCAL)
	RTLD_NODELETE = int(C.RTLD_NODELETE)
	RTLD_NOLOAD   = int(C.RTLD_NOLOAD)
)
View Source
const (
	LibExt = ".so"
)

Variables

This section is empty.

Functions

This section is empty.

Types

type DL

type DL struct {
	// contains filtered or unexported fields
}

DL represents an opened dynamic library. Use Open to initialize a DL and use DL.Close when you're finished with it. Note that when the DL is closed all its loaded symbols become invalid.

func Open

func Open(name string, flag int) (*DL, error)

Open opens the shared library identified by the given name with the given flags. See man dlopen for the available flags and its meaning. Note that the only difference with dlopen is that if nor RTLD_LAZY nor RTLD_NOW are specified, Open defaults to RTLD_NOW rather than returning an error. If the name argument passed to name does not have extension, the default for the platform will be appended to it (e.g. .so, .dylib, etc...).

Example (Snprintf)
package main

import (
	"bytes"
	"fmt"

	"dl"
)

func main() {
	lib, err := dl.Open("libc", 0)
	if err != nil {
		panic(err)
	}
	defer lib.Close()
	var snprintf func([]byte, uint, string, ...interface{}) int
	if err := lib.Sym("snprintf", &snprintf); err != nil {
		panic(err)
	}
	buf := make([]byte, 200)
	snprintf(buf, uint(len(buf)), "hello %s!\n", "world")
	s := string(buf[:bytes.IndexByte(buf, 0)])
	fmt.Println(s)
}
Output:

hello world!

func (*DL) Close

func (d *DL) Close() error

Close closes the shared library handle. All symbols loaded from the library will become invalid.

func (*DL) Sym

func (d *DL) Sym(symbol string, out interface{}) error

Sym loads the symbol identified by the given name into the out parameter. Note that out must always be a pointer. See the package documentation to learn how types are mapped between Go and C.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL