diff options
author | Joe Zhao <ztuowen@gmail.com> | 2014-05-16 13:48:41 +0800 |
---|---|---|
committer | Joe Zhao <ztuowen@gmail.com> | 2014-05-16 13:48:41 +0800 |
commit | 01a12fdad10b5995495e1a4236fdfb1a583979ab (patch) | |
tree | 44010320ae31d4e967871a8e9b1231134b6ecd45 /rs422lib/sysctl.h | |
download | rsbus-01a12fdad10b5995495e1a4236fdfb1a583979ab.tar.gz rsbus-01a12fdad10b5995495e1a4236fdfb1a583979ab.tar.bz2 rsbus-01a12fdad10b5995495e1a4236fdfb1a583979ab.zip |
First Commit
Diffstat (limited to 'rs422lib/sysctl.h')
-rw-r--r-- | rs422lib/sysctl.h | 38 |
1 files changed, 38 insertions, 0 deletions
diff --git a/rs422lib/sysctl.h b/rs422lib/sysctl.h new file mode 100644 index 0000000..11b65ed --- /dev/null +++ b/rs422lib/sysctl.h @@ -0,0 +1,38 @@ +/*
+ * sysctl.h
+ *
+ * Created on: 2014-4-26
+ * Author: Tuowen
+ */
+
+// Support 8 different syscalls
+// Possible improvement
+// CPUOFF all the time, wakeup after syscall invoked.
+
+#ifndef SYSCTL_H_
+#define SYSCTL_H_
+
+#define SYS_BIT7 (0x80)
+#define SYS_BIT6 (0x40)
+#define SYS_BIT5 (0x20)
+#define SYS_BIT4 (0x10)
+#define SYS_BIT3 (0x08)
+#define SYS_BIT2 (0x04)
+#define SYS_BIT1 (0x02)
+#define SYS_BIT0 (0x01)
+#define SYSCALL_IRQ(X) (syscall|=X,_BIC_SR_IRQ(CPUOFF))
+#define SYSCALL(X) (syscall|=X)
+
+typedef void (*syshdlr)();
+
+void sysctl_reghdlr(unsigned int bit,syshdlr rot);// Always replace
+
+void sysctl_rmhdlr(unsigned int bit);// Replace with something useless
+
+void sysroutine();
+
+void sysctl_init();
+
+extern volatile unsigned char syscall;
+
+#endif /* SYSCTL_H_ */
|