ipfwechochk man page on BSDi

Man page or keyword search:  
man Server   6284 pages
apropos Keyword Search (all sections)
Output format
BSDi logo
[printable version]

IPFWECHOCHK(8)		  BSD System Manager's Manual		IPFWECHOCHK(8)

NAME
     ipfwechochk - Check ICMP echo packet

SYNOPSIS
     ipfwechochk [-nv] [-b buckets] [-s serial] [-t when] [-T tag]
		 [maxentries]

DESCRIPTION
     The ipfwechochk utility is used to reject ICMP Echo Reply packets that
     have no matching ICMP Echo Request packets.  This is accomplished by
     recording each ICMP Echo Request and accepting only ICMP Echo Replies
     that match the outgoing request.  The IP addresses, sequence number and
     id must all match.	 When an ICMP Echo Reply is matched to a previous ICMP
     Echo Request the entry is removed, further replies will be ignored unless
     a new echo request is sent.

     Since the only way for an entry to be automatically removed is for a
     matching ICMP Echo Reply to be seen, a maximum number of entries must be
     specified by maxentries when installing the filter.  The value used will
     depend on how many hosts inside the network will be doing pings at the
     same time.	 If an ICMP Echo Request is seen and there are too many en-
     tries, the old oldest entry is removed.

     With no arguments (options only), all outstanding echo requests are dis-
     played.

     The following options are available:

     -b buckets
	     Set the number of hash buckets to be used to buckets. The default
	     setting of 997 is probably good for most situations.  If you are
	     expecting a large number of simultaneous icmp echo requests you
	     may want to increase this value.  The value should be reasonably
	     prime.  To support about 50,000 outstanding requests a value of
	     9977 would probably work fine.

     -n	     Do not sort output when displaying.

     -s serial
	     Display only the information for the specified serial number.

     -t when
	     Expire all outstanding requests that are older than when seconds.
	     Times may be modified with s, m, h, d, w, and y to specify sec-
	     onds, minutes, hours, days, weeks and years.  For example: 1m30s
	     is 1 minute and 30 seconds.  A year is always considered to have
	     365 days.

     -T tag  Specify the tag to be used.  If this is not specified then the
	     tag "echochk" will be used.

     -v	     Provide additional information while running.

HOW TO USE
     Typically only a single echochk filter is installed on a system, there is
     little advantage in installing more than one.  It is always installed on
     the CALL filter chain.  A pre-input and pre-output filter are then in-
     stalled.  The pre-output filter should contain code similar to:

	   icmp {
		   switch icmptype {
		   case echo:
			   call("echochk");
			   break;
		   case echoreply:	   // don't allow incoming pings
			   reject;
			   break;
		   }
	   }

     The pre-input filter would contain:

	   icmp {
		   switch icmptype {
		   case echo:		   // don't allow incoming pings
			   reject;
			   break;
		   case echoreply:
			   ! call("echochk") {
				   reject; // unknown reply
			   }
			   break;
		   }
	   }

     In each case, the standard IPFW language is used to determine if the
     packet should be subject to the check.  If it is subject to the check the
     echochk filter is called.	For ICMP Echo requests we simply call the fil-
     ter to have us recorded.  For ICMP Echo replies we reject the packet if
     the filter does not report a match.

     A gateway could also put the checks on the forward filter based on what
     IP addresses are being used:

	   input interface(exp0) {
		   // Packets from inside my net
		   ...
		   switch icmptype {
		   case echo:
			   call("echochk");
			   break;
		   case echoreply:
			   reject;
			   break;
		   }
		   ...
	   }
	   input interface(exp1) {
		   // Packets from outside my net
	   icmp {
		   switch icmptype {
		   case echo:		   // don't allow incoming pings
			   reject;
			   break;
		   case echoreply:
			   ! call("echochk") {
				   reject; // unknown reply
			   }
			   break;
		   }
	   }
	   }

     Old entries can be periodically removed, however, it is generally okay to
     let them be removed when the maximum number of entries is hit.

SEE ALSO
     ipfw(8,) ipfwcmp(8)

			       January 19, 2000				     2
[top]

List of man pages available for BSDi

Copyright (c) for man pages and the logo by the respective OS vendor.

For those who want to learn more, the polarhome community provides shell access and support.

[legal] [privacy] [GNU] [policy] [cookies] [netiquette] [sponsors] [FAQ]
Tweet
Polarhome, production since 1999.
Member of Polarhome portal.
Based on Fawad Halim's script.
....................................................................
Vote for polarhome
Free Shell Accounts :: the biggest list on the net