Download Brainboxes USB Devices Driver



  1. Download Brainboxes Usb Devices Driver Updater
  2. Download Brainboxes Usb Devices Drivers
  3. Download Brainboxes Usb Devices Driver Windows 7
  4. Download Brainboxes Usb Devices Driver Win 7
  5. Download Brainboxes USB Devices Driver
Linux & Wireless LANsIrDAPapersMain page
DownloadInformationBrainboxesBT StacksPcmcia cardOpenBTBlueZ 1.2

Download usb driver - Best answers Spvd-012.1 usb driver for windows 10 - Forum - Drivers Sony psp usb driver windows 10 - How-To - PSP.

USB Driver Updates. Need USB Driver Downloads for Windows 10, Windows 8, Windows 7, Vista and XP?If you are having problems with your USB not working, read the article below to help fix your USB problems.USB issues often, but not always, relate to drivers problems. BRAINBOXES US-324 DRIVER DOWNLOAD - Nvidia launches GeForce Now 'recommended router' program So you don't have to muck around with the settings on your gaming router. USB to serial is the quick low cost way to connect your computer to a serial communications enabled device. USB to serial drivers for most serial RS232 devices. The drivers for. Brainboxes 1 Port RS232 USB to Serial Adapter - US-101 USB to Serial adapter providing one RS232 serial port. Data transfer rates up to 921,600 baud rates and the 128 byte deep transmit and 256 byte receive FIFOS, coupled with 1Mbit line drivers deliver uncompromising performance on your laptop/PC.


Introduction

Part of my job at Hewlett Packard is to evaluate various kind of wireless technologies. Of course, BlueTooth could not escape this investigation.

I read my first BlueTooth specification in autumn 1997, when it was still called MC-Link and only 58 pages. Since then, I did like everybody else : attend the various conference, try to contribute to the workgroups, buy the expensive development kits and wait. But now, at least, I've got a few experiences to share with you ;-)

Note that BlueTooth support under Linux is constantly evolving, and BlueZ in particular has a lot of entropy. That's why I mention the exact version that worked for me. And remember the developers always expect you to only run the latest version.

Bits to download

If you are using the Brainboxes Pcmcia card :
  • Patch for the serial driver in the Linux kernel 2.4.12 (and most 2.4.X kernels).
  • Patch for the serial driver in the Linux kernel 2.4.13-ac6 (and most 2.4.X-acX kernels).
  • Patch for the setserial utility version 2.17

If you are using BlueZ :

  • This following patch was integrated in BlueZ 2.0 and further improved by other people, so those are only listed for historical reasons.
  • Patch for the hciattach in BlueZ 1.6.
  • Patch for the hcid utility in BlueZ 1.2

Links and more information

Brainboxes hardware :
  • The company making the hardware is Brainboxes.
  • The chips are made by Cambridge Silicon Radio.
  • The BlueTooth spec is available from the BlueTooth SIG.

BlueZ Linux BlueTooth stack :

  • BlueZ hardware survey (pretty exhaustive and detailed)
  • Tentative PAN Howto : how to set up PAN with BlueZ 2.2.

OpenBT Linux BlueTooth stack :

  • OpenBT + Brainboxes Howto : How to set up the BrainBoxes Pcmcia card with OpenBT.
  • OpenBT + CSR Howto : How to set up serial devices based on the CSR chip with OpenBT.
OpenObex over BlueZ :
  • The OpenObex web page, where you will find the latest version of the Obex package for Linux. Version 1.0.0 and later fully support BlueZ.
  • ObexFTP, an implementation of FTP over OpenObex, with a nice graphical interface. Can be used to browse some cellular phones (including over BlueTooth).
  • MultiSync allows you to synchronise data over OBEX with your cell phone (including over BlueTooth).
  • My e-Squirt implementation supports Obex over BlueTooth.
Related information :
  • My Linux Wireless LAN Howto.
  • Linux-IrDA web pages, with very helpful mailing list, and my quick tutorial.
  • The BlueDrekar Linux BlueTooth stack from IBM (not Open Source).
  • Affix, another Open Source BlueTooth stack for Linux, developped by Nokia, and quite similar in concept to BlueZ. BlueZ and Affix borrow good ideas from each other and their APIs are mostly compatible.
  • The Linux Serial Driver home page where you can download the source of setserial.

BlueTooth and Brainboxes

BlueTooth is a radio standard heavily influenced by IrDA and USB, and offers the functionality of a wireless USB and serial cable replacement (see BlueTooth for a more complete description). BlueTooth defines its own protocol stack as well, and offers the possibility to create long term binding between devices (attach wirelessly peripherals to a phone or a PDA). TCP/IP networking over BlueTooth can be done using PPP over RfComm.

