Important changes to repositories hosted on mbed.com
Mbed hosted mercurial repositories are deprecated and are due to be permanently deleted in July 2026.
To keep a copy of this software download the repository Zip archive or clone locally using Mercurial.
It is also possible to export all your personal repositories from the account settings page.
Fork of RPCInterface by
SerialRPCInterface.cpp
00001 /** 00002 * @section LICENSE 00003 *Copyright (c) 2010 ARM Ltd. 00004 * 00005 *Permission is hereby granted, free of charge, to any person obtaining a copy 00006 *of this software and associated documentation files (the "Software"), to deal 00007 *in the Software without restriction, including without limitation the rights 00008 *to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 00009 *copies of the Software, and to permit persons to whom the Software is 00010 *furnished to do so, subject to the following conditions: 00011 * 00012 *The above copyright notice and this permission notice shall be included in 00013 *all copies or substantial portions of the Software. 00014 * 00015 *THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 00016 *IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 00017 *FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 00018 *AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 00019 *LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 00020 *OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN 00021 *THE SOFTWARE. 00022 * 00023 * 00024 * @section DESCRIPTION 00025 * 00026 *This class sets up RPC communication. This allows objects on mbed to be controlled. Objects can be created or existing objects can be used 00027 * 00028 * Substantially updated Jan 2016 to work with the updated RPC system 00029 */ 00030 #include "SerialRPCInterface.h" 00031 00032 using namespace mbed; 00033 00034 //Requires multiple contstructors for each type, serial to set different pin numbers, TCP for port. 00035 SerialRPCInterface::SerialRPCInterface(PinName tx, PinName rx, int baud):pc(tx, rx) { 00036 _RegClasses(); 00037 _enabled = true; 00038 pc.attach(this, &SerialRPCInterface::_RPCSerial, Serial::RxIrq); 00039 if(baud != 9600)pc.baud(baud); 00040 } 00041 00042 void SerialRPCInterface::_RegClasses(void){ 00043 /* 00044 //Register classes with base 00045 Base::add_rpc_class<AnalogIn>(); 00046 Base::add_rpc_class<DigitalIn>(); 00047 Base::add_rpc_class<DigitalOut>(); 00048 Base::add_rpc_class<DigitalInOut>(); 00049 Base::add_rpc_class<PwmOut>(); 00050 Base::add_rpc_class<Timer>(); 00051 Base::add_rpc_class<BusOut>(); 00052 Base::add_rpc_class<BusIn>(); 00053 Base::add_rpc_class<BusInOut>(); 00054 Base::add_rpc_class<Serial>(); 00055 00056 //AnalogOut not avaliable on mbed LPC11U24 so only compile for other devices 00057 #if !defined(TARGET_LPC11U24) 00058 Base::add_rpc_class<AnalogOut>(); 00059 #endif 00060 */ 00061 } 00062 00063 void SerialRPCInterface::Disable(void){ 00064 _enabled = false; 00065 } 00066 void SerialRPCInterface::Enable(void){ 00067 _enabled = true; 00068 } 00069 void SerialRPCInterface::_MsgProcess(void) { 00070 if(_enabled == true){ 00071 RPC::call(_command, _response); 00072 } 00073 } 00074 00075 void SerialRPCInterface::_RPCSerial() { 00076 _RPCflag = true; 00077 if(_enabled == true){ 00078 pc.gets(_command, 256); 00079 _MsgProcess(); 00080 pc.printf("%s\n", _response); 00081 } 00082 _RPCflag = false; 00083 }
Generated on Fri Jul 15 2022 17:33:11 by
1.7.2
