Exploring Android – Part 6 – Profiles

One of the absolute must have's for me I use quite heavily on my Symbian phone today is profiles with which I can configure the phone's behavior with the touch of a button. Especially the functionality to silence the phone in general and only allow it to ring for a select few phone numbers is a real must for me. On Android there is no such functionality out of the box. Either the phone rings or it doesn't independently of the number of the caller. So I started to look for something in the Android market and found "Auto Ring" which fits my needs quite nicely. When Auto Ring is installed one can select the numbers out of the phone book which will make the phone ring when the phone is either in "silent" or "vibrate only" mode. Works great and another important piece of my Android puzzle gets solved this way!

Chipset Digging With Android

As a "radio" man, I'm quite interested in how applications and mobile device operating systems communicate with the part of the device responsible for the cellular data connectivity not only in terms of transmitting and receiving user data packets but also how to connectivity to the cellular network is controlled. Here's how it works in Android:

Application Layer

For application layer programs in the Dalvik Virtual Machine, information about the current state of the cellular network can be obtained via the android.telephony package. In the package there are a number of classes with methods to query the current type of network (e.g. GSM, UMTS), information on the current cell such as the cell ID for GSM or the primary scrambling code (PSC) for UMTS cells, signal strength and quality and also detailed information about neighboring cells found, including signal strength and quality.

Another package of interest in this regard is android.net. This package contains classes and methods to discover the type of connectivity (e.g. WiFi or cellular), own IP and DNS server information. In other words, an application can find out a lot of technical information from the physical layer up to the IP stack.

Operating System

From an operating system point of view the radio layer information has to be retrieved from the piece of hardware that is responsible for cellular connectivity. This is done via an abstraction library, the Radio Interface Layer (RIL) that offers a hardware independent interface to the operating system and higher layers to query such information and receive unsolicited information from the radio chip about events such as cell changes.

On the other end, the RIL communicates with the radio chip via a non-standardized interface with Google giving a reference implementation based on well known Hayes AT-commands (more on that below). Here's a link with some more infos on what vendors have to do if they want to customize the radio hardware facing side of the RIL. Over this interface, pretty much anything about the radio can be controlled, including retrieving and modifying information stored in files on the SIM card. This link contains an interesting AT-command log traced while a circuit switched call was established. Further details about the at commands can be found in 3GPP TS 27.007

Hardware

Remains the question of where the radio stack is running on a mobile device. In some mobiles a dedicated chip is used while in others, a single chip is used that contains both the processor(s) for the radio stack and the processor(s) for the application layer, i.e. the processors that Android runs on. The radio processor(s) and the application processor(s) run independently from each other.

In the case of the first Android device, the HTC Dream, also known as the G1, a Qualcomm MSM7201A system on a chip is used as per the Wikipedia entry for the device. That's of course an old and slow chipset platform compared to the dual-core application processors running at GHz speeds in 2011, but that doesn't really matter from a radio/application separation point of view. On the Wikipedia page for the chip it is stated that than an ARM11 core is used for the application processor, while an ARM9 core is used for the radio stack. In other words, the RIL described above runs on the ARM11 core and communicates via an interface to the ARM9 core that executes the radio stack independently, asynchronously and in real time from the application processor.

That separation comes in very handy from an Android development point of view because apart from the RIL, the 2G/3G radio code is completely independent and is even running on a different hardware unit or even on a different chip. Android and the radio OS can thus evolve completely separately from each other. If you look at it from the radio stack of things, it couldn't care less which application OS is running on the other processor, it just delivers its services to Android, Symbian, WP7 or any other OS sitting next door.

This separation is very similar to a scenario in which a 3G USB dongle is used as a modem and a notebook or netbook that runs the operating system (Windows, Linux, Mac OS). Between the 3G dongle (the radio) and the notebook (the application processor), USB is used as the interface. And if you dig a bit deeper, the afore mentioned AT commands are used to initiate and tear down IP connections (PDP contexts) and to control the radio in general (e.g. manual network selection, report of signal strengths, etc.). The RIL in Android in other words is doing something very similar as the PPP daemon in Linux or the dial-up network support in Windows.