Brainboxes was one of the first company to offer BlueTooth products which are available, relatively cheap (~$220) and compatible with Linux. At that time, most other products did fail on one of those 3 criteria, but today the situation has dramatically improved. You can contact them directly via e-mail to order. If you order the Pcmcia, CF or RS232 card, I would recommend H4 version (as opposed to BCSP), on the other hand for USB this subtelty doesn't exist.

I've personally tested the Pcmcia card (BL620) and USB dongle (BL554) with both OpenBT and BlueZ. The RS232 dongle would probably work without troubles, but at restricted speed (115200 bauds). The UART of the CF card (BL631) would require some investigation.

From my light testing, the Pcmcia card and the USB dongle gives you more or less the same throughput (limited by the radio channel or PPP framing overhead). However, the USB dongle has a lower latency and lower CPU usage than the Pcmcia card (USB uses DMA transfer and the UART uses PIO, which explains a lot). However, I still get much better results with 802.11 or IrDA ;-)

Other hardware I have tested

USB dongles are the best way to start with BlueTooth, as :
  • The driver interface is standard, so there is no compatibility issues.
  • The driver interface is well designed (let say, as opposed to 802.11 over USB which is a hack).
  • Performance is good (as far as BlueTooth goes).

I personally have used the following USB dongles :

  • Brainboxes BL554 (CSR chipset)
  • 3Com 3CREB96 (CSR chipset rev 0x73)
  • Epox BT-DG02 (CSR chipset rev 0x110)
  • D-Link DBT-120 (CSR chipset rev 0x1bb)
  • 3Com 3CREB96B (CSR chipset rev 0x20e)

Linux BlueTooth stacks : OpenBT and BlueZ

There is two totally different BlueTooth stacks available for Linux, both of them Open Source. OpenBT is mostly a contribution of Axis, and BlueZ is originally a contribution of Qualcom.

The strength of OpenBT 0.8 are :

  • More mature, used in real products
  • Wider set of utilities and documentation
  • Support BCSP (and a wider range of hardware functions)
  • Easier to hook your programs to RfComm

The strength of BlueZ 1.2 are :

  • Included in standard Linux kernel, better integration
  • Modular design, more than one BlueTooth port per stack
  • Excellent USB support
  • hcidump

The additional strength of BlueZ 2.4 are :

  • Excellent PAN/BNEP support (complete and flexible)
  • Excellent RfCOMM support (now as easy as OpenBT, but more flexible)
  • Supported in OpenObex 1.0.0 (Obex over RfCOMM)

Of course, this list will probably evolve over time...

The main architectural difference between the stacks is their interfaces, both to drivers and applications. OpenBT uses a serial abstraction, and BlueZ uses a network abstraction. We'll come back to it later.

Brainboxes Pcmcia card and higher speeds

The Brainboxes Pcmcia card contains a real UART (16C950). This UART has some interesting features, such as higher speeds and deep fifos, enabling higher performance transfer to the CSR chip.

The standard Pcmcia drivers (in the Pcmcia package) will automatically recognise the UART and enable the Linux serial driver on it. Different PCs and different configurations will load the UART at different addresses. With kernel 2.4.X, the way to know which serial port on your PC is the Pcmcia card is to check the message log using dmesg or to use setserial to look for the UART identified as '16C950/954'. Mine is loaded as /dev/ttyS2.

The kernel 2.2.X won't recognise this UART and won't enable the extended features (i.e. you will be stuck at 115200 bauds). The kernel 2.4.X recognise most of the features of the chip, but will enable you to reach only 460800 bauds.

To reach the maximum speed of the card (921600 bauds), you will need to do a bit of hacking :

  1. Download the kernel source (version 2.4.X - you may also get it from your distribution).
  2. Apply my serial driver patch to the kernel.
  3. Download the setserial utility.
  4. Apply my patch for setserial.
  5. Install the new kernel, its modules and the new setserial.

Then, after every time you reset the computer or insert the card, you just need to use this magic incantation : After that, you should be able to configure your BlueTooth stack to use 921600 bauds.

OpenBT 0.8 setup

I did only limited testing with OpenBT 0.8, both with the Brainboxes Pcmcia card and the USB dongle.

OpenBT use a serial abstraction (TTY) to interface both to drivers and applications. OpenBT talk to the hardware either directly to the serial port (for example /dev/ttyS2) or to a pseudo serial port (for example /dev/ttyUB0 for the USB-serial converter). Applications talk to the OpenBT stack using one of OpenBT pseudo serial port, such as /dev/ttyBT0.

OpenBT and the Brainboxes Pcmcia card

The operation is already described in details in the BlueTooth Howto of Frank Kargl, so I won't repeat it all here.

