This patch enables ARP support for the RT-Proxy Linux device. Incoming ARP replys are delivered to both, the RTnet and the Linux network stack. The RT-Proxy then gets attached to the corresponding RTnet device, rteth0 by default. You can enable this feature with the configure option "--enable-proxy-arp".
Note: this patch requires running "scripts/autogen.sh" Signed-off-by: Wolfang Grandegger <[EMAIL PROTECTED]> Index: rtnet/stack/ipv4/arp.c =================================================================== --- rtnet.orig/stack/ipv4/arp.c +++ rtnet/stack/ipv4/arp.c @@ -25,6 +25,9 @@ #include <stack_mgr.h> #include <ipv4/arp.h> +#ifdef CONFIG_RTNET_ADDON_PROXY_ARP +#include <ipv4/ip_input.h> +#endif /* CONFIG_RTNET_ADDON_PROXY_ARP */ /*** * arp_send: Create and send an arp packet. If (dest_hw == NULL), @@ -174,6 +177,12 @@ int rt_arp_rcv(struct rtskb *skb, struct } out: +#ifdef CONFIG_RTNET_ADDON_PROXY_ARP + if (rt_ip_fallback_handler) { + rt_ip_fallback_handler(skb); + return 0; + } +#endif kfree_rtskb(skb); return 0; } Index: rtnet/addons/rtnetproxy.c =================================================================== --- rtnet.orig/addons/rtnetproxy.c +++ rtnet/addons/rtnetproxy.c @@ -105,6 +105,14 @@ static rtdm_task_t rtnetproxy_thread; static rtdm_sem_t rtnetproxy_sem; +#ifdef CONFIG_RTNET_ADDON_PROXY_ARP +static char* rtdev_attach = "rteth0"; +module_param(rtdev_attach, charp, 0444); +MODULE_PARM_DESC(rtdev_attach, "Attach to the specified RTnet device"); + +struct rtnet_device *rtnetproxy_rtdev; +#endif + /* *********************************************************************** * Returns the next pointer from the ringbuffer or zero if nothing is * available @@ -181,7 +189,10 @@ static inline void send_data_out(struct { struct rtskb *rtskb; +#ifndef CONFIG_RTNET_ADDON_PROXY_ARP struct dest_route rt; + int rc; +#endif struct skb_data_format { @@ -194,7 +205,6 @@ static inline void send_data_out(struct * thus no spaces are allowed! */ struct skb_data_format *pData; - int rc; /* Copy the data from the standard sk_buff to the realtime sk_buff: * Both have the same length. */ @@ -208,6 +218,18 @@ static inline void send_data_out(struct pData = (struct skb_data_format*) rtskb->data; +#ifdef CONFIG_RTNET_ADDON_PROXY_ARP + rtskb->rtdev = rtnetproxy_rtdev; + + /* Call the actual transmit function */ + rtdev_xmit_proxy(rtskb); + + /* The rtskb is freed somewhere deep in the driver... + * No need to do it here. */ + + rtdev_dereference(rtskb->rtdev); + +#else /* !CONFIG_RTNET_ADDON_PROXY_ARP */ /* Determine the device to use: Only ip routing is used here. * Non-ip protocols are not supported... */ rc = rt_ip_route_output(&rt, pData->ip_dst, INADDR_ANY); @@ -244,6 +266,7 @@ static inline void send_data_out(struct kfree_rtskb(rtskb); } +#endif /* !CONFIG_RTNET_ADDON_PROXY_ARP */ } /* ************************************************************************ @@ -456,7 +479,11 @@ static int __init rtnetproxy_init(struct /* Fill in device structure with ethernet-generic values. */ ether_setup(dev); dev->tx_queue_len = 0; +#ifdef CONFIG_RTNET_ADDON_PROXY_ARP + memcpy(dev->dev_addr, rtnetproxy_rtdev->dev_addr, sizeof(dev->dev_addr)); +#else dev->flags |= IFF_NOARP; +#endif dev->flags &= ~IFF_MULTICAST; return 0; @@ -479,6 +506,14 @@ static int __init rtnetproxy_init_module { int err; +#ifdef CONFIG_RTNET_ADDON_PROXY_ARP + if ((rtnetproxy_rtdev = rtdev_get_by_name(rtdev_attach)) == NULL) { + printk("Couldn't attach to %s\n", rtdev_attach); + return -EINVAL; + } + printk("RTproxy attached to %s\n", rtdev_attach); +#endif + /* Initialize the proxy's rtskb pool (JK) */ if (rtskb_pool_init(&rtskb_pool, proxy_rtskbs) < proxy_rtskbs) { rtskb_pool_release(&rtskb_pool); Index: rtnet/configure.ac =================================================================== --- rtnet.orig/configure.ac +++ rtnet/configure.ac @@ -1202,6 +1202,19 @@ if test "$CONFIG_RTNET_ADDON_PROXY_UDP" AC_DEFINE(CONFIG_RTNET_ADDON_PROXY_UDP,1,[rtnetproxy UDP support]) fi +AC_MSG_CHECKING([whether to enable rtnetproxy ARP support]) +AC_ARG_ENABLE(proxy-arp, + AS_HELP_STRING([--enable-proxy-arp], [enable ARP support for IP protocol proxy driver @<:@default=no@:>@]), + [case "$enableval" in + y | yes) CONFIG_RTNET_ADDON_PROXY_ARP=y ;; + *) CONFIG_RTNET_ADDON_PROXY_ARP=n ;; + esac]) +AC_MSG_RESULT([${CONFIG_RTNET_ADDON_PROXY_ARP:-n}]) +AM_CONDITIONAL(CONFIG_RTNET_ADDON_PROXY_ARP,[test "$CONFIG_RTNET_ADDON_PROXY_ARP" = "y"]) +if test "$CONFIG_RTNET_ADDON_PROXY_ARP" = "y"; then + AC_DEFINE(CONFIG_RTNET_ADDON_PROXY_ARP,1,[rtnetproxy ARP support]) +fi + #dnl ====================================================================== #dnl RTDM select (disabled until RTDM actually supports this) -- ------------------------------------------------------------------------- This SF.net email is sponsored by the 2008 JavaOne(SM) Conference Don't miss this year's exciting event. There's still time to save $100. Use priority code J8TL2D2. http://ad.doubleclick.net/clk;198757673;13503038;p?http://java.sun.com/javaone _______________________________________________ RTnet-users mailing list RTnet-users@lists.sourceforge.net https://lists.sourceforge.net/lists/listinfo/rtnet-users