Click here for the API reference documentation.
This file contains the the prototype definitions of the high level Modem Radio Control (MRC) APIs.
Radio Power Management
Radio Access Technology
Network Registration
Signal Quality
Home Network Information
Network Scan
Neighboring Cells Information
Radio configuration tree
It's important for many M2M apps to know details about cellular network environments (like network registration and signal quality). It allows you to limit some M2M services based on the reliability of the network environment, and provides information to control power consumption (power on or shutdown the radio module).
le_mrc_SetRadioPower()
API allows the application to power up or shutdown the radio module.
le_mrc_GetRadioPower()
API displays radio module power state.
le_mrc_GetRadioAccessTechInUse()
API retrieves the current active Radio Access Technology.
The application can register a handler function to retrieve the Radio Access Technology each time the RAT changes.
le_mrc_AddRatChangeHandler()
API installs a RAT change handler.
le_mrc_RemoveRatChangeHandler()
API uninstalls the handler function.
le_mrc_GetNetRegState()
API retrieves the radio module network registration status.
The application can register a handler function to retrieve the registration status each time the registration state changes.
le_mrc_AddNetRegStateHandler()
API installs a registration state handler.
le_mrc_RemoveNetRegStateHandler()
API uninstalls the handler function.
le_mrc_RegisterCellularNetwork()
API registers on a cellular network.
le_mrc_GetSignalQual()
retrieves the received signal strength details.
le_mrc_GetHomeNetworkName()
retrieves the Home Network Name. This value can be empty even if connected to a GSM network.
Call le_mrc_PerformCellularNetworkScan()
to fill a list of all network in sight. You can go through all Scan Information by calling le_mrc_GetFirstCellularNetworkScan()
and le_mrc_GetNextCellularNetworkScan()
.
For each Scan Information, you can call:
le_mrc_GetCellularNetworkMccMnc()
to have the operator code.le_mrc_GetCellularNetworkName()
to get the operator name.le_mrc_IsCellularNetworkRatAvailable()
to check is this is the radio access technology.le_mrc_IsCellularNetworkInUse()
to check if this is currently in use by the network.le_mrc_IsCellularNetworkAvailable()
to check if this is available.le_mrc_IsCellularNetworkHome()
to check if this is in home status.le_mrc_IsCellularNetworkForbidden()
to check if this is forbidden by the network.le_mrc_DeleteCellularNetworkScan()
should be called when you do not need the list anymore.
Usage example:
You must call le_mrc_GetNeighborCellsInfo()
to retrieve the neighboring cells information. It returns a reference of le_mrc_NeighborCellsRef_t
type.
When the neighboring cells information is no longer needed, you must call le_mrc_DeleteNeighborCellsInfo()
to free all allocated ressources associated with the object.
Then, you can use the following function to get the information: le_mrc_GetFirstNeighborCellInfo()
and le_mrc_GetFirstNeighborCellInfo()
allow to go among the single cell information retrieved with le_mrc_GetNeighborCellsInfo()
. These two functions return a reference of le_mrc_CellInfoRef_t
type. le_mrc_GetNeighborCellId()
gets the identifier of the cell specified with the le_mrc_CellInfoRef_t
parameter. le_mrc_GetNeighborCellLac()
gets the location area code of the cell specified with the le_mrc_CellInfoRef_t
parameter. le_mrc_GetNeighborCellRxLevel()
gets the signal strength (in dBm) of the cell specified le_mrc_CellInfoRef_t
parameter.
The configuration database path for the Radio is:
/ modemServices/ radio/ preferredOperators/ 0/ mcc<int> = <MCC_VALUE> mnc<int> = <MNC_VALUE> rat/ 0<string> = <RAT_VALUE> 1<string> = <RAT_VALUE> ... 1/ mcc<int> = <MCC_VALUE> mnc<int> = <MNC_VALUE> rat/ 0<string> = <RAT_VALUE> 1<string> = <RAT_VALUE> ... ... scanMode/ manual<bool> mcc<int> = <MCC_VALUE> mnc<int> = <MNC_VALUE> preferences/ rat/ 0<string> == <Rat> 1<string> == <Rat> 2<string> == <Rat> ... band/ 0<string> == <Band> 1<string> == <Band> 2<string> == <Band> ... lteBand/ 0<string> == <LteBand> 1<string> = <LteBand> 2<string> = <LteBand> ... tdScdmaBand/ 0<string> = <TdScdmaBand> 1<string> = <TdScdmaBand> 2<string> = <TdScdmaBand> ...
The preferred operators can be set using the following choices (string type):
The Radio Access Technology preferences can be set with the following choices (string type):
The 2G/3G Band preferences can be set with the following choices (string type):
The LTE Band preferences can be set by specifying the number of E-UTRA operating band, 0 to 43 except: 15, 16, 22, 23, and 26 to 32.
The TD-SCDMA Band preferences can be set with the following choices (string type): "A" to "F".
Copyright (C) Sierra Wireless, Inc. 2014. Use of this work is subject to license.