mirror of https://github.com/ARMmbed/mbed-os.git
175 lines
5.2 KiB
C++
175 lines
5.2 KiB
C++
/*
|
|
* Copyright (c) 2018, Arm Limited and affiliates.
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
*
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
* you may not use this file except in compliance with the License.
|
|
* You may obtain a copy of the License at
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
* See the License for the specific language governing permissions and
|
|
* limitations under the License.
|
|
*/
|
|
|
|
#include "STModCellular.h"
|
|
#include "rtos/ThisThread.h"
|
|
#include "mbed_trace.h"
|
|
|
|
#define TRACE_GROUP "CELL"
|
|
|
|
using namespace mbed;
|
|
|
|
STModCellular::STModCellular(FileHandle *fh) : STMOD_CELLULAR_MODEM(fh),
|
|
m_powerkey(MBED_CONF_STMOD_CELLULAR_POWER),
|
|
m_reset(MBED_CONF_STMOD_CELLULAR_RESET),
|
|
m_simsel0(MBED_CONF_STMOD_CELLULAR_SIMSEL0),
|
|
m_simsel1(MBED_CONF_STMOD_CELLULAR_SIMSEL1),
|
|
m_mdmdtr(MBED_CONF_STMOD_CELLULAR_MDMDTR),
|
|
m_sim_reset(MBED_CONF_STMOD_CELLULAR_SIM_RESET),
|
|
m_sim_clk(MBED_CONF_STMOD_CELLULAR_SIM_CLK),
|
|
m_sim_data(MBED_CONF_STMOD_CELLULAR_SIM_DATA)
|
|
{
|
|
tr_debug("STModCellular creation\r\n");
|
|
|
|
// start with modem disabled
|
|
m_powerkey.write(0);
|
|
m_reset.write(1);
|
|
rtos::ThisThread::sleep_for(200);
|
|
m_reset.write(0);
|
|
rtos::ThisThread::sleep_for(150);
|
|
|
|
rtos::ThisThread::sleep_for(50);
|
|
m_simsel0.write(MBED_CONF_STMOD_CELLULAR_SIM_SELECTION & 0x01);
|
|
m_simsel1.write(MBED_CONF_STMOD_CELLULAR_SIM_SELECTION & 0x02);
|
|
rtos::ThisThread::sleep_for(50);
|
|
}
|
|
|
|
STModCellular::~STModCellular()
|
|
{
|
|
}
|
|
|
|
nsapi_error_t STModCellular::soft_power_on()
|
|
{
|
|
tr_debug("STMOD cellular modem power ON\r\n");
|
|
|
|
#if (MBED_CONF_STMOD_CELLULAR_TYPE == STMOD_UG96)
|
|
tr_debug("Booting UG96\r\n");
|
|
m_reset.write(1);
|
|
rtos::ThisThread::sleep_for(200);
|
|
m_reset.write(0);
|
|
rtos::ThisThread::sleep_for(150);
|
|
m_powerkey.write(1);
|
|
rtos::ThisThread::sleep_for(150);
|
|
m_powerkey.write(0);
|
|
/* Because modem status is not available on STMOD+ connector,
|
|
* let's wait for Modem complete boot */
|
|
rtos::ThisThread::sleep_for(2300);
|
|
#endif
|
|
#if (MBED_CONF_STMOD_CELLULAR_TYPE == STMOD_BG96)
|
|
tr_debug("Booting BG96\r\n");
|
|
m_powerkey.write(1);
|
|
m_reset.write(1);
|
|
rtos::ThisThread::sleep_for(150);
|
|
m_powerkey.write(0);
|
|
m_reset.write(0);
|
|
rtos::ThisThread::sleep_for(100);
|
|
m_powerkey.write(1);
|
|
rtos::ThisThread::sleep_for(200);
|
|
m_powerkey.write(0);
|
|
rtos::ThisThread::sleep_for(5000);
|
|
#endif
|
|
|
|
nsapi_error_t err = STMOD_CELLULAR_MODEM::soft_power_on();
|
|
if (err != 0) {
|
|
return err;
|
|
}
|
|
|
|
// wait for RDY
|
|
_at->lock();
|
|
_at->set_at_timeout(5000);
|
|
_at->set_stop_tag("RDY");
|
|
bool rdy = _at->consume_to_stop_tag();
|
|
(void)rdy;
|
|
|
|
/* Modem may send more bytes are RDY flag */
|
|
_at->flush();
|
|
|
|
/* Turn OFF ECHO before anything else */
|
|
_at->set_stop_tag(mbed::OK);
|
|
_at->cmd_start("ATE0");
|
|
_at->cmd_stop();
|
|
_at->consume_to_stop_tag();
|
|
|
|
_at->restore_at_timeout();
|
|
_at->unlock();
|
|
|
|
tr_debug("Modem %sready to receive AT commands\r\n", rdy ? "" : "NOT ");
|
|
|
|
#if DEVICE_SERIAL_FC
|
|
if ((MBED_CONF_STMOD_CELLULAR_CTS != NC) && (MBED_CONF_STMOD_CELLULAR_RTS != NC)) {
|
|
tr_debug("Enable flow control\r\n");
|
|
|
|
_at->lock();
|
|
// enable CTS/RTS flowcontrol
|
|
_at->set_stop_tag(mbed::OK);
|
|
_at->set_at_timeout(400);
|
|
_at->cmd_start("AT+IFC=");
|
|
_at->write_int(2);
|
|
_at->write_int(2);
|
|
_at->cmd_stop_read_resp();
|
|
err = _at->get_last_error();
|
|
_at->restore_at_timeout();
|
|
_at->unlock();
|
|
|
|
if (err == NSAPI_ERROR_OK) {
|
|
tr_debug("Flow control turned ON\r\n");
|
|
} else {
|
|
tr_error("Failed to enable hw flow control\r\n");
|
|
}
|
|
}
|
|
#endif
|
|
|
|
rtos::ThisThread::sleep_for(500);
|
|
|
|
#if MBED_CONF_CELLULAR_DEBUG_AT
|
|
_at->lock();
|
|
/* Verify Flow Control settings */
|
|
_at->cmd_start("AT+IFC?");
|
|
_at->cmd_stop_read_resp();
|
|
_at->unlock();
|
|
#endif // MBED_CONF_CELLULAR_DEBUG_AT
|
|
|
|
return err;
|
|
}
|
|
|
|
nsapi_error_t STModCellular::soft_power_off()
|
|
{
|
|
_at->cmd_start("AT+QPOWD");
|
|
_at->cmd_stop();
|
|
rtos::ThisThread::sleep_for(1000);
|
|
// should wait for POWERED DOWN with a time out up to 65 second according to the manual.
|
|
// we cannot afford such a long wait though.
|
|
return STMOD_CELLULAR_MODEM::soft_power_off();
|
|
}
|
|
|
|
#if MBED_CONF_STMOD_CELLULAR_PROVIDE_DEFAULT
|
|
#include "UARTSerial.h"
|
|
CellularDevice *CellularDevice::get_default_instance()
|
|
{
|
|
tr_debug("MODEM default instance\r\n");
|
|
|
|
static UARTSerial serial(MBED_CONF_STMOD_CELLULAR_TX, MBED_CONF_STMOD_CELLULAR_RX, MBED_CONF_STMOD_CELLULAR_BAUDRATE);
|
|
#if defined (MBED_CONF_STMOD_CELLULAR_RTS) && defined(MBED_CONF_STMOD_CELLULAR_CTS)
|
|
tr_debug("STMOD_CELLULAR flow control: RTS %d CTS %d\r\n", MBED_CONF_STMOD_CELLULAR_RTS, MBED_CONF_STMOD_CELLULAR_CTS);
|
|
serial.set_flow_control(SerialBase::RTSCTS, MBED_CONF_STMOD_CELLULAR_RTS, MBED_CONF_STMOD_CELLULAR_CTS);
|
|
#endif
|
|
static STModCellular device(&serial);
|
|
return &device;
|
|
}
|
|
#endif
|
|
|