A few caveats :

  • The diff file doesn't apply cleanly on OpenBT 0.8, so you need to do the modifications by hand.
  • Frank configure the stack with the Pcmcia card at 921600 bauds. With a standard installation and the Pcmcia card, you will reach only 460800 bauds, and to enable 921600 bauds you will need to do a bit of hacking.
Brainboxes

Starting OpenBT at 921600 bauds looks like this :

OpenBT and the USB dongle

The operation is somewhat similar to the procedure described above. Instead of using a real serial port, you will need to use a BlueTooth USB-serial converter driver. Such a driver is included in kernel 2.4.X, and usually create a pseudo serial port as /dev/ttyUB0 (you may need to check your logs for confirmation).

The whole installation procedure looks like :

  1. Enable appropriate USB support in you kernel (UHCI/OHCI)
  2. Enable the BlueTooth USB-Serial converter in your kernel : the option is called USB Bluetooth support in the menu USB support.
  3. Create the pseudo serial device :
  4. Compile OpenBT for USB support, by selecting the option CONFIG_BLUETOOTH_USBMODULE in .../openbt/linux/include/linux/bluetooth/btconfig.h.
  5. Don't forget to comment out MODFLAGS and check INCLUDEDIR in .../openbt/linux/drivers/char/bluetooth/Makefile.

Now, to start OpenBT on the USB dongle, you just need to do :

From the mailing list, it seems that USB support in OpenBT is not totally stable (I didn't try much).

PPP over RfComm

One of the main application of BlueTooth is to network two host (although I would argue that 802.11 is better suited for that), which is currently done via PPP over RfComm (better alternatives are on the way).

First, you need to know what is the address of the other end of the link. One way is to check the other end, but that's cheating, the other way is to do an Inquiry :

Then, you can connect to this device. With OpenBT, the RfComm server is always runnning, so you only need to start the client :

After that, you can check that PPP created a new interface (with ifconfig and route) and that you can ping the IP address on the other end of the tunnel.

Obex

Obex is the prefered way to communicate over BlueTooth for a wide variety of function (file transfer, vCal, vCard).

At this time, it doesn't seem that OpenObex and OpenBT work with each other, and it doesn't look like OpenBT has any OBEX support.

BlueZ 1.2 setup

I did only limited testing with BlueZ 1.2, both with the Brainboxes Pcmcia card and the USB dongle. This section only deals with version 1.2, the more recent version 2.2 is described below.

As opposed to OpenBT, BlueZ use a network abstraction to interface both to drivers and applications. BlueZ need special network driver for serial and USB devices, and BlueTooth devices will be referenced as hciX (most often hci0). Applications talk to the BlueZ stack using sockets (using the AF_BLUETOOTH family).

Common configuration

The BlueZ web site already contains an excellent Howto, so you may want to start by reading that...

To enable BlueZ, you will need to do the following operations :

  1. Get a fairly recent Linux kernel (I've used 2.4.12 and 2.4.14).
  2. Enable BlueZ and related options in your kernel, under the menu Bluetooth support.
  3. Download and install the BlueZ package. Don't pay attention to various errors when compiling the kernel part of the package.
  4. Download and install the hcidump package.
  5. Download and install the rfcomm package.

BlueZ and the USB dongle

BlueZ has strong support for USB dongles. As opposed to OpenBT, BlueZ doesn't use the BlueTooth USB to serial converter, but uses its own USB driver (and of course, you can't have both running at the same time).

To get your USB dongle working, you need to do :

After that, you can setup RfComm links (see Howto).

BlueZ and the Brainboxes Pcmcia card

BlueZ support of serial devices is not as strong as OpenBT. For example, BlueZ doesn't support BCSP (that's why you need to order your cards in the H4 variety).

By default, BlueZ will only be able to run the CSR chip at 115200 bauds. I've made a patch to add support for the higher speeds of the CSR chip. This will enable you to run at 460800 bauds, and with a few more patches you will be able to do 921600 bauds.

With this patch, you need to configure the last section of /etc/hcid.conf in the following way :

Then, you start the stack like this :

PPP over RfComm

BlueZ is a bit more complex when it comes to RfComm. I'll just give you a few pointers, see the Howto for actual details.

You still need to know the address of the other end of the link ; the inquiry is currently done like this :

Assuming the file rfcommd.conf is properly configured on both side, you first start rfcomm on the server side : Then, on the client side : To close the connection, you need to kill the rfcomm instance on one side.

BlueZ 2.3 setup

Maksim and their friends are working too hard, and BlueZ has matured significantely since I last tested it, so it was time to revisit the issue. With version 2.2, the most interesting new feature is of course PAN/BNEP support. With version 2.3, we have the new RfCOMM support which is a big improvement.

