IPv4 cleanup: Difference between revisions
		
		
		
		
		
		Jump to navigation
		Jump to search
		
				
		
		
	
| (11 intermediate revisions by the same user not shown) | |||
| Line 1: | Line 1: | ||
| {{TOC}} | |||
| This page lists things that need to be done for IPv4 and routing protocols. | |||
| == API issues == | |||
| # Public API needed to look at or manipulate the ARP cache | |||
| #* '''Proposal:''' Defer to ns-3.6 or later | |||
| # <s>Ipv4StaticRouting:  split into unicast and multicast separate objects?  Or just remove Impl class?</s> | |||
| # <s>No way to remove an IP address from an interface | |||
| #* '''Proposal:''' Fix this for ns-3.5.  bugfix patch is in tracker.</s> | |||
| # Ipv4RoutingProtocol::RouteOutput() may require Ptr<Packet> for supporting Nix vector routing (and perhaps other use cases) | |||
| #* '''Proposal:''' Fix this for ns-3.5.  | |||
| # Ipv4StaticRouting multicast mrouted API does not support VIFs and TTLs | |||
| #* For reference, see http://tldp.org/HOWTO/Multicast-HOWTO-7.html, MRT_ADD_MFC, MRT_DEL_MFC | |||
| #* '''Proposal:''' Defer to ns-3.6 or later  | |||
| # GlobalRouteManager static API could be moved to a helper API | |||
| #* '''Proposal:''' ?? how to deal with API breakage | |||
| # Tunneling net device (Ipv4 in ipv4) will require a public entry point into Ipv4 so that packets can be looped back through | |||
| #* '''Proposal:''' Defer class Ipv4's API extension until we have working example | |||
| # Ipv4RoutingHelper API could be created and delegated the task of creating routing protocols, and passed into InternetStackHelper | |||
| # Multicast API for hosts (setting group membership, setting TTL, setting loopback behavior) needs to be completed | |||
| #* '''Proposal:''' Defer to ns-3.6 or later. | |||
| == Bugs and cleanup == | |||
| * IpForward attribute (ipv4.cc) doesn't do anything (bug 63) | |||
| * <s>Ipv4L3Protocol needs a unit test or a module test</s> <- this has been started | |||
| * <s>some XXXs remain around the multi-address (ip aliasing) code | |||
| ** Ipv4L3Protocol::LocalDeliver | |||
| ** IPv4L3Protocol::IpForward | |||
| ** ArpL3Protocol::Receive | |||
| ** ArpL3Protocol::SendArpRequest | |||
| ** ArpL3Protocol::SendArpReply | |||
| ** Ipv4StaticRoutingImpl::LookupStatic | |||
| ** Ipv4EndPointDemux::Lookup</s> | |||
| * case 4) of Ipv4L3Protocol::Send() is not implemented, but this case is for currently non-existent on-demand ad-hoc routing protocol | |||
| ** n.b. this may be an invalid case anyway | |||
| * should some of the routing protocol interfaces be aggregated to node, or to Ipv4ListRouting?  Not clear. | |||
| * TcpL4Protocol::Send () probably needs to be passed a route from TcpSocketImpl() instead of looking up the route again | |||
| * Ipv4StaticRoutingImpl is not robust enough to be added as a standalone routing protocol (e.g. for hosts and not routers, to perform local delivery). | |||
| ==  | == New features needed == | ||
| * Multicast | |||
| ** add VIF (virtual interface) and better TTL handling logic, for multicast forwarding | |||
| ** for multicast hosts, the API for group membership, TTL, loopback (multicast sockets) | |||
| * Ability to dump routing tables for logging/output | |||
| * helpers to provide iproute2-like interface | |||
| *  | |||
| *  | |||
| *  | |||
| *  | |||
Latest revision as of 06:50, 22 June 2009
Main Page - Roadmap - Summer Projects - Project Ideas - Developer FAQ - Tools - Related Projects
HOWTOs - Installation - Troubleshooting - User FAQ - Samples - Models - Education - Contributed Code - Papers
This page lists things that need to be done for IPv4 and routing protocols.
API issues
- Public API needed to look at or manipulate the ARP cache
- Proposal: Defer to ns-3.6 or later
 
- Ipv4StaticRouting: split into unicast and multicast separate objects? Or just remove Impl class?
- No way to remove an IP address from an interface- Proposal: Fix this for ns-3.5. bugfix patch is in tracker.
 
- Ipv4RoutingProtocol::RouteOutput() may require Ptr<Packet> for supporting Nix vector routing (and perhaps other use cases)
- Proposal: Fix this for ns-3.5.
 
- Ipv4StaticRouting multicast mrouted API does not support VIFs and TTLs
- For reference, see http://tldp.org/HOWTO/Multicast-HOWTO-7.html, MRT_ADD_MFC, MRT_DEL_MFC
- Proposal: Defer to ns-3.6 or later
 
- GlobalRouteManager static API could be moved to a helper API
- Proposal: ?? how to deal with API breakage
 
- Tunneling net device (Ipv4 in ipv4) will require a public entry point into Ipv4 so that packets can be looped back through
- Proposal: Defer class Ipv4's API extension until we have working example
 
- Ipv4RoutingHelper API could be created and delegated the task of creating routing protocols, and passed into InternetStackHelper
- Multicast API for hosts (setting group membership, setting TTL, setting loopback behavior) needs to be completed
- Proposal: Defer to ns-3.6 or later.
 
Bugs and cleanup
- IpForward attribute (ipv4.cc) doesn't do anything (bug 63)
- Ipv4L3Protocol needs a unit test or a module test<- this has been started
- some XXXs remain around the multi-address (ip aliasing) code- Ipv4L3Protocol::LocalDeliver
- IPv4L3Protocol::IpForward
- ArpL3Protocol::Receive
- ArpL3Protocol::SendArpRequest
- ArpL3Protocol::SendArpReply
- Ipv4StaticRoutingImpl::LookupStatic
- Ipv4EndPointDemux::Lookup
 
- case 4) of Ipv4L3Protocol::Send() is not implemented, but this case is for currently non-existent on-demand ad-hoc routing protocol
- n.b. this may be an invalid case anyway
 
- should some of the routing protocol interfaces be aggregated to node, or to Ipv4ListRouting? Not clear.
- TcpL4Protocol::Send () probably needs to be passed a route from TcpSocketImpl() instead of looking up the route again
- Ipv4StaticRoutingImpl is not robust enough to be added as a standalone routing protocol (e.g. for hosts and not routers, to perform local delivery).
New features needed
- Multicast
- add VIF (virtual interface) and better TTL handling logic, for multicast forwarding
- for multicast hosts, the API for group membership, TTL, loopback (multicast sockets)
 
- Ability to dump routing tables for logging/output
- helpers to provide iproute2-like interface