5.2.1 - Updated I2C files
Dependents: mbed-TFT-example-NCS36510 mbed-Accelerometer-example-NCS36510 mbed-Accelerometer-example-NCS36510
TESTS/mbedmicro-rtos-mbed/mutex/main.cpp@1:f30bdcd2b33b, 2017-02-27 (annotated)
- Committer:
- jacobjohnson
- Date:
- Mon Feb 27 17:45:05 2017 +0000
- Revision:
- 1:f30bdcd2b33b
- Parent:
- 0:098463de4c5d
changed the inputscale from 1 to 7 in analogin_api.c. This will need to be changed later, and accessed from the main level, but for now this allows the adc to read a value from 0 to 3.7V, instead of just up to 1V.;
Who changed what in which revision?
User | Revision | Line number | New contents of line |
---|---|---|---|
group-onsemi | 0:098463de4c5d | 1 | #include "mbed.h" |
group-onsemi | 0:098463de4c5d | 2 | #include "greentea-client/test_env.h" |
group-onsemi | 0:098463de4c5d | 3 | #include "rtos.h" |
group-onsemi | 0:098463de4c5d | 4 | |
group-onsemi | 0:098463de4c5d | 5 | #if defined(MBED_RTOS_SINGLE_THREAD) |
group-onsemi | 0:098463de4c5d | 6 | #error [NOT_SUPPORTED] test not supported |
group-onsemi | 0:098463de4c5d | 7 | #endif |
group-onsemi | 0:098463de4c5d | 8 | |
group-onsemi | 0:098463de4c5d | 9 | #define THREAD_DELAY 50 |
group-onsemi | 0:098463de4c5d | 10 | #define SIGNALS_TO_EMIT 100 |
group-onsemi | 0:098463de4c5d | 11 | |
group-onsemi | 0:098463de4c5d | 12 | /* |
group-onsemi | 0:098463de4c5d | 13 | * The stack size is defined in cmsis_os.h mainly dependent on the underlying toolchain and |
group-onsemi | 0:098463de4c5d | 14 | * the C standard library. For GCC, ARM_STD and IAR it is defined with a size of 2048 bytes |
group-onsemi | 0:098463de4c5d | 15 | * and for ARM_MICRO 512. Because of reduce RAM size some targets need a reduced stacksize. |
group-onsemi | 0:098463de4c5d | 16 | */ |
group-onsemi | 0:098463de4c5d | 17 | #if defined(TARGET_STM32F334R8) && defined(TOOLCHAIN_IAR) |
group-onsemi | 0:098463de4c5d | 18 | #define STACK_SIZE DEFAULT_STACK_SIZE/4 |
group-onsemi | 0:098463de4c5d | 19 | #elif defined(TARGET_STM32F070RB) |
group-onsemi | 0:098463de4c5d | 20 | #define STACK_SIZE DEFAULT_STACK_SIZE/2 |
group-onsemi | 0:098463de4c5d | 21 | #elif defined(TARGET_STM32F072RB) |
group-onsemi | 0:098463de4c5d | 22 | #define STACK_SIZE DEFAULT_STACK_SIZE/2 |
group-onsemi | 0:098463de4c5d | 23 | #elif defined(TARGET_STM32F302R8) && defined(TOOLCHAIN_IAR) |
group-onsemi | 0:098463de4c5d | 24 | #define STACK_SIZE DEFAULT_STACK_SIZE/2 |
group-onsemi | 0:098463de4c5d | 25 | #elif defined(TARGET_STM32F303K8) && defined(TOOLCHAIN_IAR) |
group-onsemi | 0:098463de4c5d | 26 | #define STACK_SIZE DEFAULT_STACK_SIZE/2 |
group-onsemi | 0:098463de4c5d | 27 | #elif defined(TARGET_STM32L073RZ) |
group-onsemi | 0:098463de4c5d | 28 | #define STACK_SIZE DEFAULT_STACK_SIZE/2 |
group-onsemi | 0:098463de4c5d | 29 | #elif (defined(TARGET_EFM32HG_STK3400)) && !defined(TOOLCHAIN_ARM_MICRO) |
group-onsemi | 0:098463de4c5d | 30 | #define STACK_SIZE 512 |
group-onsemi | 0:098463de4c5d | 31 | #elif (defined(TARGET_EFM32LG_STK3600) || defined(TARGET_EFM32WG_STK3800) || defined(TARGET_EFM32PG_STK3401)) && !defined(TOOLCHAIN_ARM_MICRO) |
group-onsemi | 0:098463de4c5d | 32 | #define STACK_SIZE 768 |
group-onsemi | 0:098463de4c5d | 33 | #elif (defined(TARGET_EFM32GG_STK3700)) && !defined(TOOLCHAIN_ARM_MICRO) |
group-onsemi | 0:098463de4c5d | 34 | #define STACK_SIZE 1536 |
group-onsemi | 0:098463de4c5d | 35 | #elif (defined(TARGET_EFR32)) && !defined(TOOLCHAIN_ARM_MICRO) |
group-onsemi | 0:098463de4c5d | 36 | #define STACK_SIZE 768 |
group-onsemi | 0:098463de4c5d | 37 | #elif defined(TARGET_MCU_NRF51822) || defined(TARGET_MCU_NRF52832) |
group-onsemi | 0:098463de4c5d | 38 | #define STACK_SIZE 1024 |
group-onsemi | 0:098463de4c5d | 39 | #elif defined(TARGET_XDOT_L151CC) |
group-onsemi | 0:098463de4c5d | 40 | #define STACK_SIZE 1024 |
group-onsemi | 0:098463de4c5d | 41 | #else |
group-onsemi | 0:098463de4c5d | 42 | #define STACK_SIZE DEFAULT_STACK_SIZE |
group-onsemi | 0:098463de4c5d | 43 | #endif |
group-onsemi | 0:098463de4c5d | 44 | |
group-onsemi | 0:098463de4c5d | 45 | void print_char(char c = '*') { |
group-onsemi | 0:098463de4c5d | 46 | printf("%c", c); |
group-onsemi | 0:098463de4c5d | 47 | fflush(stdout); |
group-onsemi | 0:098463de4c5d | 48 | } |
group-onsemi | 0:098463de4c5d | 49 | |
group-onsemi | 0:098463de4c5d | 50 | Mutex stdio_mutex; |
group-onsemi | 0:098463de4c5d | 51 | DigitalOut led(LED1); |
group-onsemi | 0:098463de4c5d | 52 | |
group-onsemi | 0:098463de4c5d | 53 | volatile int change_counter = 0; |
group-onsemi | 0:098463de4c5d | 54 | volatile bool changing_counter = false; |
group-onsemi | 0:098463de4c5d | 55 | volatile bool mutex_defect = false; |
group-onsemi | 0:098463de4c5d | 56 | |
group-onsemi | 0:098463de4c5d | 57 | bool manipulate_protected_zone(const int thread_delay) { |
group-onsemi | 0:098463de4c5d | 58 | bool result = true; |
group-onsemi | 0:098463de4c5d | 59 | |
group-onsemi | 0:098463de4c5d | 60 | stdio_mutex.lock(); // LOCK |
group-onsemi | 0:098463de4c5d | 61 | if (changing_counter == true) { |
group-onsemi | 0:098463de4c5d | 62 | // 'e' stands for error. If changing_counter is true access is not exclusively |
group-onsemi | 0:098463de4c5d | 63 | print_char('e'); |
group-onsemi | 0:098463de4c5d | 64 | result = false; |
group-onsemi | 0:098463de4c5d | 65 | mutex_defect = true; |
group-onsemi | 0:098463de4c5d | 66 | } |
group-onsemi | 0:098463de4c5d | 67 | changing_counter = true; |
group-onsemi | 0:098463de4c5d | 68 | |
group-onsemi | 0:098463de4c5d | 69 | // Some action on protected |
group-onsemi | 0:098463de4c5d | 70 | led = !led; |
group-onsemi | 0:098463de4c5d | 71 | change_counter++; |
group-onsemi | 0:098463de4c5d | 72 | print_char('.'); |
group-onsemi | 0:098463de4c5d | 73 | Thread::wait(thread_delay); |
group-onsemi | 0:098463de4c5d | 74 | |
group-onsemi | 0:098463de4c5d | 75 | changing_counter = false; |
group-onsemi | 0:098463de4c5d | 76 | stdio_mutex.unlock(); // UNLOCK |
group-onsemi | 0:098463de4c5d | 77 | return result; |
group-onsemi | 0:098463de4c5d | 78 | } |
group-onsemi | 0:098463de4c5d | 79 | |
group-onsemi | 0:098463de4c5d | 80 | void test_thread(int const *thread_delay) { |
group-onsemi | 0:098463de4c5d | 81 | while (true) { |
group-onsemi | 0:098463de4c5d | 82 | manipulate_protected_zone(*thread_delay); |
group-onsemi | 0:098463de4c5d | 83 | } |
group-onsemi | 0:098463de4c5d | 84 | } |
group-onsemi | 0:098463de4c5d | 85 | |
group-onsemi | 0:098463de4c5d | 86 | int main() { |
group-onsemi | 0:098463de4c5d | 87 | GREENTEA_SETUP(20, "default_auto"); |
group-onsemi | 0:098463de4c5d | 88 | |
group-onsemi | 0:098463de4c5d | 89 | const int t1_delay = THREAD_DELAY * 1; |
group-onsemi | 0:098463de4c5d | 90 | const int t2_delay = THREAD_DELAY * 2; |
group-onsemi | 0:098463de4c5d | 91 | const int t3_delay = THREAD_DELAY * 3; |
group-onsemi | 0:098463de4c5d | 92 | Thread t2(osPriorityNormal, STACK_SIZE); |
group-onsemi | 0:098463de4c5d | 93 | Thread t3(osPriorityNormal, STACK_SIZE); |
group-onsemi | 0:098463de4c5d | 94 | |
group-onsemi | 0:098463de4c5d | 95 | t2.start(callback(test_thread, &t2_delay)); |
group-onsemi | 0:098463de4c5d | 96 | t3.start(callback(test_thread, &t3_delay)); |
group-onsemi | 0:098463de4c5d | 97 | |
group-onsemi | 0:098463de4c5d | 98 | while (true) { |
group-onsemi | 0:098463de4c5d | 99 | // Thread 1 action |
group-onsemi | 0:098463de4c5d | 100 | Thread::wait(t1_delay); |
group-onsemi | 0:098463de4c5d | 101 | manipulate_protected_zone(t1_delay); |
group-onsemi | 0:098463de4c5d | 102 | if (change_counter >= SIGNALS_TO_EMIT or mutex_defect == true) { |
group-onsemi | 0:098463de4c5d | 103 | t2.terminate(); |
group-onsemi | 0:098463de4c5d | 104 | t3.terminate(); |
group-onsemi | 0:098463de4c5d | 105 | break; |
group-onsemi | 0:098463de4c5d | 106 | } |
group-onsemi | 0:098463de4c5d | 107 | } |
group-onsemi | 0:098463de4c5d | 108 | |
group-onsemi | 0:098463de4c5d | 109 | fflush(stdout); |
group-onsemi | 0:098463de4c5d | 110 | GREENTEA_TESTSUITE_RESULT(!mutex_defect); |
group-onsemi | 0:098463de4c5d | 111 | return 0; |
group-onsemi | 0:098463de4c5d | 112 | } |