这是去年跟两个学生一起做OpenBTS时总结的一点笔记,贴出来吧,经常有人问OpenBTS的安装配置问题,如果搜到这里,可以做个参考。
请注意,这份安装笔记是针对OpenBTS-2.5.4版本的。有点老了,装2.8版本的话就不要看了啊。

OpenBTS操作指南

一.安装配置OpenBTS和相关软件

1. 安装GNUradio:

A.安装依赖库:

1
2
3
4
5
6
7
sudo apt-get update
sudo apt-get -y install swig g++ automake libtool python-dev libfftw3-dev \
libcppunit-dev libboost1.38-dev libusb-dev fort77 sdcc sdcc-libraries \
libsdl1.2-dev python-wxgtk2.8 subversion git-core guile-1.8-dev \
libqt4-dev python-numpy ccache python-opengl libgsl0-dev \
python-cheetah python-lxml doxygen qt4-dev-tools \
libqwt5-qt4-dev libqwtplot3d-qt4-dev pyqt4-dev-tools

B.下载安装GNUradio:

下载gnuradio-3.2.2.tar.gz

1
2
3
4
5
6
tar xvzf gnuradio-3.1.3.tar.gz
cd gnuradio-3.1.3
./configure
make
sudo make install
sudo ldconfig

2. 安装依赖库libosip、ortp:

A.可以通过package Manager得到libosip和ortp的支持库,通过下面的方法得到:

1
sudo apt-get install asterisk libosip2-dev libortp7-*  

B.为了保证依赖库的版本符合要求仍通过通常./configure, make, make install process.的方法进行安装:

  • download libosip2-3.3.0.tar.gz
1
2
3
4
5
tar xvzf libosip2-3.3.0.tar.gz
cd libosip2-3.3.0
./configure
make
sudo make install
  • download ortp-0.16.1.tar.gz
1
2
3
4
5
tar xvzf ortp-0.16.1.tar.gz
cd ortp-0.16.1
./configure
make
sudo make install

3. 安装Asterisk:

  • download asterisdk-1.6.2.6.tar.gz
1
2
3
4
5
tar xvzf asterisdk-1.6.2.6.tar.gz
cd asterisdk-1.6.2.6
./configure
make
sudo make install

4. 安装OpenBTS:

1
2
3
4
5
tar xvzf openbts-2.5.4Lacassine.tar.gz.tar.gz
cd openbts-2.5.4Lacassine
./configure
make
sudo make install

5. 配置OpenBTS:

将app/下的openbts.example.config复制为openbts.config,通过修改openbts.config相关参数配置OpenBTS。

A. 设置PLMN(MCC+MNC),MCC为国家号,例如中国为460,MNC为网络号,例如中国移动为01和02。最好将OpenBTS的PLMN设置为手机prefer PLMN 列表中的PLMN号,使手机能够更为顺利找到OpenBTS。此处我们设置为460-02,为中国移动在1800MHz频段备用的PLMN号,一般国内的手机都将此PLMN号列入prefer PLMN列表。(后来我们一直用001 01这个号,是一个测试用的PLMN号,保证不会与运营商的网络冲突。)

B. 设置工作频段,此处我们使用900MHz频段,将频段设为900MHz。

C. 设置ARFCN,需要将OpenBTS的工作频点(ARFCN)设置为当前空闲的频点,通过usrp_fft.py扫描900MHz下行频段,找到空闲的频点(f)。900MHz下行频段的ARFCN可以通过公式ARFCN=(f-935)/0.2得到。此处我们使用35号频点(即942MHz)(这里我们是通过频谱扫描确定的频点,建议你们也先观察一下,看哪个频点是可用的。)

6. 配置Asterisk:

A. 将OpenBTS中AsteriskConfigure/文件夹下的sip.conf和extensions.conf的内容复制到/etc/asterisk/下sip.conf和extensions.conf。若使用自动注册用户程序,则不用对sip.conf和extensions.conf文件进行编辑。

B. 若使用手动注册,测、、则需修改sip.conf和extensions.conf文件,过程如下:

  1.     得到SIM卡的IMSI号
    

通过OpenBTS自身得到IMSI号,当手机试图接入OpenBTS时,会向OpenBTS发送IMSI号,可通过OpenBTS的CLI显示的信息中读出,如下所示:

1
2
3
4
RadioResource.cpp:152: AccessGrantResponder RA=0x15 when=0:1192710 age=25 TOA=0.0000
ChannelDescription=(typeAndOffset=SDCCH/4-0 TN=0 TSC=0 ARFCN=975) RequestReference=(RA=21 T1=3 T2=12 T3=24) TimingAdvance=0
MobilityManagement.cpp:119: LocationUpdatingController MM Location Updating Request LAI=(MCC=901 MNC=55 LAC=0x29b) MobileIdentity=(TMSI=0x49ffcddd)
MobilityManagement.cpp:172: LocationUpdatingController registration FAIL: IMSI=234100223456161
  1.     把上一步得到的IMSI号写入sip.conf中,示例如下:
    
