Virtual Um » History » Version 4
In July 2017, the Osmocom project has inroduced a Virtual Um interface (i.e. virtual radio layer) between OsmoBTS and OsmocomBB. This allows us to run a complete GSM network with 1-N BTSs and 1-M MSs without any actual radio hardware, which is of course excellent for all kinds of testing scenarios.
The Virtual Um layer is based on sending L2 frames (blocks) encapsulated via GSMTAP UDP multicast packets. There are two separate multicast groups, one for uplink and one for downlink. The multicast nature simulates the shared medium and enables any simulated phone to receive the signal from multiple BTSs via the downlink multicast group.
In OsmoBTS, this is implemented via the new
osmo-bts-virtual BTS model.
In OsmocomBB, this is realized by adding
virtphy virtual L1, which speask the same L1CTL protocol that is used between the real OsmcoomBB Layer1 and the Layer2/3 programs such as [[OsmocomBB:Mobile] and the like.
This page describes how to set up the Virtual Um layer. It assumes that you are famliar with classic operation of OsmocomBB and OsmoBTS and OsmoNITB with a real radio layer. In case of doubt, look at the genric documentation and tutorials for real RF hardware.
The big picture¶
Using OsmoBSC, OsmoMSC, OsmoHLR¶
The BTS side¶
Setting up OsmoBTS in its
osmo-bts-virtual flavor isn't really much different from setting it up with real hardware. The amount of required configuration at the BTS configuration file is (as always) very minimal, as in the GSM network architecture provides almost all relevant configuration to the BTS from the BSC.
An example configuratin file is provided as part of the osmo-bts source code:
The only parameters that you must ensure to match your local configuration are:
bts 0 band DCS1800 ipa unit-id 6969 0 oml remote-ip 127.0.0.1
- band must match the frequency band of your simulated radio layer
- ipa unit-id must match what you have configured on the BSC (OsmoBSC or OsmoNITB)
- oml remote-ip must point to the IP address to which your BSC is listening
You can subsequently start
osmo-bts-virtual using the following commands:
$ ./osmo-bts-virtual -c osmo-bts.cfg
whre of course
osmo-bts.cfgis the file name (in current directory or with path) of your configuration file, starting from the provided example.
You should get output like this:
((*)) | / \ OsmoBTS <000f> main.c:117 Unimplemneted bts_model_phy_instance_set_defaults <0017> control_if.c:788 CTRL at 127.0.0.1 4238 <0006> bts_model.c:175 Unimplemneted bts_model_ctrl_cmds_install <0010> telnet_interface.c:102 telnet at 127.0.0.1 4241 <0012> input/ipaccess.c:884 enabling ipaccess BTS mode, OML connecting to 127.0.0.1:3002 <000d> abis.c:207 Input Signal 4 received <0006> phy_link.c:58 PHY link state change shutdown -> connecting <0006> scheduler.c:216 Init scheduler for trx=0 <0007> scheduler_virtbts.c:637 starting VBTS scheduler <0006> phy_link.c:58 PHY link state change connecting -> connected <0006> phy_link.c:68 trx_set_avail(1) <0012> input/ipa.c:129 connection done. <0012> input/ipaccess.c:705 received ID get <000d> abis.c:101 OML Signalling link up
followed by the usual OML initialization sequence according to TS 12.21 and finally the RSL initialization:
<0000> rsl.c:299 Rx RSL BCCH INFO (SI1, 23 bytes) <0000> rsl.c:299 Rx RSL BCCH INFO (SI2, 23 bytes) <0000> rsl.c:299 Rx RSL BCCH INFO (SI3, 23 bytes) <0000> bts.c:374 Updated AGCH max queue length to 25 <0000> rsl.c:299 Rx RSL BCCH INFO (SI4, 23 bytes) <0000> rsl.c:506 Rx RSL SACCH FILLING (SI5, 19 bytes) <0000> rsl.c:506 Rx RSL SACCH FILLING (SI6, 13 bytes)
At this point your virtual BTS should be happily transmitting virtual radio frames. How can you verify that? Check in wireshark if you see it emitting UDP multicast packets to 220.127.116.11 port 4729. Those packets should be properly displayed/decoded by the wireshark GSMTAP dissector, and you should see e.g. the repeated transmission of the SYSTEM INFORMATION messages on BCCH.
If you cannot see related packets, it might be that your network stack (routing, packet filter) is configured in a way that multiast is disabled/filtered.