And finally, here are two links that show how this is implemented on the circuit board. The first one shows the solution described above, i.e. radio processor and application processor in the same chip in the case of the G1. In the case of the Nokia N8, radio processor and application processor are implemented in two separate chips (Texas Instruments baseband processor and Samsung Application processor) as shown and described here. The Nokia N95 has a similar separation with TI providing both the radio and the application processor chips as shown here. The hardware diagram shows this very nicely.

UMTS 900 in London – A Tough Decision

Recent press reports (e.g. here and here) revealed that O2 UK has expanded their 3G service to the 900 MHz band in London and other big cities in the UK. Quite a surprising move for me since the common perception is that there is not enough bandwidth in the 900 MHz range to allow operators to remove a 5 MHz chunk from GSM services in busy cities and use it for UMTS in this band. So how is this possible in the UK from a technical point of view?

After some digging I have found the two references (here and in particular here) that suggest that in the UK, the 2×35 MHz bandwidth in the 900 MHz band is only shared between two network operators. That makes things very easy from a technical point of view as each operator has much more spectrum compared to countries in which up to four network operators share the resource.

In a first instance, this is very good for customers since 3G indoor coverage should be considerably enhanced by this. Personally, I can't wait to come to London again to get some first hand experience.

From a competitive point of view the move by Ofcom to allow the incumbent two operators to keep all the spectrum and to use it for more than just GSM (refarming) must have been a very difficult one as it puts the other operators at a disadvantage in the short and medium term. Until they can get similar spectrum, e.g. in the 800 MHz band, until manage to deploy a network and until they can get devices, a significant amount of time will pass.

And here's why: The bandwidth auctions for the 800 MHz band in the UK is set for 2Q2012 and there are still some question marks attached. And once that spectrum is allocated it is most likely going to be used for LTE. That's good for high speed Internet access with 3G dongles and embedded 3G/LTE modules but that still leaves the LTE voice problem to be solved. Here's a post of mine from back in 2008 describing the issue. It's 2011 now and I don't see that the industry has moved an inch closer to a solution (dual radio mobiles don't count).

It's not the additional 5 MHz that is the business advantage, it's the indoor coverage. And smartphone owner don't care only for 2G indoor coverage they want fast Internet access as well. According to this report (again, but see (*) below) the 900 MHz operators have to pay a yearly fee to compensate for the fact that 2100 MHz 3G operators would have to build three times more base stations in order to reach a similar coverage. But that's easier said than done, just imagine how an operator could triple the number of base stations in London. I wonder if that yearly fee (how much is it by the way?), which in theory should make tariffs more expensive with the 900 MHz operators, will be enough to ensure ongoing competition between four network operators. I am a bit skeptical.

Would it have been better to give some of the 900 MHz spectrum to other network operators? Difficult question. Perhaps it would have been a bit more fair in that band but it would also have meant that, according to current wisdom, there would have been no 900 MHz 3G in the UK, just like in other countries. That leaves the 800 MHz digital dividend band for fast Internet services with good indoor coverage in cities and economical rural coverage like in other countries. Unfortunately, the bandwidth of 30 MHz there is not enough for four operators, three is the best you can reasonable do here.

Tough choices!

(*) P.S.: The article states that EE uses 1800 MHz for 3G services. That is unlikely as there are no 1800 MHz 3G devices on the market today.

doesBenefitFromBatteryConsumptionOptimisation

A bit of a strange post title today but fitting the tech deep dive. When recently looking for something in the UTMS RRC Specification Document (3GPP TS 25.331) I noticed a parameter introduced in Release 6 of the specification which is called "deviceType". The parameter is included for example in the ue-radioAccessCapabilities Information element in the RRC Connection Setup Complete message. By default its value is "doesBenefitFromBatteryConsumptionOptimisation" but can be set to the device to "doesNotBenefitFromBatteryConsumptionOptimisation". No further explanation is given in the spec. I have to say I'm intrigued as to me it looks like something that could be used on top of the Fast Dormancy and Continuous Packet Connectivity extensions. So far the world has mostly looked at these two and I think the combination of the two of them makes a good package indeed as I described here.

