From owner-freebsd-net@FreeBSD.ORG Mon Sep 29 22:17:50 2008 Return-Path: Delivered-To: freebsd-net@freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [IPv6:2001:4f8:fff6::34]) by hub.freebsd.org (Postfix) with ESMTP id 7A0E21065691 for ; Mon, 29 Sep 2008 22:17:50 +0000 (UTC) (envelope-from rwatson@FreeBSD.org) Received: from cyrus.watson.org (cyrus.watson.org [65.122.17.42]) by mx1.freebsd.org (Postfix) with ESMTP id 53CF58FC1F for ; Mon, 29 Sep 2008 22:17:50 +0000 (UTC) (envelope-from rwatson@FreeBSD.org) Received: from fledge.watson.org (fledge.watson.org [65.122.17.41]) by cyrus.watson.org (Postfix) with ESMTP id 0129A46B65; Mon, 29 Sep 2008 18:17:50 -0400 (EDT) Date: Mon, 29 Sep 2008 23:17:49 +0100 (BST) From: Robert Watson X-X-Sender: robert@fledge.watson.org To: Ryan French In-Reply-To: Message-ID: References: User-Agent: Alpine 1.10 (BSF 962 2008-03-14) MIME-Version: 1.0 Content-Type: TEXT/PLAIN; charset=US-ASCII; format=flowed Cc: freebsd-net@freebsd.org Subject: Re: Initialisation of a networking protocol X-BeenThere: freebsd-net@freebsd.org X-Mailman-Version: 2.1.5 Precedence: list List-Id: Networking and TCP/IP with FreeBSD List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Mon, 29 Sep 2008 22:17:50 -0000 On Mon, 29 Sep 2008, Ryan French wrote: > I'm having a bit of trouble with my MPLS protocol code at the moment. I have > the code written and compiling (mostly based on some OpenBSD code I was > shown) but when an MPLS packet is received it doesnt appear as thou my > mpls_input routine is being called. I believe this is because I have not > initialised the protocol properly. I have created protosw structure for MPLS > as well as created an mpls_init(void) function which registers the protocol > with netisr via netisr_register. Other than that I am not really sure where > I tell the kernel to call the mpls_init function so that the protocol is > initialised, and a couple of hours of googling/looking through ip6 code > hasnt really helped at all. If anyone can help and needs to see the code it > can be viewed on Perforce at > http://perforce.freebsd.org/depotTreeBrowser.cgi?FSPC=//depot/projects/soc2008/rfrench_mpls&HIDEDEL=NO Hi Ryan: netisr is just a dispatch facility consisting of a series of named queues, worker thread(s), and a dispatch model -- it is the responsibility of some other piece of driver or protocol code to inject packets using netisr_queue() or netisr_dispatch(). Typically this occurs in the decapsulation code for the layer below the dispatched layer -- often the link layer. You can take a look at current dispatch points here: http://fxr.watson.org/fxr/ident?im=bigexcerpts;i=netisr_queue http://fxr.watson.org/fxr/ident?im=bigexcerpts;i=netisr_dispatch A typical dispatch point is ether_demux(), which switches on the etherhet frame header's protocol field and then hands off the packet to netisr for dispatch. If the dispatch may lead to recursion, then you may need to use netisr_queue() rather than netisr_direct() to disallow direct dispatch. Robert N M Watson Computer Laboratory University of Cambridge