So, I did again limited testing with BlueZ 2.2, both with the Brainboxes Pcmcia card and the USB dongle. I also did extensive testing of BlueZ 2.3 with the 3Com 3CREB96 USB dongle. A lot of the tools and procedure have changed with respect to BlueZ 1.2

As opposed to OpenBT, BlueZ use a network abstraction to interface both to drivers and applications. BlueZ need special network driver for serial and USB devices, and BlueTooth devices will be referenced as hciX (most often hci0). Applications talk to the BlueZ stack using sockets (using the AF_BLUETOOTH family).

Common configuration

The BlueZ web site already contains an excellent Howto, so you may want to start by reading that...

To enable BlueZ, you will need to do the following operations :

  1. Get a fairly recent Linux kernel, BlueZ 2.3 is included in kernel 2.4.21-pre3 and later.
  2. Enable BlueZ and related options in your kernel, under the menu Bluetooth support.
  3. Compile and reinstall your kernel.
  4. Download and install the BlueZ library package.
  5. Download and install the BlueZ utilities and BlueZ sdp package. Those will compile only if the library is fully installed.
  6. Optionally, download and install the hcidump package. It's a good debugging tool and necessary to do proper bug reports.
  7. Download and install the PAN package. This will compile only if both the utils and sdp packages are fully installed.
To get module auto-loading to work, you need to add in /etc/modules.conf the following :

BlueZ and the USB dongle

BlueZ has strong support for USB dongles. As opposed to OpenBT, BlueZ doesn't use the BlueTooth USB to serial converter, but uses its own USB driver (and of course, you can't have both running at the same time).

First, you need to get the USB stack up and running. This depend on your USB controller (UHCI vs OHCI).

To get you USB dongle working, you then need to do :

BlueZ and the Brainboxes Pcmcia card

The version 1.6 of BlueZ has changed the way serial devices are initialised. Instead of using hcid, you will need to use hciattach.

My obsolete patchthat adds CSR chip support to hciattach has been included in BlueZ 2.0 (and improved), so it will work out of the box at 460800 bauds. With a few more patches you will be able to do 921600 bauds.

You start the stack like this :

TCP/IP over PAN/BNEP

PAN and BNEP are the 'official' way to do networking with BlueTooth. BNEP is a simple encapsulation of Ethernet frames in a L2CAP session. PAN is the BlueTooth profile using BNEP and defining how to do networking. It includes the definition of the SDP attributes and various node roles.

What are the node roles ? It's just something to make your life more complex. In a typical Ad-Hoc scenario, the server will have the role GN, and up to 7 clients with role PANU can be connected to it. An Access Point would take a NAP (yeah, boring).

The support of BNEP in BlueZ is quite new and and not yet documented in the Official Howto, but there is an alternate Unofficial Howto.

As usual, I'll go straight to a very simple example of setting up TCP/IP between two nodes. You can do more complex stuff by reading the Howto above.


First, you need to set up the server. The server will listen for incomming connections. In our example, it's not an Access Point, so we do :

On the client side, we first need to know the address of the server ; the inquiry is currently done like this :

Now, you just need to connect to the other side :

Unfortunately, pand can fail silently, so the way to check if this succeed is to see if a new device bnep0 has been created, either using cat /proc/net/dev or ifconfig bnep0. You may notice that the interface is down, that's perfectly normal at this point. In case of problem, you need to check the logs for details, in my case /var/log/daemon.log.

What's left ? BNEP is only a Ethernet emulation. We need to configure TCP/IP on the new interface. This is done with :

Just remember that you need to assign an different IP address on each node, otherwise it won't work. After that, you should be able to ping, telnet and all that jazz.

To terminate your connection on the client, just do :

If you want to get more fancy, you can use HotPlug to automatically assign IP addresses to the bnep interfaces, and you can start playing with the SPD to know which node support PAN or not. And, if you want to build an Access Point, you will need to enable bridging. The HOWTO explains that in details.

OpenObex over RfCOMM

Download Brainboxes Usb Devices Driver Updater

Obex is the prefered way to communicate over BlueTooth for a wide variety of profiles (file transfer, image push, vCal, vCard). Obex runs over RfCOMM.

The support of Obex over BlueTooth is not fully documented, and various application will implement it differently. It requires BlueZ 2.3 or later and OpenObex 1.0.0 or later.

Here is a very simple example of Obex over BlueTooth :

  1. Make sure you have BlueZ 2.3 and RfCOMM protocol support enabled in your kernel. However, you don't need RfCOMM TTY support.
  2. Download and install the OpenObex 1.0.0 package (this is the main Obex library).
  3. Download and install the OpenObex-apps 1.0.0 package (which contains the obex_test utility).
