| Commit message (Collapse) | Author | Age | Files | Lines | 
| ...  |  | 
| | | 
| | 
| | 
| |  | 
This fixes 2 wrong unlocks in the bind API method.
 | 
| |/  
|   
|   
|   
|   
|    | 
This will invoke the bind operation when using the irm tool to create
a new IPCP. The new IPCP will be bound to the IPCP name as specified
by the administrator.
 | 
| |\  
| | 
| | 
| |  | 
ipcpd: Add threadpool for main loop
 | 
| | | 
| | 
| | 
| | 
| | 
| | 
| |  | 
This adds a threadpool for the main loop of the IPCPs. Before there
was a single thread handling each request, which could result in
starvation since performing name queries at the same time as enrolling
a normal IPCP was impossible.
 | 
| |\ \  
| |/  
|/|   
| |    | 
lib: API for accepting flows with QoS
 | 
| | |  | 
 | 
| |\ \  
| | | 
| | | 
| | |  | 
lib, irmd, ipcpd: Add name querying to IPCPs
 | 
| | | | 
| | | 
| | | 
| | | 
| | | 
| | | 
| | | 
| | | 
| | |  | 
This adds the ability to query IPCPs if a name can be reached through
them, e.g. if a name is available in a DIF. This means that in the
shim-udp a DNS query is performed, in the shim-eth-llc an ARP-like
query has been added, in the local a check is done to see if the name
is registered, and in the normal currently no application is reachable
through it.
 | 
| | | | 
| | | 
| | | 
| | | 
| | | 
| | |  | 
In the rewrite of the flow allocator for per-port ring buffers, the
messages were removed because they were not accurate anymore. This
adds messages when a port is allocated.
 | 
| | |/  
|/|   
| |   
| |   
| |    | 
Fixes memory leaks associated with the dif_name (which doesn't need to
be maintained in shim DIFs) and the fqueue for the N + 1 flows.
 | 
| |\ \   | 
 | 
| | |\ \  
| | |/  
| |/|   
| | |    | 
tools: Fix memory leaks in oping
 | 
| | |\ \  
| | | | 
| | | | 
| | | |  | 
lib: Stabilise flow allocation
 | 
| | | | | 
| | | | 
| | | | 
| | | | 
| | | |  | 
Remote requests for a flow that's locally deallocated should not
generate an error. Sending messages should not be under lock.
 | 
| | | | | 
| | | | 
| | | | 
| | | |  | 
This solves some potential data races in the shims.
 | 
| | |_|/  
|/| |    | 
 | 
| | |/  
|/|    | 
 | 
| |/  
|   
|   
|   
|   
|   
|    | 
Deallocation was reverted to a synchronoous operation between the AP,
IRMd and IPCP in order to avoid inconsistent states of the port_id.
Fixes some memory leaks, particularly the shm_flow_set is now closed
upon deallocation.
 | 
| | 
| 
| 
| 
|  | 
The default flow options were not set when a flow allocation request
arrives remotely. This went unnoticed due to a previous bug.
 | 
| | 
| 
| 
| 
|  | 
gethostbyname is included in POSIX 2001. Ouroboros requires at least
POSIX 2001 and recommends POSIX 2008 for stable builds.
 | 
| |  | 
 | 
| |  | 
 | 
| | 
| 
| 
|  | 
The rdrbuff was previously closed before the remaining SDUs were removed.
 | 
| | 
| 
| 
| 
|  | 
An untested (and wrong) modification to the fqueue was mistakenly
added to a previous commit. This corrects the bad code.
 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
|  | 
The BSD compiler requires explicit initializers for all fields with
the -Wmissing-field-initializers flag enabled
On branch be-fix-build # Changes to be committed: # modified:
src/irmd/main.c # modified: src/tools/irm/irm.c # modified:
src/tools/irm/irm_bind.c # modified: src/tools/irm/irm_ipcp.c #
modified: src/tools/irm/irm_unbind.c # # Untracked files: #
killouroboros.sh # start.sh #
 | 
| | 
| 
| 
|  | 
FLOW_O_RDONLY is 0, so the previous statement would always be false.
 | 
| | 
| 
| 
| 
| 
|  | 
CheckLibraryExists was not included. Apparently the
CHECK_FUNCTION_EXISTS call fails with the strict prototyping flag
turned on.
 | 