A combination of FD and CPC makes a lot of sense for battery driven devices. But what about devices that do not require an optimization to conserve battery power? UMTS Modules in netbooks for example do not have the same battery capacity restrictions and here it might be better, both for the user and the network, to keep the device in Cell-DCH state (with CPC on top) for a much longer time if the user is actively using an application that requires frequent exchanges with a server on the Internet. For the network, fewer state changes would be required while on the UE side, no state changes mean that data can be delivered more quickly after the user has, for example, clicked on a link.

One could even imagine that the parameter could be used to configure CPC in a different way depending on the type of device. For battery constrained devices, CPC could be configured with larger transmission/reception gaps to conserve energy, while for other devices, shorter gaps could be configured for faster reaction times.

But o.k., let's first let the industry figure out how to do FD (Release 8) and CPC well before going to the next level of optimization…

 

What Happened To 2D Bar Codes?

For many years I've had a 2D bar code at the side of my blog to help people to get to my blog more easily on their mobile device when they discover it on their notebook or desktop PC. But these days I wonder if it is really still necessary!? While seeming to be very popular in Japan, bar codes to get further information haven't really caught on anywhere else. Every now and then I see a 2D bar code on a poster but if I'm really interested I'd rather type in the name of the product and let Google or Bing guide me to the website. And for me it's even more convenient, as making a search query with a single term even with a virtual keyboard is still easier than trying to remember where to find and how to use the 2D bar code reader application on my mobile device. What do you think, where will the 2D bar code story go?

Spectrum Usage Comparisons

How much spectrum is used in the US today for GSM/CDMA/UMTS today vs. in a typical country in Europe? Here's a couple of thoughts on this:

In the US there are mainly two bands used today:

850 MHz US (vs. 900 in Europe)

First, there's the 850 MHz band, used for GSM, CDMA and UMTS services. The bandwidth is 25 MHz according to this link. From my point of view that pretty much compares with the usage of the 900 MHz band in Europe which has a bandwidth of 35 MHz. Here, however, it is used for GSM only in the majority of cases and only few countries such as Finland and France also use it for UMTS in rural areas. In practice I guess it is quite tough for US carriers to squeeze both voice and broadband data services in a 25 MHz band.

1900 MHz Us (vs. 1800 in Europe)

The second major band used in the US is the 1900 MHz band with a bandwidth of 60 MHz. Again, this compares to the 1800 MHz band in Europe, which is 75 MHz wide. How much of these bands is used on each side of the Atlantic I am not quite sure but I would assume that in the US quite heavy use is made as based on it's width it must be the main band for data services. In Europe on the other hand, the 1800 MHz band is mostly used for voice services and quite a bit is still unused today. That might change though as a number of carriers have announced that they will start using the 1800 MHz resources for LTE.

1700/2100 MHz

And then there is this third band, in the 1700 MHz area for uplink transmissions and in the 2100 MHz area for downlink transmissions with a width of 45 MHz. Today, as far as I know, only T-Mobile uses it for UMTS services but other major carriers have significant (unused) holdings as well as discussed in a previous post. As only one network operator uses it, I don't think it can be compared today to the 2100 MHz band in Europe which has a width of 60 MHz and is used intensively by 3 to 4 network operators per country for UMTS services.

Other bands and the future

Yes, other bands should not be forgotten but from what I can tell they are not playing an important role just yet. There's around 30 MHz of spectrum in the 700 MHz range in the US that Verizon has just started to use 10 MHz for its LTE services. And then there is the 2500 MHz band used by Clearwire for WiMAX. The former compares to the 800 MHz digital dividend band in Europe that has just started to see intensive usage by a number of operators. A definite advantage on the European side is that the 30 MHz are all in one chunk while the 700 MHz resources in the US are cut into several chunks with uplink and downlink turned bottom up on one chunk, probably to protect TV transmissions. That probably complicates transceiver design for devices aiming to support more than just one chunk compared to the straight forward approach of the 800 MHz digital dividend band. And then on the European side of course, there's the 2600 MHz "LTE" band with a total of 70 MHz of bandwidth.

No doubt, this view is a bit "Europe biased" but when looking at it I can't help the impression that things are a bit smoother and broader outside the US!?

 

Malta: Antennas in a Ruin

