summaryrefslogtreecommitdiff
Commit message (Collapse)AuthorAgeFilesLines
* ipcpd: fixes to shim-udpdimitri staessens2016-06-271-48/+60
| | | | | getsockname() can give bad behaviour when haphazardly looping fd's, added check that the fd has a flow. Replaced LOG_DBGF with LOG_DBG.
* build: correct sandboxingdimitri staessens2016-06-2713-18/+18
| | | | | paths cannot start with "/" or PREFIX will be omitted. PREFIX must be set before the project() call.
* Merged in sandervrijders/ouroboros/be (pull request #140)dimitri staessens2016-06-2718-24/+24
|\ | | | | | | build: Fix installation prefix
| * build: Fix installation prefixSander Vrijders2016-06-2718-24/+24
| | | | | | | | | | | | The installation prefix was taking a trailing backslash, while it is common not to do so. Fixed it so that any trailing backslash is removed by the compilation and installation scripts.
* | Merged in dstaesse/ouroboros/be-irmd-fixes (pull request #139)Sander Vrijders2016-06-271-24/+33
|\ \ | |/ |/| | | irmd: bugfixes
| * irmd: bugfixesdimitri staessens2016-06-271-24/+33
|/ | | | | | | | IPCP destruction was erroneously removed. This has been fixed. Autostart of application is fixed, it would trigger even with an instance waiting for flows. Moved SIGPIPE handler to the top to allow shutting down the IRMD when running with valgrind (which triggers SIGPIPE).
* Merged in dstaesse/ouroboros/be-irmd-registry (pull request #138)Sander Vrijders2016-06-251-258/+807
|\ | | | | | | irmd: name space management
| * Merge branch 'be' of bitbucket.org:ouroboros-rina/ouroboros into ↵dimitri staessens2016-06-2421-120/+127
| |\ | |/ |/| | | be-irmd-registry
* | Merged in sandervrijders/ouroboros/be (pull request #137)dimitri staessens2016-06-2213-63/+65
|\ \ | | | | | | | | | Be
| * | lib: Change DA header to NSMSander Vrijders2016-06-2210-43/+47
| | | | | | | | | | | | | | | | | | Functionality that was previously thought to be part of the DIF Allocator is actually namespace management. Hence the file has been renamed and the API updated.
| * | lib: Remove implementation specific errnosSander Vrijders2016-06-223-20/+18
| | | | | | | | | | | | | | | This removes any implementation specific error numbers. Only errors that are implementation independent should be returned.
* | | Merged in sandervrijders/ouroboros/be (pull request #136)dimitri staessens2016-06-2212-85/+90
|\| | | | | | | | | | | lib: Add errnos specific for Ouroboros
| * | lib: Add errnos specific for OuroborosSander Vrijders2016-06-2212-85/+90
|/ / | | | | | | | | | | | | This adds error numbers specificly for Ouroboros. It also refactors some of the header files that are installed. Fixes #2
| * irmd: Fixes comments on 668a32cdimitri staessens2016-06-242-57/+43
| | | | | | | | | | Also revised log messages. The core functions use err/warn/info, all other functions only have dbg.
| * irmd: name space managementdimitri staessens2016-06-242-255/+818
|/ | | | | | | irmd registry rebuilt from the ground up. Now supports * multiple APs to accept flows for the same registered name * multiple instances per registered name. * irm can select a specific process to wake up
* Merged in dstaesse/ouroboros/be-robust (pull request #135)Sander Vrijders2016-06-2115-744/+614
|\ | | | | | | lib, irmd, ipcp: robust mutexes
| * lib, irmd, ipcp: robust mutexesdimitri staessens2016-06-2115-744/+614
|/ | | | | | | | Update to POSIX 200112L to allow use of robust mutexes in the shm_du_map. Removed the implementation of the rw_lock in favor of pthread_rwlock_t. Placeholder for the shm_du_map_sanitize function.
* Merged in sandervrijders/ouroboros/be (pull request #134)dimitri staessens2016-06-2026-39/+87
|\ | | | | | | build: Change install directories and set correct permissions
| * lib, irmd: Change sockets and shm pathSander Vrijders2016-06-203-3/+5
| | | | | | | | | | | | Reverting from previous commit. Even when running Ouroboros sandboxed, the sockets and shared memory should be created in the default system paths.
| * Merge remote-tracking branch 'upstream/be' into beSander Vrijders2016-06-201-22/+183
| |\ | |/ |/|
* | Merged in sandervrijders/ouroboros/be-fast-llc (pull request #133)dimitri staessens2016-06-201-22/+183
|\ \ | | | | | | | | | ipcpd: Adds RX_RING and TX_RING in shim-eth-llc
| * | ipcpd: Adds RX_RING and TX_RING in shim-eth-llcSander Vrijders2016-06-201-22/+183
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This adds the RX_RING and TX_RING socket options to the shim-eth-llc for faster transmission and reception. On systems where these options are not available the old method of sending and receiving is used. Further optimization would be creating and assigning a read/write thread per CPU core, but that becomes very platform specific, and is not required in the short term. Fixes #10
| | * build: Change install directories and set correct permissionsSander Vrijders2016-06-2026-39/+85
| |/ |/| | | | | | | | | | | | | | | This sets the correct install directories for all the binaries, library and header files. It also sets the right permissions on the sockets and shared memory so that regular users can also use the ouroboros library. Root privileges are required to run the irmd. Fixes #7
* | Merged in dstaesse/ouroboros/be-pipe (pull request #132)Sander Vrijders2016-06-191-0/+1
|\ \ | |/ |/| | | irmd: fix erroneus SIGPIPE log
| * irmd: fix erroneus SIGPIPE logdimitri staessens2016-06-191-0/+1
| | | | | | | | | | | | | | The IRMd would always report a SIGPIPE because of a missing break statement. Close #9
* | Merged in dstaesse/ouroboros/be-cleanup-flows (pull request #131)Sander Vrijders2016-06-191-4/+14
|\ \ | |/ |/| | | irmd: improved cleanup of flows
| * irmd: improved cleanup of flowsdimitri staessens2016-06-191-4/+14
|/ | | | | If the AP exits, the IRMd will deallocate the flow. If an IPCP dies, the IRMd will remove the stale resources.
* Merged in dstaesse/ouroboros/be-cleanup-flows (pull request #130)Sander Vrijders2016-06-181-1/+11
|\ | | | | | | irmd: cleanup of flows
| * irmd: cleanup of flowsdimitri staessens2016-06-181-1/+11
|/ | | | | Port_id's on pending flows that time out are now released. Flows that are stale because one of the parent processes exited are removed.
* Merged in dstaesse/ouroboros/be-irmd-startup (pull request #129)Sander Vrijders2016-06-173-20/+36
|\ | | | | | | irmd, lib: use shm_du_map as lockfile.
| * irmd, lib: use shm_du_map as lockfile.dimitri staessens2016-06-173-20/+36
| | | | | | | | | | | | | | | | | | | | | | | | Added the pid of the irmd to the shm_du_map. The IRMd will check for an existing shm_du_map. If there is an existing file, it will exit if the owner IRMd is running or remove it if the owner IRMd is not running. Also simplifies calculation of the shm_du_map pointers and corrects exiting calls for the IRMd. Fixes #8.
* | Merged in dstaesse/ouroboros/be-cleanup-flows (pull request #128)Sander Vrijders2016-06-173-7/+5
|\| | | | | | | ipcpd: fixed missing unlock in shim UDP
| * Merge branch 'be' of bitbucket.org:ouroboros-rina/ouroboros into ↵dimitri staessens2016-06-160-0/+0
| |\ | |/ |/| | | be-cleanup-flows
* | Merged in dstaesse/ouroboros/be-cleanup-flows (pull request #127)Sander Vrijders2016-06-162-7/+61
|\ \ | | | | | | | | | irmd: clean up stale pending flows
| | * tools: fixed application shutdowndimitri staessens2016-06-162-6/+0
| | | | | | | | | | | | Tools would do a double ap_fini when an error occurred.
| | * ipcpd: fixed missing unlock in shim UDPdimitri staessens2016-06-161-1/+5
| |/ | | | | | | Unlock missing when compiled without DNS support.
| * irmd: clean up stale pending flowsdimitri staessens2016-06-162-7/+61
|/ | | | | | | Adds a thread that cleans up stale pending flows. Compile time option IRMD_FLOW_TIMEOUT allows setting the timeout period. Default timeout is 5 seconds. The thread wakes up 20 times per period to check the flows.
* Merged in dstaesse/ouroboros/be-graceful-fail-dev (pull request #126)Sander Vrijders2016-06-162-1/+5
|\ | | | | | | ipcpd: fixed locking and cleanup
| * ipcpd: fixed locking and cleanupdimitri staessens2016-06-162-1/+5
|/ | | | | The ipcpds didn't unlock the flows lock when the dst_name is unbeknownst to the IRMd.
* Merged in sandervrijders/ouroboros/be (pull request #125)dimitri staessens2016-06-141-4/+7
|\ | | | | | | ipcpd: Fix wrong length in shim-eth-llc
| * ipcpd: Fix wrong length in shim-eth-llcSander Vrijders2016-06-141-4/+7
|/ | | | | | | The shim Ethernet with LLC was using the frame length in the header of the 802.3 frame, which contained a wrong value when sent over the wire. Probably the kernel filled in a wrong value. Now it uses the length as reported by recv.
* Merged in sandervrijders/ouroboros/be-llc (pull request #124)dimitri staessens2016-06-142-6/+5
|\ | | | | | | Be llc
| * build: Change release directorySander Vrijders2016-06-141-1/+1
| | | | | | | | | | The release build was being installed sandboxed. Now it is installed system-wide.
| * ipcpd: Remove source AP name from protobuf messageSander Vrijders2016-06-141-5/+4
| | | | | | | | | | The source AP name was still present in the protobuf message the shim-eth-llc uses.
* | Merged in sandervrijders/ouroboros/be-llc (pull request #123)dimitri staessens2016-06-1413-17/+1251
|\| | | | | | | ipcpd: Adds a shim over IEEE 802.2 over IEEE 802.3
| * ipcpd: Remove source AP name from shim-eth-llcSander Vrijders2016-06-141-9/+2
| | | | | | | | | | This removes the source AP name from all shim-eth-llc flow allocation operations, since it was removed from flow allocation by 6271d09bd.
| * Merge remote-tracking branch 'upstream/be' into be-llcSander Vrijders2016-06-1427-511/+497
| |\ | |/ |/|
* | Merged in dstaesse/ouroboros/be-api (pull request #122)Sander Vrijders2016-06-1427-511/+497
|\ \ | | | | | | | | | lib, irmd, tools, ipcpd: updates to dev API.
| * | Fixed comments on #122dimitri staessens2016-06-143-7/+4
| | |
| * | ipdpd: fixed flow deallocation in local ipcpddimitri staessens2016-06-141-1/+3
| | | | | | | | | | | | | | | Now correctly deallocates the local fd if the remote already deallocated the flow.