forked from rene-dev/stmbl
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathsyscalls.c
98 lines (77 loc) · 1.68 KB
/
syscalls.c
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
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
#include <reent.h>
#include <stdlib.h>
#include <stdio.h>
#include <errno.h>
#include <sys/stat.h>
#include <sys/time.h>
#include "stm32f4xx.h"
#include "usbd_cdc_if.h"
//int __errno;
size_t __malloc_margin = 256;
char *__brkval;
int _close(int file) {
return 0;
}
int _fstat(int file, struct stat *st) {
return 0;
}
int _isatty(int file) {
return 1;
}
int _lseek(int file, int ptr, int dir) {
return 0;
}
int _open(const char *name, int flags, int mode) {
return -1;
}
int _kill_r(struct _reent *r, int pid, int sig){
return -1;
}
int _getpid_r (struct _reent *r){
return -1;
}
/* Register name faking - works in collusion with the linker. */
register char *stack_ptr asm("sp");
void *_sbrk_r(struct _reent *r, ptrdiff_t incr) {
extern char end; // provided by the linker script
if(__brkval == 0)
__brkval = &end;
if(__brkval + incr > (char *)__get_MSP() - __malloc_margin) {
r->_errno = ENOMEM;
return (void *)-1;
}
void *ret = __brkval;
__brkval += incr;
return ret;
}
ssize_t _read(int fd, void *ptr, size_t len) {
(void)fd;
while(!usb_rx_buf.len)
;
if(len > usb_rx_buf.len)
len = usb_rx_buf.len;
char *c = (char *)ptr;
for(uint16_t i = 0; i < len; i++)
rb_getc(&usb_rx_buf, c++);
return len;
}
//TODO: check if connected?
int _write(int fd, const char *ptr, int len) {
if(!USB_CDC_is_connected()) {
return 0;
}
char *c = (char *)ptr;
(void)fd;
int sent = 0;
while(len--) {
// send a queued byte - copy to usb stack buffer
APP_Rx_Buffer[APP_Rx_ptr_in++] = *c;
c++;
// To avoid buffer overflow
if(APP_Rx_ptr_in >= APP_RX_DATA_SIZE) {
APP_Rx_ptr_in = 0;
}
sent++;
}
return sent;
}