Commit message (Collapse) | Author | Age | Files | Lines | ||
---|---|---|---|---|---|---|
... | ||||||
| * | | | lib: dev.c: added locking | dimitri staessens | 2016-05-14 | 2 | -37/+179 | |
| | |/ | |/| | | | | | | | | | | Locking is required for multi-threaded applications. Flows are locked separately. Read/Write locks are used for concurrent reads. | |||||
* | | | Merged in dstaesse/ouroboros/be-udp (pull request #82) | Sander Vrijders | 2016-05-14 | 3 | -109/+387 | |
|\ \ \ | |/ / |/| | | | | | Be udp | |||||
| * | | ipcpd: shim-udp: log error when failed sending SDU | dimitri staessens | 2016-05-14 | 1 | -1/+2 | |
| | | | ||||||
| * | | Merge branch 'be' of bitbucket.org:ouroboros-rina/ouroboros into be-udp | dimitri staessens | 2016-05-14 | 0 | -0/+0 | |
| |\ \ | |/ / |/| | | ||||||
* | | | Merged in dstaesse/ouroboros/be-rw_lock (pull request #80) | dimitri staessens | 2016-05-14 | 4 | -0/+170 | |
|\ \ \ | |_|/ |/| | | | | | lib: implementation of read/write locks | |||||
| * | | Merge branch 'be' of bitbucket.org:ouroboros-rina/ouroboros into be-rw_lock | dimitri staessens | 2016-05-14 | 1 | -5/+4 | |
| |\ \ | |/ / |/| | | ||||||
* | | | Merged in dstaesse/ouroboros/be (pull request #83) | dimitri staessens | 2016-05-14 | 1 | -5/+4 | |
|\ \ \ | | | | | | | | | | | | | lib: shm_ap_rbuff: removed bad memory allocation | |||||
| * | | | lib: shm_ap_rbuff: removed bad memory allocation | dimitri staessens | 2016-05-14 | 1 | -5/+4 | |
|/ / / | | | | | | | | | | | | | moved a malloc so there is no malloc/free when there is no data to be read from the shm_ap_rbuff. | |||||
| | * | ipcpd: shim-udp: complete locking | dimitri staessens | 2016-05-14 | 4 | -114/+390 | |
| |/ | | | | | | | | | | | | | Added necessary locks for the shim-udp. This PR also improves thread management, the main thread now starts a mainloop thread, which spawns sdu handler threads when it the IPCP is enrolled. If the IPCP exits the enrolled state, the sdu loop is cancelled. | |||||
| * | lib: fixed a bug in the rw_lock | dimitri staessens | 2016-05-14 | 1 | -3/+5 | |
| | | | | | | | | Locking the main mutex should happen while the counter is locked. | |||||
| * | lib: implementation of read/write locks | dimitri staessens | 2016-05-13 | 4 | -0/+168 | |
|/ | | | | | This adds read/write locks, allowing for concurrent reads on the locked datastructure. This is needed for the fast path. | |||||
* | Merged in dstaesse/ouroboros/be-rbuff (pull request #79) | Sander Vrijders | 2016-05-12 | 1 | -5/+0 | |
|\ | | | | | | | lib: shm_ap_rbuff: small fixes | |||||
| * | lib: shm_ap_rbuff: small fixes | dimitri staessens | 2016-05-12 | 1 | -5/+0 | |
|/ | | | | Unnecessary filename string removed. Formatting fix. | |||||
* | Merged in dstaesse/ouroboros/be-irmd (pull request #78) | Sander Vrijders | 2016-05-12 | 1 | -1/+6 | |
|\ | | | | | | | irmd: fixed bad locking and added cleanup | |||||
| * | irmd: fixed bad locking and added cleanup | dimitri staessens | 2016-05-12 | 1 | -1/+6 | |
|/ | | | | flow_alloc_res had missing cleanup, added missing unlock. | |||||
* | Merged in dstaesse/ouroboros/be-flow_opts (pull request #77) | Sander Vrijders | 2016-05-12 | 1 | -0/+1 | |
|\ | | | | | | | include: added flows.h to CMakelists | |||||
| * | include: added flow.h to CMakelists | dimitri staessens | 2016-05-12 | 1 | -0/+1 | |
| | | ||||||
* | | Merged in dstaesse/ouroboros/be-flow_opts (pull request #76) | Sander Vrijders | 2016-05-12 | 4 | -10/+38 | |
|\| | | | | | | | lib: dev: implementation of flow_cntl | |||||
| * | dev: fixed wrong bracket placement | dimitri staessens | 2016-05-12 | 1 | -2/+1 | |
| | | ||||||
| * | lib: dev: implementation of flow_cntl | dimitri staessens | 2016-05-12 | 4 | -10/+39 | |
|/ | | | | | allows setting the oflags to make flow_read and flow_write blocking or non-blocking (FLOW_O_NONBLOCK). | |||||
* | Merged in dstaesse/ouroboros/irmd-cleanup (pull request #75) | Sander Vrijders | 2016-05-12 | 1 | -12/+115 | |
|\ | | | | | | | irmd: cleanup | |||||
| * | irmd: cleanup | dimitri staessens | 2016-05-12 | 1 | -12/+115 | |
|/ | | | | improved cleanup when killing the IRMd. | |||||
* | Merged in dstaesse/ouroboros/udp-static (pull request #74) | Sander Vrijders | 2016-05-11 | 1 | -98/+40 | |
|\ | | | | | | | ipcpd: threading and cleanup of ipcpd_udp | |||||
| * | ipcpd: threading and cleanup of ipcpd_udp | dimitri staessens | 2016-05-11 | 1 | -98/+40 | |
|/ | | | | | The shim_udp now correctly destroys its ringbuffer on exit. Now handles sdu's in a single thread using select() with a 10 us timeout. | |||||
* | Merged in sandervrijders/ouroboros/be (pull request #73) | Sander Vrijders | 2016-05-10 | 1 | -2/+2 | |
|\ | | | | | | | ipcpd: Fix unitialized value | |||||
| * | ipcpd: Fix unitialized value | Sander Vrijders | 2016-05-10 | 1 | -2/+2 | |
|/ | | | | | A value that was unitialized was being treated as an error in the release build with gcc. | |||||
* | Merged in sandervrijders/ouroboros/be (pull request #72) | dimitri staessens | 2016-05-10 | 5 | -68/+240 | |
|\ | | | | | | | ipcpd: Allow disabling of DNS | |||||
| * | ipcpd: Add nslookup to shim UDP | Sander Vrijders | 2016-05-10 | 3 | -25/+156 | |
| | | | | | | | | | | This adds nslookup support to the shim UDP, so that a custom DNS server can be queried. | |||||
| * | ipcpd: Allow disabling of DNS | Sander Vrijders | 2016-05-10 | 5 | -43/+84 | |
|/ | | | | | | This allows someone to disable the use of DNS in the shim UDP. It also adds a config file specific for the shim UDP (which holds the nsupdate location). Certain defines were also moved to the global config file. | |||||
* | Merged in dstaesse/ouroboros/irmd-threads (pull request #70) | Sander Vrijders | 2016-05-10 | 3 | -137/+321 | |
|\ | | | | | | | irmd: use pthread_cond_wait | |||||
| * | irmd: added dedicated locks for signaling | dimitri staessens | 2016-05-10 | 1 | -9/+40 | |
| | | | | | | | | | | it's more robust to use dedicated locks for pthread_cond_signal so no other threads can be waiting for the mutex. | |||||
| * | irmd: fixed potential data races | dimitri staessens | 2016-05-10 | 1 | -8/+10 | |
| | | | | | | | | | | bmp_allocate should be called under lock. Helgrind does not give warnings anymore during flow allocation. | |||||
| * | IRMd: set number of thread back to 3 (minimum) | dimitri staessens | 2016-05-10 | 1 | -1/+1 | |
| | | ||||||
| * | irmd: introduced locking | dimitri staessens | 2016-05-10 | 3 | -142/+287 | |
| | | | | | | | | | | This commit adds locking to the IRMd with a single global lock. It also fixes some issues in cleaning up the daemon. | |||||
| * | Merge branch 'be' of bitbucket.org:ouroboros-rina/ouroboros into irmd-threads | dimitri staessens | 2016-05-10 | 3 | -9/+9 | |
| |\ | |/ |/| | ||||||
* | | Merged in sandervrijders/ouroboros/be (pull request #71) | dimitri staessens | 2016-05-10 | 3 | -9/+9 | |
|\ \ | | | | | | | | | | Fixes some log messages | |||||
| * | | tools: Fix log messages in echo app | Sander Vrijders | 2016-05-10 | 2 | -8/+8 | |
| | | | | | | | | | | | | | | | This fixes bad indentation and log messages without a newline in the echo application. | |||||
| * | | tools: Fix log message in irm tool | Sander Vrijders | 2016-05-10 | 1 | -1/+1 | |
| | | | | | | | | | | | | | | | A wrong log message was being printed if the bootstrap command was called with a wrong parameter. | |||||
| | * | irmd: use pthread_cond_wait | dimitri staessens | 2016-05-09 | 1 | -23/+29 | |
| |/ |/| | | | | | | | | | The initial implementation looped on a nanosleep to wait for an incoming flow allocation request. This implementation is now corrected with the necessary locks and the thread sleeps on a condition variable. | |||||
* | | Merged in dstaesse/ouroboros/be-rm-shm-test (pull request #69) | Sander Vrijders | 2016-05-09 | 3 | -197/+1 | |
|\ \ | |/ |/| | | | lib/test: removed the test for the shm_du_map | |||||
| * | lib/test: removed the test for the shm_du_map | dimitri staessens | 2016-05-09 | 3 | -197/+1 | |
|/ | | | | | | | The test had a synchronisation issue. Due to rebuild of the shm_du_map for random access, there was also a hack in the shm_du_map specifically to run this test. Because of this hack, the decision was made to drop this test. | |||||
* | Merged in dstaesse/ouroboros/be-fast-path (pull request #68) | dimitri staessens | 2016-05-08 | 1 | -0/+1 | |
|\ | | | | | | | ipcpd-udp: fixed missing close | |||||
| * | ipcpd-udp: fixed missing close | dimitri staessens | 2016-05-08 | 1 | -0/+1 | |
| | | | | | | | | caused the shim to run out of file descriptors fast... | |||||
* | | Merged in dstaesse/ouroboros/be-fast-path (pull request #67) | Sander Vrijders | 2016-05-08 | 1 | -3/+6 | |
|\| | | | | | | | lib: fixed enormous memory leak in shm_ap_rbuff | |||||
| * | lib: fixed enormous memory leak in shm_ap_rbuff | dimitri staessens | 2016-05-08 | 1 | -3/+6 | |
| | | | | | | | | thanks Sander ;) | |||||
* | | Merged in dstaesse/ouroboros/be-fast-path (pull request #66) | Sander Vrijders | 2016-05-08 | 10 | -76/+73 | |
|\| | | | | | | | lib: changed port_id to int | |||||
| * | lib: changed port_id to int | dimitri staessens | 2016-05-08 | 10 | -76/+73 | |
| | | | | | | | | | | returning -1 as uint32_t leads to bugs. also changed types in GPB to sint to use zigzag encoding. | |||||
* | | Merged in dstaesse/ouroboros/be-fast-path (pull request #65) | Sander Vrijders | 2016-05-08 | 28 | -773/+1859 | |
|\| | | | | | | | irmd: flow allocation and fast path | |||||
| * | lib: changed SHM_AP_RBUFF to SHM_AP_RBUFF_PREFIX | dimitri staessens | 2016-05-08 | 2 | -5/+5 | |
| | | | | | | | | This better reflects the use as the pid is appended to that name. | |||||
| * | lib/irmd/ipcpd/tools: fixes comments on eb9f443 | dimitri staessens | 2016-05-08 | 5 | -21/+38 | |
| | |