First, we start the test server :

On the client side, we first need to know the address of the server :

Now, you just need to connect to the other side using the default RfCOMM channel :

Obviously, this is only a basic test and is not very useful. However, some popular applications such as ObexFTP and Multisync already support Obex over RfCOMM. If you are interested in the programming side, my e-Squirt library shows a complete implementation of Obex over RfCOMM (including SDP).

Wireless LANs and IrDA - jt@hpl.hp.com
Created 9 November 01
Updated 5 June 03
Project hosted and sponsored by :
Linux & Wireless LANsIrDAPapersMain page
DownloadInformationBrainboxesBT StacksPcmcia cardOpenBTBlueZ 1.2

Introduction

Part of my job at Hewlett Packard is to evaluate various kind of wireless technologies. Of course, BlueTooth could not escape this investigation.

I read my first BlueTooth specification in autumn 1997, when it was still called MC-Link and only 58 pages. Since then, I did like everybody else : attend the various conference, try to contribute to the workgroups, buy the expensive development kits and wait. But now, at least, I've got a few experiences to share with you ;-)

Note that BlueTooth support under Linux is constantly evolving, and BlueZ in particular has a lot of entropy. That's why I mention the exact version that worked for me. And remember the developers always expect you to only run the latest version.

Bits to download

If you are using the Brainboxes Pcmcia card : Download
  • Patch for the serial driver in the Linux kernel 2.4.12 (and most 2.4.X kernels).
  • Patch for the serial driver in the Linux kernel 2.4.13-ac6 (and most 2.4.X-acX kernels).
  • Patch for the setserial utility version 2.17

If you are using BlueZ :

  • This following patch was integrated in BlueZ 2.0 and further improved by other people, so those are only listed for historical reasons.
  • Patch for the hciattach in BlueZ 1.6.
  • Patch for the hcid utility in BlueZ 1.2

Links and more information

Brainboxes hardware :
  • The company making the hardware is Brainboxes.
  • The chips are made by Cambridge Silicon Radio.
  • The BlueTooth spec is available from the BlueTooth SIG.

BlueZ Linux BlueTooth stack :

  • BlueZ hardware survey (pretty exhaustive and detailed)
  • Tentative PAN Howto : how to set up PAN with BlueZ 2.2.

OpenBT Linux BlueTooth stack :

  • OpenBT + Brainboxes Howto : How to set up the BrainBoxes Pcmcia card with OpenBT.
  • OpenBT + CSR Howto : How to set up serial devices based on the CSR chip with OpenBT.
OpenObex over BlueZ :
  • The OpenObex web page, where you will find the latest version of the Obex package for Linux. Version 1.0.0 and later fully support BlueZ.
  • ObexFTP, an implementation of FTP over OpenObex, with a nice graphical interface. Can be used to browse some cellular phones (including over BlueTooth).
  • MultiSync allows you to synchronise data over OBEX with your cell phone (including over BlueTooth).
  • My e-Squirt implementation supports Obex over BlueTooth.
Related information :
  • My Linux Wireless LAN Howto.
  • Linux-IrDA web pages, with very helpful mailing list, and my quick tutorial.
  • The BlueDrekar Linux BlueTooth stack from IBM (not Open Source).
  • Affix, another Open Source BlueTooth stack for Linux, developped by Nokia, and quite similar in concept to BlueZ. BlueZ and Affix borrow good ideas from each other and their APIs are mostly compatible.
  • The Linux Serial Driver home page where you can download the source of setserial.

BlueTooth and Brainboxes

BlueTooth is a radio standard heavily influenced by IrDA and USB, and offers the functionality of a wireless USB and serial cable replacement (see BlueTooth for a more complete description). BlueTooth defines its own protocol stack as well, and offers the possibility to create long term binding between devices (attach wirelessly peripherals to a phone or a PDA). TCP/IP networking over BlueTooth can be done using PPP over RfComm.

Brainboxes was one of the first company to offer BlueTooth products which are available, relatively cheap (~$220) and compatible with Linux. At that time, most other products did fail on one of those 3 criteria, but today the situation has dramatically improved. You can contact them directly via e-mail to order. If you order the Pcmcia, CF or RS232 card, I would recommend H4 version (as opposed to BCSP), on the other hand for USB this subtelty doesn't exist.

I've personally tested the Pcmcia card (BL620) and USB dongle (BL554) with both OpenBT and BlueZ. The RS232 dongle would probably work without troubles, but at restricted speed (115200 bauds). The UART of the CF card (BL631) would require some investigation.

