Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/arch/acorn32/stand/boot32 Don't call OS_ReadSysInfo Plat...
details: https://anonhg.NetBSD.org/src/rev/06281ac56812
branches: trunk
changeset: 996217:06281ac56812
user: sborrill <sborrill%NetBSD.org@localhost>
date: Wed Jan 23 14:52:49 2019 +0000
description:
Don't call OS_ReadSysInfo Platform class call on RISC OS 3
diffstat:
sys/arch/acorn32/stand/boot32/boot32.c | 58 +++++++++++++++++++++++++++++++--
1 files changed, 54 insertions(+), 4 deletions(-)
diffs (90 lines):
diff -r 89a828c5a15f -r 06281ac56812 sys/arch/acorn32/stand/boot32/boot32.c
--- a/sys/arch/acorn32/stand/boot32/boot32.c Wed Jan 23 14:49:00 2019 +0000
+++ b/sys/arch/acorn32/stand/boot32/boot32.c Wed Jan 23 14:52:49 2019 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: boot32.c,v 1.45 2018/10/30 20:23:29 christos Exp $ */
+/* $NetBSD: boot32.c,v 1.46 2019/01/23 14:52:49 sborrill Exp $ */
/*-
* Copyright (c) 2002 Reinoud Zandijk
@@ -760,17 +760,57 @@
}
}
+int get_riscos_ver(void);
+
+#define ModuleName_UtilityModule "UtilityModule"
+
+int
+get_riscos_ver(void)
+{
+ int module, section;
+ os_error *e;
+ char *name;
+ int version;
+
+ version = 0;
+ /* Full enumeration */
+ module = 0;
+ section = -1;
+ do {
+ e = xosmodule_enumeratewithversion(&module, §ion, &name,
+ NULL, NULL, &version);
+ if (!strncmp(name, ModuleName_UtilityModule,
+ sizeof (ModuleName_UtilityModule))) {
+ return version;
+ }
+ } while (e == NULL && section == -1);
+ return 0;
+}
+
int main(int, char **);
int
main(int argc, char **argv)
{
int howto, start_args, ret;
+ int riscosver;
int class;
+ riscosver = get_riscos_ver();
+ /*
+ * RISC OS version is in BCD
+ * Top 16 bits = major version
+ * Bottom 16 bits = fractional part
+ * e.g. 3.71 = 0x00037100
+ */
+
printf("\n\n");
printf(">> %s, Revision %s\n", bootprog_name, bootprog_rev);
printf(">> Booting NetBSD/acorn32 on a RiscPC/A7000/NC\n");
+ printf(">> RISC OS version: %d.%d%d\n",
+ (riscosver >> 16) & 0xff,
+ (riscosver >> 12) & 0xf,
+ (riscosver >> 8) & 0xf);
printf("\n");
process_args(argc, argv, &howto, booted_file, &start_args);
@@ -855,9 +895,19 @@
/* dismount all filesystems */
xosfscontrol_shutdown();
- os_readsysinfo_platform_class(&class, NULL, NULL);
- if (class != osreadsysinfo_Platform_Pace) {
- /* reset devices, well they try to anyway */
+ /*
+ * OS_ReadSysInfo Platform class reason code not valid
+ * on RISC OS 3.
+ * XXX Don't know about RISC OS 4
+ */
+
+ if (riscosver >= 0x40000) {
+ os_readsysinfo_platform_class(&class, NULL, NULL);
+ if (class != osreadsysinfo_Platform_Pace) {
+ /* reset devices, well try to anyway */
+ service_pre_reset();
+ }
+ } else {
service_pre_reset();
}
Home |
Main Index |
Thread Index |
Old Index