1
2
3
4
5
6
7
[IMSI460004311159502] ; 460004311159502为IMSI号
callerid=IMSI460004311159502 <2102>;<>内为该手机的号码
canreinvite=no
type=friend
allow=gsm
context=sip-external
host=dynamic
  1.     在extensions.conf中[ sip-local ]中加入如下语句:
    
1
2
; This is a simple mapping between extensions and IMSIs.
exten => 2102,1,Macro(dialSIP,IMSI460004311159502);

重启Asterisk,在CLI中输入sip reload和dialplan reload。

在CLI中输入 sip show peers 可以看到所在线用户的ip和端口

7. 安装SMS服务器

将OpenBTS中的smqueue/文件夹下的smnet.cpp的第424行

1
2
char *p = strchr(str, ':');
char *host, *port;

改为:

1
2
3
const char *p=strchr(str,':');
const char *port;
char *host;

在smqueue/下输入:

1
make -f Makefile.standalone

将smqueue/下的smqueue.example.config复制为smqueue.config,即可。

二.运行OpenBTS和相关软件:

1. 运行OpenBTS

开启shell终端

1
2
cd openbts-2.5.4Lacassine/apps/
sudo OpenBTS (?大概是这么写的,不确定,因为我们另写了个脚本)

2. 运行Asterisk

另外开启一个shell终端

1
sudo asterisk -vvvvvc

3. 运行OpenBTS短信平台

另外开启一个shell终端

1
2
cd openbts-2.5.4Lacassine/smqueue/
sudo ./smqueue

三.手机接入OpenBTS:

1. 手机搜索和接入OpenBTS

  • A. 将手机搜索运营商方式从自动设为手动,这时手机会自动开始搜索网络,一般情况下,第一次搜索找不到OpenBTS的网络,只搜索到中国移动和中国联通。

  • B. 选择连接非手机的sim卡所在运营商的网络(如中国移动的sim卡来连接中国联通,这时,手机会显示无法进入该网络,并处于无网络的状态。

  • C. 重新进行手动搜索,这时会找到OpenBTS的网络(有时出现的是OpenBTS的PLMN号如460-02,或其他奇怪的名字,依手机的不同而定),选择OpenBTS的网络并接入。

四.改装OpenBTS软硬件,使其可以使用外接52M时钟

A.USRP硬件改装:

  • 在J2001处焊接SMA连接头,作为时钟输入, 小心不要弄断J2001与C927之间的连接线

  • 将0欧姆电阻R2029移至R2030的位置,从而阻断内部时钟

  • 将C925移至C926的位置

  • 去掉C294

B.GNUradio软件调整:

C. 对于GNUradio 3.1.3:

将usrp/host/lib/legacy/usrp_basic.h的第122行,改为

1
fpga_master_clock_freq () const { return 52000000; }

将usrp/host/lib/legacy/usrp_standard.cc第703行注释掉

1
//assert (dac_freq () == 128000000);

D. 对于GNuradio3.2或更高的版本:

将usrp/host/lib/legacy/usrp_basic.cc的第116行改为:

1
d_verbose (false), d_fpga_master_clock_freq(52000000), d_db(2)

将usrp/host/lib/legacy/usrp_standard.cc的第1024 行注释掉:

1
// assert (dac_rate() == 128000000);

将usrp/host/lib/legacy/db_flexrf.cc的第179行改为:

1
return 52e6/_refclk_divisor();

E. 做完以上调整后,重新编译GNUradio和OpenBTS,

在GNUradio的usrp/文件夹下,重新编译

1
2
make
sudo make install

重新编译OpenBTS,将openbts-2.5.4Lacassine/apps/OpenBTS.config文件中TRX.Path选项改为:

1
TRX.Path ../Transceiver52M/transceiver

四.附录

1.Asterisk的sip.conf配置示例

1
2
3
4
5
6
7
8
9
10

[IMSI460004311159502] ;手机用户sim卡的IMSI号
callerid=IMSI460004311159502 <2102>
canreinvite=no
type=friend
allow=gsm
context=sip-external
host=dynamic


2.Asterisk中extensions.conf的配置示例

1
2
3
4
5
6

[sip-local]
; local extensions
; This is a simple mapping between extensions and IMSIs.
exten => 2102,1,Macro(dialSIP,IMSI460004311159502);