aboutsummaryrefslogtreecommitdiffstats
path: root/roms/openbios/packages/disk-label.fs
diff options
context:
space:
mode:
Diffstat (limited to 'roms/openbios/packages/disk-label.fs')
-rw-r--r--roms/openbios/packages/disk-label.fs141
1 files changed, 141 insertions, 0 deletions
diff --git a/roms/openbios/packages/disk-label.fs b/roms/openbios/packages/disk-label.fs
new file mode 100644
index 000000000..0021adecf
--- /dev/null
+++ b/roms/openbios/packages/disk-label.fs
@@ -0,0 +1,141 @@
+\ tag: Utility functions
+\
+\ deblocker / filesystem support
+\
+\ Copyright (C) 2003, 2004 Samuel Rydh
+\
+\ See the file "COPYING" for further information about
+\ the copyright and warranty status of this work.
+\
+
+dev /packages
+
+\ -------------------------------------------------------------
+\ /packages/disk-label (partition handling)
+\ -------------------------------------------------------------
+
+[IFDEF] CONFIG_DISK_LABEL
+
+new-device
+ " disk-label" device-name
+ external
+
+ variable part-handlers \ list with (probe-xt, phandle) elements
+ variable fs-handlers \ list with (fs-probe-xt, phandle) elements
+
+ : find-part-handler ( block0 -- phandle | 0 )
+ >r part-handlers
+ begin list-get while
+ ( nextlist dictptr )
+ r@ over @ execute if
+ ( nextlist dictptr )
+ na1+ @ r> rot 2drop exit
+ then
+ drop
+ repeat
+ r> drop 0
+ ;
+
+ : find-filesystem ( offs.d ih -- ph | 0 )
+ >r fs-handlers ( offs.d listhead )
+ begin list-get while
+ 2over ( offs.d nextlist dictptr offs.d )
+ r@ ( offs.d nextlist dictptr offs.d ih )
+ 3 pick ( offs.d nextlist dictptr offs.d ih dictptr )
+ @ ( offs.d nextlist dictptr offs.d ih probe-xt )
+ execute ( offs.d nextlist dictptr flag? )
+ if
+ ( offs.d nextlist dictptr )
+ na1+ ( offs.d nextlist dictptr+1 )
+ @ ( offs.d nextlist phandle )
+ r> ( offs.d nextlist phandle ih )
+ rot ( offs.d phandle ih nextlist )
+ 2drop ( offs.d phandle )
+ -rot ( phandle offs.d )
+ 2drop ( phandle )
+ exit
+ then
+ drop ( offs.d nextlist )
+ repeat
+ 2drop ( offs.d )
+ r> drop 0
+ ;
+
+
+ : register-part-handler ( handler-ph -- )
+ dup " probe" rot find-method
+ 0= abort" Missing probe method!"
+ ( phandle probe-xt )
+ part-handlers list-add , ,
+ ;
+
+ : register-fs-handler ( handler-ph -- )
+ dup " probe" rot find-method
+ 0= abort" Missing probe method!"
+ ( phandle probe-xt )
+ fs-handlers list-add , ,
+ ;
+
+ : dma-alloc
+ " dma-alloc" $call-parent
+ ;
+
+ : dma-free
+ " dma-free" $call-parent
+ ;
+
+ : dma-map-in
+ " dma-map-in" $call-parent
+ ;
+
+ : dma-map-out
+ " dma-map-out" $call-parent
+ ;
+
+ : dma-sync
+ " dma-sync" $call-parent
+ ;
+finish-device
+
+\ ---------------------------------------------------------------------------
+\ methods to register partion and filesystem packages used by disk-label
+\ ---------------------------------------------------------------------------
+
+device-end
+
+: initialise-partition-package ( -- )
+ " dma-alloc" is-call-parent
+ " dma-free" is-call-parent
+ " dma-map-in" is-call-parent
+ " dma-map-out" is-call-parent
+ " dma-sync" is-call-parent
+;
+
+: initialise-fs-package ( -- )
+ " dma-alloc" is-call-parent
+ " dma-free" is-call-parent
+ " dma-map-in" is-call-parent
+ " dma-map-out" is-call-parent
+ " dma-sync" is-call-parent
+;
+
+: register-partition-package ( -- )
+ " register-part-handler" " disk-label" $find-package-method ?dup if
+ active-package swap execute
+ initialise-partition-package
+ else
+ ." [disk-label] internal error" cr
+ then
+;
+
+: register-fs-package ( -- )
+ " register-fs-handler" " disk-label" $find-package-method ?dup if
+ active-package swap execute
+ initialise-fs-package
+ else
+ ." [misc-files] internal error" cr
+ then
+;
+
+[THEN]
+device-end