Useful mobile info :
  
   - *#06# – display the IMEI of the handset
 
   - C# way to send AT Commands to mobile
 
 There are few steps you need to perform in order to send AT commands to mobile using C#
  1> configure and open the serial port using using System.IO.Ports class
  - Serialport.open() and Serialport.close() API are available for doing the same.
  
  2>Write the AT command to opened COM port in step 1.
  Serialport.Writeline() API can be used for same. 
  
  Example code is pasted for doing same:
  
  private SerialPort portConfig = new SerialPort();
  
  // configure port 
  portConfig.PortName = COM4 ;
  .....
  .....
  //open the port
  portConfig.Open();
  
  // send AT command to dial a number
  portConfig.WriteLine("ATD" + mobileNumber + ";");
  
  
  
  
 AT commands are instructions used to control a modem. AT is the abbreviation of ATtention. Every command line starts with "AT" or "at". That's why modem commands are called AT commands. Many of the commands that are used to control wired dial-up modems, such as ATD (Dial), ATA (Answer), ATH (Hook control) and ATO (Return to online data state), are also supported by GSM/GPRS modems and mobile phones. Besides this common AT command set, GSM/GPRS modems and mobile phones support an AT command set that is specific to the GSM technology, which includes SMS-related commands like AT+CMGS (Send SMS message), AT+CMSS (Send SMS message from storage), AT+CMGL (List SMS messages) and AT+CMGR (Read SMS messages).
 Note that the starting "AT" is the prefix that informs the modem about the start of a command line. It is not part of the AT command name. For example, D is the actual AT command name in ATD and +CMGS is the actual AT command name in AT+CMGS. However, some books and web sites use them interchangeably as the name of an AT command.
 Here are some of the tasks that can be done using AT commands with a GSM/GPRS modem or mobile phone:
   - Get basic information about the mobile phone or GSM/GPRS modem. For example, name of manufacturer (AT+CGMI), model number (AT+CGMM), IMEI number (International Mobile Equipment Identity) (AT+CGSN) and software version (AT+CGMR).
- Get basic information about the subscriber. For example, MSISDN (AT+CNUM) and IMSI number (International Mobile Subscriber Identity) (AT+CIMI).
- Get the current status of the mobile phone or GSM/GPRS modem. For example, mobile phone activity status (AT+CPAS), mobile network registration status (AT+CREG), radio signal strength (AT+CSQ), battery charge level and battery charging status (AT+CBC).
- Establish a data connection or voice connection to a remote modem (ATD, ATA, etc).
- Send and receive fax (ATD, ATA, AT+F*).
- Send (AT+CMGS, AT+CMSS), read (AT+CMGR, AT+CMGL), write (AT+CMGW) or delete (AT+CMGD) SMS messages and obtain notifications of newly received SMS messages (AT+CNMI).
- Read (AT+CPBR), write (AT+CPBW) or search (AT+CPBF) phonebook entries.
- Perform security-related tasks, such as opening or closing facility locks (AT+CLCK), checking whether a facility is locked (AT+CLCK) and changing passwords (AT+CPWD).
 (Facility lock examples: SIM lock [a password must be given to the SIM card every time the mobile phone is switched on] and PH-SIM lock [a certain SIM card is associated with the mobile phone. To use other SIM cards with the mobile phone, a password must be entered.])
