summaryrefslogtreecommitdiff
path: root/sim/ucsim/stm8.src/test/s0.c
blob: d0ee5f05e74251df5fbdce60c034dd0c74fe999c (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
#include <stdint.h>
#include <stdio.h>

#define DEVICE DEV_STM8S208

#include "stm8.h"

int putchar(int c)
{
  while(!(USART->sr & USART_SR_TXE));

  USART->dr = c;
  return c;
}

void main(void)
{
  unsigned long i = 0;

  CLK->ckdivr = 0x00; // Set the frequency to 16 MHz
  CLK->pckenr1 = 0xFF; // Enable peripherals

  USART->cr2 = USART_CR2_TEN; // Allow TX and RX
  USART->cr3 &= ~(USART_CR3_STOP1 | USART_CR3_STOP2); // 1 stop bit
  USART->brr2 = 0x03;
  USART->brr1 = 0x68; // 9600 baud
  
  for(;;)
    {
      printf("Hello World!\n");
      for(i = 0; i < 147456; i++); // Sleep
    }
}