dcons(4) is a very simple console driver that is not directly connected with any physical devices. It just reads and writes characters from and to a buffer in a kernel or loader. Due to its simple nature, it is very useful for kernel debugging, especially with a FireWire® device. Currently, FreeBSD provides two ways to interact with the buffer from outside of the kernel using dconschat(8).
Most FireWire® (IEEE1394) host controllers are based on the OHCI specification that supports physical access to the host memory. This means that once the host controller is initialized, we can access the host memory without the help of software (kernel). We can exploit this facility for interaction with dcons(4). dcons(4) provides similar functionality as a serial console. It emulates two serial ports, one for the console and DDB, the other for GDB. Because remote memory access is fully handled by the hardware, the dcons(4) buffer is accessible even when the system crashes.
FireWire® devices are not limited to those integrated into motherboards. PCI cards exist for desktops, and a cardbus interface can be purchased for laptops.
To enable FireWire® and Dcons support in the kernel of the target machine:
Make sure your kernel supports
dcons
, dcons_crom
and firewire
.
Dcons
should be statically linked
with the kernel. For dcons_crom
and
firewire
, modules should be
OK.
Make sure physical DMA is enabled.
You may need to add
hw.firewire.phydma_enable=1
to
/boot/loader.conf
.
Add options for debugging.
Add dcons_gdb=1
in
/boot/loader.conf
if you use GDB
over FireWire®.
Enable dcons
in
/etc/ttys
.
Optionally, to force dcons
to
be the high-level console, add
hw.firewire.dcons_crom.force_console=1
to loader.conf
.
To enable FireWire® and Dcons support in loader(8) on i386 or amd64:
Add
LOADER_FIREWIRE_SUPPORT=YES
in
/etc/make.conf
and rebuild
loader(8):
#
cd /sys/boot/i386 && make clean && make && make install
To enable dcons(4) as an active low-level
console, add boot_multicons="YES"
to
/boot/loader.conf
.
Here are a few configuration examples. A sample kernel configuration file would contain:
device dcons device dcons_crom options KDB options DDB options GDB options ALT_BREAK_TO_DEBUGGER
And a sample /boot/loader.conf
would contain:
dcons_crom_load="YES" dcons_gdb=1 boot_multicons="YES" hw.firewire.phydma_enable=1 hw.firewire.dcons_crom.force_console=1
To enable FireWire® support in the kernel on the host machine:
#
kldload firewire
Find out the EUI64 (the unique 64
bit identifier) of the FireWire® host controller, and
use fwcontrol(8) or dmesg
to
find the EUI64 of the target machine.
Run dconschat(8), with:
#
dconschat -e \# -br -G 12345 -t
00-11-22-33-44-55-66-77
The following key combinations can be used once dconschat(8) is running:
~ . | Disconnect |
~ Ctrl+B | ALT BREAK |
~ Ctrl+R | RESET target |
~ Ctrl+Z | Suspend dconschat |
Attach remote GDB by starting kgdb(1) with a remote debugging session:
kgdb -r :12345 kernel
Here are some general tips:
To take full advantage of the speed of FireWire®, disable other slow console drivers:
#
conscontrol delete ttyd0 # serial console#
conscontrol delete consolectl # video/keyboard
There exists a GDB mode for
emacs(1); this is what you will need to add to your
.emacs
:
(setq gud-gdba-command-name "kgdb -a -a -a -r :12345")
(setq gdb-many-windows t)
(xterm-mouse-mode 1)
M-x gdba
And for DDD (devel/ddd
):
# remote serial protocol LANG=C ddd --debugger kgdb -r :12345 kernel # live core debug LANG=C ddd --debugger kgdb kernel /dev/fwmem0.2
All FreeBSD documents are available for download at https://download.freebsd.org/ftp/doc/
Questions that are not answered by the
documentation may be
sent to <freebsd-questions@FreeBSD.org>.
Send questions about this document to <freebsd-doc@FreeBSD.org>.