From my light testing, the Pcmcia card and the USB dongle gives you more or less the same throughput (limited by the radio channel or PPP framing overhead). However, the USB dongle has a lower latency and lower CPU usage than the Pcmcia card (USB uses DMA transfer and the UART uses PIO, which explains a lot). However, I still get much better results with 802.11 or IrDA ;-)

Other hardware I have tested

USB dongles are the best way to start with BlueTooth, as :
  • The driver interface is standard, so there is no compatibility issues.
  • The driver interface is well designed (let say, as opposed to 802.11 over USB which is a hack).
  • Performance is good (as far as BlueTooth goes).

I personally have used the following USB dongles :

  • Brainboxes BL554 (CSR chipset)
  • 3Com 3CREB96 (CSR chipset rev 0x73)
  • Epox BT-DG02 (CSR chipset rev 0x110)
  • D-Link DBT-120 (CSR chipset rev 0x1bb)
  • 3Com 3CREB96B (CSR chipset rev 0x20e)

Linux BlueTooth stacks : OpenBT and BlueZ

There is two totally different BlueTooth stacks available for Linux, both of them Open Source. OpenBT is mostly a contribution of Axis, and BlueZ is originally a contribution of Qualcom.

The strength of OpenBT 0.8 are :

  • More mature, used in real products
  • Wider set of utilities and documentation
  • Support BCSP (and a wider range of hardware functions)
  • Easier to hook your programs to RfComm

The strength of BlueZ 1.2 are :

  • Included in standard Linux kernel, better integration
  • Modular design, more than one BlueTooth port per stack
  • Excellent USB support
  • hcidump

The additional strength of BlueZ 2.4 are :

  • Excellent PAN/BNEP support (complete and flexible)
  • Excellent RfCOMM support (now as easy as OpenBT, but more flexible)
  • Supported in OpenObex 1.0.0 (Obex over RfCOMM)

Of course, this list will probably evolve over time...

The main architectural difference between the stacks is their interfaces, both to drivers and applications. OpenBT uses a serial abstraction, and BlueZ uses a network abstraction. We'll come back to it later.

Brainboxes Pcmcia card and higher speeds

The Brainboxes Pcmcia card contains a real UART (16C950). This UART has some interesting features, such as higher speeds and deep fifos, enabling higher performance transfer to the CSR chip.

The standard Pcmcia drivers (in the Pcmcia package) will automatically recognise the UART and enable the Linux serial driver on it. Different PCs and different configurations will load the UART at different addresses. With kernel 2.4.X, the way to know which serial port on your PC is the Pcmcia card is to check the message log using dmesg or to use setserial to look for the UART identified as '16C950/954'. Mine is loaded as /dev/ttyS2.

The kernel 2.2.X won't recognise this UART and won't enable the extended features (i.e. you will be stuck at 115200 bauds). The kernel 2.4.X recognise most of the features of the chip, but will enable you to reach only 460800 bauds.

To reach the maximum speed of the card (921600 bauds), you will need to do a bit of hacking :

  1. Download the kernel source (version 2.4.X - you may also get it from your distribution).
  2. Apply my serial driver patch to the kernel.
  3. Download the setserial utility.
  4. Apply my patch for setserial.
  5. Install the new kernel, its modules and the new setserial.

Then, after every time you reset the computer or insert the card, you just need to use this magic incantation : After that, you should be able to configure your BlueTooth stack to use 921600 bauds.

OpenBT 0.8 setup

I did only limited testing with OpenBT 0.8, both with the Brainboxes Pcmcia card and the USB dongle.

OpenBT use a serial abstraction (TTY) to interface both to drivers and applications. OpenBT talk to the hardware either directly to the serial port (for example /dev/ttyS2) or to a pseudo serial port (for example /dev/ttyUB0 for the USB-serial converter). Applications talk to the OpenBT stack using one of OpenBT pseudo serial port, such as /dev/ttyBT0.

OpenBT and the Brainboxes Pcmcia card

The operation is already described in details in the BlueTooth Howto of Frank Kargl, so I won't repeat it all here.

A few caveats :

  • The diff file doesn't apply cleanly on OpenBT 0.8, so you need to do the modifications by hand.
  • Frank configure the stack with the Pcmcia card at 921600 bauds. With a standard installation and the Pcmcia card, you will reach only 460800 bauds, and to enable 921600 bauds you will need to do a bit of hacking.

Starting OpenBT at 921600 bauds looks like this :

OpenBT and the USB dongle

The operation is somewhat similar to the procedure described above. Instead of using a real serial port, you will need to use a BlueTooth USB-serial converter driver. Such a driver is included in kernel 2.4.X, and usually create a pseudo serial port as /dev/ttyUB0 (you may need to check your logs for confirmation).