| | 
| 
| 
| 
|  | 
This has the code checked with -Wcast-qual and -Wconversion flags.
These flags were removed because SWIG generated code fails.
 | 
| | 
| 
| 
| 
|  | 
This reduces the risk for some bugs, for instance due to
signed/unsigned mismatches and unused variables.
 | 
| |\  
| | 
| | 
| |  | 
lib: Demultiplex the fast path
 | 
| | | 
| | 
| | 
| | 
| |  | 
This stabilises flow allocation now that the rbuffs are created upon
flow allocation. Only the IRMd can sync this process sufficiently.
 | 
| | | 
| | 
| | 
| | 
| | 
| | 
| | 
| |  | 
The fast path will now use an incoming ring buffer per flow per
process. This necessitated the development of a new method for the
asynchronous io call, which is now based on an event queue system for
scalability (fqueue). The ipcpd's and tools have been updated to this
API.
 | 
| |/  
|   
|   
|   
|    | 
There was no check to see if the normal IPCP was enrolled or not when
a flow allocation request is done.
 | 
| | 
| 
| 
| 
| 
| 
|  | 
Added the missing implementation of setting read/write options for
flows. This allows applications to block the fast path for
remotes. IPCPs can use this to block the fast path for the N + 1 flow
when receiving remote deallocation requests.
 | 
| |  | 
 | 
| | 
| 
| 
|  | 
The safe copy was not correctly initialised.
 | 
| | 
| 
| 
| 
|  | 
Both the N and N-1 entity must now call flow_dealloc for the port_id
to be released.
 | 
| | 
| 
| 
| 
| 
| 
| 
|  | 
This commit will remove the RMT component from the normal IPCP, as
some of its functionality would else be duplicated in the FMGR. Now
all reading from flows, either N-1 or N+1 is done in the FMGR, then
either passed to the FRCT or a lookup is performed in the PFF (not
there yet) and the PDU is forwarded.
 | 
| |\   | 
 | 
| | | 
| | 
| | 
| | 
| | 
| |  | 
This will allow to finalize deallocating flows until all SDUs have
been processed. Read and write calls will now block when a flow was
deallocated. Replaces NULL checks in the fast path with asserts.
 | 
| | | 
| | 
| | 
| | 
| | 
| |  | 
The struct flow_set can now be accessed in applications as flow_set_t.
Fixes some malformed lines and homogenizes output when receiving bad
SDUs in the oping tool.
 | 
| |/  
|   
|   
|   
|   
|   
|    | 
This is the first version of the fast path bootstrap in the normal
IPCP. It sets up a connection with the other end, and creates the
appropriate data structures. N+1 and N-1 SDUs are read and written and
passed through the right components.
 | 
| |  | 
 | 
| | 
| 
| 
| 
|  | 
Flow deallocation from the application will immediately return (void
call). The IRMd will not send a reply message.
 | 
| | 
| 
| 
| 
|  | 
The SDU's were not correctly removed upon shutdown, peek should be
pop.
 | 
| | 
| 
| 
|  | 
Now correctly handles and drops non-ouroboros traffic.
 | 
| | 
| 
| 
| 
|  | 
Upon deallocation, the remote's SAP was being used to lookup the fd
instead of our own SAP. This resulted in strange behaviour.
 | 
| | 
| 
| 
| 
| 
|  | 
Some locks were taken at an inappropriate time, causing the
shim-eth-llc to block indefinitely upon shutdown and causing flow
allocation to halt since a response could never be given.
 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
|  | 
IPCPs can now use ap_init() to initialize the memory. All flows are
accessed using flow descriptors, this greatly simplifies IPCP
development. Reverts the fast path to a single ap_rbuff per process.
Splits lib/ipcp into irmd/ipcp and lib/ipcp-dev.  Adds a lib/shim-dev
holding tailored functions for shims.  Moves the buffer_t to utils.h.
Fixes the shim-eth-llc length field.  Removes the flow from shared.h.
Fixes #4
Fixes #5
 | 
| | 
| 
| 
| 
| 
|  | 
Cupertino's finest don't seem to support a write call with a
filedescriptor that points to a shared memory file. ENOTSUP is not
mentioned in their manpage either. Classic.
 |