Integrating the ublox LISA C200 modem

Fork of SprintUSBModemHTTPClientTest by Donatien Garnier

Committer:
sam_grove
Date:
Thu Sep 26 00:44:20 2013 -0500
Revision:
5:3f93dd1d4cb3
Exported program and replaced contents of the repo with the source
to build and debug using keil mdk. Libs NOT upto date are lwip, lwip-sys
and socket. these have newer versions under mbed_official but were starting
from a know working point

Who changed what in which revision?

UserRevisionLine numberNew contents of line
sam_grove 5:3f93dd1d4cb3 1 /* mbed Microcontroller Library
sam_grove 5:3f93dd1d4cb3 2 * Copyright (c) 2006-2012 ARM Limited
sam_grove 5:3f93dd1d4cb3 3 *
sam_grove 5:3f93dd1d4cb3 4 * Permission is hereby granted, free of charge, to any person obtaining a copy
sam_grove 5:3f93dd1d4cb3 5 * of this software and associated documentation files (the "Software"), to deal
sam_grove 5:3f93dd1d4cb3 6 * in the Software without restriction, including without limitation the rights
sam_grove 5:3f93dd1d4cb3 7 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
sam_grove 5:3f93dd1d4cb3 8 * copies of the Software, and to permit persons to whom the Software is
sam_grove 5:3f93dd1d4cb3 9 * furnished to do so, subject to the following conditions:
sam_grove 5:3f93dd1d4cb3 10 *
sam_grove 5:3f93dd1d4cb3 11 * The above copyright notice and this permission notice shall be included in
sam_grove 5:3f93dd1d4cb3 12 * all copies or substantial portions of the Software.
sam_grove 5:3f93dd1d4cb3 13 *
sam_grove 5:3f93dd1d4cb3 14 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
sam_grove 5:3f93dd1d4cb3 15 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
sam_grove 5:3f93dd1d4cb3 16 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
sam_grove 5:3f93dd1d4cb3 17 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
sam_grove 5:3f93dd1d4cb3 18 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
sam_grove 5:3f93dd1d4cb3 19 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
sam_grove 5:3f93dd1d4cb3 20 * SOFTWARE.
sam_grove 5:3f93dd1d4cb3 21 */
sam_grove 5:3f93dd1d4cb3 22 #include "Thread.h"
sam_grove 5:3f93dd1d4cb3 23
sam_grove 5:3f93dd1d4cb3 24 #include "error.h"
sam_grove 5:3f93dd1d4cb3 25
sam_grove 5:3f93dd1d4cb3 26 namespace rtos {
sam_grove 5:3f93dd1d4cb3 27
sam_grove 5:3f93dd1d4cb3 28 Thread::Thread(void (*task)(void const *argument), void *argument,
sam_grove 5:3f93dd1d4cb3 29 osPriority priority, uint32_t stack_size, unsigned char *stack_pointer) {
sam_grove 5:3f93dd1d4cb3 30 #ifdef CMSIS_OS_RTX
sam_grove 5:3f93dd1d4cb3 31 _thread_def.pthread = task;
sam_grove 5:3f93dd1d4cb3 32 _thread_def.tpriority = priority;
sam_grove 5:3f93dd1d4cb3 33 _thread_def.stacksize = stack_size;
sam_grove 5:3f93dd1d4cb3 34 if (stack_pointer != NULL) {
sam_grove 5:3f93dd1d4cb3 35 _thread_def.stack_pointer = stack_pointer;
sam_grove 5:3f93dd1d4cb3 36 _dynamic_stack = false;
sam_grove 5:3f93dd1d4cb3 37 } else {
sam_grove 5:3f93dd1d4cb3 38 _thread_def.stack_pointer = new unsigned char[stack_size];
sam_grove 5:3f93dd1d4cb3 39 if (_thread_def.stack_pointer == NULL)
sam_grove 5:3f93dd1d4cb3 40 error("Error allocating the stack memory");
sam_grove 5:3f93dd1d4cb3 41 _dynamic_stack = true;
sam_grove 5:3f93dd1d4cb3 42 }
sam_grove 5:3f93dd1d4cb3 43 #endif
sam_grove 5:3f93dd1d4cb3 44 _tid = osThreadCreate(&_thread_def, argument);
sam_grove 5:3f93dd1d4cb3 45 }
sam_grove 5:3f93dd1d4cb3 46
sam_grove 5:3f93dd1d4cb3 47 osStatus Thread::terminate() {
sam_grove 5:3f93dd1d4cb3 48 return osThreadTerminate(_tid);
sam_grove 5:3f93dd1d4cb3 49 }
sam_grove 5:3f93dd1d4cb3 50
sam_grove 5:3f93dd1d4cb3 51 osStatus Thread::set_priority(osPriority priority) {
sam_grove 5:3f93dd1d4cb3 52 return osThreadSetPriority(_tid, priority);
sam_grove 5:3f93dd1d4cb3 53 }
sam_grove 5:3f93dd1d4cb3 54
sam_grove 5:3f93dd1d4cb3 55 osPriority Thread::get_priority() {
sam_grove 5:3f93dd1d4cb3 56 return osThreadGetPriority(_tid);
sam_grove 5:3f93dd1d4cb3 57 }
sam_grove 5:3f93dd1d4cb3 58
sam_grove 5:3f93dd1d4cb3 59 int32_t Thread::signal_set(int32_t signals) {
sam_grove 5:3f93dd1d4cb3 60 return osSignalSet(_tid, signals);
sam_grove 5:3f93dd1d4cb3 61 }
sam_grove 5:3f93dd1d4cb3 62
sam_grove 5:3f93dd1d4cb3 63 Thread::State Thread::get_state() {
sam_grove 5:3f93dd1d4cb3 64 return ((State)_thread_def.tcb.state);
sam_grove 5:3f93dd1d4cb3 65 }
sam_grove 5:3f93dd1d4cb3 66
sam_grove 5:3f93dd1d4cb3 67 osEvent Thread::signal_wait(int32_t signals, uint32_t millisec) {
sam_grove 5:3f93dd1d4cb3 68 return osSignalWait(signals, millisec);
sam_grove 5:3f93dd1d4cb3 69 }
sam_grove 5:3f93dd1d4cb3 70
sam_grove 5:3f93dd1d4cb3 71 osStatus Thread::wait(uint32_t millisec) {
sam_grove 5:3f93dd1d4cb3 72 return osDelay(millisec);
sam_grove 5:3f93dd1d4cb3 73 }
sam_grove 5:3f93dd1d4cb3 74
sam_grove 5:3f93dd1d4cb3 75 osStatus Thread::yield() {
sam_grove 5:3f93dd1d4cb3 76 return osThreadYield();
sam_grove 5:3f93dd1d4cb3 77 }
sam_grove 5:3f93dd1d4cb3 78
sam_grove 5:3f93dd1d4cb3 79 osThreadId Thread::gettid() {
sam_grove 5:3f93dd1d4cb3 80 return osThreadGetId();
sam_grove 5:3f93dd1d4cb3 81 }
sam_grove 5:3f93dd1d4cb3 82
sam_grove 5:3f93dd1d4cb3 83 Thread::~Thread() {
sam_grove 5:3f93dd1d4cb3 84 terminate();
sam_grove 5:3f93dd1d4cb3 85 if (_dynamic_stack) {
sam_grove 5:3f93dd1d4cb3 86 delete[] (_thread_def.stack_pointer);
sam_grove 5:3f93dd1d4cb3 87 }
sam_grove 5:3f93dd1d4cb3 88 }
sam_grove 5:3f93dd1d4cb3 89
sam_grove 5:3f93dd1d4cb3 90 }