From: Randy Dunlap on 22 Jul 2010 12:10 On Thu, 22 Jul 2010 11:56:38 +0200 (CEST) Stefan Richter wrote: > This adds the traffic sniffer driver for Texas Instruments PCILynx/ > PCILynx2 based cards. The use cases for nosy are analysis of > nonstandard protocols and as an aid in development of drivers, > applications, or firmwares. > > This comparably small kernel driver sets up packet reception DMA in the > special snoop mode of the PCILynx chip. Userspace can pick up the > snooped FireWire traffic via a misc char device file "/dev/nosy". The > file supports poll(), read(), and four ioctl()s; see nosy-user.h. > > The ioctls use type code '&' which is currently unallocated according to > Documentation/ioctl/ioctl-number.txt. Is this OK or should it be moved > to a different type code? > > A side note regarding maintainability: The PCILynx chip is well > documented in Texas Instruments' literature SCPA020A and SLLA023. > > Signed-off-by: Stefan Richter <stefanr(a)s5r6.in-berlin.de> > --- > drivers/firewire/Kconfig | 23 ++ > drivers/firewire/Makefile | 1 + > drivers/firewire/nosy-user.h | 25 ++ > drivers/firewire/nosy.c | 720 ++++++++++++++++++++++++++++++++++++++++++ > drivers/firewire/nosy.h | 237 ++++++++++++++ > 5 files changed, 1006 insertions(+), 0 deletions(-) > create mode 100644 drivers/firewire/nosy-user.h > create mode 100644 drivers/firewire/nosy.c > create mode 100644 drivers/firewire/nosy.h > > diff --git a/drivers/firewire/Kconfig b/drivers/firewire/Kconfig > index a9371b3..c4edc34 100644 > --- a/drivers/firewire/Kconfig > +++ b/drivers/firewire/Kconfig > @@ -66,4 +66,27 @@ config FIREWIRE_NET > > source "drivers/ieee1394/Kconfig" > > +config FIREWIRE_NOSY > + tristate "Nosy - a FireWire traffic sniffer for PCILynx cards" > + depends on PCI Just curious: why not depends on IEEE1394_PCILYNX ? > + help > + Nosy is an IEEE 1394 packet sniffer that is used for protocol > + analysis and in development of IEEE 1394 drivers, applications, > + or firmwares. > + > + This driver lets you use a Texas Instruments PCILynx 1394 to PCI > + link layer controller TSB12LV21/A/B as a low-budget bus analyzer. > + PCILynx is a nowadays very rare IEEE 1394 controller which is > + not OHCI 1394 compliant. > + > + The following cards are known to be based on PCILynx or PCILynx-2: > + IOI IOI-1394TT (PCI card), Unibrain Fireboard 400 PCI Lynx-2 > + (PCI card), Newer Technology FireWire 2 Go (CardBus card), > + Apple Power Mac G3 blue & white (onboard controller). > + > + To compile this driver as a module, say M here: The module will be > + called nosy. > + > + If unsure, say N. > + > endmenu > diff --git a/drivers/firewire/Makefile b/drivers/firewire/Makefile > index a8f9bb6..3c6a7fb 100644 > --- a/drivers/firewire/Makefile > +++ b/drivers/firewire/Makefile > @@ -12,3 +12,4 @@ obj-$(CONFIG_FIREWIRE) += firewire-core.o > obj-$(CONFIG_FIREWIRE_OHCI) += firewire-ohci.o > obj-$(CONFIG_FIREWIRE_SBP2) += firewire-sbp2.o > obj-$(CONFIG_FIREWIRE_NET) += firewire-net.o > +obj-$(CONFIG_FIREWIRE_NOSY) += nosy.o > diff --git a/drivers/firewire/nosy-user.h b/drivers/firewire/nosy-user.h > new file mode 100644 > index 0000000..e48aa62 > --- /dev/null > +++ b/drivers/firewire/nosy-user.h > @@ -0,0 +1,25 @@ > +#ifndef __nosy_user_h > +#define __nosy_user_h > + > +#include <linux/ioctl.h> > +#include <linux/types.h> > + > +#define NOSY_IOC_GET_STATS _IOR('&', 0, struct nosy_stats) > +#define NOSY_IOC_START _IO('&', 1) > +#define NOSY_IOC_STOP _IO('&', 2) > +#define NOSY_IOC_FILTER _IOW('&', 2, __u32) Please add '&' to Documentation/ioctl/ioctl-number.txt. > +struct nosy_stats { > + __u32 total_packet_count; > + __u32 lost_packet_count; > +}; > + > +/* > + * Format of packets returned from the kernel driver: > + * > + * quadlet with timestamp (microseconds, CPU endian) > + * quadlet-padded packet data... (little endian) > + * quadlet with ack (little endian) > + */ > + > +#endif /* __nosy_user_h */ --- ~Randy *** Remember to use Documentation/SubmitChecklist when testing your code *** -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo(a)vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/
|
Pages: 1 Prev: - Mapping ACPI tables as CACHED Next: vhost: replace vhost_workqueue with per-vhost kthread |