- Control the presentation of result codes / error messages of AT commands. For example, you can control whether to enable certain error messages (AT+CMEE) and whether error messages should be displayed in numeric format or verbose format (AT+CMEE=1 or AT+CMEE=2).
- Get or change the configurations of the mobile phone or GSM/GPRS modem. For example, change the GSM network (AT+COPS), bearer service type (AT+CBST), radio link protocol parameters (AT+CRLP), SMS center address (AT+CSCA) and storage of SMS messages (AT+CPMS).
- Save and restore configurations of the mobile phone or GSM/GPRS modem. For example, save (AT+CSAS) and restore (AT+CRES) settings related to SMS messaging such as the SMS center address.
Note that mobile phone manufacturers usually do not implement all AT commands, command parameters and parameter values in their mobile phones. Also, the behavior of the implemented AT commands may be different from that defined in the standard. In general, GSM/GPRS modems designed for wireless applications have better support of AT commands than ordinary mobile phones.
 In addition, some AT commands require the support of mobile network operators. For example, SMS over GPRS can be enabled on some GPRS mobile phones and GPRS modems with the +CGSMS command (command name in text: Select Service for MO SMS Messages). But if the mobile network operator does not support the transmission of SMS over GPRS, you cannot use this feature.
  
  14.1. Basic Commands and Extended Commands
 There are two types of AT commands: basic commands and extended commands.
 Basic commands are AT commands that do not start with "+". For example, D (Dial), A (Answer), H (Hook control) and O (Return to online data state) are basic commands.
 Extended commands are AT commands that start with "+". All GSM AT commands are extended commands. For example, +CMGS (Send SMS message), +CMSS (Send SMS message from storage), +CMGL (List SMS messages) and +CMGR (Read SMS messages) are extended commands. The general syntax of extended AT commands is straightforward. The syntax rules are provided below. The syntax of basic AT commands is slightly different. We will not cover the syntax of basic AT commands in this SMS tutorial since all SMS messaging commands are extended AT commands.
  
 Syntax rule 1. All command lines must start with "AT" and end with a carriage return character. (We will use <CR> to represent a carriage return character in this SMS tutorial.) In a terminal program like HyperTerminal of Microsoft Windows, you can press the Enter key on the keyboard to output a carriage return character.
 Example: To list all unread inbound SMS messages stored in the message storage area, type "AT", then the extended AT command "+CMGL", and finally a carriage return character, like this:
  
 AT+CMGL<CR>
  
 Syntax rule 2. A command line can contain more than one AT command. Only the first AT command should be prefixed with "AT". AT commands in the same command-line string should be separated with semicolons.
 Example: To list all unread inbound SMS messages stored in the message storage area and obtain the manufacturer name of the mobile device, type "AT", then the extended AT command "+CMGL", followed by a semicolon and the next extended AT command "+CGMI":
  
 AT+CMGL;+CGMI<CR>
  
 An error will occur if both AT commands are prefixed with "AT", like this:
  
 AT+CMGL;AT+CGMI<CR>
  
 Syntax rule 3. A string is enclosed between double quotes.
 Example: To read all SMS messages from message storage in SMS text mode (at this time you do not need to know what SMS text mode is. More information will be provided later in this SMS tutorial), you need to assign the string "ALL" to the extended AT command +CMGL, like this:
  
 AT+CMGL="ALL"<CR>
  
 Syntax rule 4. Information responses and result codes (including both final result codes and unsolicited result codes) always start and end with a carriage return character and a linefeed character.  Example: After sending the command line "AT+CGMI<CR>" to the mobile device, the mobile device should return a response similar to this:
  
 <CR><LF>Nokia<CR><LF>
  <CR><LF>OK<CR><LF>
  
 The first line is the information response of the AT command +CGMI and the second line is the final result code. <CR> and <LF> represent a carriage return character and a linefeed character respectively. The final result code "OK" marks the end of the response. It indicates no more data will be sent from the mobile device to the computer / PC.
 When a terminal program such as HyperTerminal of Microsoft Windows sees a carriage return character, it moves the cursor to the beginning of the current line. When it sees a linefeed character, it moves the cursor to the same position on the next line. Hence, the command line "AT+CGMI<CR>" that you entered and the corresponding response will be displayed like this in a terminal program such as HyperTerminal of Microsoft Windows:
  
 AT+CGMI
  Nokia
  
  OK
  
  15.1. Information Response and Final Result Code
 Don't forget the meanings of information response and final result code stated above, since you will see these two terms frequently as you go through this SMS tutorial.
  
 AT+CGMI  <-- Command line entered
  Nokia  <-- Information response
  
  OK  <-- Final result code
  
  15.2. Case Sensitivity of AT Commands
 In the SMS specification, all AT commands are in uppercase letters. However, many GSM/GPRS modems and mobile phones allow you to type AT commands in either uppercase or lowercase letters. For example, on Nokia 6021, AT commands are case-insensitive and the following two command lines are equivalent:
  
 AT+CMGL<CR>
  
 at+cmgl<CR>
 Result codes are messages sent from the GSM/GPRS modem or mobile phone to provide you information about the execution of an AT command and the occurrence of an event. Two types of result codes are useful to you when dealing with AT commands for SMS messaging:
   - Final result codes
