OsmocomBB now performing location updating procedure against GSM cell
I haven't had much time for blogging recently, too much exciting work
going on at OsmocomBB:
- we now have simplistic support for Uplink (transmit) on SDCCH/4
- we have a minimal Layer2 (LAPDm) implementation
- we can send LOCATION UPDATING REQUEST to the network, and receive
the respective response
- there's wireshark integration, i.e. all packets on the L1-L2 interface
can be sent into wireshark for protocol analysis
There are still many limitations, but this is a major milestone in the project:
We have working bi-directional communication from the phone to the network!
The limitations include:
- The cell has to use a combined CCCH (SDCCH/4 on timeslot 0)
- The cell has to use no encryption/authentication
- The layer2 is not finished, especially re-transmissions will not work yet
- There's no power control loop yet
- There's no timing advance correction
However, most of those are more or less simple we know what needs to be
done, its just a matter of getting it done kind of tasks. There are no big
unknowns involved, and particularly no further reverse-engineering of the hardware
is required.
Also, the existence of a stable bi-directional communications channel between
the network and the phone means that anyone interested in working on the higher
layers can now actually do so. Completing and testing layer2 as well as
RR/MM/CC on layer3 is a major task in itself, and it definitely requires
the lower layers to be there.
The other good part is that development of layer2 and layer3 can happen
entirely on the host PC, where debugging is much easier and there's no need for
cross-compilation and we can use all the usual debugging options (gdb,
valgrind, ...)
I'm now almost heading off for holidays (starting March 10), so don't expect
any major progress from me anytime soon. I hope other interested developers
will be able to take it from here and fill in some missing gaps until I'll get
back.
[ /gsm/osmocom-bb |
permanent link ]
Looking for documentation on sunplus SPMA100B
In the Motorola/Compal C155 phone
supported by OsmocomBB, we have found a ringtone
melody chip called SPMA100B from sunplus.
As strange as it might seem, this is the only part used in the phone for which we have
not been able to find any kind of programming information. So if you know anything
about how to program this part from software (register map, programming manual, ...)
please let me know!
And no, we don't need electrical/mechanical data sheets, thanks :)
[ /gsm |
permanent link ]
Restructuring OpenBSC and OsmocomBB code
I've spent the better part of the day with , renaming files/functions/include paths, Makefiles, autotools and the
like.
The result of this is a new sub-project called libosmocore that
gathers all the shared code between the network-side GSM implementation
OpenBSC and the phone-side implementation OsmocomBB. The library is
portable enough that it can run on a proper OS (like GNU/Linux) but
also be cross-compiled to work on the actual phone without any OS.
On the other hand we now have a master Makefile in OsmocomBB to build
libosmocore for host PC and target (phone), as well as the osmocon
and layer2 host programs and the phone firmware itself.
Let's hope I can now return to writing actual code...
[ /gsm/osmocom-bb |
permanent link ]
Announcing OsmocomBB: Free Software / Open Source GSM Baseband firmware
Last, but not least, I am proud to announce the OsmocomBB project publicly. During the last
7 weeks, a small group of skilled developers has been working on this
It has now reached a point where we can
- scan the spectrum for the strongest signal GSM channels
- lock onto them and performing AFC (automatic frequency control)
- decode the SCH burst to obtain BSIC and GSM frame time
- decode the BCCH of the cell, pass it over to the host PC and feed it into
wireshark
Since this in itself is a valuable and useful milestone of the project,
it was the ideal opportunity to take this project public.
There's still a lot of work to be done in many areas. Most of them are not
even related to the GSM air interface. So if you're familiar with C
development on an ARM7TDMI based microcontroller, know your way around
I2C and SPI, are familiar with the GNU toolchain for ARM and want to
help us out: Please join the baseband-devel mailing
list right away!
[ /gsm |
permanent link ]
In six weeks from bare hardware to receiving BCCHs
After six weeks of full-time hacking, with the help of a few friends, we have
made it to receiving actual BCCH data from a GSM cell.
So what does this mean? As I have indicated publicly at the 26C3 conference:
Now, that we have managed to create a working GSM network-side implementation
(OpenBSC) during the last year, we will proceed to do the same with the phone side.
Initially we spent quite a bit of thinking on building our own custom hardware.
But while planning for the first prototype, we realized that it would simply
distract us too much from what we actually wanted to do. We don't want to take
care of component sourcing, prototype generations, quality assurance in
production, production testing, etc. -- All we want is to write a Free Software
GSM protocol implementation for a phone.
Unfortunately (as usually in the industry), the silicon and device makers do
not publish sufficient documentation about their devices to enable third-party
developers to go ahead and write their own software: The never ending
problem of Free Software in many areas beyond more-or-less standardized
hardware like in the PC industry.
So, if you want to write Free Software for such a device, you have two options:
- Reverse engineering the existing hardware and writing your code based on
that information
- Building your own hardware and then writing the software you wanted
to write.
I've been involved in both approaches multiple times while looking only at the
application processor (the PDA side) of mobile phones: OpenEZX and gnufiish are
two more or less abandoned projects aimed at reverse engineering. Openmoko was
the project that had to build its own hardware as a dependency to be fulfilled
before writing software.
If you're not a company and don't want to sell anything, the reverse
engineering approach looks more promising. You can piggy-back on existing
hardware, don't need to take care of sourcing/production/certification/shipping
and other tedious bits.
If you are a company and want to generate revenue, then of course you want
to build the hardware and ship it, as it is what you derive your profits
from.
So, just to be clear on this: Neither OpenEZX, nor gnufiish nor Openmoko were
ever about writing Free Software for the GSM baseband processor, i.e. the beast
that exchanges messages with the actual GSM operator network. But this is what
we're working on right now.
It's about time, don't you agree? after 19 years of only proprietary software
on the baseband chips in billions of phones, it is more than time for bringing
the shining light of Freedom into this area of computing.
To me personally, it is the holy grail of Free Software: Driving it beyond the
PC, beyond operating systems and application programs. Driving it into the
billions of embedded devices where everyone is stuck with proprietary software
without an alternative. Everybody takes it for granted to run megabytes of
proprietary object code, without any memory protection, attached to an
insecure public network (GSM). Who would do that with his PC on the Internet,
without a packet filter, application level gateways and a constant flow
of security updates of the software? Yet billions of people do that with
their phones all the time.
I hope with our work there will be a time where the people who paid for their
phones will be able to actually own and control what it does. If I have paid
for it, I determine what software it runs and when it send which message or
doesn't.
Oh, getting back to what our work: It will be published as soon as it is
sufficiently stable and fit for public consumption. You won't be able
to make phone calls yet, but we'll get there at some later point this
year.
[ /gsm |
permanent link ]
Symbian is Open Soruce - Really?
In recent news, the Symbian Foundation announced that "All 108 packages
containing the source code of the Symbian platform can now be downloaded from
Symbian's developer web site". This is great news!
This morning I tried to look at the parts most interesting to me: phonesrv
(implementing call engine, cell broadcast and SIM toolkit APIs) and poc
(implementing push-to-talk). Their pages don't have the usual "source code"
tab at the bottom right which links to mercurial and tarball download pages!
Either I'm too stupid, or I am unable to find any source code for those two
components. I'm quite sure something essential like the API's for making phone
calls are considered part of the Symbian platform. So how does that match
with the statement that all packages containing the Symbian platform can now
be downloaded?
[ /gsm |
permanent link ]
Sorry for new blog updates
I've been busy day and night, hacking away on my latest pet project in the GSM
field. In fact, it's been a long time since I've been able to dedicate so
much time and energy into one particular project, without many distractions at
all. The project is now finally looking quite promising and making nice
progress throughout the last three weeks.
If progress continues, I hope in another week I'll be able to reveal what this
is all about. I haven't felt this level of excitement since the early days of
Openmoko :)
[ /gsm |
permanent link ]
Illusions about MagicJack at CES
Many people have pointed out the MagicJack Femtocell product that has been announced at CES. I cannot really understand the big hype and news about it. Why? read further...
On the technical side, there is hardly anything new. Using projects like
OpenBTS or OpenBSC, you can run your own GSM network and connect it to VoIP.
Sure, the retail price of the MagicJack is much lower, but that's the economics
of scale. As soon as OpenBSC support for one of the recent femtocells is done,
we also have a much lower cost solution to the same problem.
On the legal and business side, I can see many problems for MagicJack:
- To operate equipment in the GSM or 3G spectrum, you need a license. Since
a nationwide GSM operator license is very expensive in about any country of the
world, it is economically not an option. Selling the MagicJack devices without
a license and leaving the spectrum license to the user will not work, or at least
not long, since regulatory authorities and commercial operators are not going to
let anyone deploy systems that interfere with their networks.
-
If you keep the Operator's SIM in the phone, and use that SIM on your own
network you might at least violate the terms of services of the operator. The
SIM card normally belongs to the operator, and it is part of the users business
relationship with that operator. As such, you can not really use it with other
networks. Sure, if you do this at home with your OpenBTS/OpenBSC installation,
nobody will care. But if somebody is doing this commercially, and in a way
that affects the sale of talk time of the regular operators, again it will not
take long until the commercial operator will sue you.
-
Security. If you run your phone with a "foreign" SIM, you do not know the Ki
on the SIM and thus cannot do cryptographic authentication and/or encryption.
This is a big security issue. It is once again not an issue in your personal
testbed setup, but it is going to be one if you do this at large scale as a
mass market product.
So, as you can see: It's neither technically something exceptionally new,
nor is it something that has a very promising business or legal outlook. The
only way how a product like this would work is if it is authorized by the
respective operator. But why would the operator authorize something that will
take talk time away from his network and thus his revenue stream?
[ /gsm |
permanent link ]
Planning for a GSM development board
I've finally found enough spare time to work on detailed plans for a GSM
development board. The idea here is to have a 100% open hardware design
with 100% free software that provides an inexpensive platform for GSM
related R&D.
Initially the focus is on having a board that can behave like a GSM cellphone,
next steps would be to have a multi-channel frequency-hopping receiver, and
finally the option of using it as a BTS.
The idea is fairly simple: Take a commercial off-the-shelf analog baseband and
RF circuit for GSM and attach it to a general purpose DSP, add some glue logic
and go ahead. But the devil is in the details:
- You want something where you can still find the parts on the market, but
which still has sufficient leaked documentation that you can write an open
source driver for it.
- The requirements for a MS and a BTS are quite different. A phone never
needs to continuously receive and transmit in all timeslots, e.g.
- The requirement for a multi-channel frequency-hopping receiver is mainly a
high number of receiver circuits, so the solution needs to scale to a larger
number of receivers.
- The analog baseband circuits often have quite obscure control interfaces
which need to be driven. Custom peripherals in programmable logic (CPLD/FPGA)
are required.
- The TDMA nature has strict timing requirements. Normal processors and
software-based mechanisms are not sufficient to trigger the required events
and their sequencing at a high enough precision.
Anyway, there is sort of a first plan now, and the next weeks and months will
be spent with refining the plans and building a first proof-of-concept
prototype. Once that has proven to work, we want to go ahead with finishing
the design for a real board, to be manufactured in sufficient quantities for
interested parties.
Unless you have worked in GSM phone or base station hardware design or have a
similar level of EE and DSP skills, please refrain from contacting me right
now about how to join the project. We want to focus on getting things going
first, then make a public release at a point where there is something that
works sufficiently well that we can support a larger community of developers.
[ /gsm |
permanent link ]
2010-01-02 / 2pm CET: Radio Interview at Deutschlandradio
The German radio station Deutschlandradio Kultur has invited
Constanze Kurz (46halbe) and myself for interviews during today's Breitband
radio show. We'll be talking about the 26C3, the Chaos Computer Club and -
of course - GSM [in]security.
[ /gsm |
permanent link ]
|