summaryrefslogtreecommitdiff
path: root/src/drv/ps1/interrupt/include
diff options
context:
space:
mode:
authorXavier Del Campo Romero <xavi92@disroot.org>2025-07-07 13:22:53 +0200
committerXavier Del Campo Romero <xavi92@disroot.org>2025-07-25 14:16:41 +0200
commit14f60e4fd65c42f126eaee7e09cb4251c167c6ed (patch)
tree313b5e16d7d99cf1518c953e2efe5e5fc920dfbf /src/drv/ps1/interrupt/include
parent48a61c16eaa6dcfc75d00dba302537ce1492db98 (diff)
downloadwnix-tty.tar.gz
wiptty
Diffstat (limited to 'src/drv/ps1/interrupt/include')
-rw-r--r--src/drv/ps1/interrupt/include/drv/ps1/interrupt.h39
1 files changed, 39 insertions, 0 deletions
diff --git a/src/drv/ps1/interrupt/include/drv/ps1/interrupt.h b/src/drv/ps1/interrupt/include/drv/ps1/interrupt.h
new file mode 100644
index 0000000..9e0bfb4
--- /dev/null
+++ b/src/drv/ps1/interrupt/include/drv/ps1/interrupt.h
@@ -0,0 +1,39 @@
+/*
+ * wanix, a Unix-like operating system for WebAssembly applications.
+ * Copyright (C) 2025 Xavier Del Campo Romero
+ *
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU Affero 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 Affero General Public License for more details.
+ *
+ * You should have received a copy of the GNU Affero General Public License
+ * along with this program. If not, see <https://www.gnu.org/licenses/>.
+ */
+
+#ifndef DRV_PS1_INTERRUPT_H
+#define DRV_PS1_INTERRUPT_H
+
+#include <stdint.h>
+
+union drv_ps1_interrupt
+{
+ struct
+ {
+ uint32_t vblank :1, gpu :1, cdrom :1, dma :1, tmr0 :1, tmr1 :1, tmr2 :1,
+ controller :1, sio :1, spu :1, lightpen :1, :21;
+ } bits;
+
+ uint32_t mask;
+};
+
+#define I_BASE(x) (0x1f801070 + (x))
+#define I_STAT ((volatile union drv_ps1_interrupt *)I_BASE(0))
+#define I_MASK ((volatile union drv_ps1_interrupt *)I_BASE(4))
+
+#endif