- Unsolicited result codes
 
  16.1. Final Result Codes of AT Commands
 A final result code marks the end of an AT command response. It is an indication that the GSM/GPRS modem or mobile phone has finished the execution of a command line. Two frequently used final result codes are OK and ERROR. Only one final result code will be returned for each command line. Thus, you will not see both OK and ERROR in the response of a command line.
  
  16.1.1. The OK Final Result Code
 The OK final result code indicates that a command line has been executed successfully by the GSM/GPRS modem or mobile phone. It always starts and ends with a carriage return character and a linefeed character.
 Here is an example for illustration. Let's say you send the command line "AT+CMGL;+CGMI<CR>" to your GSM/GPRS modem. The AT command "+CMGL" is used to list SMS messages stored in the message storage area and the AT command "+CGMI" is used to get the manufacturer name of the GSM/GPRS modem. If everything works properly without any errors, the command line, together with the response returned, should be something similar to this:
  
 AT+CMGL;+CGMI<CR>
  <CR><LF>+CMGL: 1,"REC UNREAD","+85291234567",,"06/11/11,00:30:29+32"<CR><LF>
  Welcome to our SMS tutorial.<CR><LF>
  <CR><LF>Nokia<CR><LF>
  <CR><LF>OK<CR><LF>
  
 As mentioned earlier, when a terminal program such as HyperTerminal of Microsoft Windows sees a carriage return character, it moves the cursor to the beginning of the current line. When it sees a linefeed character, it moves the cursor to the same position on the next line. Hence, the command line you entered, together with the response returned, will be displayed like this in a terminal program such as HyperTerminal of Microsoft Windows:
  
 AT+CMGL;+CGMI
  +CMGL: 1,"REC UNREAD","+85291234567",,"06/11/11,00:30:29+32"
  Welcome to our SMS tutorial.
  
  Nokia
  
  OK
  
  16.1.2. The ERROR Final Result Code
 The ERROR final result code indicates that an error occurs when the GSM/GPRS modem or mobile phone tries to execute a command line. After the occurrence of an error, the GSM/GPRS modem or mobile phone will not process the remaining AT commands in the command-line string.
 Below are some common causes of error:
   - The syntax of the command line is incorrect.
- The value specified to a certain parameter is invalid.
- The name of the AT command is spelt incorrectly.
- The GSM/GPRS modem or mobile phone does not support one or more of the AT commands, command parameters or parameter values in the command-line string.
Like the OK final result code, the ERROR final result code always starts and ends with a carriage return character and a linefeed character.
 Here is an example for illustration. Suppose you want to instruct your GSM/GPRS modem to list SMS messages from the message storage area and get the manufacturer name of the GSM/GPRS modem. You intend to type the command line "AT+CMGL;+CGMI<CR>" but make a careless mistake by typing "+CMFL" instead of "+CMGL". The GSM/GPRS modem will return the ERROR final result code, as shown below:
  
 AT+CMFL;+CGMI<CR>
  <CR><LF>ERROR<CR><LF>
  
 As an error occurs when the GSM/GPRS modem processes "+CMFL", the GSM/GPRS modem stops the execution of the command line and so the second AT command "+CGMI" is not processed.
 If you type the second AT command "+CGMI" incorrectly instead of the first AT command "+CMGL", the GSM/GPRS modem will output the result of the execution of the AT command "+CMGL" before outputting the ERROR final result code, like this:
  
 AT+CMGL;+CGMU<CR>
  <CR><LF>+CMGL: 1,"REC UNREAD","+85291234567",,"06/11/11,00:30:29+32"<CR><LF>
  Welcome to our SMS tutorial.<CR><LF>
  <CR><LF>ERROR<CR><LF>
  
 As mentioned earlier, when a terminal program such as HyperTerminal of Microsoft Windows sees a carriage return character, it moves the cursor to the beginning of the current line. When it sees a linefeed character, it moves the cursor to the same position on the next line. Hence, the command line you entered, together with the response returned, will be displayed like this in a terminal program such as HyperTerminal of Microsoft Windows:
  
 AT+CMGL;+CGMU
  +CMGL: 1,"REC UNREAD","+85291234567",,"06/11/11,00:30:29+32"
  Welcome to our SMS tutorial.
  
  ERROR
 The final result codes OK and ERROR are available to all AT commands. Unlike OK and ERROR, the +CMS ERROR final result code is only available to SMS AT commands. It notifies you about the occurrence of a message service failure.
  
  16.2.1. The +CMS ERROR Final Result Code -- Notifies the Occurrences and Causes of Message Service Failures
 The +CMS ERROR final result code is returned when a message service failure occurs. An error code is provided for programmers to check what causes the message service failure. The +CMS ERROR final result code is specific to SMS AT commands, i.e. the +CMS ERROR final result code will only be outputted by AT commands that are used to perform tasks related to SMS messaging. Below are the SMS AT commands that may output the final result code +CMS ERROR:
   - +CMGC (command name in text: Send Command)
