stmos/src/kernel/svc.c

87 lines
1.7 KiB
C
Raw Normal View History

2018-09-25 17:09:53 -04:00
/**
* @file svc.c
* An unused handler for SVC calls
*
* Copyright (C) 2018 Clyne Sullivan
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <https://www.gnu.org/licenses/>.
*/
#include <stdint.h>
2018-10-02 21:26:48 -04:00
#include "gpio.h"
#include "clock.h"
#include "task.h"
2018-09-25 17:09:53 -04:00
extern void gpio_svc(uint32_t *);
2018-10-02 21:26:48 -04:00
extern void clock_svc(uint32_t *);
2018-10-18 18:24:43 -04:00
extern void task_svc(uint32_t *);
2018-11-04 23:46:12 -05:00
extern void vfs_svc(uint32_t *args);
2018-09-25 17:09:53 -04:00
2018-10-21 13:10:34 -04:00
void SVC_Handler(void) {
uint32_t *args;
asm("\
tst lr, #4; \
ite eq; \
mrseq %0, msp; \
mrsne %0, psp; \
" : "=r" (args));
int svc_number = ((char *)args[6])[-2];
2018-09-25 17:09:53 -04:00
switch (svc_number) {
2018-09-25 22:42:17 -04:00
case -1:
2018-10-29 18:11:53 -04:00
case 0: /* Task-related calls
* 0 - _exit
* 1 - fork
* 2 - getpid
* 3 - waitpid
2018-11-17 13:02:57 -05:00
* 4 - sbrk (TODO bad)
2018-10-29 18:11:53 -04:00
*/
task_svc(args);
2018-09-25 22:42:17 -04:00
break;
2018-10-29 18:11:53 -04:00
case 1: /* GPIO-related calls
* 0 - gpio_mode
* 1 - gpio_type
* 2 - gpio_pupd
* 3 - gpio_speed
* 4 - gpio_dout
*/
2018-09-25 17:09:53 -04:00
gpio_svc(args);
break;
2018-10-29 18:11:53 -04:00
case 2: /* Clock-related calls
* 0 - delay
* 1 - udelay
* 2 - ticks
2018-10-29 18:11:53 -04:00
*/
2018-10-02 21:26:48 -04:00
clock_svc(args);
2018-10-18 18:24:43 -04:00
break;
2018-10-29 23:27:53 -04:00
2018-11-04 23:46:12 -05:00
case 3: /* Filesystem-related calls
* 0 - mount
* 1 - open
2018-11-17 13:02:57 -05:00
* 2 - close
* 3 - read
* 4 - write
2018-11-04 23:46:12 -05:00
*/
vfs_svc(args);
break;
2018-09-25 17:09:53 -04:00
default:
break;
}
}