FreeBSD manual
download PDF document: rfcomm_pppd.8.pdf
RFCOMM_PPPD(8) FreeBSD System Manager's Manual RFCOMM_PPPD(8)
NAME
rfcomm_pppd - RFCOMM PPP daemon
SYNOPSIS
rfcomm_pppd -c [-dh] -a address -C channel -l label -u N
rfcomm_pppd -s [-dDhS] [-a address] -C channel -l label
DESCRIPTION
The rfcomm_pppd daemon is a simple wrapper daemon that allows the use of
ppp(8) via an RFCOMM connection. It can operate in two modes: client and
server.
In client mode, rfcomm_pppd opens an RFCOMM connection to the specified
server's BD_ADRR and channel. Once the RFCOMM connection is established,
rfcomm_pppd executes ppp(8) in -direct mode with the specified label.
Likewise, ppp(8) operates over the RFCOMM connection just like it would
over a standard serial port, thus allowing a user to "dial out" and
connect to the Internet.
In server mode, rfcomm_pppd opens an RFCOMM socket and listens for
incoming connections from remote clients. Once the new incoming
connection is accepted, rfcomm_pppd forks and executes ppp(8) in -direct
mode with the specified label. Likewise, ppp(8) operates over the RFCOMM
connection just like it would over a standard serial port, thus providing
network connectivity to remote clients.
The options are as follows:
-a address
In client mode, this required option specifies the address of the
remote RFCOMM server. In server mode, this option can be used to
specify the local address to listen on. By default, in server
mode, the daemon will listen on ANY address. The address can be
specified as BD_ADDR or name. If a name was specified, the
rfcomm_pppd utility will attempt to resolve the name via
bt_gethostbyname(3).
-C channel
In both client and server mode, this required option specifies
the RFCOMM channel to connect to or listen on. In server mode,
the channel should be a number between 1 and 30. In client mode,
the channel could either be a number between 1 and 30 or a
service name. Supported service names are: DUN (Dial-Up
Networking) and LAN (LAN Access Using PPP). If a service name is
used instead of a numeric channel number, then rfcomm_pppd will
try to obtain an RFCOMM channel number via SDP (Service Discovery
Protocol).
-c Act as an RFCOMM client. This is the default mode.
-d Do not detach from the controlling terminal, i.e., run in
foreground.
-D In server mode, register the DUN (Dial-Up Networking) service in
addition to the LAN (LAN Access Using PPP) service. AT-command
exchange can be faked with ppp(8) chat script.
to the LAN (LAN Access Using PPP) service.
It appears that some cell phones are using the so-called
"callback mechanism". In this scenario, the user is trying to
connect his cell phone to the Internet, while the user's host
computer is acting as the gateway server. It seems that it is
not possible to tell the phone to just connect and start using
the LAN service. Instead, the user's host computer must "jump
start" the phone by connecting to the phone's SP service. What
happens next is the phone kills the existing connection and opens
another connection back to the user's host computer. The phone
really wants to use the LAN service, but for whatever reason it
looks for the SP service on the user's host computer. This
brain-damaged behavior was reported for the Nokia 6600 and the
Sony/Ericsson P900.
-s Act as an RFCOMM server.
-u N This option maps directly to the -unit ppp(8) command-line option
and tells rfcomm_pppd to instruct ppp(8) to only attempt to open
/dev/tunN. This option only works in client mode.
PPP CONFIGURATION
Important Notes on PPP Configuration
Special attention is required when adding new RFCOMM configurations to
the existing PPP configuration. Please keep in mind that PPP will always
execute commands in the "default" label of your /etc/ppp/ppp.conf file.
Please make sure that the "default" label only contains commands that
apply to every other label. If you need to use PPP for both dialing out
and accepting incoming RFCOMM connections, please make sure you have
moved all commands related to dialing out from the "default" section into
an appropriate outgoing label.
RFCOMM Server
One of the typical examples is the LAN access. In this example, an
RFCOMM connection is used as a null-modem connection between a client and
a server. Both client and server will start talking PPP right after the
RFCOMM connection has been established.
rfcomm-server:
set timeout 0
set lqrperiod 10
set ifaddr 10.0.0.1 10.0.0.2 255.255.255.0
enable lqr
accept lqr
accept dns
# Do not use PPP authentication. Assume that
# Bluetooth connection was authenticated already
disable pap
deny pap
disable chap
deny chap
RFCOMM Client
The rfcomm_pppd utility supports both LAN (LAN Access Using PPP) and DUN
(Dial-Up Networking) access. The client's configuration for LAN access
is very similar to the server's and might look like this:
rfcomm-client:
# Bluetooth connection was authenticated already
deny pap
disable pap
deny chap
disable chap
The client's configuration for DUN access is different. In this
scenario, the client gets connected to the virtual serial port on the
server. To open a PPP session, the client must dial a number. Note that
by default ppp(8) will not execute any configured chat scripts. The
force-scripts option can be used to override this behavior. An example
configuration is shown below:
rfcomm-dialup:
# This is IMPORTANT option
enable force-scripts
# You might want to change these
set authname
set authkey
set phone "*99***1#"
# You might want to adjust dial string as well
set dial "ABORT BUSY ABORT NO\\sCARRIER TIMEOUT 5 \
\"\" AT OK-AT-OK ATE1Q0 OK \\dATDT\\T TIMEOUT 40 CONNECT"
set login
set timeout 30
enable dns
resolv rewrite
set ifaddr 10.0.0.1/0 10.0.0.2/0 255.255.255.0 0.0.0.0
add default HISADDR
Note that by adjusting the initialization string, one can make a CSD
(Circuit Switched Data), HSCSD (High Speed Circuit Switched Data) or GPRS
(General Packet Radio Service) connection. The availability of the
particular connection type depends on the phone model and service plan
activated on the phone.
EXIT STATUS
The rfcomm_pppd utility exits 0 on success, and >0 if an error occurs.
EXAMPLES
rfcomm_pppd -s -a 00:01:02:03:04:05 -C 1 -l rfcomm-server
This command will start rfcomm_pppd in the server mode. The RFCOMM
server will listen on local address 00:01:02:03:04:05 and channel 1.
Once the incoming connection has been accepted, rfcomm_pppd will execute
ppp(8) in -direct mode with the "rfcomm-server" label.
rfcomm_pppd -c -a 00:01:02:03:04:05 -C 1 -l rfcomm-client
This command will start rfcomm_pppd in the client mode. rfcomm_pppd will
try to connect to the RFCOMM server at 00:01:02:03:04:05 address and
channel 1. Once connected, rfcomm_pppd will execute ppp(8) in -direct
mode with the "rfcomm-client" label.
SEE ALSO
rfcomm_sppd(1), bluetooth(3), ng_btsocket(4), ppp(8), sdpcontrol(8),
LAN Access Over PPP service with the local SDP daemon. If the local SDP
daemon is not running, rfcomm_pppd will exit with an error.
FreeBSD 14.2-RELEASE February 4, 2003 FreeBSD 14.2-RELEASE