- +CMGD (command name in text: Delete Message)
- +CMGL (command name in text: List Messages)
- +CMGR (command name in text: Read Message)
- +CMGS (command name in text: Sending Message)
- +CMGW (command name in text: Write Message to Memory)
- +CMSS (command name in text: Send Message from Storage)
- +CNMA (command name in text: New Message Acknowledgement to ME/TA)
- +CNMI (command name in text: New Message Indications to TE)
- +CPMS (command name in text: Preferred Message Storage)
- +CRES (command name in text: Restore Settings)
- +CSAS (command name in text: Save Settings)
- +CSMS (command name in text: Select Message Service)
The syntax of the +CMS ERROR final result code is:
  
 <CR><LF>+CMS ERROR: error_code<CR><LF>
  
 Just as the final result codes OK and ERROR, the +CMS ERROR final result code always starts and ends with a carriage return character and a linefeed character. error_code is an integer that is associated to a certain error. A list of some error codes and their meanings can be found in "Table of +CMS Error Codes and Their Meanings".  As mentioned earlier, after the execution of a command line, only one final result code is returned. Hence, when an error occurs, you will not find both +CMS ERROR and ERROR in the command response. For errors related to SMS messaging, the +CMS ERROR final result code is returned. For other errors such as invalid command syntax and unsupported AT command, the ERROR final result code is returned as usual.
 Below shows some common causes of +CMS errors:
   - A SIM card is not present in the GSM/GPRS modem or mobile phone.
- The SIM card requires a password (e.g. PIN, PIN2, PUK and PUK2) but you have not entered it.
- An invalid memory index is assigned to an AT command.
- The memory of the GSM/GPRS modem, mobile phone or SIM card for storing SMS messages is full.
- The SMSC address is unknown or incorrect.
Following is an example that demonstrates the usage of the +CMS ERROR result code. Let's say there is only one SMS text message stored on our Nokia 6021 and it is stored in the memory location at index 1. If we enter the command line "AT+CMGR=11" (it means "to read the SMS message at memory index 11"), Nokia 6021 will return a +CMS error:
  
 AT+CMGR=11<CR>
  <CR><LF>+CMS ERROR: 321<CR><LF>
  
 As mentioned earlier, when a terminal program such as HyperTerminal of Microsoft Windows sees a carriage return character, it moves the cursor to the beginning of the current line. When it sees a linefeed character, it moves the cursor to the same position on the next line. Hence, the command line you entered, together with the response returned, will be displayed like this in a terminal program such as HyperTerminal of Microsoft Windows:
  
 AT+CMGR=11
  +CMS ERROR: 321
  
 To find out the meaning of the +CMS error code 321, go to "Table of +CMS Error Codes and Their Meanings". From there, we know that the read message operation failed because an invalid memory index was assigned to the AT command +CMGR.  Note that after the occurrence of a +CMS error, the GSM/GPRS modem or mobile phone will not process the remaining AT commands in the command line. Thus, if the command line sent to Nokia 6021 is "AT+CMGR=11;+CGMI" (+CGMI is the AT command for retrieving the manufacturer name of the GSM/GPRS modem or mobile phone), you will get the following result in Windows' HyperTerminal:
  
 AT+CMGR=11;+CGMI
  +CMS ERROR: 321
  
 But if the positions of the two AT commands in the command line are exchanged, Nokia 6021 will output the result of the execution of the AT command +CGMI before outputting the +CMS ERROR result code. Below is the result displayed in Windows' HyperTerminal:
  
 AT+CGMI;+CMGR=11
  Nokia
  
  +CMS ERROR: 321
  
  16.2.1.1. Table of +CMS Error Codes and Their Meanings
 The following table lists some of the +CMS error codes and their meanings.
  
     | +CMS error code | Meaning | 
  | 300 | Mobile equipment (ME) failure. Mobile equipment refers to the mobile device that communicates with the wireless network. Usually it is a mobile phone or GSM/GPRS modem. The SIM card is defined as a separate entity and is not part of mobile equipment. | 
  | 301 | SMS service of mobile equipment (ME) is reserved. See +CMS error code 300 for the meaning of mobile equipment. | 
  | 302 | The operation to be done by the AT command is not allowed. | 
  | 303 | The operation to be done by the AT command is not supported. | 
  | 304 | One or more parameter values assigned to the AT command are invalid. (For PDU mode) | 
  | 305 | One or more parameter values assigned to the AT command are invalid. (For Text mode) | 
  | 310 | There is no SIM card. | 
  | 311 | The SIM card requires a PIN to operate. The AT command +CPIN (command name in text: Enter PIN) can be used to send the PIN to the SIM card. | 
  | 312 | The SIM card requires a PH-SIM PIN to operate. The AT command +CPIN (command name in text: Enter PIN) can be used to send the PH-SIM PIN to the SIM card. | 
  | 313 | SIM card failure. | 
  | 314 | The SIM card is busy. | 
  | 315 | The SIM card is wrong. | 
  | 316 | The SIM card requires a PUK to operate. The AT command +CPIN (command name in text: Enter PIN) can be used to send the PUK to the SIM card. | 
  | 320 | Memory/message storage failure. | 
  | 321 | The memory/message storage index assigned to the AT command is invalid. | 
  | 322 | The memory/message storage is out of space. | 
  | 330 | The SMS center (SMSC) address is unknown. | 
  | 331 | No network service is available. | 
  | 332 | Network timeout occurred. | 
  | 340 | There is no need to send message acknowledgement by the AT command +CNMA (command name in text: New Message Acknowledgement to ME/TA). | 
  | 500 | An unknown error occurred. | 
 
 Unsolicited result codes are messages sent from the GSM/GPRS modem or mobile phone to provide you information about the occurrence of an event. For example, you can use the +CNMI AT command (command name in text: New Message Indications to TE) to request the GSM/GPRS modem or mobile phone to send the unsolicited result code "+CMTI" to your computer / PC every time a new SMS message is received from the SMS center.
 Here are the unsolicited result codes that are related to SMS messaging:
  
 +CDS
 A GSM/GPRS modem or mobile phone uses +CDS to forward a newly received SMS status report to the computer / PC.
  
 +CDSI
 A GSM/GPRS modem or mobile phone uses +CDSI to notify the computer / PC that a new SMS status report has been received and the memory location where it is stored.
  
 +CMT
 A GSM/GPRS modem or mobile phone uses +CMT to forward a newly received SMS message to the computer / PC.
  
 +CMTI
 A GSM/GPRS modem or mobile phone uses +CMTI to notify the computer / PC that a new SMS message has been received and the memory location where it is stored.
 There are four types of AT command operations:
   - Test operation. A test operation is used to check whether a certain AT command is supported by the GSM/GPRS modem or mobile phone.