The whole installation procedure looks like :

  1. Enable appropriate USB support in you kernel (UHCI/OHCI)
  2. Enable the BlueTooth USB-Serial converter in your kernel : the option is called USB Bluetooth support in the menu USB support.
  3. Create the pseudo serial device :
  4. Compile OpenBT for USB support, by selecting the option CONFIG_BLUETOOTH_USBMODULE in .../openbt/linux/include/linux/bluetooth/btconfig.h.
  5. Don't forget to comment out MODFLAGS and check INCLUDEDIR in .../openbt/linux/drivers/char/bluetooth/Makefile.

Now, to start OpenBT on the USB dongle, you just need to do :

From the mailing list, it seems that USB support in OpenBT is not totally stable (I didn't try much).

PPP over RfComm

One of the main application of BlueTooth is to network two host (although I would argue that 802.11 is better suited for that), which is currently done via PPP over RfComm (better alternatives are on the way).

First, you need to know what is the address of the other end of the link. One way is to check the other end, but that's cheating, the other way is to do an Inquiry :

Then, you can connect to this device. With OpenBT, the RfComm server is always runnning, so you only need to start the client :

After that, you can check that PPP created a new interface (with ifconfig and route) and that you can ping the IP address on the other end of the tunnel.

Obex

Obex is the prefered way to communicate over BlueTooth for a wide variety of function (file transfer, vCal, vCard).

At this time, it doesn't seem that OpenObex and OpenBT work with each other, and it doesn't look like OpenBT has any OBEX support.

BlueZ 1.2 setup

I did only limited testing with BlueZ 1.2, both with the Brainboxes Pcmcia card and the USB dongle. This section only deals with version 1.2, the more recent version 2.2 is described below.

As opposed to OpenBT, BlueZ use a network abstraction to interface both to drivers and applications. BlueZ need special network driver for serial and USB devices, and BlueTooth devices will be referenced as hciX (most often hci0). Applications talk to the BlueZ stack using sockets (using the AF_BLUETOOTH family).

Common configuration

The BlueZ web site already contains an excellent Howto, so you may want to start by reading that...

To enable BlueZ, you will need to do the following operations :

  1. Get a fairly recent Linux kernel (I've used 2.4.12 and 2.4.14).
  2. Enable BlueZ and related options in your kernel, under the menu Bluetooth support.
  3. Download and install the BlueZ package. Don't pay attention to various errors when compiling the kernel part of the package.
  4. Download and install the hcidump package.
  5. Download and install the rfcomm package.

BlueZ and the USB dongle

BlueZ has strong support for USB dongles. As opposed to OpenBT, BlueZ doesn't use the BlueTooth USB to serial converter, but uses its own USB driver (and of course, you can't have both running at the same time).

To get your USB dongle working, you need to do :

After that, you can setup RfComm links (see Howto).

BlueZ and the Brainboxes Pcmcia card

BlueZ support of serial devices is not as strong as OpenBT. For example, BlueZ doesn't support BCSP (that's why you need to order your cards in the H4 variety).

By default, BlueZ will only be able to run the CSR chip at 115200 bauds. I've made a patch to add support for the higher speeds of the CSR chip. This will enable you to run at 460800 bauds, and with a few more patches you will be able to do 921600 bauds.

With this patch, you need to configure the last section of /etc/hcid.conf in the following way :

Then, you start the stack like this :

PPP over RfComm

BlueZ is a bit more complex when it comes to RfComm. I'll just give you a few pointers, see the Howto for actual details.

You still need to know the address of the other end of the link ; the inquiry is currently done like this :

Assuming the file rfcommd.conf is properly configured on both side, you first start rfcomm on the server side : Then, on the client side : To close the connection, you need to kill the rfcomm instance on one side.

BlueZ 2.3 setup

Maksim and their friends are working too hard, and BlueZ has matured significantely since I last tested it, so it was time to revisit the issue. With version 2.2, the most interesting new feature is of course PAN/BNEP support. With version 2.3, we have the new RfCOMM support which is a big improvement.

So, I did again limited testing with BlueZ 2.2, both with the Brainboxes Pcmcia card and the USB dongle. I also did extensive testing of BlueZ 2.3 with the 3Com 3CREB96 USB dongle. A lot of the tools and procedure have changed with respect to BlueZ 1.2

As opposed to OpenBT, BlueZ use a network abstraction to interface both to drivers and applications. BlueZ need special network driver for serial and USB devices, and BlueTooth devices will be referenced as hciX (most often hci0). Applications talk to the BlueZ stack using sockets (using the AF_BLUETOOTH family).

Common configuration

The BlueZ web site already contains an excellent Howto, so you may want to start by reading that...

