171 lines
3.3 KiB
Text
Executable file
171 lines
3.3 KiB
Text
Executable file
.TH BRIDGE 3
|
|
.SH NAME
|
|
bridge \- IPv4 Ethernet bridge
|
|
.SH SYNOPSIS
|
|
.nf
|
|
.B bind -a #B\fIb\fP /net
|
|
|
|
.B /net/bridge\fIb\fP/ctl
|
|
.B /net/bridge\fIb\fP/cache
|
|
.B /net/bridge\fIb\fP/log
|
|
.B /net/bridge\fIb\fP/stats
|
|
.BI /net/bridge\fIb\fP/ n
|
|
.BI /net/bridge\fIb\fP/ n /ctl
|
|
.BI /net/bridge\fIb\fP/ n /local
|
|
.BI /net/bridge\fIb\fP/ n /status
|
|
.fi
|
|
.SH DESCRIPTION
|
|
The
|
|
.I bridge
|
|
device bridges IPv4 packets amongst Ethernet interfaces.
|
|
The number
|
|
.I b
|
|
in the bind is optional and selects a particular bridge
|
|
(default 0).
|
|
.PP
|
|
The
|
|
.B /net/bridge0
|
|
directory contains
|
|
.BR ctl ,
|
|
.BR cache ,
|
|
.BR log ,
|
|
and
|
|
.B stats
|
|
files, and numbered subdirectories for each physical interface.
|
|
.PP
|
|
Opening the
|
|
.B ctl
|
|
file reserves an interface.
|
|
The file descriptor returned from the
|
|
.IR open (2)
|
|
will point to the control file,
|
|
.BR ctl ,
|
|
of the newly allocated interface.
|
|
Reading
|
|
.B ctl
|
|
returns a text string representing the number of the interface.
|
|
Writing
|
|
.B ctl
|
|
alters aspects of the interface.
|
|
The possible
|
|
.I ctl
|
|
messages are:
|
|
.TF cacheflush
|
|
.PD
|
|
.TP
|
|
.BI "bind ether " "name ownhash path"
|
|
Treat the device mounted at
|
|
.I path
|
|
(e.g.,
|
|
.LR /net/ether0 )
|
|
as an Ethernet medium carrying IPv4 and ARP packets
|
|
and associate it with this bridge (forward its packets to the
|
|
other interfaces associated with this bridge).
|
|
.I Ownhash
|
|
is an `owner hash'.
|
|
.TP
|
|
.BI "bind tunnel " "name ownhash path path2
|
|
Treat the device mounted at
|
|
.I path
|
|
as a network tunnel carrying IPv4 and ARP packets,
|
|
the device mounted at
|
|
.I path2
|
|
as an Ethernet medium carrying IPv4 and ARP packets
|
|
and associate them with this bridge
|
|
(forward its packets to the
|
|
other interfaces associated with this bridge).
|
|
Read packets from the
|
|
.I path
|
|
interface and write them to the
|
|
.I path2
|
|
interface.
|
|
Such tunnels have an MTU of 1400 bytes.
|
|
.TP
|
|
.BI "unbind " "type address [ownhash]"
|
|
Disassociate the interface associated with
|
|
.I address
|
|
from this bridge.
|
|
.I Type
|
|
must be
|
|
.L ether
|
|
or
|
|
.LR tunnel .
|
|
.TP
|
|
.B cacheflush
|
|
Clear the cache of (destination MAC address, port) tuples.
|
|
.TP
|
|
.BI "delay " "delay0 delayn"
|
|
Set the
|
|
.I delay0
|
|
and
|
|
.I delayn
|
|
parameters.
|
|
.I delay0
|
|
is the constant microsecond delay per packet
|
|
and
|
|
.I delayn
|
|
is the microsecond delay per byte.
|
|
.TP
|
|
.BI "set " option
|
|
Set bridge
|
|
.IR option .
|
|
The only known option is
|
|
.LR tcpmss ,
|
|
which limits the TCP Maximum Segment Size of
|
|
TCPv4 packets passing through to 1300 bytes.
|
|
.TP
|
|
.BI "clear " option
|
|
Clear bridge
|
|
.IR option .
|
|
.PP
|
|
Reading
|
|
.I stats
|
|
returns statistics about the bridge.
|
|
.PP
|
|
Reading the
|
|
.I log
|
|
file returns data from the bridge's log
|
|
and will block at end of file awaiting new data.
|
|
.PP
|
|
Reading the
|
|
.B cache
|
|
file prints the cache of (destination MAC address, port) tuples,
|
|
one entry per line.
|
|
The format is:
|
|
the destination MAC (e.g., Ethernet) address in hex,
|
|
port number,
|
|
count of packets from this address,
|
|
count of packets to this address,
|
|
expiry time in seconds since the epoch,
|
|
and
|
|
.L e
|
|
for expired entries or
|
|
.L v
|
|
for valid entries.
|
|
.PP
|
|
In a connection subdirectory,
|
|
.B ctl
|
|
and
|
|
.B local
|
|
don't do anything,
|
|
but
|
|
.B status
|
|
returns a one-line status summary.
|
|
.SH EXAMPLES
|
|
Set up a network bridge between two Ethernets
|
|
.RL ( #l0
|
|
and
|
|
.LR #l1 ).
|
|
.IP
|
|
.EX
|
|
bind -a '#B' /net
|
|
bind -a '#l1' /net
|
|
echo 'bind ether outer 0 /net/ether0' >/net/bridge0/ctl
|
|
echo 'bind ether inner 0 /net/ether1' >/net/bridge0/ctl
|
|
.EE
|
|
.SH "SEE ALSO"
|
|
.IR ip (3)
|
|
.SH SOURCE
|
|
.B /sys/src/9/port/devbridge.c
|
|
.SH BUGS
|
|
Doesn't understand IPv6.
|