- Set operation. A set operation is used to change the settings used by the GSM/GPRS modem or mobile phone for certain tasks.
- Read operation. A read operation is used to retrieve the current settings used by the GSM/GPRS modem or mobile phone for certain tasks.
- Execution operation. An execution operation is used to perform an action or retrieve information/status about the GSM/GPRS modem or mobile phone.
The command syntax for performing an operation will be described in detail in the following sections.
  
  17.1. Test Command -- Checks Whether a Certain AT Command is Supported
 A test operation is used to check whether a certain AT command is supported by the GSM/GPRS modem or mobile phone. All extended AT commands support the test operation. The syntax is:
  
 command=?
  
 where command is an AT command. When an AT command is used in the above syntax to perform a test operation, it is called a test command.
 Here is an example. The AT command +CGMI (command name in text: Request Manufacturer Identification) is used to get the manufacturer name of the GSM/GPRS modem or mobile phone. To test whether +CGMI is supported, you can make use of the test command "+CGMI=?". The complete command line that should be entered is:
  
 AT+CGMI=?
  
 If the GSM/GPRS modem or mobile phone supports the AT command +CGMI, the result code "OK" will be returned, like this:
  
 AT+CGMI=?
  OK
  
 If the GSM/GPRS modem or mobile phone does not support the AT command +CGMI, the result code "ERROR" will be returned, like this:
  
 AT+CGMI=?
  ERROR
  
 In the above example, the AT command +CGMI does not have any parameters. If the AT command to be tested has parameter(s), the parameter value(s) supported by the GSM/GPRS modem or mobile phone may be printed additionally. Below is an example that illustrates the format of the response. +COMMAND1 is a fictitious AT command that has four parameters.
  
 AT+COMMAND1=?
  +COMMAND1: (0,1),(0-10),(0,1,5-10),("GSM","UCS2")
  
  OK
  
 The supported values of each of the four parameters are enclosed in parentheses. Commas are used to delimit the parentheses and the values inside parentheses. A hyphen is used to indicate a range of values. The values inside parentheses can be of the string type.
 In the above example, the response of the test command "+COMMAND1=?" provides us the following information:
   - (0,1). The first parameter accepts either 0 or 1.
