From: Randy Dunlap on
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/