summaryrefslogtreecommitdiff
path: root/expansionoff.c
diff options
context:
space:
mode:
authornorly <ny-git@enpas.org>2024-12-05 20:13:02 +0900
committernorly <ny-git@enpas.org>2024-12-05 20:36:15 +0900
commit728d1f3df1ccf48292fbf57509c5144fc0f2c74d (patch)
tree76258dc4ab8dd48f23e3b786ecb40c850114d856 /expansionoff.c
parent4442901ce698a31616795b6b9e285e1143a661f6 (diff)
Decompress original filesHEADmaster
Diffstat (limited to 'expansionoff.c')
-rw-r--r--expansionoff.c124
1 files changed, 124 insertions, 0 deletions
diff --git a/expansionoff.c b/expansionoff.c
new file mode 100644
index 0000000..c0aab81
--- /dev/null
+++ b/expansionoff.c
@@ -0,0 +1,124 @@
+/*
+ disable Zorro-II/III Expansions by software
+
+ (C) 2019 Henryk Richter
+
+ This tool can either mark expansions as invalid
+ (Shutup flag) or remove them from the active expansion
+ board list. Please note that this is in software
+ only and won't help if the hidden (presumably broken)
+ devices interfere with the operation of other boards.
+
+ A more reliable way to disable Zorro devices would
+ need to patch expansion.library, which is beyond the
+ scope of this tool.
+
+ compilation:
+ m68k-amigaos-gcc expansionoff.c -o expansionoff -noixemul -Wall -s
+ or
+ sc expansionoff.c link
+
+*/
+#include <string.h>
+#include <dos/dos.h>
+#include <dos/exall.h>
+#include <proto/dos.h>
+#include <exec/memory.h>
+#include <proto/exec.h>
+#include <libraries/expansion.h>
+#include <libraries/configvars.h>
+#define __NOLIBBASE__
+#include <proto/expansion.h>
+
+
+struct Library *ExpansionBase; /* struct ExpansionBase *ExpansionBase; */
+
+/* don't use amiga.lib */
+#define REMOVE(n) ((void)(\
+ ((struct Node *)n)->ln_Pred->ln_Succ = ((struct Node *)n)->ln_Succ,\
+ ((struct Node *)n)->ln_Succ->ln_Pred = ((struct Node *)n)->ln_Pred ))
+
+
+/*----------------- options template -----------------------------------------*/
+#define OPT_TEMPLATE "MANUFACTURER=VENDOR/K/N/A,DEVICE=DEV/K/N/A,SHUTUP=S/S,REMOVE=R/S"
+
+struct progopts {
+ ULONG *vendor;
+ ULONG *dev;
+ ULONG shutup;
+ ULONG remove;
+};
+const char opt_template[];
+
+int main( int argc, char**argv )
+{
+ struct progopts opts;
+ struct RDArgs *rdargs;
+ ULONG syntax;
+ ULONG rcount=0,scount=0;
+ struct ConfigDev *cfg = (0),*cfg2;
+
+ ExpansionBase = OpenLibrary( (STRPTR)EXPANSIONNAME, 34 );
+ if( !ExpansionBase )
+ {
+ Printf("Cannot open expansion.library v34\n");
+ return 10;
+ }
+
+ do
+ {
+ memset( &opts, 0, sizeof( struct progopts ));
+ syntax=1;
+ if( (rdargs = ReadArgs( (char*)opt_template,(LONG*)&opts,NULL) ) )
+ {
+ if( (opts.vendor) && (opts.dev) )
+ syntax = 0;
+ }
+
+ if( syntax )
+ {
+ Printf("Syntax: %s\n",(ULONG)opt_template);
+ break;
+ }
+
+ cfg = FindConfigDev( cfg, *opts.vendor, *opts.dev );
+ if( !cfg )
+ {
+ Printf("Board %ld %ld not found\n",*opts.vendor, *opts.dev);
+ break;
+ }
+
+ while( (cfg) )
+ {
+ cfg2 = FindConfigDev( cfg, *opts.vendor, *opts.dev );
+
+ if( opts.remove )
+ {
+ Disable();
+ REMOVE(cfg);
+ Enable();
+ rcount++;
+ Printf("rem\n");
+ }
+ else
+ {
+ cfg->cd_Flags |= CDF_SHUTUP;
+ scount++;
+ }
+
+ cfg = cfg2;
+ }
+ }
+ while(0);
+
+ Printf("Done. Removed %ld boards, Shutup %ld boards\n",rcount,scount);
+
+ if( rdargs ) FreeArgs(rdargs);
+
+ CloseLibrary( (struct Library*)ExpansionBase );
+ return 0;
+}
+
+/* some strings down here */
+const char opt_template[] = OPT_TEMPLATE;
+const char verstring[] = "$VER: expansionoff 1.0 (03.06.2019) Disable Zorro Expansions (C) Henryk Richter";