- (0-10). The second parameter accepts any integer between 0 and 10.
- (0,1,5-10). The third parameter accepts 0, 1 or any integer between 5 and 10.
- ("GSM","UCS2"). The fourth parameter accepts either the string "GSM" or "UCS2".
To a few AT commands, the test operation does not return the parameter values supported. Instead, it returns the values that are allowed to appear in the information response of the AT command. An example is the +CBC AT command (command name in text: Battery Charge). The +CBC command is used to retrieve the connection status and charge level of the battery of the mobile device. Two values are returned in the information response of the +CBC AT command. The format is:
  
 +CBC: connection_status,charge_level
  
 For example, if the battery is placed in the mobile device with no charger connected and the charge level is 80%, the result of the execution of the +CBC AT command will be:
  
 AT+CBC
  +CBC: 0,80
  
  OK
  
 If you run the test command "+CBC=?", all the supported values that are allowed to appear in the connection status field and charge level field will be provided. With my Nokia 6021, the result is:
  
 AT+CBC=?
  +CBC: (0,1),(0-100)
  
  OK
  
 "(0,1)" means the connection status field in the information response of the +CBC AT command can contain either 0 or 1, while "(0-100)" means the charge level field can contain any integer between 0 and 100.
 A set operation changes the settings used by the GSM/GPRS modem or mobile phone for certain tasks. The syntax is:
  
 command=value1,value2,...valueN
  
 where command is an AT command and value1 to valueN are the values you want to set. When an AT command is used in the above syntax to perform a set operation, it is called a set command.
 Here is an example. The AT command +CSCA (command name in text: Service Centre Address) is used to set the SMSC (SMS center) address for sending SMS messages. It takes two parameters that specify the SMSC address and type of address. To set the SMSC address to +85291234567, enter the following command line in a terminal program such as MS Windows' HyperTerminal:   
 AT+CSCA="+85291234567",145
  
 If the set command runs successfully, the result code "OK" will be returned:
  
 AT+CSCA="+85291234567",145
  OK
  
 Some AT commands have optional parameters. You can choose not to assign values to them. For example, the second parameter of the +CSCA AT command is optional. If no value is assigned to the second parameter, the GSM/GPRS modem or mobile phone will use the default parameter value, which is 145 if the SMSC address starts with "+" (the plus character). Hence, this command line:
  
 AT+CSCA="+85291234567"
  
 is equivalent to:
  
 AT+CSCA="+85291234567",145
  
 Typically the values you specified with set commands are placed in volatile memory. If the GSM/GPRS modem or mobile phone is switched off or rebooted, the values you specified with set commands will be gone. When the GSM/GPRS modem or mobile phone is powered on again, all settings are back to the defaults.
 For some commonly used settings, there are AT commands for saving/restoring the settings to/from non-volatile memory. For example, the AT commands +CSAS (command name in text: Save Settings) and +CRES (command name in text: Restore Settings) can be used to save and restore settings related to SMS messaging such as the SMS center address.
 A read operation retrieves the current settings used by the GSM/GPRS modem or mobile phone for certain tasks. The syntax is:
  
 command?
  
 where command is an AT command. When an AT command is used in the above syntax to perform a read operation, it is called a read command. The read operation is supported by all AT commands that are capable of the set operation.
 Here is an example that illustrates how to use a read command. The AT command +CSCA (command name in text: Service Centre Address) is used to set the SMSC (SMS center) address for sending SMS messages. It takes two parameters that specify the SMSC address and type of address. Suppose you set the SMSC address to +85291234567 in Microsoft HyperTerminal, like this:   
 AT+CSCA="+85291234567",145
  OK
  
 After that, if you enter the read command "+CSCA?", the GSM/GPRS modem or mobile phone will return the SMSC address and type of address that you set in the previous step:
  
 AT+CSCA?
  +CSCA: "+85291234567",145
  
  OK
 An execution operation is used to perform an action (for example, send or read an SMS message) or retrieve information/status about the GSM/GPRS modem or mobile phone (for example, retrieve the current battery charge level, battery charging status or radio signal strength of the mobile network). The syntax is:
  
 command=value1,value2,...valueN
  
 where command is an AT command and value1 to valueN are the values to assign to the AT command. If the AT command does not have any parameters, the part "=value1,value2,...valueN" should be omitted. When an AT command is used in the above syntax to perform an execution operation, it is called an execution command.
 Here is an example illustrating the use of an execution command. The AT command +CMSS (command name in text: Send Message from Storage) can be used to perform an execution operation to send an SMS message stored in message storage. It has three parameters. They specify the index of the memory location that stores the SMS message, the destination phone number and the type of the phone number respectively. To send the SMS message at index 1 to the phone number +85291234567, the following command line can be used:
  
 AT+CMSS=1,"+85291234567",145
  
 Some AT commands have optional parameters. You can choose not to assign values to them. For example, the third parameter of the +CMSS AT command is optional. If no value is assigned to the third parameter, the GSM/GPRS modem or mobile phone will use the default parameter value, which is 145 if the destination phone number starts with "+" (the plus character). Hence, this command line:
  
 AT+CMSS=1,"+85291234567"
  
 is equivalent to:
  
 AT+CMSS=1,"+85291234567",145
  
 Unlike set commands, execution commands do not store the parameter values assigned to them. So, no read command is available for retrieving the last parameter values assigned to an execution command. For example, if you send the command line "AT+CMSS?" to your GSM/GPRS modem or mobile phone, the ERROR result code will be returned:
  
 AT+CMSS?
  ERROR
 Suppose you have connected your GSM/GPRS modem or mobile phone to your PC / computer and started a terminal program (such as HyperTerminal on Microsoft Windows). Now you are ready to enter your first command. The first thing that is usually done is to test the communication between the PC and GSM/GPRS modem/mobile phone to confirm that everything is working properly so far. Simply enter "AT" in the terminal program to perform the test. When the GSM/GPRS modem or mobile phone receives "AT", it will send back the final result code "OK" to indicate that it has received your command successfully, like this:
  
 AT
  OK
 After testing the communication between the PC and GSM/GPRS modem/mobile phone, the next thing that you may want to do is to check if the GSM/GPRS modem or mobile phone supports the use of AT commands to send, receive and read SMS messages. Most GSM/GPRS modems support all three functions. However, only some mobile phones support all of them.
  
 Sending SMS Messages
 To find out whether a GSM/GPRS modem or mobile phone supports the sending of SMS messages through AT commands, you have to:
   - Use the AT command +CSMS (command name in text: Select Message Service) to check whether mobile-originated SMS messages are supported.
