123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778 |
- /*
- ChibiOS - Copyright (C) 2016..2018 Theodore Ateba
- 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 "ch.h"
- #include "hal.h"
- #include "oslib_test_root.h"
- static THD_WORKING_AREA(waThread1, 32);
- static THD_FUNCTION(Thread1, arg) {
- (void)arg;
- chRegSetThreadName("Blinker");
- while (true) {
- palClearPad(IOPORT5, PORTE_LED);
- chThdSleepMilliseconds(1000);
- palSetPad(IOPORT5, PORTE_LED);
- chThdSleepMilliseconds(100);
- }
- }
- /*
- * Application entry point.
- */
- int main(void) {
- /*
- * System initializations.
- * - HAL initialization, this also initializes the configured device drivers
- * and performs the board-specific initializations.
- * - Kernel initialization, the main() function becomes a thread and the
- * RTOS is active.
- */
- halInit();
- chSysInit();
- palClearPad(IOPORT5, PORTE_LED);
- /*
- * Configure TX (PINC3) and RX (PIN2) for the USART1.
- */
- palSetPadMode(IOPORT3, PIN3, PAL_MODE_OUTPUT_PUSHPULL);
- palSetPadMode(IOPORT3, PIN2, PAL_MODE_INPUT_PULLUP);
- /*
- * Start the Serial driver 1.
- */
- sdStart(&SD1, NULL);
- /*
- * Starts the LED blinker thread.
- */
- chThdCreateStatic(waThread1, sizeof(waThread1), NORMALPRIO, Thread1, NULL);
- /*
- * Start the RT test suite.
- */
- test_execute((BaseSequentialStream *)&SD1, &oslib_test_suite);
- while(TRUE) {
- chThdSleepMilliseconds(1000);
- }
- return 0;
- }
|