|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| |\  
| | 
| | 
| | | ipcpd: normal: Add alternate hop PFF | 
| | | 
| | 
| | 
| | 
| | | This adds a PFF that returns an alternate hop as next hop in case the
hop that would have been returned is down. | 
| |/  
|   
|   
|   
|   
|   
|   
|   
| | This revises the sdu_scheduler of the normal IPCP to create a
scheduler thread per QoS cube and let the kernel scheduler schedule
them based on a priority. Priorities can be set at build time in a
range of 0-100, which will be mapped onto a suitable priority for the
kernel scheduler. The current scheduler policy is fixed to SCHED_RR
since it is the most suitable scheduler defined by POSIX. | 
| | 
| 
| 
| | This avoids potential data races on rib.fuse. | 
| |\  
| | 
| | 
| | | ipcpd: Handle DHT SDUs in different thread | 
| | | 
| | 
| | 
| | 
| | 
| | 
| | | The DHT will now spawn a thread when receiving SDUs to avoid
starvation of sdu scheduler threads.
Also fixes some locking issues. | 
| |/  
|   
|   
|   
| | This turns the PDU Forwarding Function of the IPCP into a policy. For
now only the simple PFF policy is available. | 
| |\  
| | 
| | 
| | | ipcpd: Refuse query when DHT not in running state | 
| | | |  | 
| |/ |  | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | The DHT will now enroll or sync when a data transfer connection is
added. This avoids the need to create a temporary data transfer
connection during enrollment (and speeds it up considerably).
The notifier system was modified to take an opaque pointer to the
object that registers as a parameter. | 
| | 
| 
| 
| 
| 
| 
| 
| | This adds the flow down event to Ouroboros. In the shim-eth-llc, a
netlink socket is opened which listens to device up/down events. For
each event the flow is then adjusted with fccntl to notify the user
the flow is down or back up again. In the normal IPCP an event is
thrown if a write reports that the flow is down. | 
| | |  | 
| | 
| 
| 
| 
| 
| 
| | This adds a virtual RIB that is accessible as a filesystem that is
accessed through a fuse mountpoint (configurable , default is
/tmp/ouroboros). Currently, each IPCP will export its link state
database. | 
| | 
| 
| 
| 
| 
| 
| 
| | This removes the RIB as a datastructure and CDAP as the protocol
between IPCPs. CDAP, the rib and related sources are deprecated. The
link-state protocol policy is udpated to use its own protocol based on
a simple broadcast strategy along a tree. The neighbors struct is
deprecated and moved to the library as a generic notifier component. | 
| |\  
| | 
| | 
| | | ipcpd: Shutdown DHT work thread first at destroy | 
| | | 
| | 
| | 
| | | This prevents a potential deadlock on the wrlock. | 
| |/  
|   
|   
|   
| | When enroll or bootstrap failed, finalize_components could be called
twice, resulting in double frees or use-after-free. | 
| | 
| 
| 
| 
| | This avoids a redefinition of a typedef which is a C11 feature, and
thus not supported by clang when the c89 switch is enabled. | 
| | 
| 
| 
| 
| 
| 
| | This will remove the dst parameter from enroll_boot, since it was only
being used in logging. It also turns some other debug logs into info
logs, and makes the component names as they are used in logs all
lowercase. | 
| | |  | 
| | |  | 
| |\  
| | 
| | 
| | | ipcpd: Fix state in dht lookup at lookup_wait | 
| | | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | | The correct state was returned but not set internally in the
lookup_struct, causing lookup_wait to return a lookup in LU_PENDING if
the wait timedout.
This also unlocks the IRMd during register calls and fixes some
cleanup if lookup_wait gets interrupted.
Fixes #48 | 
| |\ \  
| |/  
|/|   
| | | lib, ipcpd: Fix e-mail addresses in protobuf files | 
| | | 
| | 
| | 
| | | This fixes the wrong e-mail addresses in the protobuf files. | 
| |/ |  | 
| | 
| 
| 
| | This fixes several bugs as reported by the clang static analyzer. | 
| | |  | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | This enables user-written tools to instruct IPCPs to establish and
tear down connections (a.k.a. adjacencies) between its internal
components (Management and Data Transfer).
For more info, do "irm ipcp connect" or "irm ipcp disconnect" on the
command line.
This commit exposes a deletion bug in the RIB where FSO's fail to
unpack/parse. This will be fixed when the RIB is deprecated. | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | The graph adjacency manager has been deprecated in favor of providing
an external interface into the connectivity manager so that
adjacencies can be controlled from the command line, user scripts or
user applications.
The gam and its associated policies were removed from the normal IPCP
and the IRM configuration tools. The "/members" part of the RIB was
deprecated. Removal of the gam means that initial connectivity based
on changes in the RIB can't be provided, so some changes were
required throughout the normal IPCP.
The enrollment procedure was revised to establish its own
connectivity. First, it gets boot information from a peer by
establishing a connection to the remote enrollment component and
downloading the IPCP configuratoin. This is now done using its own
protocol buffers message in anticipation of deprecation of the RIB and
CDAP for communication within a DIF.
After the boot information is downloaded, it establishes a data
transfer flow for enrolling the directory (DHT). After the DHT has
enrolled, it signals the peer to that enrollment is done, and the data
transfer connection is torn down.
Signaling connections is done via the nbs struct, which is now passed
to the connmgr, which enables control of the connectivity graph from
external sources. | 
| | 
| 
| 
| 
| | This fixes several memleaks as reported by valgrind. It also fixes
some calls to close() with -1. | 
| | 
| 
| 
| | The removal of the mutex and signal in 198b709 was a mistake. | 
| | |  | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | This revises the build system to have configuration per system
component. System settings can now be set using cmake.
The standard compliance defines were removed from configuration header
and are set in the sources where needed. Also some small code
refactors, such as moving the data for shims out of the ipcp structure
to the respective shims were performed. | 
| | |  | 
| | |  | 
| | |  | 
| |\  
| | 
| | 
| | | lib: Fix instability in threadpool manager | 
| | | 
| | 
| | 
| | 
| | 
| | | The DHT failed when receiving multiple responses in a short
timeframe. The lookup struct now keeps track of the number of
outstanding requests. | 
| |/ |  | 
| | 
| 
| 
| | This fixes several assignments to the wrong enum type. | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | This adds support for libgcrypt. If at least version 1.7.0 of
libgcrypt is present, it may be used for secure random number
generation and is used for hashing in the irmd/ipcp.
The hash definitions are moved to the internal hash.h header, and
defined independently of the hashes that are defined as part of the
directory policy for the normal IPCP. The translation is moved from
the IRMd to ipcpd/ipcp.h. The bootstrap call from the IRMd expects the
IPCP to return the correct hash algorithm with a dif_info struct,
which is in line with the behavior of the enroll call.
This also improves how some platform checks in the build system are
handled. | 
| | |  | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | The DHT lookup would stop if a node returned no new useful information
(i.e. the value for the key or unknown nodes closer to the key)
without waiting for other pending requests that could still return
useful information. Now it correctly tracks the number of outstanding
requests or returns if it doesn't get a response for KAD_T_RESP
seconds. This fixes multi-hop flow allocation over the normal. | 
| |\ |  | 
| | | 
| | 
| | 
| | 
| | 
| | | This fixes pthread_condtimedwaits in the flow allocator of all IPCPs
that had bad deadlines set (the interval instead of the actual
absolute time). | 
| | | |  | 
| | | 
| | 
| | 
| | 
| | 
| | 
| | 
| | | The scheduler in the normal IPCP is now multithreaded. While useful in
itself for scalability, it currently solves thread starvation in case
of executing post_sdu operations that may require a response. This
could be further revised in the future to split the SDU handling
threads from the component tasks. | 
| | | |  |