- Perform test operations to check whether +CMGS (command name in text: Send Message) and/or +CMSS (command name in text: Send Message from Storage) are supported.
 (You may want to check the AT commands +CMGW [command name in text: Write Message to Memory] and +CMGD [command name in text: Delete Message] in addition as they are sometimes used together with +CMSS.)
 
 Receiving SMS Messages and Reading SMS Messages from Message Storage
 To find out whether a GSM/GPRS modem or mobile phone supports the receiving and reading of SMS messages through AT commands, you have to:
   - Use the AT command +CSMS (command name in text: Select Message Service) to check whether mobile-terminated SMS messages are supported.
- Perform test operations to check whether +CNMI (command name in text: New Message Indications to TE), +CMGL (command name in text: List Messages) and/or +CMGR (command name in text: Read Message) are supported.
If the GSM/GPRS modem or mobile phone supports the +CNMI AT command, it can send a notification or directly forward the message to the PC whenever a new SMS message arrives.
 If the GSM/GPRS modem or mobile phone does not support +CNMI but supports +CMGL and/or +CMGR, the PC has to poll the GSM/GPRS modem or mobile phone repeatedly in order to know if any new SMS messages have arrived.
 One use of the AT command +CSMS (command name in text: Select Message Service) is to check the message types supported by the GSM/GPRS modem or mobile phone. There are three message types: mobile-originated SMS messages, mobile-terminated SMS messages and cell broadcast messages.
 Mobile-originated SMS messages refer to SMS messages that are sent from a mobile device to an SMSC, i.e. outbound SMS messages.
 Mobile-terminated SMS messages refer to SMS messages that are sent from an SMSC to a mobile device, i.e. inbound SMS messages.
 Cell broadcast messages are text messages pushed to subscribers located in a certain mobile network area by the network operator. These text messages may contain news, weather information, etc.
 Here is an example that demonstrates how to use the +CSMS AT command to check if mobile-originated and mobile-terminated SMS messages are supported. First, send the read command "+CSMS?" to the GSM/GPRS modem or mobile phone. The response returned from our Nokia 6021 to HyperTerminal is shown below:
  
 AT+CSMS?
  +CSMS: 0,1,1,1
  
  OK
  
 As you can see, the information response contains four values. The second, third and fourth values indicate whether Nokia 6021 supports mobile-terminated SMS messages, mobile-originated SMS messages and cell broadcast messages respectively. If the value is 1, it means the message type is supported. If the value is 0, it means the message type is not supported.
 For Nokia 6021:
   - The third value in the information response is 1, which indicates Nokia 6021 supports mobile-originated SMS messages. So, Nokia 6021 is capable of sending SMS messages to an SMSC.