To enable BlueZ, you will need to do the following operations :

  1. Get a fairly recent Linux kernel, BlueZ 2.3 is included in kernel 2.4.21-pre3 and later.
  2. Enable BlueZ and related options in your kernel, under the menu Bluetooth support.
  3. Compile and reinstall your kernel.
  4. Download and install the BlueZ library package.
  5. Download and install the BlueZ utilities and BlueZ sdp package. Those will compile only if the library is fully installed.
  6. Optionally, download and install the hcidump package. It's a good debugging tool and necessary to do proper bug reports.
  7. Download and install the PAN package. This will compile only if both the utils and sdp packages are fully installed.
To get module auto-loading to work, you need to add in /etc/modules.conf the following :

BlueZ and the USB dongle

BlueZ has strong support for USB dongles. As opposed to OpenBT, BlueZ doesn't use the BlueTooth USB to serial converter, but uses its own USB driver (and of course, you can't have both running at the same time).

First, you need to get the USB stack up and running. This depend on your USB controller (UHCI vs OHCI).

To get you USB dongle working, you then need to do :

BlueZ and the Brainboxes Pcmcia card

The version 1.6 of BlueZ has changed the way serial devices are initialised. Instead of using hcid, you will need to use hciattach.

My obsolete patchthat adds CSR chip support to hciattach has been included in BlueZ 2.0 (and improved), so it will work out of the box at 460800 bauds. With a few more patches you will be able to do 921600 bauds.

You start the stack like this :

TCP/IP over PAN/BNEP

PAN and BNEP are the 'official' way to do networking with BlueTooth. BNEP is a simple encapsulation of Ethernet frames in a L2CAP session. PAN is the BlueTooth profile using BNEP and defining how to do networking. It includes the definition of the SDP attributes and various node roles.

What are the node roles ? It's just something to make your life more complex. In a typical Ad-Hoc scenario, the server will have the role GN, and up to 7 clients with role PANU can be connected to it. An Access Point would take a NAP (yeah, boring).

The support of BNEP in BlueZ is quite new and and not yet documented in the Official Howto, but there is an alternate Unofficial Howto.

As usual, I'll go straight to a very simple example of setting up TCP/IP between two nodes. You can do more complex stuff by reading the Howto above.


First, you need to set up the server. The server will listen for incomming connections. In our example, it's not an Access Point, so we do :

On the client side, we first need to know the address of the server ; the inquiry is currently done like this :

Now, you just need to connect to the other side :

Unfortunately, pand can fail silently, so the way to check if this succeed is to see if a new device bnep0 has been created, either using cat /proc/net/dev or ifconfig bnep0. You may notice that the interface is down, that's perfectly normal at this point. In case of problem, you need to check the logs for details, in my case /var/log/daemon.log.

What's left ? BNEP is only a Ethernet emulation. We need to configure TCP/IP on the new interface. This is done with :

Just remember that you need to assign an different IP address on each node, otherwise it won't work. After that, you should be able to ping, telnet and all that jazz.

To terminate your connection on the client, just do :

If you want to get more fancy, you can use HotPlug to automatically assign IP addresses to the bnep interfaces, and you can start playing with the SPD to know which node support PAN or not. And, if you want to build an Access Point, you will need to enable bridging. The HOWTO explains that in details.

Download Brainboxes Usb Devices Drivers

OpenObex over RfCOMM

Obex is the prefered way to communicate over BlueTooth for a wide variety of profiles (file transfer, image push, vCal, vCard). Obex runs over RfCOMM.

The support of Obex over BlueTooth is not fully documented, and various application will implement it differently. It requires BlueZ 2.3 or later and OpenObex 1.0.0 or later.

Here is a very simple example of Obex over BlueTooth :

  1. Make sure you have BlueZ 2.3 and RfCOMM protocol support enabled in your kernel. However, you don't need RfCOMM TTY support.
  2. Download and install the OpenObex 1.0.0 package (this is the main Obex library).
  3. Download and install the OpenObex-apps 1.0.0 package (which contains the obex_test utility).
First, we start the test server :

On the client side, we first need to know the address of the server :

Download Brainboxes Usb Devices Driver Windows 7

Now, you just need to connect to the other side using the default RfCOMM channel :

Download Brainboxes Usb Devices Driver Win 7

Obviously, this is only a basic test and is not very useful. However, some popular applications such as ObexFTP and Multisync already support Obex over RfCOMM. If you are interested in the programming side, my e-Squirt library shows a complete implementation of Obex over RfCOMM (including SDP).

Wireless LANs and IrDA - jt@hpl.hp.com
Created 9 November 01
Updated 5 June 03
Project hosted and sponsored by :

Download Brainboxes USB Devices Driver