Ruin1 Here are a couple of pictures from a somewhat special antenna placement on Malta. In the midst of a ruin, one of the Maltese network operators has installed, rather ad-hoc, a base station. At first I thought that a ruin might not be the best place for a BTS but on the other hand, I don't think that ruin is going anywhere in the next decade and is unlikely to be demolished either. And the rent for the network operator is probably quite cheap as well. The second picture shows how well the antenna is hidden. The black color makes the antenna blend in with the black background perfectly so most people will likely never notice it despite it being only a meter or so away. On the third picture I used a different setting on the camera and the support of the flash to make the antenna more visible. That's how you see it once you've become aware of it. An interesting installation and probably one of the reasons why both 2G and 3G coverage is excellent on the island. 

Ruin2 Ruin3

Who Owns and Uses AWS Spectrum

While doing a bit of background research on the amount of wireless spectrum available and used in the US today (more on that in a future post) I had a closer look at the AWS band. The AWS band is mostly used in North America today and encompasses a bandwidth of 45 MHz in the 1700 MHz frequency range for uplink transmission and another 45 MHz for downlink transmission in the 2100 MHz range.

Here's a link that shows who owns how much of that spectrum in the US. T-Mobile US seems to be the only active user today for its UMTS services but pretty much every one else including Verizon and I suppose AT&T (through Cingular) have a chunk as well and might use it in the future for UMTS or LTE services.

But like T-Mobile US, whoever starts using that band will require specific devices supporting that band. For T-Mobile US things have improved a bit in the last year or so with quite a few devices supporting the band now, including all new Symbian3 devices that are even pentaband UMTS capable, i.e. supporting all three US bands and the two major bands used in the rest of the world.

So in other words, most parts of the AWS band is still unused in the US at the moment.

Malta – Go Mobile and Internet Access – A Near Miss

This week I was in Malta for a couple of days and as usual I was looking for some affordable local tariffs for wireless Internet access with one of the 3G operators on the island.

Offers from both Vodafone and Go Mobile sounded promising and reception in the hotel room was equally good so I let chance decide which one to take. Vodafone SIMs were sold out in two tourist shops I tried but I was able to get a Go Mobile SIM card with the second one. No registration, they are just sold over the counter for 10 euros and an extra 10 euros for some credit to activate their internet offer for 4 euros for 10 days, 350 MB max. This should do for the vacation. So far so good. Activation of the SIM card was straight forward by just calling a short code and activation of the Internet offer was done quickly as well by sending an SMS with the name of the offer which was confirmed within the minute. What didn't quite work as expected was that the line was not provisioned for packet access, i.e. the GPRS attach was always rejected. Strange, you can book an Internet offer but GPRS services are not activated at the same time?

So I first called the customer help and top-up line (123), or at least tried to, as whenever I pressed the option in the voice based menu for a customer representative the call was released. Real good customer service… After the third time I gave the leaflet that came with the SIM card a closer look and found another direct number for the customer help line. Fortunately there was an English help-desk so I explained the issue without getting too technical. The support person insisted to send me an SMS to configure my phone despite me explaining several times that it's not the phone but the network that needs to be configured. I gave up in the end hoping that the SMS configuration would perhaps also trigger the corresponding network parameters for my line to be set up. Unfortunately it didn't. I was almost prepared to give up and search for a Vodafone SIM but wasting 20 Euros is a bit much. So I decided to give them a final call. I ended up with the same support person as earlier, explained to him the issue again and this time gave him the full technical issue –> "Configure my line in the HLR for GPRS services". I was put on hold for a couple of minutes so I guess he spoke to a network technician. When he came back he told me that things should be working now so I restarted the phone and indeed, the GPRS attach went through this time.

Fine, I had Internet access now but this raised a number of questions:

  • Why were packet services not activated in the first place?
  • Why weren't they activated when I bought the Internet bundle via SMS?
  • Why was the call to the help line not working via the general number?
  • Why did it take two calls to get things working despite a precise error description?

Without technical background knowledge I don't think I would have gotten it to work. Also I was quite glad I had a Symbian phone with me because here one can see on the idle screen why things weren't working (the GPRS attach already failed). On other devices based on Android, for example, this information can't be seen at all.

So, Go Mobile, if you read this, have a look at your back-end procedures to see how they can be streamlined to make things a bit smoother. Oh and yes, by the way, make the default APN work so people don't have to guess the APN for general Internet access after the GPRS attach works (which is 'rtgsurfing' by the way).