- The second value in the information response is 1, which indicates Nokia 6021 supports mobile-terminated SMS messages. So, Nokia 6021 is capable of receiving SMS messages from an SMSC.
If the final result code "ERROR" is returned (as shown below), it is likely that the +CSMS AT command is not supported by the mobile device.
  
 AT+CSMS?
  ERROR
  
 To confirm, send the test command "+CSMS=?" to the GSM/GPRS modem or mobile phone. If the final result code "ERROR" is returned (as shown below), it means the mobile device does not support the +CSMS AT command.
  
 AT+CSMS=?
  ERROR
  
 Note that +CSMS is a mandatory command in the AT command set for SMS messaging. If it is not supported, normally the whole AT command set for SMS messaging is not supported.
 The next thing to do is to check if the AT commands required for sending, receiving and reading SMS messages are supported by the mobile phone or GSM/GPRS modem. As pointed out earlier in this SMS tutorial, you can check if a certain AT command is supported by performing a test operation. Simply execute an AT command with "=?" attached at its end. For example, "AT+CMGS=?".
 Before we begin the check, let's go through an overview of the AT commands that are required for sending, receiving and reading SMS messages. You will learn which AT commands should be checked and get a general idea about when these AT commands should be used.
  
  19.2.1. Overview of the AT Commands Required
  
 For Sending SMS Messages
 To send SMS messages via AT commands, the GSM/GPRS modem or mobile phone has to support either +CMGS (command name in text: Send Message) or +CMSS (command name in text: Send Message from Storage). You may also find +CMGW (command name in text: Write Message to Memory) and +CMGD (command name in text: Delete Message) useful, since they are sometimes used together with +CMSS. +CMSS is used to send an SMS message located in the message storage area. If an SMS message does not exist in the message storage area, you must first use the AT command +CMGW to write the SMS message to the message storage area before you can use the AT command +CMSS to send the SMS message to the SMSC. After message submission, you may use the AT command +CMGD to delete the SMS message to free some space from the message storage area.
  
 For Receiving and Reading SMS Messages
 To receive and read SMS messages via AT commands, the GSM/GPRS modem or mobile phone has to support the AT command +CNMI (command name in text: New Message Indications to TE. TE stands for Terminal Equipment, which is the equipment that controls the GSM/GPRS modem or mobile phone. For example, a PC / computer), +CMGL (command name in text: List Messages), or +CMGR (command name in text: Read Messages).
 The AT command +CNMI is used to specify how newly arrived SMS messages should be handled. You can tell the GSM/GPRS modem or mobile phone either to forward newly arrived SMS messages directly to the PC, or to save them in message storage and then notify the PC about their locations in message storage.
 The AT command +CMGL is used to read all SMS messages that have a certain status (e.g. "received unread", "received read", etc) from the message storage area, while the AT command +CMGR is used to read the SMS message saved at a certain location of the message storage area.
  
  19.2.2. Beginning the Check
 Now that you've learned the AT commands required for outbound and inbound SMS messaging are +CMGS, +CMSS, +CNMI, +CMGL and +CMGR. You can begin the check by performing a test operation with each of the AT commands. For example, you can execute the command line "AT+CMGS=?" to check whether +CMGS is supported, like this:
  
 AT+CMGS=?
  OK
  
 The final result code "OK" indicates the AT command +CMGS is supported. If the GSM/GPRS modem or mobile phone returns the final result code "ERROR", it means the command is not supported.
 A quicker way is to copy and paste the following command line to the terminal program and execute it:
  
 AT+CMGS=?;+CMSS=?;+CNMI=?;+CMGL=?;+CMGR=?
  
 As an example, here shows the response returned from my Nokia 6021 to HyperTerminal after the execution of above command line:
  
 AT+CMGS=?;+CMSS=?;+CNMI=?;+CMGL=?;+CMGR=?
  +CNMI: (0-2),(0-3),(0,2,3),(0-2),(0,1)
  
  +CMGL: (0-4)
  
  OK
  
 The return of the final result code "OK" indicates all AT commands under test are supported. If the final result code "ERROR" is returned, it means one or more AT commands are not supported.
 The SMS specification has defined two modes in which a GSM/GPRS modem or mobile phone can operate. They are called SMS text mode and SMS PDU mode. (PDU stands for Protocol Data Unit.) The mode that a GSM/GPRS modem or mobile phone is operating in determines the syntax of some SMS AT commands and the format of the responses returned after execution. Below are the SMS AT commands affected:
   - +CMGS (Send Message)
- +CMSS (Send Message from Storage)
- +CMGR (Read Message)
- +CMGL (List Messages)
- +CMGW (Write Message to Memory)
- +CNMA (New Message Acknowledgement to ME/TA)
- +CMGC (Send Command)
The syntax of the unsolicited result codes below also depends on the mode in which the GSM/GPRS modem or mobile phone is operating:    - +CMT (Used to forward received SMS messages to the computer / PC.)
- +CBM (Used to forward received cell broadcast messages to the computer / PC.)
- +CDS (Used to forward received status reports to the computer / PC.)
These two AT commands are useful to you only if SMS text mode is used:
   - +CSMP (Set Text Mode Parameters)
- +CSDH (Show Text Mode Parameters)