2025-01-03 12:44:26 +01:00
; ( function ( ) { 'use strict' ; function aa ( a , b ) { function c ( x ) { x = x . toString ( 16 ) ; return "#" + "0" . repeat ( 6 - x . length ) + x } function d ( x ) { var v = 256 * la , E = 8 * S , J = Na ? Na . canvas : null ; J && J . width === v && J . height === E || ( J ? ( J . width = v , J . height = E ) : ( J = new OffscreenCanvas ( v , E ) , Na = J . getContext ( "2d" ) ) , rb = Na . createImageData ( v , E ) ) ; const P = rb . data ; let O = 0 , T ; E = sb ? function ( Y ) { T = T || Y ; P [ O + 3 ] = Y ; P [ O + 7 ] = Y ; O += 8 } : function ( Y ) { T = T || Y ; P [ O + 3 ] = Y ; O += 4 } ; J = 32 - S ; const ha = v * ( S - 1 ) * 4 ; v = 4 * ( la - v * S ) ; const ea = 1020 * la ; for ( let Y = 0 , Aa = 0 ; 2048 > Y ; ++ Y , Aa += J , O += v ) { const Ba = Y % 256 ; Y && ! Ba && ( O +=
ha ) ; T = ! 1 ; for ( let Ha = 0 ; Ha < S ; ++ Ha , ++ Aa , O += ea ) { const Ia = x [ Aa ] ; for ( let sa = 128 ; 0 < sa ; sa >>= 1 ) E ( Ia & sa ? 255 : 0 ) ; tb && E ( ub && 192 <= Ba && 223 >= Ba && Ia & 1 ? 255 : 0 ) } Lb [ Y ] = T ? 1 : 0 } Na . putImageData ( rb , 0 , 0 ) } function e ( x , v , E , J ) { if ( v && E ) { x . style . width = "" ; x . style . height = "" ; J && ( x . style . transform = "" ) ; var P = x . getBoundingClientRect ( ) ; J ? x . style . transform = ( 1 === v ? "" : " scaleX(" + v + ")" ) + ( 1 === E ? "" : " scaleY(" + E + ")" ) : ( 0 === v % 1 && 0 === E % 1 ? ( f . style . imageRendering = "crisp-edges" , f . style . imageRendering = "pixelated" , f . style [ "-ms-interpolation-mode" ] = "nearest-neighbor" ) :
( f . style . imageRendering = "" , f . style [ "-ms-interpolation-mode" ] = "" ) , J = window . devicePixelRatio || 1 , 0 !== J % 1 && ( v /= J , E /= J ) ) ; 1 !== v && ( x . style . width = P . width * v + "px" ) ; 1 !== E && ( x . style . height = P . height * E + "px" ) } } const g = a . container ; this . screen _fill _buffer = b ; console . assert ( g , "options.container must be provided" ) ; this . FLAG _BLINKING = 1 ; this . FLAG _FONT _PAGE _B = 2 ; var f = g . getElementsByTagName ( "canvas" ) [ 0 ] , k = f . getContext ( "2d" , { alpha : ! 1 } ) , l = g . getElementsByTagName ( "div" ) [ 0 ] , m = document . createElement ( "div" ) , n , p , q = void 0 !== a . scale ?
a . scale : 1 , r = void 0 !== a . scale ? a . scale : 1 , A = 1 , z , u , F , y , I , R , ma , Na , rb , Lb = new Int8Array ( 2048 ) , S , la , tb , sb , ub , vb = 0 , wb = 0 , db , Mb = 0 , eb , xb , fb , yb = [ ] , gb = yb , hb = 0 , zb = ! 1 ; this . init = function ( ) { const x = new Uint16Array ( [ 32 , 9786 , 9787 , 9829 , 9830 , 9827 , 9824 , 8226 , 9688 , 9675 , 9689 , 9794 , 9792 , 9834 , 9835 , 9788 , 9658 , 9668 , 8597 , 8252 , 182 , 167 , 9644 , 8616 , 8593 , 8595 , 8594 , 8592 , 8735 , 8596 , 9650 , 9660 ] ) , v = new Uint16Array ( [ 8962 , 199 , 252 , 233 , 226 , 228 , 224 , 229 , 231 , 234 , 235 , 232 , 239 , 238 , 236 , 196 , 197 , 201 , 230 , 198 , 244 , 246 , 242 , 251 , 249 , 255 , 214 , 220 , 162 , 163 , 165 , 8359 ,
402 , 225 , 237 , 243 , 250 , 241 , 209 , 170 , 186 , 191 , 8976 , 172 , 189 , 188 , 161 , 171 , 187 , 9617 , 9618 , 9619 , 9474 , 9508 , 9569 , 9570 , 9558 , 9557 , 9571 , 9553 , 9559 , 9565 , 9564 , 9563 , 9488 , 9492 , 9524 , 9516 , 9500 , 9472 , 9532 , 9566 , 9567 , 9562 , 9556 , 9577 , 9574 , 9568 , 9552 , 9580 , 9575 , 9576 , 9572 , 9573 , 9561 , 9560 , 9554 , 9555 , 9579 , 9578 , 9496 , 9484 , 9608 , 9604 , 9612 , 9616 , 9600 , 945 , 223 , 915 , 960 , 931 , 963 , 181 , 964 , 934 , 920 , 937 , 948 , 8734 , 966 , 949 , 8745 , 8801 , 177 , 8805 , 8804 , 8992 , 8993 , 247 , 8776 , 176 , 8729 , 183 , 8730 , 8319 , 178 , 9632 , 160 ] ) ; for ( var E = 0 , J ; 256 > E ; E ++ ) J = 126 < E ? v [ E - 127 ] : 32 > E ? x [ E ] :
E , yb . push ( String . fromCharCode ( J ) ) ; m . classList . add ( "cursor" ) ; m . style . position = "absolute" ; m . style . backgroundColor = "#ccc" ; m . style . width = "7px" ; m . style . display = "inline-block" ; this . set _mode ( ! 1 ) ; this . set _size _text ( 80 , 25 ) ; 2 === u && this . set _size _graphical ( 720 , 400 , 720 , 400 ) ; this . set _scale ( q , r ) ; this . timer ( ) } ; this . make _screenshot = function ( ) { const x = new Image ; if ( 1 === u || 2 === u ) x . src = f . toDataURL ( "image/png" ) ; else { const v = [ 9 , 16 ] , E = document . createElement ( "canvas" ) ; E . width = y * v [ 0 ] ; E . height = I * v [ 1 ] ; const J = E . getContext ( "2d" ) ;
J . imageSmoothingEnabled = ! 1 ; J . font = window . getComputedStyle ( l ) . font ; J . textBaseline = "top" ; for ( let P = 0 ; P < I ; P ++ ) for ( let O = 0 ; O < y ; O ++ ) { const T = 4 * ( P * y + O ) , ha = F [ T + 0 ] , ea = F [ T + 3 ] ; J . fillStyle = c ( F [ T + 2 ] ) ; J . fillRect ( O * v [ 0 ] , P * v [ 1 ] , v [ 0 ] , v [ 1 ] ) ; J . fillStyle = c ( ea ) ; J . fillText ( gb [ ha ] , O * v [ 0 ] , P * v [ 1 ] ) } "none" !== m . style . display && n < I && p < y && ( J . fillStyle = m . style . backgroundColor , J . fillRect ( p * v [ 0 ] , n * v [ 1 ] + parseInt ( m . style . marginTop , 10 ) , parseInt ( m . style . width , 10 ) , parseInt ( m . style . height , 10 ) ) ) ; x . src = E . toDataURL ( "image/png" ) } return x } ;
this . put _char = function ( x , v , E , J , P , O ) { v = 4 * ( x * y + v ) ; F [ v + 0 ] = E ; F [ v + 1 ] = J ; F [ v + 2 ] = P ; F [ v + 3 ] = O ; z [ x ] = 1 } ; this . timer = function ( ) { hb = requestAnimationFrame ( ( ) => this . update _screen ( ) ) } ; this . update _screen = function ( ) { zb || ( 0 === u ? this . update _text ( ) : 1 === u ? this . update _graphical ( ) : this . update _graphical _text ( ) ) ; this . timer ( ) } ; this . update _text = function ( ) { for ( var x = 0 ; x < I ; x ++ ) z [ x ] && ( this . text _update _row ( x ) , z [ x ] = 0 ) } ; this . update _graphical = function ( ) { this . screen _fill _buffer ( ) } ; this . update _graphical _text = function ( ) { if ( R ) { var x = performance . now ( ) ;
if ( 266 < x - Mb ) { db = ! db ; fb && ( z [ n ] = 1 ) ; var v = 4 * y ; for ( let ha = 0 , ea = 0 ; ha < I ; ++ ha ) if ( z [ ha ] ) ea += v ; else for ( var E = 0 ; E < y ; ++ E , ea += 4 ) if ( F [ ea + 1 ] & 1 ) { z [ ha ] = 1 ; ea += v - 4 * E ; break } Mb = x } x = Na . canvas ; v = ma . canvas ; E = 4 * y ; const P = y * la , O = S ; let T = 0 ; for ( let ha = 0 , ea = 0 , Y = 0 ; ha < I ; ++ ha , ea += S ) { if ( ! z [ ha ] ) { Y += E ; continue } ++ T ; ma . clearRect ( 0 , O , P , S ) ; let Aa , Ba , Ha , Ia ; for ( let sa = 0 ; sa < P ; sa += la , Y += 4 ) { const Nb = F [ Y + 0 ] ; var J = F [ Y + 1 ] ; const Ob = F [ Y + 2 ] , Pb = F [ Y + 3 ] , Qb = J & 2 ? wb : vb ; J = ( ! ( J & 1 ) || db ) && Lb [ ( Qb << 8 ) + Nb ] ; Ha !== Ob && ( void 0 !== Ha && ( R . fillStyle = c ( Ha ) , R . fillRect ( Ia ,
ea , sa - Ia , S ) ) , Ha = Ob , Ia = sa ) ; Aa !== Pb && ( void 0 !== Aa && ( ma . fillStyle = c ( Aa ) , ma . fillRect ( Ba , 0 , sa - Ba , S ) ) , Aa = Pb , Ba = sa ) ; J && ma . drawImage ( x , Nb * la , Qb * S , la , S , sa , O , la , S ) } ma . fillStyle = c ( Aa ) ; ma . fillRect ( Ba , 0 , P - Ba , S ) ; ma . globalCompositeOperation = "destination-in" ; ma . drawImage ( v , 0 , O , P , S , 0 , 0 , P , S ) ; ma . globalCompositeOperation = "source-over" ; R . fillStyle = c ( Ha ) ; R . fillRect ( Ia , ea , P - Ia , S ) ; R . drawImage ( v , 0 , 0 , P , S , 0 , ea , P , S ) } T && ( db && fb && z [ n ] && ( R . fillStyle = c ( F [ 4 * ( n * y + p ) + 3 ] ) , R . fillRect ( p * la , n * S + eb , la , xb - eb + 1 ) ) , z . fill ( 0 ) ) ; T && k . drawImage ( R . canvas ,
0 , 0 ) } } ; this . destroy = function ( ) { hb && ( cancelAnimationFrame ( hb ) , hb = 0 ) } ; this . pause = function ( ) { zb = ! 0 ; m . classList . remove ( "blinking-cursor" ) } ; this . continue = function ( ) { zb = ! 1 ; m . classList . add ( "blinking-cursor" ) } ; this . set _mode = function ( x ) { u = x ? 1 : a . use _graphical _text ? 2 : 0 ; 0 === u ? ( l . style . display = "block" , f . style . display = "none" ) : ( l . style . display = "none" , f . style . display = "block" , 2 === u && z && z . fill ( 1 ) ) } ; this . set _font _bitmap = function ( x , v , E , J , P , O ) { const T = E ? 16 : v ? 9 : 8 ; if ( S !== x || la !== T || tb !== v || sb !== E || ub !== J || O ) O = la !== T || S !==
x , S = x , la = T , tb = v , sb = E , ub = J , 2 === u && ( d ( P ) , z . fill ( 1 ) , O && this . set _size _graphical _text ( ) ) } ; this . set _font _page = function ( x , v ) { if ( vb !== x || wb !== v ) vb = x , wb = v , z . fill ( 1 ) } ; this . clear _screen = function ( ) { k . fillStyle = "#000" ; k . fillRect ( 0 , 0 , f . width , f . height ) } ; this . set _size _graphical _text = function ( ) { if ( Na ) { var x = la * y , v = S * I , E = 2 * S ; R && R . canvas . width === x && R . canvas . height === v && ma . canvas . height === E || ( R ? ( R . canvas . width = x , R . canvas . height = v , ma . canvas . width = x , ma . canvas . height = E ) : ( R = ( new OffscreenCanvas ( x , v ) ) . getContext ( "2d" , { alpha : ! 1 } ) ,
ma = ( new OffscreenCanvas ( x , E ) ) . getContext ( "2d" ) ) , this . set _size _graphical ( x , v , x , v ) , z . fill ( 1 ) ) } } ; this . set _size _text = function ( x , v ) { if ( x !== y || v !== I ) if ( z = new Int8Array ( v ) , F = new Int32Array ( x * v * 4 ) , y = x , I = v , 0 === u ) { for ( ; l . childNodes . length > v ; ) l . removeChild ( l . firstChild ) ; for ( ; l . childNodes . length < v ; ) l . appendChild ( document . createElement ( "div" ) ) ; for ( x = 0 ; x < v ; x ++ ) this . text _update _row ( x ) ; e ( l , q , r , ! 0 ) } else 2 === u && this . set _size _graphical _text ( ) } ; this . set _size _graphical = function ( x , v ) { f . style . display = "block" ; f . width = x ;
f . height = v ; k . imageSmoothingEnabled = ! 1 ; A = 640 >= x && 2 * x < window . innerWidth * window . devicePixelRatio && 2 * v < window . innerHeight * window . devicePixelRatio ? 2 : 1 ; e ( f , q * A , r * A , ! 1 ) } ; this . set _charmap = function ( x ) { gb = x || yb } ; this . set _scale = function ( x , v ) { q = x ; r = v ; e ( l , q , r , ! 0 ) ; e ( f , q * A , r * A , ! 1 ) } ; this . update _cursor _scanline = function ( x , v , E ) { if ( x !== eb || v !== xb || E !== fb ) 0 === u ? E ? ( m . style . display = "inline" , m . style . height = v - x + "px" , m . style . marginTop = x + "px" ) : m . style . display = "none" : 2 === u && n < I && ( z [ n ] = 1 ) , eb = x , xb = v , fb = E } ; this . update _cursor =
function ( x , v ) { if ( x !== n || v !== p ) x < I && ( z [ x ] = 1 ) , n < I && ( z [ n ] = 1 ) , n = x , p = v } ; this . text _update _row = function ( x ) { var v = 4 * x * y , E ; var J = l . childNodes [ x ] ; var P = document . createElement ( "div" ) ; for ( var O = 0 ; O < y ; ) { var T = document . createElement ( "span" ) ; var ha = F [ v + 1 ] & 1 ; var ea = F [ v + 2 ] ; var Y = F [ v + 3 ] ; ha && T . classList . add ( "blink" ) ; T . style . backgroundColor = c ( ea ) ; T . style . color = c ( Y ) ; for ( E = "" ; O < y && ( F [ v + 1 ] & 1 ) === ha && F [ v + 2 ] === ea && F [ v + 3 ] === Y ; ) if ( E += gb [ F [ v + 0 ] ] , O ++ , v += 4 , x === n ) if ( O === p ) break ; else if ( O === p + 1 ) { m . style . backgroundColor = T . style . color ;
P . appendChild ( m ) ; break } T . textContent = E ; P . appendChild ( T ) } J . parentNode . replaceChild ( P , J ) } ; this . update _buffer = function ( x ) { for ( const v of x ) k . putImageData ( v . image _data , v . screen _x - v . buffer _x , v . screen _y - v . buffer _y , v . buffer _x , v . buffer _y , v . buffer _width , v . buffer _height ) } ; this . get _text _screen = function ( ) { for ( var x = [ ] , v = 0 ; v < I ; v ++ ) x . push ( this . get _text _row ( v ) ) ; return x } ; this . get _text _row = function ( x ) { let v = "" ; for ( let E = 0 ; E < y ; E ++ ) v += gb [ F [ 4 * ( x * y + E ) ] ] ; return v } ; this . init ( ) } ; const ba = [ "shared" , "exclusive" , "unlock" ] ;
2024-11-28 07:25:05 +01:00
function ca ( a , b , c ) { this . fs = a ; this . bus = c ; this . configspace _tagname = [ 104 , 111 , 115 , 116 , 57 , 112 ] ; this . configspace _taglen = this . configspace _tagname . length ; this . VERSION = "9P2000.L" ; this . msize = this . BLOCKSIZE = 8192 ; this . replybuffer = new Uint8Array ( 2 * this . msize ) ; this . replybuffersize = 0 ; this . fids = [ ] ; this . virtio = new da ( b , { name : "virtio-9p" , pci _id : 48 , device _id : 4169 , subsystem _device _id : 9 , common : { initial _port : 43008 , queues : [ { size _supported : 32 , notify _offset : 0 } ] , features : [ 0 , 32 , 29 , 28 ] , on _driver _ok : ( ) => { } } , notification : { initial _port : 43264 ,
2025-01-03 12:44:26 +01:00
single _handler : ! 1 , handlers : [ d => { if ( 0 === d ) { for ( ; this . virtqueue . has _request ( ) ; ) d = this . virtqueue . pop _request ( ) , this . ReceiveRequest ( d ) ; this . virtqueue . notify _me _after ( 0 ) } } ] } , isr _status : { initial _port : 42752 } , device _specific : { initial _port : 42496 , struct : [ { bytes : 2 , name : "mount tag length" , read : ( ) => this . configspace _taglen , write : ( ) => { } } ] . concat ( h . range ( 254 ) . map ( d => ( { bytes : 1 , name : "mount tag name " + d , read : ( ) => this . configspace _tagname [ d ] || 0 , write : ( ) => { } } ) ) ) } } ) ; this . virtqueue = this . virtio . queues [ 0 ] }
2024-10-02 21:03:04 +02:00
ca . prototype . get _state = function ( ) { var a = [ ] ; a [ 0 ] = this . configspace _tagname ; a [ 1 ] = this . configspace _taglen ; a [ 2 ] = this . virtio ; a [ 3 ] = this . VERSION ; a [ 4 ] = this . BLOCKSIZE ; a [ 5 ] = this . msize ; a [ 6 ] = this . replybuffer ; a [ 7 ] = this . replybuffersize ; a [ 8 ] = this . fids . map ( function ( b ) { return [ b . inodeid , b . type , b . uid , b . dbg _name ] } ) ; a [ 9 ] = this . fs ; return a } ;
ca . prototype . set _state = function ( a ) { this . configspace _tagname = a [ 0 ] ; this . configspace _taglen = a [ 1 ] ; this . virtio . set _state ( a [ 2 ] ) ; this . virtqueue = this . virtio . queues [ 0 ] ; this . VERSION = a [ 3 ] ; this . BLOCKSIZE = a [ 4 ] ; this . msize = a [ 5 ] ; this . replybuffer = a [ 6 ] ; this . replybuffersize = a [ 7 ] ; this . fids = a [ 8 ] . map ( function ( b ) { return { inodeid : b [ 0 ] , type : b [ 1 ] , uid : b [ 2 ] , dbg _name : b [ 3 ] } } ) ; this . fs . set _state ( a [ 9 ] ) } ; ca . prototype . Createfid = function ( a , b , c , d ) { return { inodeid : a , type : b , uid : c , dbg _name : d } } ;
2025-01-03 12:44:26 +01:00
ca . prototype . update _dbg _name = function ( a , b ) { for ( const c of this . fids ) c . inodeid === a && ( c . dbg _name = b ) } ; ca . prototype . reset = function ( ) { this . fids = [ ] ; this . virtio . reset ( ) } ; ca . prototype . BuildReply = function ( a , b , c ) { t . Marshall ( [ "w" , "b" , "h" ] , [ c + 7 , a + 1 , b ] , this . replybuffer , 0 ) ; c + 7 >= this . replybuffer . length && w . Debug ( "Error in 9p: payloadsize exceeds maximum length" ) ; this . replybuffersize = c + 7 } ; ca . prototype . SendError = function ( a , b , c ) { b = t . Marshall ( [ "w" ] , [ c ] , this . replybuffer , 7 ) ; this . BuildReply ( 6 , a , b ) } ;
2024-10-02 21:03:04 +02:00
ca . prototype . SendReply = function ( a ) { a . set _next _blob ( this . replybuffer . subarray ( 0 , this . replybuffersize ) ) ; this . virtqueue . push _reply ( a ) ; this . virtqueue . flush _replies ( ) } ;
2025-01-03 12:44:26 +01:00
ca . prototype . ReceiveRequest = async function ( a ) { var b = new Uint8Array ( a . length _readable ) ; a . get _next _blob ( b ) ; var c = { offset : 0 } , d = t . Unmarshall ( [ "w" , "b" , "h" ] , b , c ) , e = d [ 0 ] , g = d [ 1 ] , f = d [ 2 ] ; switch ( g ) { case 8 : e = this . fs . GetTotalSize ( ) ; b = this . fs . GetSpace ( ) ; d = [ 16914839 ] ; d [ 1 ] = this . BLOCKSIZE ; d [ 2 ] = Math . floor ( b / d [ 1 ] ) ; d [ 3 ] = d [ 2 ] - Math . floor ( e / d [ 1 ] ) ; d [ 4 ] = d [ 2 ] - Math . floor ( e / d [ 1 ] ) ; d [ 5 ] = this . fs . CountUsedInodes ( ) ; d [ 6 ] = this . fs . CountFreeInodes ( ) ; d [ 7 ] = 0 ; d [ 8 ] = 256 ; e = t . Marshall ( "wwddddddw" . split ( "" ) , d , this . replybuffer , 7 ) ; this . BuildReply ( g ,
f , e ) ; this . SendReply ( a ) ; break ; case 112 : case 12 : d = t . Unmarshall ( [ "w" , "w" ] , b , c ) ; var k = d [ 0 ] ; c = d [ 1 ] ; w . Debug ( "[open] fid=" + k + ", mode=" + c ) ; b = this . fids [ k ] . inodeid ; var l = this . fs . GetInode ( b ) ; w . Debug ( "file open " + this . fids [ k ] . dbg _name ) ; e = this . fs . OpenInode ( b , c ) ; this . fs . AddEvent ( this . fids [ k ] . inodeid , function ( ) { w . Debug ( "file opened " + this . fids [ k ] . dbg _name + " tag:" + f ) ; var q = [ ] ; q [ 0 ] = l . qid ; q [ 1 ] = this . msize - 24 ; t . Marshall ( [ "Q" , "w" ] , q , this . replybuffer , 7 ) ; this . BuildReply ( g , f , 17 ) ; this . SendReply ( a ) } . bind ( this ) ) ; break ; case 70 : d =
t . Unmarshall ( [ "w" , "w" , "s" ] , b , c ) ; b = d [ 0 ] ; k = d [ 1 ] ; e = d [ 2 ] ; w . Debug ( "[link] dfid=" + b + ", name=" + e ) ; e = this . fs . Link ( this . fids [ b ] . inodeid , this . fids [ k ] . inodeid , e ) ; if ( 0 > e ) { this . SendError ( f , - 1 === e ? "Operation not permitted" : "Unknown error: " + - e , - e ) ; this . SendReply ( a ) ; break } this . BuildReply ( g , f , 0 ) ; this . SendReply ( a ) ; break ; case 16 : d = t . Unmarshall ( [ "w" , "s" , "s" , "w" ] , b , c ) ; k = d [ 0 ] ; e = d [ 1 ] ; b = d [ 2 ] ; d = d [ 3 ] ; w . Debug ( "[symlink] fid=" + k + ", name=" + e + ", symgt=" + b + ", gid=" + d ) ; b = this . fs . CreateSymlink ( e , this . fids [ k ] . inodeid , b ) ; l = this . fs . GetInode ( b ) ;
l . uid = this . fids [ k ] . uid ; l . gid = d ; t . Marshall ( [ "Q" ] , [ l . qid ] , this . replybuffer , 7 ) ; this . BuildReply ( g , f , 13 ) ; this . SendReply ( a ) ; break ; case 18 : d = t . Unmarshall ( "wswwww" . split ( "" ) , b , c ) ; k = d [ 0 ] ; e = d [ 1 ] ; c = d [ 2 ] ; b = d [ 3 ] ; var m = d [ 4 ] ; d = d [ 5 ] ; w . Debug ( "[mknod] fid=" + k + ", name=" + e + ", major=" + b + ", minor=" + m ) ; b = this . fs . CreateNode ( e , this . fids [ k ] . inodeid , b , m ) ; l = this . fs . GetInode ( b ) ; l . mode = c ; l . uid = this . fids [ k ] . uid ; l . gid = d ; t . Marshall ( [ "Q" ] , [ l . qid ] , this . replybuffer , 7 ) ; this . BuildReply ( g , f , 13 ) ; this . SendReply ( a ) ; break ; case 22 : d = t . Unmarshall ( [ "w" ] ,
b , c ) ; k = d [ 0 ] ; l = this . fs . GetInode ( this . fids [ k ] . inodeid ) ; w . Debug ( "[readlink] fid=" + k + " name=" + this . fids [ k ] . dbg _name + " target=" + l . symlink ) ; e = t . Marshall ( [ "s" ] , [ l . symlink ] , this . replybuffer , 7 ) ; this . BuildReply ( g , f , e ) ; this . SendReply ( a ) ; break ; case 72 : d = t . Unmarshall ( [ "w" , "s" , "w" , "w" ] , b , c ) ; k = d [ 0 ] ; e = d [ 1 ] ; c = d [ 2 ] ; d = d [ 3 ] ; w . Debug ( "[mkdir] fid=" + k + ", name=" + e + ", mode=" + c + ", gid=" + d ) ; b = this . fs . CreateDirectory ( e , this . fids [ k ] . inodeid ) ; l = this . fs . GetInode ( b ) ; l . mode = c | fa ; l . uid = this . fids [ k ] . uid ; l . gid = d ; t . Marshall ( [ "Q" ] , [ l . qid ] ,
this . replybuffer , 7 ) ; this . BuildReply ( g , f , 13 ) ; this . SendReply ( a ) ; break ; case 14 : d = t . Unmarshall ( [ "w" , "s" , "w" , "w" , "w" ] , b , c ) ; k = d [ 0 ] ; e = d [ 1 ] ; b = d [ 2 ] ; c = d [ 3 ] ; d = d [ 4 ] ; this . bus . send ( "9p-create" , [ e , this . fids [ k ] . inodeid ] ) ; w . Debug ( "[create] fid=" + k + ", name=" + e + ", flags=" + b + ", mode=" + c + ", gid=" + d ) ; b = this . fs . CreateFile ( e , this . fids [ k ] . inodeid ) ; this . fids [ k ] . inodeid = b ; this . fids [ k ] . type = 1 ; this . fids [ k ] . dbg _name = e ; l = this . fs . GetInode ( b ) ; l . uid = this . fids [ k ] . uid ; l . gid = d ; l . mode = c | ia ; t . Marshall ( [ "Q" , "w" ] , [ l . qid , this . msize - 24 ] , this . replybuffer ,
7 ) ; this . BuildReply ( g , f , 17 ) ; this . SendReply ( a ) ; break ; case 52 : d = t . Unmarshall ( "wbwddws" . split ( "" ) , b , c ) ; k = d [ 0 ] ; b = d [ 2 ] ; e = 0 === d [ 4 ] ? Infinity : d [ 4 ] ; d = this . fs . DescribeLock ( d [ 1 ] , d [ 3 ] , e , d [ 5 ] , d [ 6 ] ) ; w . Debug ( "[lock] fid=" + k + ", type=" + ba [ d . type ] + ", start=" + d . start + ", length=" + d . length + ", proc_id=" + d . proc _id ) ; e = this . fs . Lock ( this . fids [ k ] . inodeid , d , b ) ; t . Marshall ( [ "b" ] , [ e ] , this . replybuffer , 7 ) ; this . BuildReply ( g , f , 1 ) ; this . SendReply ( a ) ; break ; case 54 : d = t . Unmarshall ( "wbddws" . split ( "" ) , b , c ) ; k = d [ 0 ] ; e = 0 === d [ 3 ] ? Infinity : d [ 3 ] ;
d = this . fs . DescribeLock ( d [ 1 ] , d [ 2 ] , e , d [ 4 ] , d [ 5 ] ) ; w . Debug ( "[getlock] fid=" + k + ", type=" + ba [ d . type ] + ", start=" + d . start + ", length=" + d . length + ", proc_id=" + d . proc _id ) ; e = this . fs . GetLock ( this . fids [ k ] . inodeid , d ) ; e || ( e = d , e . type = 2 ) ; e = t . Marshall ( [ "b" , "d" , "d" , "w" , "s" ] , [ e . type , e . start , Infinity === e . length ? 0 : e . length , e . proc _id , e . client _id ] , this . replybuffer , 7 ) ; this . BuildReply ( g , f , e ) ; this . SendReply ( a ) ; break ; case 24 : d = t . Unmarshall ( [ "w" , "d" ] , b , c ) ; k = d [ 0 ] ; l = this . fs . GetInode ( this . fids [ k ] . inodeid ) ; w . Debug ( "[getattr]: fid=" +
k + " name=" + this . fids [ k ] . dbg _name + " request mask=" + d [ 1 ] ) ; if ( ! l || l . status === ja ) { w . Debug ( "getattr: unlinked" ) ; this . SendError ( f , "No such file or directory" , 2 ) ; this . SendReply ( a ) ; break } d [ 0 ] = d [ 1 ] ; d [ 1 ] = l . qid ; d [ 2 ] = l . mode ; d [ 3 ] = l . uid ; d [ 4 ] = l . gid ; d [ 5 ] = l . nlinks ; d [ 6 ] = l . major << 8 | l . minor ; d [ 7 ] = l . size ; d [ 8 ] = this . BLOCKSIZE ; d [ 9 ] = Math . floor ( l . size / 512 + 1 ) ; d [ 10 ] = l . atime ; d [ 11 ] = 0 ; d [ 12 ] = l . mtime ; d [ 13 ] = 0 ; d [ 14 ] = l . ctime ; d [ 15 ] = 0 ; d [ 16 ] = 0 ; d [ 17 ] = 0 ; d [ 18 ] = 0 ; d [ 19 ] = 0 ; t . Marshall ( "dQwwwddddddddddddddd" . split ( "" ) , d , this . replybuffer , 7 ) ; this . BuildReply ( g ,
f , 153 ) ; this . SendReply ( a ) ; break ; case 26 : d = t . Unmarshall ( "wwwwwddddd" . split ( "" ) , b , c ) ; k = d [ 0 ] ; l = this . fs . GetInode ( this . fids [ k ] . inodeid ) ; w . Debug ( "[setattr]: fid=" + k + " request mask=" + d [ 1 ] + " name=" + this . fids [ k ] . dbg _name ) ; d [ 1 ] & 1 && ( l . mode = d [ 2 ] ) ; d [ 1 ] & 2 && ( l . uid = d [ 3 ] ) ; d [ 1 ] & 4 && ( l . gid = d [ 4 ] ) ; d [ 1 ] & 16 && ( l . atime = Math . floor ( ( new Date ) . getTime ( ) / 1E3 ) ) ; d [ 1 ] & 32 && ( l . mtime = Math . floor ( ( new Date ) . getTime ( ) / 1E3 ) ) ; d [ 1 ] & 64 && ( l . ctime = Math . floor ( ( new Date ) . getTime ( ) / 1E3 ) ) ; d [ 1 ] & 128 && ( l . atime = d [ 6 ] ) ; d [ 1 ] & 256 && ( l . mtime = d [ 8 ] ) ; d [ 1 ] & 8 &&
await this . fs . ChangeSize ( this . fids [ k ] . inodeid , d [ 5 ] ) ; this . BuildReply ( g , f , 0 ) ; this . SendReply ( a ) ; break ; case 50 : d = t . Unmarshall ( [ "w" , "d" ] , b , c ) ; k = d [ 0 ] ; this . BuildReply ( g , f , 0 ) ; this . SendReply ( a ) ; break ; case 40 : case 116 : d = t . Unmarshall ( [ "w" , "d" , "w" ] , b , c ) ; k = d [ 0 ] ; e = d [ 1 ] ; m = d [ 2 ] ; l = this . fs . GetInode ( this . fids [ k ] . inodeid ) ; 40 === g && w . Debug ( "[treaddir]: fid=" + k + " offset=" + e + " count=" + m ) ; 116 === g && w . Debug ( "[read]: fid=" + k + " (" + this . fids [ k ] . dbg _name + ") offset=" + e + " count=" + m + " fidtype=" + this . fids [ k ] . type ) ; if ( ! l || l . status ===
ja ) { w . Debug ( "read/treaddir: unlinked" ) ; this . SendError ( f , "No such file or directory" , 2 ) ; this . SendReply ( a ) ; break } if ( 2 === this . fids [ k ] . type ) for ( l . caps . length < e + m && ( m = l . caps . length - e ) , d = 0 ; d < m ; d ++ ) this . replybuffer [ 11 + d ] = l . caps [ e + d ] ; else this . fs . OpenInode ( this . fids [ k ] . inodeid , void 0 ) , d = this . fids [ k ] . inodeid , m = Math . min ( m , this . replybuffer . length - 11 ) , l . size < e + m ? m = l . size - e : 40 === g && ( m = this . fs . RoundToDirentry ( d , e + m ) - e ) , e > l . size && ( m = 0 ) , this . bus . send ( "9p-read-start" , [ this . fids [ k ] . dbg _name ] ) , d = await this . fs . Read ( d ,
e , m ) , this . bus . send ( "9p-read-end" , [ this . fids [ k ] . dbg _name , m ] ) , d && this . replybuffer . set ( d , 11 ) ; t . Marshall ( [ "w" ] , [ m ] , this . replybuffer , 7 ) ; this . BuildReply ( g , f , 4 + m ) ; this . SendReply ( a ) ; break ; case 118 : d = t . Unmarshall ( [ "w" , "d" , "w" ] , b , c ) ; k = d [ 0 ] ; e = d [ 1 ] ; m = d [ 2 ] ; d = this . fids [ k ] . dbg _name ; w . Debug ( "[write]: fid=" + k + " (" + d + ") offset=" + e + " count=" + m + " fidtype=" + this . fids [ k ] . type ) ; if ( 2 === this . fids [ k ] . type ) { this . SendError ( f , "Setxattr not supported" , 95 ) ; this . SendReply ( a ) ; break } else await this . fs . Write ( this . fids [ k ] . inodeid , e ,
m , b . subarray ( c . offset ) ) ; this . bus . send ( "9p-write-end" , [ d , m ] ) ; t . Marshall ( [ "w" ] , [ m ] , this . replybuffer , 7 ) ; this . BuildReply ( g , f , 4 ) ; this . SendReply ( a ) ; break ; case 74 : d = t . Unmarshall ( [ "w" , "s" , "w" , "s" ] , b , c ) ; e = d [ 0 ] ; b = d [ 1 ] ; c = d [ 2 ] ; d = d [ 3 ] ; w . Debug ( "[renameat]: oldname=" + b + " newname=" + d ) ; e = await this . fs . Rename ( this . fids [ e ] . inodeid , b , this . fids [ c ] . inodeid , d ) ; if ( 0 > e ) { this . SendError ( f , - 2 === e ? "No such file or directory" : - 1 === e ? "Operation not permitted" : - 39 === e ? "Directory not empty" : "Unknown error: " + - e , - e ) ; this . SendReply ( a ) ;
break } this . BuildReply ( g , f , 0 ) ; this . SendReply ( a ) ; break ; case 76 : d = t . Unmarshall ( [ "w" , "s" , "w" ] , b , c ) ; c = d [ 0 ] ; e = d [ 1 ] ; b = d [ 2 ] ; w . Debug ( "[unlink]: dirfd=" + c + " name=" + e + " flags=" + b ) ; k = this . fs . Search ( this . fids [ c ] . inodeid , e ) ; if ( - 1 === k ) { this . SendError ( f , "No such file or directory" , 2 ) ; this . SendReply ( a ) ; break } e = this . fs . Unlink ( this . fids [ c ] . inodeid , e ) ; if ( 0 > e ) { this . SendError ( f , - 39 === e ? "Directory not empty" : - 1 === e ? "Operation not permitted" : "Unknown error: " + - e , - e ) ; this . SendReply ( a ) ; break } this . BuildReply ( g , f , 0 ) ; this . SendReply ( a ) ;
break ; case 100 : d = t . Unmarshall ( [ "w" , "s" ] , b , c ) ; w . Debug ( "[version]: msize=" + d [ 0 ] + " version=" + d [ 1 ] ) ; this . msize !== d [ 0 ] && ( this . msize = d [ 0 ] , this . replybuffer = new Uint8Array ( Math . min ( 16777216 , 2 * this . msize ) ) ) ; e = t . Marshall ( [ "w" , "s" ] , [ this . msize , this . VERSION ] , this . replybuffer , 7 ) ; this . BuildReply ( g , f , e ) ; this . SendReply ( a ) ; break ; case 104 : d = t . Unmarshall ( [ "w" , "w" , "s" , "s" , "w" ] , b , c ) ; k = d [ 0 ] ; e = d [ 4 ] ; w . Debug ( "[attach]: fid=" + k + " afid=" + B ( d [ 1 ] ) + " uname=" + d [ 2 ] + " aname=" + d [ 3 ] ) ; this . fids [ k ] = this . Createfid ( 0 , 1 , e , "" ) ; l = this . fs . GetInode ( this . fids [ k ] . inodeid ) ;
t . Marshall ( [ "Q" ] , [ l . qid ] , this . replybuffer , 7 ) ; this . BuildReply ( g , f , 13 ) ; this . SendReply ( a ) ; this . bus . send ( "9p-attach" ) ; break ; case 108 : d = t . Unmarshall ( [ "h" ] , b , c ) ; w . Debug ( "[flush] " + f ) ; this . BuildReply ( g , f , 0 ) ; this . SendReply ( a ) ; break ; case 110 : d = t . Unmarshall ( [ "w" , "w" , "h" ] , b , c ) ; k = d [ 0 ] ; m = d [ 1 ] ; var n = d [ 2 ] ; w . Debug ( "[walk]: fid=" + d [ 0 ] + " nwfid=" + d [ 1 ] + " nwname=" + n ) ; if ( 0 === n ) { this . fids [ m ] = this . Createfid ( this . fids [ k ] . inodeid , 1 , this . fids [ k ] . uid , this . fids [ k ] . dbg _name ) ; t . Marshall ( [ "h" ] , [ 0 ] , this . replybuffer , 7 ) ; this . BuildReply ( g ,
f , 2 ) ; this . SendReply ( a ) ; break } e = [ ] ; for ( d = 0 ; d < n ; d ++ ) e . push ( "s" ) ; c = t . Unmarshall ( e , b , c ) ; b = this . fids [ k ] . inodeid ; e = 9 ; var p = 0 ; w . Debug ( "walk in dir " + this . fids [ k ] . dbg _name + " to: " + c . toString ( ) ) ; for ( d = 0 ; d < n ; d ++ ) { b = this . fs . Search ( b , c [ d ] ) ; if ( - 1 === b ) { w . Debug ( "Could not find: " + c [ d ] ) ; break } e += t . Marshall ( [ "Q" ] , [ this . fs . GetInode ( b ) . qid ] , this . replybuffer , e ) ; p ++ ; this . fids [ m ] = this . Createfid ( b , 1 , this . fids [ k ] . uid , c [ d ] ) } t . Marshall ( [ "h" ] , [ p ] , this . replybuffer , 7 ) ; this . BuildReply ( g , f , e - 7 ) ; this . SendReply ( a ) ; break ; case 120 : d =
t . Unmarshall ( [ "w" ] , b , c ) ; w . Debug ( "[clunk]: fid=" + d [ 0 ] ) ; this . fids [ d [ 0 ] ] && 0 <= this . fids [ d [ 0 ] ] . inodeid && ( await this . fs . CloseInode ( this . fids [ d [ 0 ] ] . inodeid ) , this . fids [ d [ 0 ] ] . inodeid = - 1 , this . fids [ d [ 0 ] ] . type = - 1 ) ; this . BuildReply ( g , f , 0 ) ; this . SendReply ( a ) ; break ; case 32 : d = t . Unmarshall ( [ "w" , "s" , "d" , "w" ] , b , c ) ; k = d [ 0 ] ; e = d [ 1 ] ; c = d [ 2 ] ; b = d [ 3 ] ; w . Debug ( "[txattrcreate]: fid=" + k + " name=" + e + " attr_size=" + c + " flags=" + b ) ; this . fids [ k ] . type = 2 ; this . BuildReply ( g , f , 0 ) ; this . SendReply ( a ) ; break ; case 30 : d = t . Unmarshall ( [ "w" , "w" , "s" ] , b ,
c ) ; k = d [ 0 ] ; e = d [ 2 ] ; w . Debug ( "[xattrwalk]: fid=" + d [ 0 ] + " newfid=" + d [ 1 ] + " name=" + d [ 2 ] ) ; this . SendError ( f , "Setxattr not supported" , 95 ) ; this . SendReply ( a ) ; break ; default : w . Debug ( "Error in Virtio9p: Unknown id " + g + " received" ) , w . Abort ( ) } } ; function C ( a ) { this . ports = [ ] ; this . cpu = a ; for ( var b = 0 ; 65536 > b ; b ++ ) this . ports [ b ] = this . create _empty _entry ( ) ; var c = a . memory _size [ 0 ] ; for ( b = 0 ; b << 17 < c ; b ++ ) a . memory _map _read8 [ b ] = a . memory _map _write8 [ b ] = void 0 , a . memory _map _read32 [ b ] = a . memory _map _write32 [ b ] = void 0 ; this . mmap _register ( c , 4294967296 - c , function ( d ) { B ( d >>> 0 , 8 ) ; return 255 } , function ( d , e ) { B ( d >>> 0 , 8 ) ; B ( e , 2 ) } , function ( d ) { B ( d >>> 0 , 8 ) ; return - 1 } , function ( d , e ) { B ( d >>> 0 , 8 ) ; B ( e >>> 0 , 8 ) } ) }
C . prototype . create _empty _entry = function ( ) { return { read8 : this . empty _port _read8 , read16 : this . empty _port _read16 , read32 : this . empty _port _read32 , write8 : this . empty _port _write , write16 : this . empty _port _write , write32 : this . empty _port _write , device : void 0 } } ; C . prototype . empty _port _read8 = function ( ) { return 255 } ; C . prototype . empty _port _read16 = function ( ) { return 65535 } ; C . prototype . empty _port _read32 = function ( ) { return - 1 } ; C . prototype . empty _port _write = function ( ) { } ;
C . prototype . register _read = function ( a , b , c , d , e ) { c && ( this . ports [ a ] . read8 = c ) ; d && ( this . ports [ a ] . read16 = d ) ; e && ( this . ports [ a ] . read32 = e ) ; this . ports [ a ] . device = b } ; C . prototype . register _write = function ( a , b , c , d , e ) { c && ( this . ports [ a ] . write8 = c ) ; d && ( this . ports [ a ] . write16 = d ) ; e && ( this . ports [ a ] . write32 = e ) ; this . ports [ a ] . device = b } ;
C . prototype . register _read _consecutive = function ( a , b , c , d , e , g ) { function f ( ) { return c . call ( this ) | d . call ( this ) << 8 } function k ( ) { return e . call ( this ) | g . call ( this ) << 8 } function l ( ) { return c . call ( this ) | d . call ( this ) << 8 | e . call ( this ) << 16 | g . call ( this ) << 24 } e && g ? ( this . register _read ( a , b , c , f , l ) , this . register _read ( a + 1 , b , d ) , this . register _read ( a + 2 , b , e , k ) , this . register _read ( a + 3 , b , g ) ) : ( this . register _read ( a , b , c , f ) , this . register _read ( a + 1 , b , d ) ) } ;
C . prototype . register _write _consecutive = function ( a , b , c , d , e , g ) { function f ( m ) { c . call ( this , m & 255 ) ; d . call ( this , m >> 8 & 255 ) } function k ( m ) { e . call ( this , m & 255 ) ; g . call ( this , m >> 8 & 255 ) } function l ( m ) { c . call ( this , m & 255 ) ; d . call ( this , m >> 8 & 255 ) ; e . call ( this , m >> 16 & 255 ) ; g . call ( this , m >>> 24 ) } e && g ? ( this . register _write ( a , b , c , f , l ) , this . register _write ( a + 1 , b , d ) , this . register _write ( a + 2 , b , e , k ) , this . register _write ( a + 3 , b , g ) ) : ( this . register _write ( a , b , c , f ) , this . register _write ( a + 1 , b , d ) ) } ;
C . prototype . mmap _read32 _shim = function ( a ) { var b = this . cpu . memory _map _read8 [ a >>> 17 ] ; return b ( a ) | b ( a + 1 ) << 8 | b ( a + 2 ) << 16 | b ( a + 3 ) << 24 } ; C . prototype . mmap _write32 _shim = function ( a , b ) { var c = this . cpu . memory _map _write8 [ a >>> 17 ] ; c ( a , b & 255 ) ; c ( a + 1 , b >> 8 & 255 ) ; c ( a + 2 , b >> 16 & 255 ) ; c ( a + 3 , b >>> 24 ) } ;
C . prototype . mmap _register = function ( a , b , c , d , e , g ) { B ( a >>> 0 , 8 ) ; B ( b , 8 ) ; e || ( e = this . mmap _read32 _shim . bind ( this ) ) ; g || ( g = this . mmap _write32 _shim . bind ( this ) ) ; for ( a >>>= 17 ; 0 < b ; a ++ ) this . cpu . memory _map _read8 [ a ] = c , this . cpu . memory _map _write8 [ a ] = d , this . cpu . memory _map _read32 [ a ] = e , this . cpu . memory _map _write32 [ a ] = g , b -= 131072 } ; C . prototype . port _write8 = function ( a , b ) { var c = this . ports [ a ] ; c . write8 === this . empty _port _write && ( B ( a , 4 ) , B ( b , 2 ) , this . get _port _description ( a ) ) ; return c . write8 . call ( c . device , b ) } ;
C . prototype . port _write16 = function ( a , b ) { var c = this . ports [ a ] ; c . write16 === this . empty _port _write && ( B ( a , 4 ) , B ( b , 4 ) , this . get _port _description ( a ) ) ; return c . write16 . call ( c . device , b ) } ; C . prototype . port _write32 = function ( a , b ) { var c = this . ports [ a ] ; c . write32 === this . empty _port _write && ( B ( a , 4 ) , B ( b >>> 0 , 8 ) , this . get _port _description ( a ) ) ; return c . write32 . call ( c . device , b ) } ;
C . prototype . port _read8 = function ( a ) { var b = this . ports [ a ] ; b . read8 === this . empty _port _read8 && ( B ( a , 4 ) , this . get _port _description ( a ) ) ; b = b . read8 . call ( b . device ) ; B ( a ) ; return b } ; C . prototype . port _read16 = function ( a ) { var b = this . ports [ a ] ; b . read16 === this . empty _port _read16 && ( B ( a , 4 ) , this . get _port _description ( a ) ) ; b = b . read16 . call ( b . device ) ; B ( a ) ; return b } ; C . prototype . port _read32 = function ( a ) { var b = this . ports [ a ] ; b . read32 === this . empty _port _read32 && ( B ( a , 4 ) , this . get _port _description ( a ) ) ; return b . read32 . call ( b . device ) } ;
2024-11-28 07:25:05 +01:00
var ka = { 4 : "PORT_DMA_ADDR_2" , 5 : "PORT_DMA_CNT_2" , 10 : "PORT_DMA1_MASK_REG" , 11 : "PORT_DMA1_MODE_REG" , 12 : "PORT_DMA1_CLEAR_FF_REG" , 13 : "PORT_DMA1_MASTER_CLEAR" , 32 : "PORT_PIC1_CMD" , 33 : "PORT_PIC1_DATA" , 64 : "PORT_PIT_COUNTER0" , 65 : "PORT_PIT_COUNTER1" , 66 : "PORT_PIT_COUNTER2" , 67 : "PORT_PIT_MODE" , 96 : "PORT_PS2_DATA" , 97 : "PORT_PS2_CTRLB" , 100 : "PORT_PS2_STATUS" , 112 : "PORT_CMOS_INDEX" , 113 : "PORT_CMOS_DATA" , 128 : "PORT_DIAG" , 129 : "PORT_DMA_PAGE_2" , 146 : "PORT_A20" , 160 : "PORT_PIC2_CMD" , 161 : "PORT_PIC2_DATA" , 178 : "PORT_SMI_CMD" , 179 : "PORT_SMI_STATUS" ,
2024-06-28 09:23:02 +02:00
212 : "PORT_DMA2_MASK_REG" , 214 : "PORT_DMA2_MODE_REG" , 218 : "PORT_DMA2_MASTER_CLEAR" , 240 : "PORT_MATH_CLEAR" , 368 : "PORT_ATA2_CMD_BASE" , 496 : "PORT_ATA1_CMD_BASE" , 632 : "PORT_LPT2" , 744 : "PORT_SERIAL4" , 760 : "PORT_SERIAL2" , 884 : "PORT_ATA2_CTRL_BASE" , 888 : "PORT_LPT1" , 1E3 : "PORT_SERIAL3" , 1008 : "PORT_FD_BASE" , 1010 : "PORT_FD_DOR" , 1012 : "PORT_FD_STATUS" , 1013 : "PORT_FD_DATA" , 1014 : "PORT_HD_DATA" , 1015 : "PORT_FD_DIR" , 1016 : "PORT_SERIAL1" , 3320 : "PORT_PCI_CMD" , 3321 : "PORT_PCI_REBOOT" , 3324 : "PORT_PCI_DATA" , 1026 : "PORT_BIOS_DEBUG" , 1296 : "PORT_QEMU_CFG_CTL" ,
2025-01-03 12:44:26 +01:00
1297 : "PORT_QEMU_CFG_DATA" , 45056 : "PORT_ACPI_PM_BASE" , 45312 : "PORT_SMB_BASE" , 35072 : "PORT_BIOS_APM" } ; C . prototype . get _port _description = function ( a ) { return ka [ a ] ? " (" + ka [ a ] + ")" : "" } ; function D ( a , b ) { this . stopping = this . running = ! 1 ; this . idle = ! 0 ; this . tick _counter = 0 ; this . worker = null ; this . cpu = new G ( a , b , ( ) => { this . idle && this . next _tick ( 0 ) } ) ; this . bus = a ; this . register _yield ( ) } D . prototype . run = function ( ) { this . stopping = ! 1 ; this . running || ( this . running = ! 0 , this . bus . send ( "emulator-started" ) ) ; this . next _tick ( 0 ) } ; D . prototype . do _tick = function ( ) { if ( this . stopping || ! this . running ) this . stopping = this . running = ! 1 , this . bus . send ( "emulator-stopped" ) ; else { this . idle = ! 1 ; var a = this . cpu . main _loop ( ) ; this . next _tick ( a ) } } ;
D . prototype . next _tick = function ( a ) { const b = ++ this . tick _counter ; this . idle = ! 0 ; this . yield ( a , b ) } ; D . prototype . yield _callback = function ( a ) { a === this . tick _counter && this . do _tick ( ) } ; D . prototype . stop = function ( ) { this . running && ( this . stopping = ! 0 ) } ; D . prototype . destroy = function ( ) { this . unregister _yield ( ) } ; D . prototype . restart = function ( ) { this . cpu . reset _cpu ( ) ; this . cpu . load _bios ( ) } ; D . prototype . init = function ( a ) { this . cpu . init ( a , this . bus ) ; this . bus . send ( "emulator-ready" ) } ;
if ( "undefined" !== typeof process ) D . prototype . yield = function ( a , b ) { 1 > a ? global . setImmediate ( c => this . yield _callback ( c ) , b ) : setTimeout ( c => this . yield _callback ( c ) , a , b ) } , D . prototype . register _yield = function ( ) { } , D . prototype . unregister _yield = function ( ) { } ; else if ( "undefined" !== typeof Worker ) { function a ( ) { let b ; globalThis . onmessage = function ( c ) { const d = c . data . t ; b = b && clearTimeout ( b ) ; 1 > d ? postMessage ( c . data . tick ) : b = setTimeout ( ( ) => postMessage ( c . data . tick ) , d ) } } D . prototype . register _yield = function ( ) { const b = URL . createObjectURL ( new Blob ( [ "(" +
a . toString ( ) + ")()" ] , { type : "text/javascript" } ) ) ; this . worker = new Worker ( b ) ; this . worker . onmessage = c => this . yield _callback ( c . data ) ; URL . revokeObjectURL ( b ) } ; D . prototype . yield = function ( b , c ) { this . worker . postMessage ( { t : b , tick : c } ) } ; D . prototype . unregister _yield = function ( ) { this . worker && this . worker . terminate ( ) ; this . worker = null } } else D . prototype . yield = function ( a ) { setTimeout ( ( ) => { this . do _tick ( ) } , a ) } , D . prototype . register _yield = function ( ) { } , D . prototype . unregister _yield = function ( ) { } ; D . prototype . save _state = function ( ) { return this . cpu . save _state ( ) } ;
D . prototype . restore _state = function ( a ) { return this . cpu . restore _state ( a ) } ; if ( "object" === typeof performance && performance . now ) D . microtick = performance . now . bind ( performance ) ; else if ( "function" === typeof require ) { const { performance : a } = require ( "perf_hooks" ) ; D . microtick = a . now . bind ( a ) } else D . microtick = "object" === typeof process && process . hrtime ? function ( ) { var a = process . hrtime ( ) ; return 1E3 * a [ 0 ] + a [ 1 ] / 1E6 } : Date . now ; var H = H || { } ; H . exportSymbol = function ( ) { } ; H . exportProperty = function ( ) { } ; var h = h || { } ; h . pads = function ( a , b ) { return ( a || 0 === a ? a + "" : "" ) . padEnd ( b , " " ) } ; h . pad0 = function ( a , b ) { return ( a || 0 === a ? a + "" : "" ) . padStart ( b , "0" ) } ; h . zeros = function ( a ) { return Array ( a ) . fill ( 0 ) } ; h . range = function ( a ) { return Array . from ( Array ( a ) . keys ( ) ) } ;
h . view = function ( a , b , c , d ) { return new Proxy ( { } , { get : function ( e , g ) { e = new a ( b . buffer , c , d ) ; const f = e [ g ] ; if ( "function" === typeof f ) return f . bind ( e ) ; /^\d+$/ . test ( g ) ; return f } , set : function ( e , g , f ) { /^\d+$/ . test ( g ) ; ( new a ( b . buffer , c , d ) ) [ g ] = f ; return ! 0 } } ) } ; function B ( a , b ) { a = a ? a . toString ( 16 ) : "" ; return "0x" + h . pad0 ( a . toUpperCase ( ) , b || 1 ) }
if ( "undefined" !== typeof crypto && crypto . getRandomValues ) { const a = new Int32Array ( 1 ) ; h . get _rand _int = function ( ) { crypto . getRandomValues ( a ) ; return a [ 0 ] } } else if ( "undefined" !== typeof require ) { const a = require ( "crypto" ) ; h . get _rand _int = function ( ) { return a . randomBytes ( 4 ) . readInt32LE ( 0 ) } }
( function ( ) { if ( "function" === typeof Math . clz32 ) h . int _log2 = function ( d ) { return 31 - Math . clz32 ( d ) } ; else { for ( var a = new Int8Array ( 256 ) , b = 0 , c = - 2 ; 256 > b ; b ++ ) b & b - 1 || c ++ , a [ b ] = c ; h . int _log2 = function ( d ) { d >>>= 0 ; var e = d >>> 16 ; if ( e ) { var g = e >>> 8 ; return g ? 24 + a [ g ] : 16 + a [ e ] } return ( g = d >>> 8 ) ? 8 + a [ g ] : a [ d ] } } } ) ( ) ; h . round _up _to _next _power _of _2 = function ( a ) { return 1 >= a ? 1 : 1 << 1 + h . int _log2 ( a - 1 ) } ;
2024-11-28 07:25:05 +01:00
function na ( a ) { var b = new Uint8Array ( a ) , c , d ; this . length = 0 ; this . push = function ( e ) { this . length !== a && this . length ++ ; b [ d ] = e ; d = d + 1 & a - 1 } ; this . shift = function ( ) { if ( this . length ) { var e = b [ c ] ; c = c + 1 & a - 1 ; this . length -- ; return e } return - 1 } ; this . peek = function ( ) { return this . length ? b [ c ] : - 1 } ; this . clear = function ( ) { this . length = d = c = 0 } ; this . clear ( ) } function oa ( a ) { this . size = a ; this . data = new Float32Array ( a ) ; this . length = this . end = this . start = 0 }
oa . prototype . push = function ( a ) { this . length === this . size ? this . start = this . start + 1 & this . size - 1 : this . length ++ ; this . data [ this . end ] = a ; this . end = this . end + 1 & this . size - 1 } ; oa . prototype . shift = function ( ) { if ( this . length ) { var a = this . data [ this . start ] ; this . start = this . start + 1 & this . size - 1 ; this . length -- ; return a } } ;
oa . prototype . shift _block = function ( a ) { var b = new Float32Array ( a ) ; a > this . length && ( a = this . length ) ; var c = this . start + a , d = this . data . subarray ( this . start , c ) ; b . set ( d ) ; c >= this . size && ( c -= this . size , b . set ( this . data . subarray ( 0 , c ) , d . length ) ) ; this . start = c ; this . length -= a ; return b } ; oa . prototype . peek = function ( ) { if ( this . length ) return this . data [ this . start ] } ; oa . prototype . clear = function ( ) { this . length = this . end = this . start = 0 } ;
2025-01-03 12:44:26 +01:00
h . Bitmap = function ( a ) { "number" === typeof a ? this . view = new Uint8Array ( a + 7 >> 3 ) : a instanceof ArrayBuffer && ( this . view = new Uint8Array ( a ) ) } ; h . Bitmap . prototype . set = function ( a , b ) { const c = a >> 3 ; a = 1 << ( a & 7 ) ; this . view [ c ] = b ? this . view [ c ] | a : this . view [ c ] & ~ a } ; h . Bitmap . prototype . get = function ( a ) { return this . view [ a >> 3 ] >> ( a & 7 ) & 1 } ; h . Bitmap . prototype . get _buffer = function ( ) { return this . view . buffer } ; h . load _file = "undefined" === typeof XMLHttpRequest ? pa : qa ;
function qa ( a , b , c ) { function d ( ) { const l = c || 0 ; setTimeout ( ( ) => { qa ( a , b , l + 1 ) } , 1E3 * ( [ 1 , 1 , 2 , 3 , 5 , 8 , 13 , 21 ] [ l ] || 34 ) ) } var e = new XMLHttpRequest ; e . open ( b . method || "get" , a , ! 0 ) ; e . responseType = b . as _json ? "json" : "arraybuffer" ; if ( b . headers ) for ( var g = Object . keys ( b . headers ) , f = 0 ; f < g . length ; f ++ ) { var k = g [ f ] ; e . setRequestHeader ( k , b . headers [ k ] ) } b . range && ( g = b . range . start , e . setRequestHeader ( "Range" , "bytes=" + g + "-" + ( g + b . range . length - 1 ) ) , e . setRequestHeader ( "X-Accept-Encoding" , "identity" ) , e . onreadystatechange = function ( ) { 200 === e . status &&
2024-11-28 07:25:05 +01:00
( console . error ( "Server sent full file in response to ranged request, aborting" , { filename : a } ) , e . abort ( ) ) } ) ; e . onload = function ( ) { if ( 4 === e . readyState ) if ( 200 !== e . status && 206 !== e . status ) console . error ( "Loading the image " + a + " failed (status %d)" , e . status ) , 500 <= e . status && 600 > e . status && d ( ) ; else if ( e . response ) { if ( b . range ) { const l = e . getResponseHeader ( "Content-Encoding" ) ; l && "identity" !== l && console . error ( "Server sent Content-Encoding in response to ranged request" , { filename : a , enc : l } ) } b . done && b . done ( e . response ,
e ) } } ; e . onerror = function ( l ) { console . error ( "Loading the image " + a + " failed" , l ) ; d ( ) } ; b . progress && ( e . onprogress = function ( l ) { b . progress ( l ) } ) ; e . send ( null ) }
2025-01-03 12:44:26 +01:00
function pa ( a , b ) { const c = require ( "fs" ) ; b . range ? c . open ( a , "r" , ( d , e ) => { if ( d ) throw d ; d = b . range . length ; var g = Buffer . allocUnsafe ( d ) ; c . read ( e , g , 0 , d , b . range . start , f => { if ( f ) throw f ; b . done && b . done ( new Uint8Array ( g ) ) ; c . close ( e , k => { if ( k ) throw k ; } ) } ) } ) : c . readFile ( a , { encoding : b . as _json ? "utf-8" : null } , function ( d , e ) { d ? console . log ( "Could not read file:" , a , d ) : ( d = e , d = b . as _json ? JSON . parse ( d ) : ( new Uint8Array ( d ) ) . buffer , b . done ( d ) ) } ) }
h . read _sized _string _from _mem = function ( a , b , c ) { return String . fromCharCode ( ... ( new Uint8Array ( a . buffer , b >>> 0 , c >>> 0 ) ) ) } ; ( function ( ) { function a ( f ) { this . buffer = f ; this . byteLength = f . byteLength ; this . onprogress = this . onload = void 0 } function b ( f , k , l ) { this . filename = f ; this . byteLength = k ; this . block _cache = new Map ; this . block _cache _is _write = new Set ; this . fixed _chunk _size = l ; this . cache _reads = ! ! l ; this . onprogress = this . onload = void 0 } function c ( f , k , l , m , n ) { const p = f . match ( /\.[^\.]+(\.zst)?$/ ) ; this . extension = p ? p [ 0 ] : "" ; this . basename = f . substring ( 0 , f . length - this . extension . length ) ; this . is _zstd = this . extension . endsWith ( ".zst" ) ; this . basename . endsWith ( "/" ) ||
( this . basename += "-" ) ; this . block _cache = new Map ; this . block _cache _is _write = new Set ; this . byteLength = k ; this . fixed _chunk _size = l ; this . partfile _alt _format = ! ! m ; this . zstd _decompress = n ; this . cache _reads = ! ! l ; this . onprogress = this . onload = void 0 } function d ( f ) { this . file = f ; this . byteLength = f . size ; 1073741824 < f . size && console . warn ( "SyncFileBuffer: Allocating buffer of " + ( f . size >> 20 ) + " MB ..." ) ; this . buffer = new ArrayBuffer ( f . size ) ; this . onprogress = this . onload = void 0 } function e ( f ) { this . file = f ; this . byteLength = f . size ; this . block _cache =
new Map ; this . block _cache _is _write = new Set ; this . onprogress = this . onload = void 0 } h . SyncBuffer = a ; h . AsyncXHRBuffer = b ; h . AsyncXHRPartfileBuffer = c ; h . AsyncFileBuffer = e ; h . SyncFileBuffer = d ; h . buffer _from _object = function ( f , k ) { if ( f . buffer instanceof ArrayBuffer ) return new h . SyncBuffer ( f . buffer ) ; if ( "undefined" !== typeof File && f . buffer instanceof File ) return k = f . async , void 0 === k && ( k = 268435456 <= f . buffer . size ) , k ? new h . AsyncFileBuffer ( f . buffer ) : new h . SyncFileBuffer ( f . buffer ) ; if ( f . url ) return f . use _parts ? new h . AsyncXHRPartfileBuffer ( f . url ,
f . size , f . fixed _chunk _size , ! 1 , k ) : new h . AsyncXHRBuffer ( f . url , f . size , f . fixed _chunk _size ) } ; a . prototype . load = function ( ) { this . onload && this . onload ( { buffer : this . buffer } ) } ; a . prototype . get = function ( f , k , l ) { l ( new Uint8Array ( this . buffer , f , k ) ) } ; a . prototype . set = function ( f , k , l ) { ( new Uint8Array ( this . buffer , f , k . byteLength ) ) . set ( k ) ; l ( ) } ; a . prototype . get _buffer = function ( f ) { f ( this . buffer ) } ; a . prototype . get _state = function ( ) { const f = [ ] ; f [ 0 ] = this . byteLength ; f [ 1 ] = new Uint8Array ( this . buffer ) ; return f } ; a . prototype . set _state =
function ( f ) { this . byteLength = f [ 0 ] ; this . buffer = f [ 1 ] . slice ( ) . buffer } ; b . prototype . load = function ( ) { void 0 !== this . byteLength ? this . onload && this . onload ( Object . create ( null ) ) : g ( this . filename , ( f , k ) => { if ( f ) throw Error ( "Cannot use: " + this . filename + ". " + f ) ; this . byteLength = k ; this . onload && this . onload ( Object . create ( null ) ) } ) } ; b . prototype . get _from _cache = function ( f , k ) { var l = k / 256 ; f /= 256 ; for ( var m = 0 ; m < l ; m ++ ) if ( ! this . block _cache . get ( f + m ) ) return ; if ( 1 === l ) return this . block _cache . get ( f ) ; k = new Uint8Array ( k ) ; for ( m = 0 ; m < l ; m ++ ) k . set ( this . block _cache . get ( f +
m ) , 256 * m ) ; return k } ; b . prototype . get = function ( f , k , l ) { var m = this . get _from _cache ( f , k ) ; if ( m ) l ( m ) ; else { var n = f , p = k ; this . fixed _chunk _size && ( n = f - f % this . fixed _chunk _size , p = Math . ceil ( ( f - n + k ) / this . fixed _chunk _size ) * this . fixed _chunk _size ) ; h . load _file ( this . filename , { done : function ( q ) { q = new Uint8Array ( q ) ; this . handle _read ( n , p , q ) ; n === f && p === k ? l ( q ) : l ( q . subarray ( f - n , f - n + k ) ) } . bind ( this ) , range : { start : n , length : p } } ) } } ; b . prototype . set = function ( f , k , l ) { f /= 256 ; for ( var m = k . length / 256 , n = 0 ; n < m ; n ++ ) { var p = this . block _cache . get ( f +
n ) ; if ( void 0 === p ) p = k . slice ( 256 * n , 256 * ( n + 1 ) ) , this . block _cache . set ( f + n , p ) ; else { const q = k . subarray ( 256 * n , 256 * ( n + 1 ) ) ; p . set ( q ) } this . block _cache _is _write . add ( f + n ) } l ( ) } ; b . prototype . handle _read = function ( f , k , l ) { f /= 256 ; k /= 256 ; for ( var m = 0 ; m < k ; m ++ ) { const n = this . block _cache . get ( f + m ) ; n ? l . set ( n , 256 * m ) : this . cache _reads && this . block _cache . set ( f + m , l . slice ( 256 * m , 256 * ( m + 1 ) ) ) } } ; b . prototype . get _buffer = function ( f ) { f ( ) } ; b . prototype . get _state = function ( ) { const f = [ ] , k = [ ] ; for ( const [ l , m ] of this . block _cache ) isFinite ( l ) , this . block _cache _is _write . has ( l ) &&
k . push ( [ l , m ] ) ; f [ 0 ] = k ; return f } ; b . prototype . set _state = function ( f ) { f = f [ 0 ] ; this . block _cache . clear ( ) ; this . block _cache _is _write . clear ( ) ; for ( const [ k , l ] of f ) isFinite ( k ) , this . block _cache . set ( k , l ) , this . block _cache _is _write . add ( k ) } ; c . prototype . load = function ( ) { this . onload && this . onload ( Object . create ( null ) ) } ; c . prototype . get = function ( f , k , l ) { var m = this . get _from _cache ( f , k ) ; if ( m ) l ( m ) ; else if ( this . fixed _chunk _size ) { const p = Math . floor ( f / this . fixed _chunk _size ) , q = f - p * this . fixed _chunk _size , r = Math . ceil ( ( q + k ) / this . fixed _chunk _size ) ,
A = new Uint8Array ( r * this . fixed _chunk _size ) ; let z = 0 ; for ( let u = 0 ; u < r ; u ++ ) { var n = ( p + u ) * this . fixed _chunk _size ; m = this . partfile _alt _format ? this . basename + ( p + u + "" ) . padStart ( 8 , "0" ) + this . extension : this . basename + n + "-" + ( n + this . fixed _chunk _size ) + this . extension ; ( n = this . get _from _cache ( n , this . fixed _chunk _size ) ) ? ( A . set ( n , u * this . fixed _chunk _size ) , z ++ , z === r && l ( A . subarray ( q , q + k ) ) ) : h . load _file ( m , { done : async function ( F ) { F = new Uint8Array ( F ) ; this . is _zstd && ( F = await this . zstd _decompress ( this . fixed _chunk _size , F ) , F = new Uint8Array ( F ) ) ;
A . set ( F , u * this . fixed _chunk _size ) ; this . handle _read ( ( p + u ) * this . fixed _chunk _size , this . fixed _chunk _size | 0 , F ) ; z ++ ; z === r && l ( A . subarray ( q , q + k ) ) } . bind ( this ) } ) } } else h . load _file ( this . basename + f + "-" + ( f + k ) + this . extension , { done : function ( p ) { p = new Uint8Array ( p ) ; this . handle _read ( f , k , p ) ; l ( p ) } . bind ( this ) } ) } ; c . prototype . get _from _cache = b . prototype . get _from _cache ; c . prototype . set = b . prototype . set ; c . prototype . handle _read = b . prototype . handle _read ; c . prototype . get _state = b . prototype . get _state ; c . prototype . set _state = b . prototype . set _state ;
d . prototype . load = function ( ) { this . load _next ( 0 ) } ; d . prototype . load _next = function ( f ) { var k = new FileReader ; k . onload = function ( m ) { m = new Uint8Array ( m . target . result ) ; ( new Uint8Array ( this . buffer , f ) ) . set ( m ) ; this . load _next ( f + 4194304 ) } . bind ( this ) ; if ( this . onprogress ) this . onprogress ( { loaded : f , total : this . byteLength , lengthComputable : ! 0 } ) ; if ( f < this . byteLength ) { var l = this . file . slice ( f , Math . min ( f + 4194304 , this . byteLength ) ) ; k . readAsArrayBuffer ( l ) } else this . file = void 0 , this . onload && this . onload ( { buffer : this . buffer } ) } ; d . prototype . get =
a . prototype . get ; d . prototype . set = a . prototype . set ; d . prototype . get _buffer = a . prototype . get _buffer ; d . prototype . get _state = a . prototype . get _state ; d . prototype . set _state = a . prototype . set _state ; e . prototype . load = function ( ) { this . onload && this . onload ( Object . create ( null ) ) } ; e . prototype . get = function ( f , k , l ) { var m = this . get _from _cache ( f , k ) ; m ? l ( m ) : ( m = new FileReader , m . onload = function ( n ) { n = new Uint8Array ( n . target . result ) ; this . handle _read ( f , k , n ) ; l ( n ) } . bind ( this ) , m . readAsArrayBuffer ( this . file . slice ( f , f + k ) ) ) } ; e . prototype . get _from _cache =
b . prototype . get _from _cache ; e . prototype . set = b . prototype . set ; e . prototype . handle _read = b . prototype . handle _read ; e . prototype . get _state = b . prototype . get _state ; e . prototype . set _state = b . prototype . set _state ; e . prototype . get _buffer = function ( f ) { f ( ) } ; e . prototype . get _as _file = function ( f ) { for ( var k = [ ] , l = Array . from ( this . block _cache . keys ( ) ) . sort ( function ( r , A ) { return r - A } ) , m = 0 , n = 0 ; n < l . length ; n ++ ) { var p = l [ n ] , q = this . block _cache . get ( p ) ; p *= 256 ; p !== m && ( k . push ( this . file . slice ( m , p ) ) , m = p ) ; k . push ( q ) ; m += q . length } m !== this . file . size &&
k . push ( this . file . slice ( m ) ) ; return new File ( k , f ) } ; var g = "undefined" === typeof XMLHttpRequest ? function ( f , k ) { require ( "fs" ) . stat ( f , ( l , m ) => { l ? k ( l ) : k ( null , m . size ) } ) } : function ( f , k ) { h . load _file ( f , { done : ( l , m ) => { l = m . getResponseHeader ( "Content-Range" ) || "" ; ( m = l . match ( /\/(\d+)\s*$/ ) ) ? k ( null , + m [ 1 ] ) : k ( "`Range: bytes=...` header not supported (Got `" + l + "`)" ) } , headers : { Range : "bytes=0-0" , "X-Accept-Encoding" : "identity" } } ) } } ) ( ) ; function ra ( a , b , c , d , e , g ) { this . master = new K ( this , a , b , d , e , 0 , g ) ; this . slave = new K ( this , a , c , ! 1 , e , 1 , g ) ; this . current _interface = this . master ; this . cpu = a ; 0 === e ? ( this . ata _port = 496 , this . irq = 14 , this . pci _id = 240 ) : 1 === e && ( this . ata _port = 368 , this . irq = 15 , this . pci _id = 248 ) ; this . ata _port _high = this . ata _port | 516 ; this . master _port = 46080 ; this . pci _space = [ 134 , 128 , 16 , 112 , 5 , 0 , 160 , 2 , 0 , 128 , 1 , 1 , 0 , 0 , 0 , 0 , this . ata _port & 255 | 1 , this . ata _port >> 8 , 0 , 0 , this . ata _port _high & 255 | 1 , this . ata _port _high >> 8 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , this . master _port & 255 | 1 ,
2024-06-28 09:23:02 +02:00
this . master _port >> 8 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 67 , 16 , 212 , 130 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , this . irq , 1 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 ] ; this . pci _bars = [ { size : 8 } , { size : 4 } , void 0 , void 0 , { size : 16 } ] ; this . name = "ide" + e ; this . device _control = 2 ; a . io . register _read ( this . ata _port | 7 , this , function ( ) { this . cpu . device _lower _irq ( this . irq ) ; return this . read _status ( ) } ) ; a . io . register _read ( this . ata _port _high |
2025-01-03 12:44:26 +01:00
2 , this , this . read _status ) ; a . io . register _write ( this . ata _port _high | 2 , this , this . write _control ) ; a . io . register _read ( this . ata _port | 0 , this , function ( ) { return this . current _interface . read _data ( 1 ) } , function ( ) { return this . current _interface . read _data ( 2 ) } , function ( ) { return this . current _interface . read _data ( 4 ) } ) ; a . io . register _read ( this . ata _port | 1 , this , function ( ) { B ( this . current _interface . error & 255 ) ; return this . current _interface . error & 255 } ) ; a . io . register _read ( this . ata _port | 2 , this , function ( ) { B ( this . current _interface . bytecount &
255 ) ; return this . current _interface . bytecount & 255 } ) ; a . io . register _read ( this . ata _port | 3 , this , function ( ) { B ( this . current _interface . sector & 255 ) ; return this . current _interface . sector & 255 } ) ; a . io . register _read ( this . ata _port | 4 , this , function ( ) { B ( this . current _interface . cylinder _low & 255 ) ; return this . current _interface . cylinder _low & 255 } ) ; a . io . register _read ( this . ata _port | 5 , this , function ( ) { B ( this . current _interface . cylinder _high & 255 ) ; return this . current _interface . cylinder _high & 255 } ) ; a . io . register _read ( this . ata _port |
6 , this , function ( ) { return this . current _interface . drive _head & 255 } ) ; a . io . register _write ( this . ata _port | 0 , this , function ( f ) { this . current _interface . write _data _port8 ( f ) } , function ( f ) { this . current _interface . write _data _port16 ( f ) } , function ( f ) { this . current _interface . write _data _port32 ( f ) } ) ; a . io . register _write ( this . ata _port | 1 , this , function ( f ) { B ( f ) ; this . master . lba _count = ( this . master . lba _count << 8 | f ) & 65535 ; this . slave . lba _count = ( this . slave . lba _count << 8 | f ) & 65535 } ) ; a . io . register _write ( this . ata _port | 2 , this , function ( f ) { B ( f ) ;
this . master . bytecount = ( this . master . bytecount << 8 | f ) & 65535 ; this . slave . bytecount = ( this . slave . bytecount << 8 | f ) & 65535 } ) ; a . io . register _write ( this . ata _port | 3 , this , function ( f ) { B ( f ) ; this . master . sector = ( this . master . sector << 8 | f ) & 65535 ; this . slave . sector = ( this . slave . sector << 8 | f ) & 65535 } ) ; a . io . register _write ( this . ata _port | 4 , this , function ( f ) { B ( f ) ; this . master . cylinder _low = ( this . master . cylinder _low << 8 | f ) & 65535 ; this . slave . cylinder _low = ( this . slave . cylinder _low << 8 | f ) & 65535 } ) ; a . io . register _write ( this . ata _port | 5 , this , function ( f ) { B ( f ) ;
this . master . cylinder _high = ( this . master . cylinder _high << 8 | f ) & 65535 ; this . slave . cylinder _high = ( this . slave . cylinder _high << 8 | f ) & 65535 } ) ; a . io . register _write ( this . ata _port | 6 , this , function ( f ) { var k = f & 16 ; B ( f , 2 ) ; this . current _interface = k ? this . slave : this . master ; this . master . drive _head = f ; this . slave . drive _head = f ; this . master . is _lba = this . slave . is _lba = f >> 6 & 1 ; this . master . head = this . slave . head = f & 15 } ) ; this . dma _command = this . dma _status = this . prdt _addr = 0 ; a . io . register _write ( this . ata _port | 7 , this , function ( f ) { this . cpu . device _lower _irq ( this . irq ) ;
2024-11-28 07:25:05 +01:00
this . current _interface . ata _command ( f ) } ) ; a . io . register _read ( this . master _port | 4 , this , void 0 , void 0 , this . dma _read _addr ) ; a . io . register _write ( this . master _port | 4 , this , void 0 , void 0 , this . dma _set _addr ) ; a . io . register _read ( this . master _port , this , this . dma _read _command8 , void 0 , this . dma _read _command ) ; a . io . register _write ( this . master _port , this , this . dma _write _command8 , void 0 , this . dma _write _command ) ; a . io . register _read ( this . master _port | 2 , this , this . dma _read _status ) ; a . io . register _write ( this . master _port | 2 , this , this . dma _write _status ) ;
2025-01-03 12:44:26 +01:00
a . io . register _read ( this . master _port | 8 , this , function ( ) { return 0 } ) ; a . io . register _read ( this . master _port | 10 , this , function ( ) { return 0 } ) ; a . devices . pci . register _device ( this ) } ra . prototype . read _status = function ( ) { if ( this . current _interface . buffer ) { var a = this . current _interface . status ; B ( a , 2 ) ; return a } return 0 } ; ra . prototype . write _control = function ( a ) { B ( a , 2 ) ; a & 4 && ( this . cpu . device _lower _irq ( this . irq ) , this . master . device _reset ( ) , this . slave . device _reset ( ) ) ; this . device _control = a } ;
ra . prototype . dma _read _addr = function ( ) { B ( this . prdt _addr , 8 ) ; return this . prdt _addr } ; ra . prototype . dma _set _addr = function ( a ) { B ( a , 8 ) ; this . prdt _addr = a } ; ra . prototype . dma _read _status = function ( ) { B ( this . dma _status ) ; return this . dma _status } ; ra . prototype . dma _write _status = function ( a ) { B ( a ) ; this . dma _status &= ~ ( a & 6 ) } ; ra . prototype . dma _read _command = function ( ) { return this . dma _read _command8 ( ) | this . dma _read _status ( ) << 16 } ; ra . prototype . dma _read _command8 = function ( ) { B ( this . dma _command ) ; return this . dma _command } ;
ra . prototype . dma _write _command = function ( a ) { B ( a ) ; this . dma _write _command8 ( a & 255 ) ; this . dma _write _status ( a >> 16 & 255 ) } ;
ra . prototype . dma _write _command8 = function ( a ) { B ( a ) ; const b = this . dma _command ; this . dma _command = a & 9 ; if ( ( b & 1 ) !== ( a & 1 ) ) if ( 0 === ( a & 1 ) ) this . dma _status &= - 2 ; else switch ( this . dma _status |= 1 , this . current _interface . current _command ) { case 37 : case 200 : this . current _interface . do _ata _read _sectors _dma ( ) ; break ; case 202 : case 53 : this . current _interface . do _ata _write _sectors _dma ( ) ; break ; case 160 : this . current _interface . do _atapi _dma ( ) ; break ; default : B ( this . current _interface . current _command ) } } ;
ra . prototype . push _irq = function ( ) { 0 === ( this . device _control & 2 ) && ( this . dma _status |= 4 , this . cpu . device _raise _irq ( this . irq ) ) } ; ra . prototype . get _state = function ( ) { var a = [ ] ; a [ 0 ] = this . master ; a [ 1 ] = this . slave ; a [ 2 ] = this . ata _port ; a [ 3 ] = this . irq ; a [ 4 ] = this . pci _id ; a [ 5 ] = this . ata _port _high ; a [ 6 ] = this . master _port ; a [ 7 ] = this . name ; a [ 8 ] = this . device _control ; a [ 9 ] = this . prdt _addr ; a [ 10 ] = this . dma _status ; a [ 11 ] = this . current _interface === this . master ; a [ 12 ] = this . dma _command ; return a } ;
ra . prototype . set _state = function ( a ) { this . master . set _state ( a [ 0 ] ) ; this . slave . set _state ( a [ 1 ] ) ; this . ata _port = a [ 2 ] ; this . irq = a [ 3 ] ; this . pci _id = a [ 4 ] ; this . ata _port _high = a [ 5 ] ; this . master _port = a [ 6 ] ; this . name = a [ 7 ] ; this . device _control = a [ 8 ] ; this . prdt _addr = a [ 9 ] ; this . dma _status = a [ 10 ] ; this . current _interface = a [ 11 ] ? this . master : this . slave ; this . dma _command = a [ 12 ] } ;
2024-11-28 07:25:05 +01:00
function K ( a , b , c , d , e , g , f ) { this . device = a ; this . bus = f ; this . nr = e ; this . cpu = b ; this . buffer = c ; this . sector _size = d ? 2048 : 512 ; this . is _atapi = d ; this . cylinder _count = this . sectors _per _track = this . head _count = this . sector _count = 0 ; this . buffer && ( this . sector _count = this . buffer . byteLength / this . sector _size , this . sector _count !== ( this . sector _count | 0 ) && ( this . sector _count = Math . ceil ( this . sector _count ) ) , d ? ( this . head _count = 1 , this . sectors _per _track = 0 ) : ( this . head _count = 16 , this . sectors _per _track = 63 ) , this . cylinder _count = this . sector _count /
2024-06-28 09:23:02 +02:00
this . head _count / this . sectors _per _track , this . cylinder _count !== ( this . cylinder _count | 0 ) && ( this . cylinder _count = Math . floor ( this . cylinder _count ) ) , a = b . devices . rtc , a . cmos _write ( 57 , a . cmos _read ( 57 ) | 1 << 4 * this . nr ) , a . cmos _write ( 18 , a . cmos _read ( 18 ) & 15 | 240 ) , a . cmos _write ( 27 , this . cylinder _count & 255 ) , a . cmos _write ( 28 , this . cylinder _count >> 8 & 255 ) , a . cmos _write ( 29 , this . head _count & 255 ) , a . cmos _write ( 30 , 255 ) , a . cmos _write ( 31 , 255 ) , a . cmos _write ( 32 , 200 ) , a . cmos _write ( 33 , this . cylinder _count & 255 ) , a . cmos _write ( 34 , this . cylinder _count >>
2024-10-02 21:03:04 +02:00
8 & 255 ) , a . cmos _write ( 35 , this . sectors _per _track & 255 ) ) ; this . buffer = c ; this . drive _head = this . head = this . cylinder _high = this . cylinder _low = this . lba _count = this . sector = this . bytecount = this . is _lba = 0 ; this . status = 80 ; this . sectors _per _drq = 128 ; this . data _pointer = this . error = 0 ; this . data = new Uint8Array ( 65536 ) ; this . data16 = new Uint16Array ( this . data . buffer ) ; this . data32 = new Int32Array ( this . data . buffer ) ; this . data _end = this . data _length = 0 ; this . current _atapi _command = this . current _command = - 1 ; this . last _io _id = this . write _dest = 0 ; this . in _progress _io _ids =
2024-11-28 07:25:05 +01:00
new Set ; this . cancelled _io _ids = new Set ; Object . seal ( this ) } K . prototype . device _reset = function ( ) { this . is _atapi ? ( this . status = 0 , this . sector = this . error = this . bytecount = 1 , this . cylinder _low = 20 , this . cylinder _high = 235 ) : ( this . status = 81 , this . sector = this . error = this . bytecount = 1 , this . cylinder _high = this . cylinder _low = 0 ) ; this . cancel _io _operations ( ) } ; K . prototype . push _irq = function ( ) { this . device . push _irq ( ) } ;
2025-01-03 12:44:26 +01:00
K . prototype . ata _command = function ( a ) { B ( a ) ; if ( this . buffer ) switch ( this . current _command = a , this . error = 0 , a ) { case 8 : this . data _length = this . data _end = this . data _pointer = 0 ; this . device _reset ( ) ; this . push _irq ( ) ; break ; case 16 : this . status = 80 ; this . cylinder _low = 0 ; this . push _irq ( ) ; break ; case 248 : this . status = 80 ; a = this . sector _count - 1 ; this . sector = a & 255 ; this . cylinder _low = a >> 8 & 255 ; this . cylinder _high = a >> 16 & 255 ; this . drive _head = this . drive _head & 240 | a >> 24 & 15 ; this . push _irq ( ) ; break ; case 39 : this . status = 80 ; a = this . sector _count - 1 ; this . sector =
2024-06-28 09:23:02 +02:00
a & 255 ; this . cylinder _low = a >> 8 & 255 ; this . cylinder _high = a >> 16 & 255 ; this . sector |= a >> 24 << 8 & 65280 ; this . push _irq ( ) ; break ; case 32 : case 36 : case 41 : case 196 : this . ata _read _sectors ( a ) ; break ; case 48 : case 52 : case 57 : case 197 : this . ata _write _sectors ( a ) ; break ; case 144 : this . push _irq ( ) ; this . error = 257 ; this . status = 80 ; break ; case 145 : this . status = 80 ; this . push _irq ( ) ; break ; case 160 : this . is _atapi && ( this . status = 88 , this . data _allocate ( 12 ) , this . data _end = 12 , this . bytecount = 1 , this . push _irq ( ) ) ; break ; case 161 : this . is _atapi ? ( this . create _identify _packet ( ) ,
2025-01-03 12:44:26 +01:00
this . status = 88 , this . cylinder _low = 20 , this . cylinder _high = 235 ) : this . status = 65 ; this . push _irq ( ) ; break ; case 198 : B ( this . bytecount & 255 ) ; this . sectors _per _drq = this . bytecount & 255 ; this . status = 80 ; this . push _irq ( ) ; break ; case 37 : case 200 : this . ata _read _sectors _dma ( a ) ; break ; case 53 : case 202 : this . ata _write _sectors _dma ( a ) ; break ; case 64 : this . status = 80 ; this . push _irq ( ) ; break ; case 218 : this . status = 65 ; this . error = 4 ; this . push _irq ( ) ; break ; case 224 : this . status = 80 ; this . push _irq ( ) ; break ; case 225 : this . status = 80 ; this . push _irq ( ) ; break ;
case 231 : this . status = 80 ; this . push _irq ( ) ; break ; case 236 : if ( this . is _atapi ) { this . status = 65 ; this . error = 4 ; this . push _irq ( ) ; break } this . create _identify _packet ( ) ; this . status = 88 ; this . push _irq ( ) ; break ; case 234 : this . status = 80 ; this . push _irq ( ) ; break ; case 239 : B ( this . bytecount & 255 ) ; this . status = 80 ; this . push _irq ( ) ; break ; case 222 : this . status = 80 ; this . push _irq ( ) ; break ; case 245 : this . status = 80 ; this . push _irq ( ) ; break ; case 249 : this . status = 65 ; this . error = 4 ; break ; default : B ( a ) , this . status = 65 , this . error = 4 } else this . error = 4 , this . status =
2024-06-28 09:23:02 +02:00
65 , this . push _irq ( ) } ;
2025-01-03 12:44:26 +01:00
K . prototype . atapi _handle = function ( ) { B ( this . data [ 0 ] ) ; this . data _pointer = 0 ; this . current _atapi _command = this . data [ 0 ] ; switch ( this . current _atapi _command ) { case 0 : this . data _allocate ( 0 ) ; this . data _end = this . data _length ; this . status = 80 ; break ; case 3 : this . data _allocate ( this . data [ 4 ] ) ; this . data _end = this . data _length ; this . status = 88 ; this . data [ 0 ] = 240 ; this . data [ 2 ] = 5 ; this . data [ 7 ] = 8 ; break ; case 18 : var a = this . data [ 4 ] ; this . status = 88 ; B ( this . data [ 1 ] , 2 ) ; this . data . set ( [ 5 , 128 , 1 , 49 , 31 , 0 , 0 , 0 , 83 , 79 , 78 , 89 , 32 , 32 , 32 , 32 , 67 , 68 , 45 , 82 , 79 ,
2024-06-28 09:23:02 +02:00
77 , 32 , 67 , 68 , 85 , 45 , 49 , 48 , 48 , 48 , 32 , 49 , 46 , 49 , 97 ] ) ; this . data _end = this . data _length = Math . min ( 36 , a ) ; break ; case 26 : this . data _allocate ( this . data [ 4 ] ) ; this . data _end = this . data _length ; this . status = 88 ; break ; case 30 : this . data _allocate ( 0 ) ; this . data _end = this . data _length ; this . status = 80 ; break ; case 37 : a = this . sector _count - 1 ; this . data _set ( new Uint8Array ( [ a >> 24 & 255 , a >> 16 & 255 , a >> 8 & 255 , a & 255 , 0 , 0 , this . sector _size >> 8 & 255 , this . sector _size & 255 ] ) ) ; this . data _end = this . data _length ; this . status = 88 ; break ; case 40 : this . lba _count & 1 ? this . atapi _read _dma ( this . data ) :
2025-01-03 12:44:26 +01:00
this . atapi _read ( this . data ) ; break ; case 66 : a = this . data [ 8 ] ; this . data _allocate ( Math . min ( 8 , a ) ) ; this . data _end = this . data _length ; this . status = 88 ; break ; case 67 : a = this . data [ 8 ] | this . data [ 7 ] << 8 ; var b = this . data [ 9 ] >> 6 ; this . data _allocate ( a ) ; this . data _end = this . data _length ; B ( b , 2 ) ; B ( this . data [ 6 ] ) ; 0 === b ? ( a = this . sector _count , this . data . set ( new Uint8Array ( [ 0 , 18 , 1 , 1 , 0 , 20 , 1 , 0 , 0 , 0 , 0 , 0 , 0 , 22 , 170 , 0 , a >> 24 , a >> 16 & 255 , a >> 8 & 255 , a & 255 ] ) ) ) : 1 === b && this . data . set ( new Uint8Array ( [ 0 , 10 , 1 , 1 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 ] ) ) ; this . status = 88 ; break ; case 70 : a =
this . data [ 8 ] | this . data [ 7 ] << 8 ; a = Math . min ( a , 32 ) ; this . data _allocate ( a ) ; this . data _end = this . data _length ; this . data [ 0 ] = a - 4 >> 24 & 255 ; this . data [ 1 ] = a - 4 >> 16 & 255 ; this . data [ 2 ] = a - 4 >> 8 & 255 ; this . data [ 3 ] = a - 4 & 255 ; this . data [ 6 ] = 8 ; this . data [ 10 ] = 3 ; this . status = 88 ; break ; case 81 : this . data _allocate ( 0 ) ; this . data _end = this . data _length ; this . status = 80 ; break ; case 82 : B ( this . data [ 0 ] ) ; this . status = 81 ; this . data _length = 0 ; this . error = 80 ; break ; case 90 : a = this . data [ 8 ] | this . data [ 7 ] << 8 ; b = this . data [ 2 ] ; B ( b ) ; 42 === b && this . data _allocate ( Math . min ( 30 ,
a ) ) ; this . data _end = this . data _length ; this . status = 88 ; break ; case 189 : this . data _allocate ( this . data [ 9 ] | this . data [ 8 ] << 8 ) ; this . data _end = this . data _length ; this . data [ 5 ] = 1 ; this . status = 88 ; break ; case 74 : this . status = 81 ; this . data _length = 0 ; this . error = 80 ; B ( this . data [ 0 ] ) ; break ; case 190 : B ( this . data [ 0 ] ) ; this . data _allocate ( 0 ) ; this . data _end = this . data _length ; this . status = 80 ; break ; default : this . status = 81 , this . data _length = 0 , this . error = 80 , B ( this . data [ 0 ] ) } this . bytecount = this . bytecount & - 8 | 2 ; 0 === ( this . status & 128 ) && this . push _irq ( ) ;
2024-11-28 07:25:05 +01:00
0 === ( this . status & 128 ) && 0 === this . data _length && ( this . bytecount |= 1 , this . status &= - 9 ) } ; K . prototype . do _write = function ( ) { this . status = 80 ; var a = this . data . subarray ( 0 , this . data _length ) ; this . ata _advance ( this . current _command , this . data _length / 512 ) ; this . push _irq ( ) ; this . buffer . set ( this . write _dest , a , function ( ) { } ) ; this . report _write ( this . data _length ) } ;
2025-01-03 12:44:26 +01:00
K . prototype . atapi _read = function ( a ) { var b = a [ 2 ] << 24 | a [ 3 ] << 16 | a [ 4 ] << 8 | a [ 5 ] , c = a [ 7 ] << 8 | a [ 8 ] ; a = a [ 1 ] ; var d = c * this . sector _size , e = b * this . sector _size ; ta ( "CD read lba=" + B ( b ) + " lbacount=" + B ( c ) + " bytecount=" + B ( d ) + " flags=" + B ( a ) , 32768 ) ; this . data _length = 0 ; var g = this . cylinder _high << 8 & 65280 | this . cylinder _low & 255 ; ta ( B ( this . cylinder _high , 2 ) + " " + B ( this . cylinder _low , 2 ) , 32768 ) ; this . cylinder _low = this . cylinder _high = 0 ; 65535 === g && g -- ; g > d && ( g = d ) ; e >= this . buffer . byteLength ? ( ua ( ! 1 , "CD read: Outside of disk end=" + B ( e + d ) + " size=" +
B ( this . buffer . byteLength ) , 32768 ) , this . status = 255 , this . push _irq ( ) ) : 0 === d ? ( this . status = 80 , this . data _pointer = 0 ) : ( d = Math . min ( d , this . buffer . byteLength - e ) , this . status = 208 , this . report _read _start ( ) , this . read _buffer ( e , d , f => { this . data _set ( f ) ; this . status = 88 ; this . bytecount = this . bytecount & - 8 | 2 ; this . push _irq ( ) ; this . data _end = g &= - 4 ; this . data _end > this . data _length && ( this . data _end = this . data _length ) ; this . cylinder _low = this . data _end & 255 ; this . cylinder _high = this . data _end >> 8 & 255 ; this . report _read _end ( d ) } ) ) } ;
K . prototype . atapi _read _dma = function ( a ) { var b = a [ 2 ] << 24 | a [ 3 ] << 16 | a [ 4 ] << 8 | a [ 5 ] , c = a [ 7 ] << 8 | a [ 8 ] ; a = a [ 1 ] ; var d = c * this . sector _size , e = b * this . sector _size ; ta ( "CD read DMA lba=" + B ( b ) + " lbacount=" + B ( c ) + " bytecount=" + B ( d ) + " flags=" + B ( a ) , 32768 ) ; e >= this . buffer . byteLength ? ( ua ( ! 1 , "CD read: Outside of disk end=" + B ( e + d ) + " size=" + B ( this . buffer . byteLength ) , 32768 ) , this . status = 255 , this . push _irq ( ) ) : ( this . status = 208 , this . report _read _start ( ) , this . read _buffer ( e , d , g => { this . report _read _end ( d ) ; this . status = 88 ; this . bytecount = this . bytecount &
2024-11-28 07:25:05 +01:00
- 8 | 2 ; this . data _set ( g ) ; this . do _atapi _dma ( ) } ) ) } ;
2025-01-03 12:44:26 +01:00
K . prototype . do _atapi _dma = function ( ) { if ( 0 !== ( this . device . dma _status & 1 ) && 0 !== ( this . status & 8 ) ) { var a = this . device . prdt _addr , b = 0 , c = this . data ; do { var d = this . cpu . read32s ( a ) , e = this . cpu . read16 ( a + 4 ) , g = this . cpu . read8 ( a + 7 ) & 128 ; e || ( e = 65536 ) ; B ( d ) ; B ( e ) ; B ( this . data _length ) ; this . cpu . write _blob ( c . subarray ( b , Math . min ( b + e , this . data _length ) ) , d ) ; b += e ; a += 8 ; if ( b >= this . data _length && ! g ) { B ( b ) ; B ( this . data _length ) ; B ( this . current _command ) ; break } } while ( ! g ) ; this . status = 80 ; this . device . dma _status &= - 2 ; this . bytecount = this . bytecount &
- 8 | 3 ; this . push _irq ( ) } } ; K . prototype . read _data = function ( a ) { if ( this . data _pointer < this . data _end ) { B ( this . data _pointer ) ; var b = 1 === a ? this . data [ this . data _pointer ] : 2 === a ? this . data16 [ this . data _pointer >>> 1 ] : this . data32 [ this . data _pointer >>> 2 ] ; this . data _pointer += a ; 0 === ( this . data _pointer & ( 0 === ( this . data _end & 4095 ) ? 4095 : 255 ) ) && ( B ( this . data [ this . data _pointer ] , 2 ) , B ( this . data _pointer ) , B ( this . data _length ) ) ; this . data _pointer >= this . data _end && this . read _end ( ) ; return b } this . data _pointer += a ; return 0 } ;
K . prototype . read _end = function ( ) { B ( this . current _command ) ; B ( this . data _pointer ) ; B ( this . data _end ) ; B ( this . data _length ) ; if ( 160 === this . current _command ) if ( this . data _end === this . data _length ) this . status = 80 , this . bytecount = this . bytecount & - 8 | 3 , this . push _irq ( ) ; else { this . status = 88 ; this . bytecount = this . bytecount & - 8 | 2 ; this . push _irq ( ) ; var a = this . cylinder _high << 8 & 65280 | this . cylinder _low & 255 ; this . data _end + a > this . data _length ? ( this . cylinder _low = this . data _length - this . data _end & 255 , this . cylinder _high = this . data _length - this . data _end >>
8 & 255 , this . data _end = this . data _length ) : this . data _end += a ; B ( this . data _end ) } else this . error = 0 , this . data _pointer >= this . data _length ? this . status = 80 : ( a = 196 === this . current _command || 41 === this . current _command ? Math . min ( this . sectors _per _drq , ( this . data _length - this . data _end ) / 512 ) : 1 , this . ata _advance ( this . current _command , a ) , this . data _end += 512 * a , this . status = 88 , this . push _irq ( ) ) } ;
K . prototype . write _data _port = function ( a , b ) { if ( this . data _pointer >= this . data _end ) B ( a ) , B ( this . data _end ) , B ( this . data _pointer ) ; else { if ( 0 === ( this . data _pointer + b & ( 0 === ( this . data _end & 4095 ) ? 4095 : 255 ) ) || 20 > this . data _end ) B ( a >>> 0 ) , B ( this . data _end ) , B ( this . data _pointer ) ; 1 === b ? this . data [ this . data _pointer ++ ] = a : 2 === b ? ( this . data16 [ this . data _pointer >>> 1 ] = a , this . data _pointer += 2 ) : ( this . data32 [ this . data _pointer >>> 2 ] = a , this . data _pointer += 4 ) ; this . data _pointer === this . data _end && this . write _end ( ) } } ;
K . prototype . write _data _port8 = function ( a ) { this . write _data _port ( a , 1 ) } ; K . prototype . write _data _port16 = function ( a ) { this . write _data _port ( a , 2 ) } ; K . prototype . write _data _port32 = function ( a ) { this . write _data _port ( a , 4 ) } ; K . prototype . write _end = function ( ) { 160 === this . current _command ? this . atapi _handle ( ) : ( B ( this . data _pointer ) , B ( this . data _length ) , this . data _pointer >= this . data _length ? this . do _write ( ) : ( B ( this . current _command ) , this . status = 88 , this . data _end += 512 , this . push _irq ( ) ) ) } ;
2024-11-28 07:25:05 +01:00
K . prototype . ata _advance = function ( a , b ) { this . bytecount -= b ; 36 === a || 41 === a || 52 === a || 57 === a || 37 === a || 53 === a ? ( a = b + this . get _lba48 ( ) , this . sector = a & 255 | a >> 16 & 65280 , this . cylinder _low = a >> 8 & 255 , this . cylinder _high = a >> 16 & 255 ) : this . is _lba ? ( a = b + this . get _lba28 ( ) , this . sector = a & 255 , this . cylinder _low = a >> 8 & 255 , this . cylinder _high = a >> 16 & 255 , this . head = this . head & - 16 | a & 15 ) : ( a = b + this . get _chs ( ) , b = a / ( this . head _count * this . sectors _per _track ) | 0 , this . cylinder _low = b & 255 , this . cylinder _high = b >> 8 & 255 , this . head = ( a / this . sectors _per _track |
2024-06-28 09:23:02 +02:00
0 ) % this . head _count & 15 , this . sector = a % this . sectors _per _track + 1 & 255 , this . get _chs ( ) ) } ;
2025-01-03 12:44:26 +01:00
K . prototype . ata _read _sectors = function ( a ) { var b = 36 === a || 41 === a , c = this . get _count ( b ) ; b = this . get _lba ( b ) ; var d = 32 === a || 36 === a , e = c * this . sector _size , g = b * this . sector _size ; ta ( "ATA read cmd=" + B ( a ) + " mode=" + ( this . is _lba ? "lba" : "chs" ) + " lba=" + B ( b ) + " lbacount=" + B ( c ) + " bytecount=" + B ( e ) , 32768 ) ; g + e > this . buffer . byteLength ? ( this . status = 255 , this . push _irq ( ) ) : ( this . status = 192 , this . report _read _start ( ) , this . read _buffer ( g , e , f => { this . data _set ( f ) ; this . status = 88 ; this . data _end = d ? 512 : Math . min ( e , 512 * this . sectors _per _drq ) ; this . ata _advance ( a ,
d ? 1 : Math . min ( c , this . sectors _per _track ) ) ; this . push _irq ( ) ; this . report _read _end ( e ) } ) ) } ; K . prototype . ata _read _sectors _dma = function ( a ) { var b = 37 === a ; a = this . get _count ( b ) ; b = this . get _lba ( b ) ; var c = a * this . sector _size , d = b * this . sector _size ; B ( b ) ; B ( a ) ; B ( c ) ; d + c > this . buffer . byteLength ? ( this . status = 255 , this . push _irq ( ) ) : ( this . status = 88 , this . device . dma _status |= 1 ) } ;
K . prototype . do _ata _read _sectors _dma = function ( ) { var a = 37 === this . current _command , b = this . get _count ( a ) ; a = this . get _lba ( a ) ; var c = b * this . sector _size ; a *= this . sector _size ; this . report _read _start ( ) ; this . read _buffer ( a , c , d => { var e = this . device . prdt _addr , g = 0 ; do { var f = this . cpu . read32s ( e ) , k = this . cpu . read16 ( e + 4 ) , l = this . cpu . read8 ( e + 7 ) & 128 ; k || ( k = 65536 ) ; B ( f ) ; B ( k ) ; this . cpu . write _blob ( d . subarray ( g , g + k ) , f ) ; g += k ; e += 8 } while ( ! l ) ; this . ata _advance ( this . current _command , b ) ; this . status = 80 ; this . device . dma _status &= - 2 ; this . current _command =
- 1 ; this . push _irq ( ) ; this . report _read _end ( c ) } ) } ; K . prototype . ata _write _sectors = function ( a ) { var b = 52 === a || 57 === a , c = this . get _count ( b ) ; b = this . get _lba ( b ) ; a = 48 === a || 52 === a ; var d = c * this . sector _size , e = b * this . sector _size ; B ( b ) ; B ( c ) ; B ( d ) ; e + d > this . buffer . byteLength ? ( this . status = 255 , this . push _irq ( ) ) : ( this . status = 88 , this . data _allocate _noclear ( d ) , this . data _end = a ? 512 : Math . min ( d , 512 * this . sectors _per _drq ) , this . write _dest = e ) } ;
K . prototype . ata _write _sectors _dma = function ( a ) { var b = 53 === a ; a = this . get _count ( b ) ; b = this . get _lba ( b ) ; var c = a * this . sector _size , d = b * this . sector _size ; B ( b ) ; B ( a ) ; B ( c ) ; d + c > this . buffer . byteLength ? ( this . status = 255 , this . push _irq ( ) ) : ( this . status = 88 , this . device . dma _status |= 1 ) } ;
K . prototype . do _ata _write _sectors _dma = function ( ) { var a = 53 === this . current _command , b = this . get _count ( a ) , c = this . get _lba ( a ) ; a = b * this . sector _size ; c *= this . sector _size ; var d = this . device . prdt _addr , e = 0 ; ta ( "prdt addr: " + B ( d , 8 ) , 32768 ) ; const g = new Uint8Array ( a ) ; do { var f = this . cpu . read32s ( d ) , k = this . cpu . read16 ( d + 4 ) , l = this . cpu . read8 ( d + 7 ) & 128 ; k || ( k = 65536 ) ; ta ( "dma write transfer dest=" + B ( f ) + " prd_count=" + B ( k ) , 32768 ) ; f = this . cpu . mem8 . subarray ( f , f + k ) ; g . set ( f , e ) ; e += k ; d += 8 } while ( ! l ) ; this . buffer . set ( c , g , ( ) => { this . ata _advance ( this . current _command ,
2024-11-28 07:25:05 +01:00
b ) ; this . status = 80 ; this . push _irq ( ) ; this . device . dma _status &= - 2 ; this . current _command = - 1 } ) ; this . report _write ( a ) } ; K . prototype . get _chs = function ( ) { return ( ( this . cylinder _low & 255 | this . cylinder _high << 8 & 65280 ) * this . head _count + this . head ) * this . sectors _per _track + ( this . sector & 255 ) - 1 } ; K . prototype . get _lba28 = function ( ) { return this . sector & 255 | this . cylinder _low << 8 & 65280 | this . cylinder _high << 16 & 16711680 | ( this . head & 15 ) << 24 } ;
K . prototype . get _lba48 = function ( ) { return ( this . sector & 255 | this . cylinder _low << 8 & 65280 | this . cylinder _high << 16 & 16711680 | this . sector >> 8 << 24 & 4278190080 ) >>> 0 } ; K . prototype . get _lba = function ( a ) { return a ? this . get _lba48 ( ) : this . is _lba ? this . get _lba28 ( ) : this . get _chs ( ) } ; K . prototype . get _count = function ( a ) { a ? ( a = this . bytecount , 0 === a && ( a = 65536 ) ) : ( a = this . bytecount & 255 , 0 === a && ( a = 256 ) ) ; return a } ;
K . prototype . create _identify _packet = function ( ) { if ( this . drive _head & 16 ) this . data _allocate ( 0 ) ; else { for ( var a = 0 ; 512 > a ; a ++ ) this . data [ a ] = 0 ; a = Math . min ( 16383 , this . cylinder _count ) ; this . data _set ( [ 64 , this . is _atapi ? 133 : 0 , a , a >> 8 , 0 , 0 , this . head _count , this . head _count >> 8 , this . sectors _per _track / 512 , this . sectors _per _track / 512 >> 8 , 0 , 2 , this . sectors _per _track , this . sectors _per _track >> 8 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 3 , 0 , 0 , 2 , 4 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 56 , 118 , 32 , 54 , 68 , 72 , 32 , 32 , 32 , 32 , 32 , 32 , 32 , 32 , 32 , 32 , 32 , 32 , 32 ,
2024-06-28 09:23:02 +02:00
32 , 32 , 32 , 32 , 32 , 32 , 32 , 32 , 32 , 32 , 32 , 32 , 32 , 32 , 32 , 32 , 32 , 32 , 32 , 32 , 32 , 128 , 0 , 1 , 0 , 0 , 2 , 0 , 0 , 0 , 2 , 0 , 2 , 7 , 0 , a , a >> 8 , this . head _count , this . head _count >> 8 , this . sectors _per _track , 0 , this . sector _count & 255 , this . sector _count >> 8 & 255 , this . sector _count >> 16 & 255 , this . sector _count >> 24 & 255 , 0 , 0 , this . sector _count & 255 , this . sector _count >> 8 & 255 , this . sector _count >> 16 & 255 , this . sector _count >> 24 & 255 , 0 , 0 , 160 === this . current _command ? 0 : 7 , 160 === this . current _command ? 0 : 4 , 0 , 0 , 30 , 0 , 30 , 0 , 30 , 0 , 30 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 126 , 0 ,
2024-11-28 07:25:05 +01:00
0 , 0 , 0 , 0 , 0 , 116 , 0 , 64 , 0 , 64 , 0 , 116 , 0 , 64 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 1 , 96 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , this . sector _count & 255 , this . sector _count >> 8 & 255 , this . sector _count >> 16 & 255 , this . sector _count >> 24 & 255 ] ) ; this . data _end = this . data _length = 512 } } ; K . prototype . data _allocate = function ( a ) { this . data _allocate _noclear ( a ) ; for ( var b = 0 ; b < a + 3 >> 2 ; b ++ ) this . data32 [ b ] = 0 } ;
K . prototype . data _allocate _noclear = function ( a ) { this . data . length < a && ( this . data = new Uint8Array ( a + 3 & - 4 ) , this . data16 = new Uint16Array ( this . data . buffer ) , this . data32 = new Int32Array ( this . data . buffer ) ) ; this . data _length = a ; this . data _pointer = 0 } ; K . prototype . data _set = function ( a ) { this . data _allocate _noclear ( a . length ) ; this . data . set ( a ) } ; K . prototype . report _read _start = function ( ) { this . bus . send ( "ide-read-start" ) } ; K . prototype . report _read _end = function ( a ) { this . bus . send ( "ide-read-end" , [ this . nr , a , a / this . sector _size | 0 ] ) } ;
K . prototype . report _write = function ( a ) { this . bus . send ( "ide-write-end" , [ this . nr , a , a / this . sector _size | 0 ] ) } ; K . prototype . read _buffer = function ( a , b , c ) { const d = this . last _io _id ++ ; this . in _progress _io _ids . add ( d ) ; this . buffer . get ( a , b , e => { this . cancelled _io _ids . delete ( d ) ? this . in _progress _io _ids . has ( d ) : ( this . in _progress _io _ids . delete ( d ) , c ( e ) ) } ) } ; K . prototype . cancel _io _operations = function ( ) { for ( const a of this . in _progress _io _ids ) this . cancelled _io _ids . add ( a ) ; this . in _progress _io _ids . clear ( ) } ;
K . prototype . get _state = function ( ) { var a = [ ] ; a [ 0 ] = this . bytecount ; a [ 1 ] = this . cylinder _count ; a [ 2 ] = this . cylinder _high ; a [ 3 ] = this . cylinder _low ; a [ 4 ] = this . data _pointer ; a [ 5 ] = 0 ; a [ 6 ] = 0 ; a [ 7 ] = 0 ; a [ 8 ] = 0 ; a [ 9 ] = this . drive _head ; a [ 10 ] = this . error ; a [ 11 ] = this . head ; a [ 12 ] = this . head _count ; a [ 13 ] = this . is _atapi ; a [ 14 ] = this . is _lba ; a [ 15 ] = this . lba _count ; a [ 16 ] = this . data ; a [ 17 ] = this . data _length ; a [ 18 ] = this . sector ; a [ 19 ] = this . sector _count ; a [ 20 ] = this . sector _size ; a [ 21 ] = this . sectors _per _drq ; a [ 22 ] = this . sectors _per _track ; a [ 23 ] = this . status ; a [ 24 ] =
2024-06-28 09:23:02 +02:00
this . write _dest ; a [ 25 ] = this . current _command ; a [ 26 ] = this . data _end ; a [ 27 ] = this . current _atapi _command ; a [ 28 ] = this . buffer ; return a } ;
2024-11-28 07:25:05 +01:00
K . prototype . set _state = function ( a ) { this . bytecount = a [ 0 ] ; this . cylinder _count = a [ 1 ] ; this . cylinder _high = a [ 2 ] ; this . cylinder _low = a [ 3 ] ; this . data _pointer = a [ 4 ] ; this . drive _head = a [ 9 ] ; this . error = a [ 10 ] ; this . head = a [ 11 ] ; this . head _count = a [ 12 ] ; this . is _atapi = a [ 13 ] ; this . is _lba = a [ 14 ] ; this . lba _count = a [ 15 ] ; this . data = a [ 16 ] ; this . data _length = a [ 17 ] ; this . sector = a [ 18 ] ; this . sector _count = a [ 19 ] ; this . sector _size = a [ 20 ] ; this . sectors _per _drq = a [ 21 ] ; this . sectors _per _track = a [ 22 ] ; this . status = a [ 23 ] ; this . write _dest = a [ 24 ] ; this . current _command =
a [ 25 ] ; this . data _end = a [ 26 ] ; this . current _atapi _command = a [ 27 ] ; this . data16 = new Uint16Array ( this . data . buffer ) ; this . data32 = new Int32Array ( this . data . buffer ) ; this . buffer && this . buffer . set _state ( a [ 28 ] ) } ; function va ( a ) { this . pci _addr = new Uint8Array ( 4 ) ; this . pci _value = new Uint8Array ( 4 ) ; this . pci _response = new Uint8Array ( 4 ) ; this . pci _status = new Uint8Array ( 4 ) ; this . pci _addr32 = new Int32Array ( this . pci _addr . buffer ) ; this . pci _value32 = new Int32Array ( this . pci _value . buffer ) ; this . pci _response32 = new Int32Array ( this . pci _response . buffer ) ; this . pci _status32 = new Int32Array ( this . pci _status . buffer ) ; this . device _spaces = [ ] ; this . devices = [ ] ; this . cpu = a ; for ( var b = 0 ; 256 > b ; b ++ ) this . device _spaces [ b ] = void 0 , this . devices [ b ] = void 0 ; this . io =
2024-06-28 09:23:02 +02:00
a . io ; a . io . register _write ( 3324 , this , function ( c ) { this . pci _write8 ( this . pci _addr32 [ 0 ] , c ) } , function ( c ) { this . pci _write16 ( this . pci _addr32 [ 0 ] , c ) } , function ( c ) { this . pci _write32 ( this . pci _addr32 [ 0 ] , c ) } ) ; a . io . register _write ( 3325 , this , function ( c ) { this . pci _write8 ( this . pci _addr32 [ 0 ] + 1 | 0 , c ) } ) ; a . io . register _write ( 3326 , this , function ( c ) { this . pci _write8 ( this . pci _addr32 [ 0 ] + 2 | 0 , c ) } , function ( c ) { this . pci _write16 ( this . pci _addr32 [ 0 ] + 2 | 0 , c ) } ) ; a . io . register _write ( 3327 , this , function ( c ) { this . pci _write8 ( this . pci _addr32 [ 0 ] + 3 | 0 , c ) } ) ;
a . io . register _read _consecutive ( 3324 , this , function ( ) { return this . pci _response [ 0 ] } , function ( ) { return this . pci _response [ 1 ] } , function ( ) { return this . pci _response [ 2 ] } , function ( ) { return this . pci _response [ 3 ] } ) ; a . io . register _read _consecutive ( 3320 , this , function ( ) { return this . pci _status [ 0 ] } , function ( ) { return this . pci _status [ 1 ] } , function ( ) { return this . pci _status [ 2 ] } , function ( ) { return this . pci _status [ 3 ] } ) ; a . io . register _write _consecutive ( 3320 , this , function ( c ) { this . pci _addr [ 0 ] = c & 252 } , function ( c ) { 2 === ( this . pci _addr [ 1 ] &
6 ) && 6 === ( c & 6 ) ? a . reboot _internal ( ) : this . pci _addr [ 1 ] = c } , function ( c ) { this . pci _addr [ 2 ] = c } , function ( c ) { this . pci _addr [ 3 ] = c ; this . pci _query ( ) } ) ; this . register _device ( { pci _id : 0 , pci _space : [ 134 , 128 , 55 , 18 , 0 , 0 , 0 , 0 , 2 , 0 , 0 , 6 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 16 , 0 , 0 , 0 , 0 , 0 , 0 ] , pci _bars : [ ] , name : "82441FX PMC" } ) ; this . isa _bridge = { pci _id : 8 , pci _space : [ 134 , 128 , 0 , 112 , 7 , 0 , 0 , 2 , 0 , 0 , 1 , 6 , 0 , 0 , 128 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 ,
2024-11-28 07:25:05 +01:00
0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 ] , pci _bars : [ ] , name : "82371SB PIIX3 ISA" } ; this . isa _bridge _space = this . register _device ( this . isa _bridge ) ; this . isa _bridge _space8 = new Uint8Array ( this . isa _bridge _space . buffer ) } va . prototype . get _state = function ( ) { for ( var a = [ ] , b = 0 ; 256 > b ; b ++ ) a [ b ] = this . device _spaces [ b ] ; a [ 256 ] = this . pci _addr ; a [ 257 ] = this . pci _value ; a [ 258 ] = this . pci _response ; a [ 259 ] = this . pci _status ; return a } ;
2025-01-03 12:44:26 +01:00
va . prototype . set _state = function ( a ) { for ( var b = 0 ; 256 > b ; b ++ ) { var c = this . devices [ b ] , d = a [ b ] ; if ( c && d ) { for ( var e = 0 ; e < c . pci _bars . length ; e ++ ) { var g = d [ 4 + e ] ; if ( g & 1 ) { var f = c . pci _bars [ e ] ; this . set _io _bars ( f , f . original _bar & 65534 , g & 65534 ) } } this . device _spaces [ b ] . set ( d ) } else d && B ( b , 2 ) } this . pci _addr . set ( a [ 256 ] ) ; this . pci _value . set ( a [ 257 ] ) ; this . pci _response . set ( a [ 258 ] ) ; this . pci _status . set ( a [ 259 ] ) } ;
va . prototype . pci _query = function ( ) { var a = this . pci _addr [ 2 ] << 8 | this . pci _addr [ 1 ] , b = this . pci _addr [ 0 ] & 252 , c = a >> 3 & 31 ; var d = "query enabled=" + ( this . pci _addr [ 3 ] >> 7 ) + ( " bdf=" + B ( a , 4 ) ) ; d += " dev=" + B ( c , 2 ) ; d += " addr=" + B ( b , 2 ) ; a = this . device _spaces [ a ] ; void 0 !== a ? ( this . pci _status32 [ 0 ] = - 2147483648 , this . pci _response32 [ 0 ] = b < a . byteLength ? a [ b >> 2 ] : 0 , d += " " + B ( this . pci _addr32 [ 0 ] >>> 0 , 8 ) + " -> " + B ( this . pci _response32 [ 0 ] >>> 0 , 8 ) ) : ( this . pci _response32 [ 0 ] = - 1 , this . pci _status32 [ 0 ] = 0 ) } ;
va . prototype . pci _write8 = function ( a , b ) { var c = a >> 8 & 65535 ; a &= 255 ; var d = new Uint8Array ( this . device _spaces [ c ] . buffer ) ; B ( a ) ; B ( c >> 3 , 2 ) ; B ( a , 4 ) ; B ( b , 2 ) ; d [ a ] = b } ; va . prototype . pci _write16 = function ( a , b ) { var c = a >> 8 & 65535 ; a &= 255 ; var d = new Uint16Array ( this . device _spaces [ c ] . buffer ) ; 16 <= a && 44 > a ? B ( a ) : ( B ( a ) , B ( c >> 3 , 2 ) , B ( a , 4 ) , B ( b , 4 ) , d [ a >>> 1 ] = b ) } ;
va . prototype . pci _write32 = function ( a , b ) { var c = a >> 8 & 65535 ; a &= 255 ; var d = this . device _spaces [ c ] , e = this . devices [ c ] ; if ( d ) if ( 16 <= a && 40 > a ) { e = e . pci _bars [ a - 16 >> 2 ] ; B ( b >>> 0 ) ; B ( c >> 3 , 2 ) ; if ( e ) { c = a >> 2 ; var g = d [ c ] & 1 ; - 1 === ( b | 3 | e . size - 1 ) ? ( b = ~ ( e . size - 1 ) | g , 0 === g && ( d [ c ] = b ) ) : 0 === g && ( d [ c ] = e . original _bar ) ; if ( 1 === g ) { g = d [ c ] & 65534 ; var f = b & 65534 ; B ( g >>> 0 , 8 ) ; B ( f >>> 0 , 8 ) ; this . set _io _bars ( e , g , f ) ; d [ c ] = b | 1 } } else d [ a >> 2 ] = 0 ; B ( d [ a >> 2 ] >>> 0 ) } else 48 === a ? ( B ( c >> 3 , 2 ) , B ( b >>> 0 , 8 ) , d [ a >> 2 ] = e . pci _rom _size ? - 1 === ( b | 2047 ) ? - e . pci _rom _size | 0 : e . pci _rom _address |
0 : 0 ) : 4 === a ? ( B ( c >> 3 , 2 ) , B ( a , 4 ) , B ( b >>> 0 , 8 ) ) : ( B ( c >> 3 , 2 ) , B ( a , 4 ) , B ( b >>> 0 , 8 ) , d [ a >>> 2 ] = b ) } ; va . prototype . register _device = function ( a ) { var b = a . pci _id ; B ( b ) ; var c = new Int32Array ( 64 ) ; c . set ( new Int32Array ( ( new Uint8Array ( a . pci _space ) ) . buffer ) ) ; this . device _spaces [ b ] = c ; this . devices [ b ] = a ; b = c . slice ( 4 , 10 ) ; for ( var d = 0 ; d < a . pci _bars . length ; d ++ ) { var e = a . pci _bars [ d ] ; if ( e ) { var g = b [ d ] , f = g & 1 ; e . original _bar = g ; e . entries = [ ] ; if ( 0 !== f ) for ( g &= - 2 , f = 0 ; f < e . size ; f ++ ) e . entries [ f ] = this . io . ports [ g + f ] } } return c } ;
va . prototype . set _io _bars = function ( a , b , c ) { var d = a . size ; B ( b ) ; B ( c ) ; for ( var e = this . io . ports , g = 0 ; g < d ; g ++ ) { var f = e [ b + g ] ; 4096 <= b + g && ( e [ b + g ] = this . io . create _empty _entry ( ) ) ; f . read8 === this . io . empty _port _read8 && f . read16 === this . io . empty _port _read16 && f . read32 === this . io . empty _port _read32 && f . write8 === this . io . empty _port _write && f . write16 === this . io . empty _port _write && f . write32 === this . io . empty _port _write && B ( b + g , 4 ) ; f = a . entries [ g ] ; var k = e [ c + g ] ; 4096 <= c + g && ( e [ c + g ] = f ) ; k . read8 !== this . io . empty _port _read8 && k . read16 !== this . io . empty _port _read16 &&
k . read32 !== this . io . empty _port _read32 && k . write8 !== this . io . empty _port _write && k . write16 !== this . io . empty _port _write && k . write32 !== this . io . empty _port _write || B ( c + g , 4 ) } } ; va . prototype . raise _irq = function ( a ) { this . cpu . device _raise _irq ( this . isa _bridge _space8 [ 96 + ( ( this . device _spaces [ a ] [ 15 ] >> 8 & 255 ) - 1 + ( ( a >> 3 ) - 1 & 255 ) & 3 ) ] ) } ; va . prototype . lower _irq = function ( a ) { this . cpu . device _lower _irq ( this . isa _bridge _space8 [ 96 + ( ( this . device _spaces [ a ] [ 15 ] >> 8 & 255 ) + ( a >> 3 & 255 ) - 2 & 3 ) ] ) } ; function L ( a , b ) { this . io = a . io ; this . cpu = a ; this . dma = a . devices . dma ; this . bytes _expecting = 0 ; this . receiving _command = new Uint8Array ( 10 ) ; this . receiving _index = 0 ; this . next _command = null ; this . response _data = new Uint8Array ( 10 ) ; this . last _head = this . last _cylinder = this . drive = this . status _reg2 = this . status _reg1 = this . status _reg0 = this . response _length = this . response _index = 0 ; this . last _sector = 1 ; this . dir = this . dor = 0 ; this . fdb _image = this . fda _image = null ; b ? this . set _fda ( b ) : ( this . eject _fda ( ) , this . cpu . devices . rtc . cmos _write ( 16 , 64 ) ) ;
2024-06-28 09:23:02 +02:00
this . io . register _read ( 1008 , this , this . port3F0 _read ) ; this . io . register _read ( 1010 , this , this . port3F2 _read ) ; this . io . register _read ( 1012 , this , this . port3F4 _read ) ; this . io . register _read ( 1013 , this , this . port3F5 _read ) ; this . io . register _read ( 1015 , this , this . port3F7 _read ) ; this . io . register _write ( 1010 , this , this . port3F2 _write ) ; this . io . register _write ( 1012 , this , this . port3F4 _write ) ; this . io . register _write ( 1013 , this , this . port3F5 _write ) }
2024-11-28 07:25:05 +01:00
L . prototype . eject _fda = function ( ) { this . fda _image = null ; this . number _of _cylinders = this . number _of _heads = this . sectors _per _track = 0 ; this . dir = 128 } ;
L . prototype . set _fda = function ( a ) { var b = { [ 163840 ] : { type : 1 , tracks : 40 , sectors : 8 , heads : 1 } , [ 184320 ] : { type : 1 , tracks : 40 , sectors : 9 , heads : 1 } , [ 204800 ] : { type : 1 , tracks : 40 , sectors : 10 , heads : 1 } , [ 327680 ] : { type : 1 , tracks : 40 , sectors : 8 , heads : 2 } , [ 368640 ] : { type : 1 , tracks : 40 , sectors : 9 , heads : 2 } , [ 409600 ] : { type : 1 , tracks : 40 , sectors : 10 , heads : 2 } , [ 737280 ] : { type : 3 , tracks : 80 , sectors : 9 , heads : 2 } , [ 1228800 ] : { type : 2 , tracks : 80 , sectors : 15 , heads : 2 } , [ 1474560 ] : { type : 4 , tracks : 80 , sectors : 18 , heads : 2 } , [ 1763328 ] : { type : 5 , tracks : 82 , sectors : 21 , heads : 2 } ,
2025-01-03 12:44:26 +01:00
[ 2949120 ] : { type : 5 , tracks : 80 , sectors : 36 , heads : 2 } , 512 : { type : 1 , tracks : 1 , sectors : 1 , heads : 1 } } ; let c = a . byteLength , d = b [ c ] ; d || ( c = 1474560 < a . byteLength ? 2949120 : 1474560 , d = b [ c ] , b = new Uint8Array ( c ) , b . set ( new Uint8Array ( a . buffer ) ) , a = new h . SyncBuffer ( b . buffer ) ) ; this . sectors _per _track = d . sectors ; this . number _of _heads = d . heads ; this . number _of _cylinders = d . tracks ; this . fda _image = a ; this . dir = 128 ; this . cpu . devices . rtc . cmos _write ( 16 , d . type << 4 ) } ;
2024-11-28 07:25:05 +01:00
L . prototype . get _state = function ( ) { var a = [ ] ; a [ 0 ] = this . bytes _expecting ; a [ 1 ] = this . receiving _command ; a [ 2 ] = this . receiving _index ; a [ 4 ] = this . response _data ; a [ 5 ] = this . response _index ; a [ 6 ] = this . response _length ; a [ 8 ] = this . status _reg0 ; a [ 9 ] = this . status _reg1 ; a [ 10 ] = this . status _reg2 ; a [ 11 ] = this . drive ; a [ 12 ] = this . last _cylinder ; a [ 13 ] = this . last _head ; a [ 14 ] = this . last _sector ; a [ 15 ] = this . dor ; a [ 16 ] = this . sectors _per _track ; a [ 17 ] = this . number _of _heads ; a [ 18 ] = this . number _of _cylinders ; return a } ;
L . prototype . set _state = function ( a ) { this . bytes _expecting = a [ 0 ] ; this . receiving _command = a [ 1 ] ; this . receiving _index = a [ 2 ] ; this . next _command = a [ 3 ] ; this . response _data = a [ 4 ] ; this . response _index = a [ 5 ] ; this . response _length = a [ 6 ] ; this . status _reg0 = a [ 8 ] ; this . status _reg1 = a [ 9 ] ; this . status _reg2 = a [ 10 ] ; this . drive = a [ 11 ] ; this . last _cylinder = a [ 12 ] ; this . last _head = a [ 13 ] ; this . last _sector = a [ 14 ] ; this . dor = a [ 15 ] ; this . sectors _per _track = a [ 16 ] ; this . number _of _heads = a [ 17 ] ; this . number _of _cylinders = a [ 18 ] } ; L . prototype . port3F0 _read = function ( ) { return 0 } ;
2025-01-03 12:44:26 +01:00
L . prototype . port3F4 _read = function ( ) { var a = 128 ; this . response _index < this . response _length && ( a |= 80 ) ; 0 === ( this . dor & 8 ) && ( a |= 32 ) ; return a } ; L . prototype . port3F7 _read = function ( ) { return this . dir } ; L . prototype . port3F5 _read = function ( ) { return this . response _index < this . response _length ? ( this . cpu . device _lower _irq ( 6 ) , this . response _data [ this . response _index ++ ] ) : 255 } ; L . prototype . port3F4 _write = function ( a ) { B ( a ) ; a & 128 && ( this . status _reg0 = 192 , this . cpu . device _raise _irq ( 6 ) ) } ;
L . prototype . port3F5 _write = function ( a ) { ta ( "3F5 write " + B ( a ) , 8192 ) ; if ( 0 < this . bytes _expecting ) this . receiving _command [ this . receiving _index ++ ] = a , this . bytes _expecting -- , 0 === this . bytes _expecting && this . next _command . call ( this , this . receiving _command ) ; else { switch ( a ) { case 3 : this . next _command = this . fix _drive _data ; this . bytes _expecting = 2 ; break ; case 19 : this . next _command = this . configure ; this . bytes _expecting = 3 ; break ; case 4 : this . next _command = this . check _drive _status ; this . bytes _expecting = 1 ; break ; case 5 : case 69 : case 197 : this . next _command =
2024-10-02 21:03:04 +02:00
function ( b ) { this . do _sector ( ! 0 , b ) } ; this . bytes _expecting = 8 ; break ; case 6 : case 70 : case 198 : case 230 : this . next _command = function ( b ) { this . do _sector ( ! 1 , b ) } ; this . bytes _expecting = 8 ; break ; case 7 : this . next _command = this . calibrate ; this . bytes _expecting = 1 ; break ; case 8 : this . check _interrupt _status ( ) ; break ; case 74 : this . next _command = this . read _sector _id ; this . bytes _expecting = 1 ; break ; case 15 : this . bytes _expecting = 2 ; this . next _command = this . seek ; break ; case 14 : case 16 : this . status _reg0 = 128 ; this . response _data [ 0 ] = this . status _reg0 ;
2025-01-03 12:44:26 +01:00
this . response _index = 0 ; this . response _length = 1 ; this . bytes _expecting = 0 ; break ; default : ua ( ! 1 , "Unimplemented floppy command call " + B ( a ) ) } this . receiving _index = 0 } } ; L . prototype . port3F2 _read = function ( ) { return this . dor } ; L . prototype . port3F2 _write = function ( a ) { 4 === ( a & 4 ) && 0 === ( this . dor & 4 ) && ( this . status _reg0 = 192 , this . cpu . device _raise _irq ( 6 ) ) ; B ( a >> 4 ) ; B ( a ) ; this . dor = a } ; L . prototype . check _drive _status = function ( ) { this . status _reg1 = this . fda _image ? 0 : 5 ; this . response _index = 0 ; this . response _length = 1 ; this . response _data [ 0 ] = 0 } ;
2024-11-28 07:25:05 +01:00
L . prototype . seek = function ( a ) { if ( 0 === ( a [ 0 ] & 3 ) ) { var b = a [ 1 ] ; a = a [ 0 ] >> 2 & 1 ; b !== this . last _cylinder && ( this . dir = 0 ) ; this . status _reg1 = this . fda _image ? 0 : 5 ; this . status _reg0 = 32 ; this . last _cylinder = b ; this . last _head = a } this . raise _irq ( ) } ; L . prototype . calibrate = function ( a ) { this . seek ( [ a [ 0 ] , 0 ] ) } ; L . prototype . check _interrupt _status = function ( ) { this . response _index = 0 ; this . response _length = 2 ; this . response _data [ 0 ] = this . status _reg0 ; this . response _data [ 1 ] = this . last _cylinder } ;
2025-01-03 12:44:26 +01:00
L . prototype . do _sector = function ( a , b ) { var c = b [ 2 ] , d = b [ 1 ] , e = b [ 3 ] , g = 128 << b [ 4 ] , f = b [ 5 ] - b [ 3 ] + 1 , k = ( ( c + this . number _of _heads * d ) * this . sectors _per _track + e - 1 ) * g ; B ( k ) ; B ( f * g ) ; this . fda _image ? ( this . status _reg1 = 0 , a ? this . dma . do _write ( this . fda _image , k , f * g , 2 , this . done . bind ( this , b , d , c , e ) ) : this . dma . do _read ( this . fda _image , k , f * g , 2 , this . done . bind ( this , b , d , c , e ) ) ) : this . status _reg1 = 5 } ;
2024-11-28 07:25:05 +01:00
L . prototype . done = function ( a , b , c , d , e ) { e || ( d ++ , d > this . sectors _per _track && ( d = 1 , c ++ , c >= this . number _of _heads && ( c = 0 , b ++ ) ) , b !== this . last _cylinder && ( this . dir = 0 ) , this . status _reg0 = 32 , this . last _cylinder = b , this . last _head = c , this . last _sector = d , this . response _index = 0 , this . response _length = 7 , this . response _data [ 0 ] = c << 2 | 32 , this . response _data [ 1 ] = 0 , this . response _data [ 2 ] = 0 , this . response _data [ 3 ] = b , this . response _data [ 4 ] = c , this . response _data [ 5 ] = d , this . response _data [ 6 ] = a [ 4 ] , this . raise _irq ( ) ) } ;
2025-01-03 12:44:26 +01:00
L . prototype . fix _drive _data = function ( a ) { a . slice ( 0 , this . bytes _expecting ) } ; L . prototype . configure = function ( a ) { a . slice ( 0 , this . bytes _expecting ) } ; L . prototype . read _sector _id = function ( ) { this . response _index = 0 ; this . response _length = 7 ; this . response _data [ 0 ] = 0 ; this . response _data [ 1 ] = 0 ; this . response _data [ 2 ] = 0 ; this . response _data [ 3 ] = 0 ; this . response _data [ 4 ] = 0 ; this . response _data [ 5 ] = 0 ; this . response _data [ 6 ] = 0 ; this . raise _irq ( ) } ; L . prototype . raise _irq = function ( ) { this . dor & 8 && this . cpu . device _raise _irq ( 6 ) } ; G . prototype . mmap _read8 = function ( a ) { return this . memory _map _read8 [ a >>> 17 ] ( a ) } ; G . prototype . mmap _write8 = function ( a , b ) { this . memory _map _write8 [ a >>> 17 ] ( a , b ) } ; G . prototype . mmap _read16 = function ( a ) { var b = this . memory _map _read8 [ a >>> 17 ] ; return b ( a ) | b ( a + 1 | 0 ) << 8 } ; G . prototype . mmap _write16 = function ( a , b ) { var c = this . memory _map _write8 [ a >>> 17 ] ; c ( a , b & 255 ) ; c ( a + 1 | 0 , b >> 8 ) } ; G . prototype . mmap _read32 = function ( a ) { return this . memory _map _read32 [ a >>> 17 ] ( a ) } ;
G . prototype . mmap _write32 = function ( a , b ) { this . memory _map _write32 [ a >>> 17 ] ( a , b ) } ; G . prototype . mmap _write64 = function ( a , b , c ) { var d = this . memory _map _write32 [ a >>> 17 ] ; d ( a , b ) ; d ( a + 4 , c ) } ; G . prototype . mmap _write128 = function ( a , b , c , d , e ) { var g = this . memory _map _write32 [ a >>> 17 ] ; g ( a , b ) ; g ( a + 4 , c ) ; g ( a + 8 , d ) ; g ( a + 12 , e ) } ; G . prototype . write _blob = function ( a , b ) { a . length && ( this . in _mapped _range ( b ) , this . in _mapped _range ( b + a . length - 1 ) , this . jit _dirty _cache ( b , b + a . length ) , this . mem8 . set ( a , b ) ) } ;
G . prototype . read _blob = function ( a , b ) { b && ( this . in _mapped _range ( a ) , this . in _mapped _range ( a + b - 1 ) ) ; return this . mem8 . subarray ( a , a + b ) } ; function M ( a ) { this . cpu = a ; this . channel _page = new Uint8Array ( 8 ) ; this . channel _pagehi = new Uint8Array ( 8 ) ; this . channel _addr = new Uint16Array ( 8 ) ; this . channel _addr _init = new Uint16Array ( 8 ) ; this . channel _count = new Uint16Array ( 8 ) ; this . channel _count _init = new Uint16Array ( 8 ) ; this . channel _mask = new Uint8Array ( 8 ) ; this . channel _mode = new Uint8Array ( 8 ) ; this . unmask _listeners = [ ] ; this . lsb _msb _flipflop = 0 ; a = a . io ; a . register _write ( 0 , this , this . port _addr _write . bind ( this , 0 ) ) ; a . register _write ( 2 , this , this . port _addr _write . bind ( this ,
2024-06-28 09:23:02 +02:00
1 ) ) ; a . register _write ( 4 , this , this . port _addr _write . bind ( this , 2 ) ) ; a . register _write ( 6 , this , this . port _addr _write . bind ( this , 3 ) ) ; a . register _write ( 1 , this , this . port _count _write . bind ( this , 0 ) ) ; a . register _write ( 3 , this , this . port _count _write . bind ( this , 1 ) ) ; a . register _write ( 5 , this , this . port _count _write . bind ( this , 2 ) ) ; a . register _write ( 7 , this , this . port _count _write . bind ( this , 3 ) ) ; a . register _read ( 0 , this , this . port _addr _read . bind ( this , 0 ) ) ; a . register _read ( 2 , this , this . port _addr _read . bind ( this , 1 ) ) ; a . register _read ( 4 , this , this . port _addr _read . bind ( this ,
2 ) ) ; a . register _read ( 6 , this , this . port _addr _read . bind ( this , 3 ) ) ; a . register _read ( 1 , this , this . port _count _read . bind ( this , 0 ) ) ; a . register _read ( 3 , this , this . port _count _read . bind ( this , 1 ) ) ; a . register _read ( 5 , this , this . port _count _read . bind ( this , 2 ) ) ; a . register _read ( 7 , this , this . port _count _read . bind ( this , 3 ) ) ; a . register _write ( 192 , this , this . port _addr _write . bind ( this , 4 ) ) ; a . register _write ( 196 , this , this . port _addr _write . bind ( this , 5 ) ) ; a . register _write ( 200 , this , this . port _addr _write . bind ( this , 6 ) ) ; a . register _write ( 204 , this ,
this . port _addr _write . bind ( this , 7 ) ) ; a . register _write ( 194 , this , this . port _count _write . bind ( this , 4 ) ) ; a . register _write ( 198 , this , this . port _count _write . bind ( this , 5 ) ) ; a . register _write ( 202 , this , this . port _count _write . bind ( this , 6 ) ) ; a . register _write ( 206 , this , this . port _count _write . bind ( this , 7 ) ) ; a . register _read ( 192 , this , this . port _addr _read . bind ( this , 4 ) ) ; a . register _read ( 196 , this , this . port _addr _read . bind ( this , 5 ) ) ; a . register _read ( 200 , this , this . port _addr _read . bind ( this , 6 ) ) ; a . register _read ( 204 , this , this . port _addr _read . bind ( this ,
7 ) ) ; a . register _read ( 194 , this , this . port _count _read . bind ( this , 4 ) ) ; a . register _read ( 198 , this , this . port _count _read . bind ( this , 5 ) ) ; a . register _read ( 202 , this , this . port _count _read . bind ( this , 6 ) ) ; a . register _read ( 206 , this , this . port _count _read . bind ( this , 7 ) ) ; a . register _write ( 135 , this , this . port _page _write . bind ( this , 0 ) ) ; a . register _write ( 131 , this , this . port _page _write . bind ( this , 1 ) ) ; a . register _write ( 129 , this , this . port _page _write . bind ( this , 2 ) ) ; a . register _write ( 130 , this , this . port _page _write . bind ( this , 3 ) ) ; a . register _write ( 143 ,
this , this . port _page _write . bind ( this , 4 ) ) ; a . register _write ( 139 , this , this . port _page _write . bind ( this , 5 ) ) ; a . register _write ( 137 , this , this . port _page _write . bind ( this , 6 ) ) ; a . register _write ( 138 , this , this . port _page _write . bind ( this , 7 ) ) ; a . register _read ( 135 , this , this . port _page _read . bind ( this , 0 ) ) ; a . register _read ( 131 , this , this . port _page _read . bind ( this , 1 ) ) ; a . register _read ( 129 , this , this . port _page _read . bind ( this , 2 ) ) ; a . register _read ( 130 , this , this . port _page _read . bind ( this , 3 ) ) ; a . register _read ( 143 , this , this . port _page _read . bind ( this ,
4 ) ) ; a . register _read ( 139 , this , this . port _page _read . bind ( this , 5 ) ) ; a . register _read ( 137 , this , this . port _page _read . bind ( this , 6 ) ) ; a . register _read ( 138 , this , this . port _page _read . bind ( this , 7 ) ) ; a . register _write ( 1159 , this , this . port _pagehi _write . bind ( this , 0 ) ) ; a . register _write ( 1155 , this , this . port _pagehi _write . bind ( this , 1 ) ) ; a . register _write ( 1153 , this , this . port _pagehi _write . bind ( this , 2 ) ) ; a . register _write ( 1154 , this , this . port _pagehi _write . bind ( this , 3 ) ) ; a . register _write ( 1163 , this , this . port _pagehi _write . bind ( this , 5 ) ) ;
a . register _write ( 1161 , this , this . port _pagehi _write . bind ( this , 6 ) ) ; a . register _write ( 1162 , this , this . port _pagehi _write . bind ( this , 7 ) ) ; a . register _read ( 1159 , this , this . port _pagehi _read . bind ( this , 0 ) ) ; a . register _read ( 1155 , this , this . port _pagehi _read . bind ( this , 1 ) ) ; a . register _read ( 1153 , this , this . port _pagehi _read . bind ( this , 2 ) ) ; a . register _read ( 1154 , this , this . port _pagehi _read . bind ( this , 3 ) ) ; a . register _read ( 1163 , this , this . port _pagehi _read . bind ( this , 5 ) ) ; a . register _read ( 1161 , this , this . port _pagehi _read . bind ( this , 6 ) ) ; a . register _read ( 1162 ,
this , this . port _pagehi _read . bind ( this , 7 ) ) ; a . register _write ( 10 , this , this . port _singlemask _write . bind ( this , 0 ) ) ; a . register _write ( 212 , this , this . port _singlemask _write . bind ( this , 4 ) ) ; a . register _write ( 15 , this , this . port _multimask _write . bind ( this , 0 ) ) ; a . register _write ( 222 , this , this . port _multimask _write . bind ( this , 4 ) ) ; a . register _read ( 15 , this , this . port _multimask _read . bind ( this , 0 ) ) ; a . register _read ( 222 , this , this . port _multimask _read . bind ( this , 4 ) ) ; a . register _write ( 11 , this , this . port _mode _write . bind ( this , 0 ) ) ; a . register _write ( 214 ,
2024-11-28 07:25:05 +01:00
this , this . port _mode _write . bind ( this , 4 ) ) ; a . register _write ( 12 , this , this . portC _write ) ; a . register _write ( 216 , this , this . portC _write ) } M . prototype . get _state = function ( ) { return [ this . channel _page , this . channel _pagehi , this . channel _addr , this . channel _addr _init , this . channel _count , this . channel _count _init , this . channel _mask , this . channel _mode , this . lsb _msb _flipflop ] } ;
2025-01-03 12:44:26 +01:00
M . prototype . set _state = function ( a ) { this . channel _page = a [ 0 ] ; this . channel _pagehi = a [ 1 ] ; this . channel _addr = a [ 2 ] ; this . channel _addr _init = a [ 3 ] ; this . channel _count = a [ 4 ] ; this . channel _count _init = a [ 5 ] ; this . channel _mask = a [ 6 ] ; this . channel _mode = a [ 7 ] ; this . lsb _msb _flipflop = a [ 8 ] } ; M . prototype . port _count _write = function ( a , b ) { B ( b ) ; this . channel _count [ a ] = this . flipflop _get ( this . channel _count [ a ] , b , ! 1 ) ; this . channel _count _init [ a ] = this . flipflop _get ( this . channel _count _init [ a ] , b , ! 0 ) } ;
M . prototype . port _count _read = function ( a ) { B ( this . channel _count [ a ] ) ; return this . flipflop _read ( this . channel _count [ a ] ) } ; M . prototype . port _addr _write = function ( a , b ) { B ( b ) ; this . channel _addr [ a ] = this . flipflop _get ( this . channel _addr [ a ] , b , ! 1 ) ; this . channel _addr _init [ a ] = this . flipflop _get ( this . channel _addr _init [ a ] , b , ! 0 ) } ; M . prototype . port _addr _read = function ( a ) { B ( this . channel _addr [ a ] ) ; return this . flipflop _read ( this . channel _addr [ a ] ) } ; M . prototype . port _pagehi _write = function ( a , b ) { B ( b ) ; this . channel _pagehi [ a ] = b } ;
M . prototype . port _pagehi _read = function ( a ) { return this . channel _pagehi [ a ] } ; M . prototype . port _page _write = function ( a , b ) { B ( b ) ; this . channel _page [ a ] = b } ; M . prototype . port _page _read = function ( a ) { return this . channel _page [ a ] } ; M . prototype . port _singlemask _write = function ( a , b ) { this . update _mask ( ( b & 3 ) + a , b & 4 ? 1 : 0 ) } ; M . prototype . port _multimask _write = function ( a , b ) { B ( b ) ; for ( var c = 0 ; 4 > c ; c ++ ) this . update _mask ( a + c , b & 1 << c ) } ;
M . prototype . port _multimask _read = function ( a ) { var b = 0 | this . channel _mask [ a + 0 ] ; b |= this . channel _mask [ a + 1 ] << 1 ; b |= this . channel _mask [ a + 2 ] << 2 ; b |= this . channel _mask [ a + 3 ] << 3 ; B ( b ) ; return b } ; M . prototype . port _mode _write = function ( a , b ) { a = ( b & 3 ) + a ; B ( b ) ; this . channel _mode [ a ] = b } ; M . prototype . portC _write = function ( ) { this . lsb _msb _flipflop = 0 } ; M . prototype . on _unmask = function ( a , b ) { this . unmask _listeners . push ( { fn : a , this _value : b } ) } ;
2024-11-28 07:25:05 +01:00
M . prototype . update _mask = function ( a , b ) { if ( this . channel _mask [ a ] !== b && ( this . channel _mask [ a ] = b , ! b ) ) for ( b = 0 ; b < this . unmask _listeners . length ; b ++ ) this . unmask _listeners [ b ] . fn . call ( this . unmask _listeners [ b ] . this _value , a ) } ;
2025-01-03 12:44:26 +01:00
M . prototype . do _read = function ( a , b , c , d , e ) { var g = this . count _get _8bit ( d ) , f = this . address _get _8bit ( d ) ; ta ( "to " + B ( f ) + " len " + B ( g ) , 16 ) ; c < g && ta ( "DMA should read more than provided: " + B ( c ) + " " + B ( g ) , 16 ) ; if ( b + g > a . byteLength ) e ( ! 0 ) ; else { var k = this . cpu ; this . channel _addr [ d ] += g ; a . get ( b , g , function ( l ) { k . write _blob ( l , f ) ; e ( ! 1 ) } ) } } ;
M . prototype . do _write = function ( a , b , c , d , e ) { var g = this . channel _count [ d ] + 1 & 65535 , f = 5 <= d ? 2 : 1 , k = g * f , l = this . address _get _8bit ( d ) , m = ! 1 , n = ! 1 , p = this . channel _mode [ d ] & 16 ; ta ( "to " + B ( l ) + " len " + B ( k ) , 16 ) ; c < k ? ( g = Math . floor ( c / f ) , k = g * f , m = ! 0 ) : c > k && ( n = ! 0 ) ; b + k > a . byteLength ? e ( ! 0 ) : ( this . channel _addr [ d ] += g , this . channel _count [ d ] -= g , ! m && p && ( this . channel _addr [ d ] = this . channel _addr _init [ d ] , this . channel _count [ d ] = this . channel _count _init [ d ] ) , a . set ( b , this . cpu . mem8 . subarray ( l , l + k ) , ( ) => { n && p ? this . do _write ( a , b + k , c - k , d , e ) : e ( ! 1 ) } ) ) } ;
M . prototype . address _get _8bit = function ( a ) { var b = this . channel _addr [ a ] ; 5 <= a && ( b <<= 1 ) ; b = b & 65535 | this . channel _page [ a ] << 16 ; return b |= this . channel _pagehi [ a ] << 24 } ; M . prototype . count _get _8bit = function ( a ) { var b = this . channel _count [ a ] + 1 ; 5 <= a && ( b *= 2 ) ; return b } ; M . prototype . flipflop _get = function ( a , b , c ) { c || ( this . lsb _msb _flipflop ^= 1 ) ; return this . lsb _msb _flipflop ? a & - 256 | b : a & - 65281 | b << 8 } ; M . prototype . flipflop _read = function ( a ) { return ( this . lsb _msb _flipflop ^= 1 ) ? a & 255 : a >> 8 & 255 } ; function wa ( a , b ) { this . cpu = a ; this . bus = b ; this . counter _start _time = new Float64Array ( 3 ) ; this . counter _start _value = new Uint16Array ( 3 ) ; this . counter _next _low = new Uint8Array ( 4 ) ; this . counter _enabled = new Uint8Array ( 4 ) ; this . counter _mode = new Uint8Array ( 4 ) ; this . counter _read _mode = new Uint8Array ( 4 ) ; this . counter _latch = new Uint8Array ( 4 ) ; this . counter _latch _value = new Uint16Array ( 3 ) ; this . counter _reload = new Uint16Array ( 3 ) ; a . io . register _read ( 97 , this , function ( ) { var c = D . microtick ( ) , d = 66.66666666666667 * c & 1 ; c = this . did _rollover ( 2 ,
2024-06-28 09:23:02 +02:00
c ) ; return d << 4 | c << 5 } ) ; a . io . register _write ( 97 , this , function ( c ) { c & 1 ? this . bus . send ( "pcspeaker-enable" ) : this . bus . send ( "pcspeaker-disable" ) } ) ; a . io . register _read ( 64 , this , function ( ) { return this . counter _read ( 0 ) } ) ; a . io . register _read ( 65 , this , function ( ) { return this . counter _read ( 1 ) } ) ; a . io . register _read ( 66 , this , function ( ) { return this . counter _read ( 2 ) } ) ; a . io . register _write ( 64 , this , function ( c ) { this . counter _write ( 0 , c ) } ) ; a . io . register _write ( 65 , this , function ( c ) { this . counter _write ( 1 , c ) } ) ; a . io . register _write ( 66 , this ,
2024-11-28 07:25:05 +01:00
function ( c ) { this . counter _write ( 2 , c ) ; this . bus . send ( "pcspeaker-update" , [ this . counter _mode [ 2 ] , this . counter _reload [ 2 ] ] ) } ) ; a . io . register _write ( 67 , this , this . port43 _write ) } wa . prototype . get _state = function ( ) { var a = [ ] ; a [ 0 ] = this . counter _next _low ; a [ 1 ] = this . counter _enabled ; a [ 2 ] = this . counter _mode ; a [ 3 ] = this . counter _read _mode ; a [ 4 ] = this . counter _latch ; a [ 5 ] = this . counter _latch _value ; a [ 6 ] = this . counter _reload ; a [ 7 ] = this . counter _start _time ; a [ 8 ] = this . counter _start _value ; return a } ;
wa . prototype . set _state = function ( a ) { this . counter _next _low = a [ 0 ] ; this . counter _enabled = a [ 1 ] ; this . counter _mode = a [ 2 ] ; this . counter _read _mode = a [ 3 ] ; this . counter _latch = a [ 4 ] ; this . counter _latch _value = a [ 5 ] ; this . counter _reload = a [ 6 ] ; this . counter _start _time = a [ 7 ] ; this . counter _start _value = a [ 8 ] } ;
wa . prototype . timer = function ( a , b ) { var c = 100 ; b || ( this . counter _enabled [ 0 ] && this . did _rollover ( 0 , a ) ? ( this . counter _start _value [ 0 ] = this . get _counter _value ( 0 , a ) , this . counter _start _time [ 0 ] = a , this . cpu . device _lower _irq ( 0 ) , this . cpu . device _raise _irq ( 0 ) , 0 === this . counter _mode [ 0 ] && ( this . counter _enabled [ 0 ] = 0 ) ) : this . cpu . device _lower _irq ( 0 ) , this . counter _enabled [ 0 ] && ( c = ( this . counter _start _value [ 0 ] - Math . floor ( 1193.1816666 * ( a - this . counter _start _time [ 0 ] ) ) ) / 1193.1816666 ) ) ; return c } ;
wa . prototype . get _counter _value = function ( a , b ) { if ( ! this . counter _enabled [ a ] ) return 0 ; b = this . counter _start _value [ a ] - Math . floor ( 1193.1816666 * ( b - this . counter _start _time [ a ] ) ) ; a = this . counter _reload [ a ] ; b >= a ? b %= a : 0 > b && ( b = b % a + a ) ; return b } ; wa . prototype . did _rollover = function ( a , b ) { b -= this . counter _start _time [ a ] ; return 0 > b ? ! 0 : this . counter _start _value [ a ] < Math . floor ( 1193.1816666 * b ) } ;
2025-01-03 12:44:26 +01:00
wa . prototype . counter _read = function ( a ) { var b = this . counter _latch [ a ] ; if ( b ) return this . counter _latch [ a ] -- , 2 === b ? this . counter _latch _value [ a ] & 255 : this . counter _latch _value [ a ] >> 8 ; b = this . counter _next _low [ a ] ; 3 === this . counter _mode [ a ] && ( this . counter _next _low [ a ] ^= 1 ) ; a = this . get _counter _value ( a , D . microtick ( ) ) ; return b ? a & 255 : a >> 8 } ;
wa . prototype . counter _write = function ( a , b ) { this . counter _reload [ a ] = this . counter _next _low [ a ] ? this . counter _reload [ a ] & - 256 | b : this . counter _reload [ a ] & 255 | b << 8 ; 3 === this . counter _read _mode [ a ] && this . counter _next _low [ a ] || ( this . counter _reload [ a ] || ( this . counter _reload [ a ] = 65535 ) , this . counter _start _value [ a ] = this . counter _reload [ a ] , this . counter _enabled [ a ] = ! 0 , this . counter _start _time [ a ] = D . microtick ( ) , B ( this . counter _reload [ a ] ) ) ; 3 === this . counter _read _mode [ a ] && ( this . counter _next _low [ a ] ^= 1 ) } ;
wa . prototype . port43 _write = function ( a ) { var b = a >> 1 & 7 , c = a >> 6 & 3 ; a = a >> 4 & 3 ; 3 !== c && ( 0 === a ? ( this . counter _latch [ c ] = 2 , b = this . get _counter _value ( c , D . microtick ( ) ) , this . counter _latch _value [ c ] = b ? b - 1 : 0 ) : ( 6 <= b && ( b &= - 5 ) , this . counter _next _low [ c ] = 1 === a ? 0 : 1 , 0 === c && this . cpu . device _lower _irq ( 0 ) , 0 !== b && 3 !== b && 2 !== b && B ( b ) , this . counter _mode [ c ] = b , this . counter _read _mode [ c ] = a , 2 === c && this . bus . send ( "pcspeaker-update" , [ this . counter _mode [ 2 ] , this . counter _reload [ 2 ] ] ) ) ) } ; wa . prototype . dump = function ( ) { } ; const xa = Uint32Array . from ( [ 655360 , 655360 , 720896 , 753664 ] ) , ya = Uint32Array . from ( [ 131072 , 65536 , 32768 , 32768 ] ) ;
2024-11-28 07:25:05 +01:00
function N ( a , b , c , d ) { this . cpu = a ; this . bus = b ; this . screen = c ; this . vga _memory _size = d ; this . cursor _address = 0 ; this . cursor _scanline _start = 14 ; this . cursor _scanline _end = 15 ; this . max _cols = 80 ; this . max _rows = 25 ; this . virtual _height = this . virtual _width = this . screen _height = this . screen _width = 0 ; this . layers = [ ] ; this . start _address _latched = this . start _address = 0 ; this . crtc = new Uint8Array ( 25 ) ; this . line _compare = this . offset _register = this . preset _row _scan = this . underline _location _register = this . vertical _blank _start = this . vertical _display _enable _end =
2025-01-03 12:44:26 +01:00
this . horizontal _blank _start = this . horizontal _display _enable _end = this . crtc _mode = 0 ; this . graphical _mode = ! 1 ; this . vga256 _palette = new Int32Array ( 256 ) ; this . latch _dword = 0 ; this . svga _version = 45253 ; this . svga _height = this . svga _width = 0 ; this . svga _enabled = ! 1 ; this . svga _bpp = 32 ; this . svga _offset _y = this . svga _offset _x = this . svga _offset = this . svga _bank _offset = 0 ; this . vga _memory _size = void 0 === this . vga _memory _size || 262144 > this . vga _memory _size ? 262144 : 268435456 < this . vga _memory _size ? 268435456 : h . round _up _to _next _power _of _2 ( this . vga _memory _size ) ;
2024-10-02 21:03:04 +02:00
this . pci _space = [ 52 , 18 , 17 , 17 , 3 , 1 , 0 , 0 , 0 , 0 , 0 , 3 , 0 , 0 , 0 , 0 , 8 , 14680064 , 57344 , 224 , 0 , 0 , 0 , 0 , 0 , 0 , 191 , 254 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 244 , 26 , 0 , 17 , 0 , 0 , 190 , 254 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 ] ; this . pci _id = 144 ; this . pci _bars = [ { size : this . vga _memory _size } ] ; this . pci _rom _size = 65536 ; this . pci _rom _address = 4272947200 ; this . name = "vga" ; this . dac _state = this . dac _color _index _read = this . dac _color _index _write = this . index _crtc = 0 ; this . dac _mask = 255 ; this . dac _map = new Uint8Array ( 16 ) ; this . attribute _controller _index = - 1 ; this . palette _source = 32 ; this . color _select =
this . horizontal _panning = this . color _plane _enable = this . attribute _mode = 0 ; this . sequencer _index = - 1 ; this . plane _write _bm = 15 ; this . clocking _mode = this . sequencer _memory _mode = 0 ; this . graphics _index = - 1 ; this . planar _rotate _reg = this . planar _mode = this . plane _read = this . character _map _select = 0 ; this . planar _bitmap = 255 ; this . max _scan _line = this . color _dont _care = this . color _compare = this . miscellaneous _graphics _register = this . planar _setreset _enable = this . planar _setreset = 0 ; this . port _3DA _value = this . miscellaneous _output _register = 255 ;
2024-11-28 07:25:05 +01:00
this . font _page _ab _enabled = ! 1 ; b = a . io ; b . register _write ( 960 , this , this . port3C0 _write ) ; b . register _read ( 960 , this , this . port3C0 _read , this . port3C0 _read16 ) ; b . register _read ( 961 , this , this . port3C1 _read ) ; b . register _write ( 962 , this , this . port3C2 _write ) ; b . register _write _consecutive ( 964 , this , this . port3C4 _write , this . port3C5 _write ) ; b . register _read ( 964 , this , this . port3C4 _read ) ; b . register _read ( 965 , this , this . port3C5 _read ) ; b . register _write _consecutive ( 974 , this , this . port3CE _write , this . port3CF _write ) ; b . register _read ( 974 , this ,
this . port3CE _read ) ; b . register _read ( 975 , this , this . port3CF _read ) ; b . register _read ( 966 , this , this . port3C6 _read ) ; b . register _write ( 966 , this , this . port3C6 _write ) ; b . register _write ( 967 , this , this . port3C7 _write ) ; b . register _read ( 967 , this , this . port3C7 _read ) ; b . register _write ( 968 , this , this . port3C8 _write ) ; b . register _read ( 968 , this , this . port3C8 _read ) ; b . register _write ( 969 , this , this . port3C9 _write ) ; b . register _read ( 969 , this , this . port3C9 _read ) ; b . register _read ( 972 , this , this . port3CC _read ) ; b . register _write ( 980 , this , this . port3D4 _write ,
this . port3D4 _write16 ) ; b . register _write ( 981 , this , this . port3D5 _write , this . port3D5 _write16 ) ; b . register _read ( 980 , this , this . port3D4 _read ) ; b . register _read ( 981 , this , this . port3D5 _read , this . port3D5 _read16 ) ; b . register _write ( 948 , this , this . port3D4 _write , this . port3D4 _write16 ) ; b . register _write ( 949 , this , this . port3D5 _write , this . port3D5 _write16 ) ; b . register _read ( 948 , this , this . port3D4 _read ) ; b . register _read ( 949 , this , this . port3D5 _read , this . port3D5 _read16 ) ; b . register _read ( 970 , this , function ( ) { return 0 } ) ; b . register _read ( 986 ,
2025-01-03 12:44:26 +01:00
this , this . port3DA _read ) ; b . register _read ( 954 , this , this . port3DA _read ) ; this . dispi _index = - 1 ; this . dispi _enable _value = 0 ; b . register _write ( 462 , this , void 0 , this . port1CE _write ) ; b . register _write ( 463 , this , void 0 , this . port1CF _write ) ; b . register _read ( 463 , this , void 0 , this . port1CF _read ) ; c = a . svga _allocate _memory ( this . vga _memory _size ) >>> 0 ; this . svga _memory = h . view ( Uint8Array , a . wasm _memory , c , this . vga _memory _size ) ; this . diff _addr _min = this . vga _memory _size ; this . diff _addr _max = 0 ; this . diff _plot _min = this . vga _memory _size ; this . diff _plot _max =
2024-11-28 07:25:05 +01:00
0 ; this . image _data = null ; this . vga _memory = new Uint8Array ( 262144 ) ; this . plane0 = new Uint8Array ( this . vga _memory . buffer , 0 , 65536 ) ; this . plane1 = new Uint8Array ( this . vga _memory . buffer , 65536 , 65536 ) ; this . plane2 = new Uint8Array ( this . vga _memory . buffer , 131072 , 65536 ) ; this . plane3 = new Uint8Array ( this . vga _memory . buffer , 196608 , 65536 ) ; this . pixel _buffer = new Uint8Array ( 524288 ) ; b . mmap _register ( 655360 , 131072 , e => this . vga _memory _read ( e ) , ( e , g ) => this . vga _memory _write ( e , g ) ) ; a . devices . pci . register _device ( this ) }
2024-10-02 21:03:04 +02:00
N . prototype . get _state = function ( ) { var a = [ ] ; a [ 0 ] = this . vga _memory _size ; a [ 1 ] = this . cursor _address ; a [ 2 ] = this . cursor _scanline _start ; a [ 3 ] = this . cursor _scanline _end ; a [ 4 ] = this . max _cols ; a [ 5 ] = this . max _rows ; a [ 6 ] = this . vga _memory ; a [ 7 ] = this . dac _state ; a [ 8 ] = this . start _address ; a [ 9 ] = this . graphical _mode ; a [ 10 ] = this . vga256 _palette ; a [ 11 ] = this . latch _dword ; a [ 12 ] = this . color _compare ; a [ 13 ] = this . color _dont _care ; a [ 14 ] = this . miscellaneous _graphics _register ; a [ 15 ] = this . svga _width ; a [ 16 ] = this . svga _height ; a [ 17 ] = this . crtc _mode ; a [ 18 ] = this . svga _enabled ;
2024-06-28 09:23:02 +02:00
a [ 19 ] = this . svga _bpp ; a [ 20 ] = this . svga _bank _offset ; a [ 21 ] = this . svga _offset ; a [ 22 ] = this . index _crtc ; a [ 23 ] = this . dac _color _index _write ; a [ 24 ] = this . dac _color _index _read ; a [ 25 ] = this . dac _map ; a [ 26 ] = this . sequencer _index ; a [ 27 ] = this . plane _write _bm ; a [ 28 ] = this . sequencer _memory _mode ; a [ 29 ] = this . graphics _index ; a [ 30 ] = this . plane _read ; a [ 31 ] = this . planar _mode ; a [ 32 ] = this . planar _rotate _reg ; a [ 33 ] = this . planar _bitmap ; a [ 34 ] = this . max _scan _line ; a [ 35 ] = this . miscellaneous _output _register ; a [ 36 ] = this . port _3DA _value ; a [ 37 ] = this . dispi _index ;
2024-10-02 21:03:04 +02:00
a [ 38 ] = this . dispi _enable _value ; a [ 39 ] = this . svga _memory ; a [ 41 ] = this . attribute _controller _index ; a [ 42 ] = this . offset _register ; a [ 43 ] = this . planar _setreset ; a [ 44 ] = this . planar _setreset _enable ; a [ 45 ] = this . start _address _latched ; a [ 46 ] = this . crtc ; a [ 47 ] = this . horizontal _display _enable _end ; a [ 48 ] = this . horizontal _blank _start ; a [ 49 ] = this . vertical _display _enable _end ; a [ 50 ] = this . vertical _blank _start ; a [ 51 ] = this . underline _location _register ; a [ 52 ] = this . preset _row _scan ; a [ 53 ] = this . offset _register ; a [ 54 ] = this . palette _source ; a [ 55 ] = this . attribute _mode ;
2024-11-28 07:25:05 +01:00
a [ 56 ] = this . color _plane _enable ; a [ 57 ] = this . horizontal _panning ; a [ 58 ] = this . color _select ; a [ 59 ] = this . clocking _mode ; a [ 60 ] = this . line _compare ; a [ 61 ] = this . pixel _buffer ; a [ 62 ] = this . dac _mask ; a [ 63 ] = this . character _map _select ; a [ 64 ] = this . font _page _ab _enabled ; return a } ;
2024-10-02 21:03:04 +02:00
N . prototype . set _state = function ( a ) { this . vga _memory _size = a [ 0 ] ; this . cursor _address = a [ 1 ] ; this . cursor _scanline _start = a [ 2 ] ; this . cursor _scanline _end = a [ 3 ] ; this . max _cols = a [ 4 ] ; this . max _rows = a [ 5 ] ; a [ 6 ] && this . vga _memory . set ( a [ 6 ] ) ; this . dac _state = a [ 7 ] ; this . start _address = a [ 8 ] ; this . graphical _mode = a [ 9 ] ; this . vga256 _palette = a [ 10 ] ; this . latch _dword = a [ 11 ] ; this . color _compare = a [ 12 ] ; this . color _dont _care = a [ 13 ] ; this . miscellaneous _graphics _register = a [ 14 ] ; this . svga _width = a [ 15 ] ; this . svga _height = a [ 16 ] ; this . crtc _mode = a [ 17 ] ; this . svga _enabled =
2024-06-28 09:23:02 +02:00
a [ 18 ] ; this . svga _bpp = a [ 19 ] ; this . svga _bank _offset = a [ 20 ] ; this . svga _offset = a [ 21 ] ; this . index _crtc = a [ 22 ] ; this . dac _color _index _write = a [ 23 ] ; this . dac _color _index _read = a [ 24 ] ; this . dac _map = a [ 25 ] ; this . sequencer _index = a [ 26 ] ; this . plane _write _bm = a [ 27 ] ; this . sequencer _memory _mode = a [ 28 ] ; this . graphics _index = a [ 29 ] ; this . plane _read = a [ 30 ] ; this . planar _mode = a [ 31 ] ; this . planar _rotate _reg = a [ 32 ] ; this . planar _bitmap = a [ 33 ] ; this . max _scan _line = a [ 34 ] ; this . miscellaneous _output _register = a [ 35 ] ; this . port _3DA _value = a [ 36 ] ; this . dispi _index =
2024-10-02 21:03:04 +02:00
a [ 37 ] ; this . dispi _enable _value = a [ 38 ] ; this . svga _memory . set ( a [ 39 ] ) ; this . attribute _controller _index = a [ 41 ] ; this . offset _register = a [ 42 ] ; this . planar _setreset = a [ 43 ] ; this . planar _setreset _enable = a [ 44 ] ; this . start _address _latched = a [ 45 ] ; this . crtc . set ( a [ 46 ] ) ; this . horizontal _display _enable _end = a [ 47 ] ; this . horizontal _blank _start = a [ 48 ] ; this . vertical _display _enable _end = a [ 49 ] ; this . vertical _blank _start = a [ 50 ] ; this . underline _location _register = a [ 51 ] ; this . preset _row _scan = a [ 52 ] ; this . offset _register = a [ 53 ] ; this . palette _source =
2024-11-28 07:25:05 +01:00
a [ 54 ] ; this . attribute _mode = a [ 55 ] ; this . color _plane _enable = a [ 56 ] ; this . horizontal _panning = a [ 57 ] ; this . color _select = a [ 58 ] ; this . clocking _mode = a [ 59 ] ; this . line _compare = a [ 60 ] ; a [ 61 ] && this . pixel _buffer . set ( a [ 61 ] ) ; this . dac _mask = void 0 === a [ 62 ] ? 255 : a [ 62 ] ; this . character _map _select = void 0 === a [ 63 ] ? 0 : a [ 63 ] ; this . font _page _ab _enabled = void 0 === a [ 64 ] ? 0 : a [ 64 ] ; this . screen . set _mode ( this . graphical _mode ) ; this . graphical _mode ? ( this . screen _height = this . screen _width = 0 , this . svga _enabled ? ( this . set _size _graphical ( this . svga _width , this . svga _height ,
this . svga _width , this . svga _height , this . svga _bpp ) , this . update _layers ( ) ) : ( this . update _vga _size ( ) , this . update _layers ( ) , this . complete _replot ( ) ) ) : ( this . set _font _bitmap ( ! 0 ) , this . set _size _text ( this . max _cols , this . max _rows ) , this . set _font _page ( ) , this . update _cursor _scanline ( ) , this . update _cursor ( ) ) ; this . complete _redraw ( ) } ;
2025-01-03 12:44:26 +01:00
N . prototype . vga _memory _read = function ( a ) { if ( this . svga _enabled ) return this . cpu . read8 ( ( a - 655360 | this . svga _bank _offset ) + 3758096384 | 0 ) ; var b = this . miscellaneous _graphics _register >> 2 & 3 ; a -= xa [ b ] ; if ( 0 > a || a >= ya [ b ] ) return B ( a ) , 0 ; this . latch _dword = this . plane0 [ a ] ; this . latch _dword |= this . plane1 [ a ] << 8 ; this . latch _dword |= this . plane2 [ a ] << 16 ; this . latch _dword |= this . plane3 [ a ] << 24 ; if ( this . planar _mode & 8 ) return b = 255 , this . color _dont _care & 1 && ( b &= this . plane0 [ a ] ^ ~ ( this . color _compare & 1 ? 255 : 0 ) ) , this . color _dont _care & 2 && ( b &= this . plane1 [ a ] ^
2024-10-02 21:03:04 +02:00
~ ( this . color _compare & 2 ? 255 : 0 ) ) , this . color _dont _care & 4 && ( b &= this . plane2 [ a ] ^ ~ ( this . color _compare & 4 ? 255 : 0 ) ) , this . color _dont _care & 8 && ( b &= this . plane3 [ a ] ^ ~ ( this . color _compare & 8 ? 255 : 0 ) ) , b ; b = this . plane _read ; this . graphical _mode ? this . sequencer _memory _mode & 8 ? ( b = a & 3 , a &= - 4 ) : this . planar _mode & 16 && ( b = a & 1 , a &= - 2 ) : b &= 3 ; return this . vga _memory [ b << 16 | a ] } ;
2025-01-03 12:44:26 +01:00
N . prototype . vga _memory _write = function ( a , b ) { if ( this . svga _enabled ) this . cpu . write8 ( ( a - 655360 | this . svga _bank _offset ) + 3758096384 | 0 , b ) ; else { var c = this . miscellaneous _graphics _register >> 2 & 3 ; a -= xa [ c ] ; 0 > a || a >= ya [ c ] ? ( B ( a ) , B ( b ) ) : this . graphical _mode ? this . vga _memory _write _graphical ( a , b ) : this . plane _write _bm & 3 ? this . vga _memory _write _text _mode ( a , b ) : this . plane _write _bm & 4 && ( this . plane2 [ a ] = b ) } } ;
2024-11-28 07:25:05 +01:00
N . prototype . vga _memory _write _graphical = function ( a , b ) { var c = this . planar _mode & 3 , d = this . apply _feed ( this . planar _bitmap ) , e = this . apply _expand ( this . planar _setreset ) , g = this . apply _expand ( this . planar _setreset _enable ) ; switch ( c ) { case 0 : b = this . apply _rotate ( b ) ; var f = this . apply _feed ( b ) ; f = this . apply _setreset ( f , g ) ; f = this . apply _logical ( f , this . latch _dword ) ; f = this . apply _bitmask ( f , d ) ; break ; case 1 : f = this . latch _dword ; break ; case 2 : f = this . apply _expand ( b ) ; f = this . apply _logical ( f , this . latch _dword ) ; f = this . apply _bitmask ( f , d ) ;
break ; case 3 : b = this . apply _rotate ( b ) , d &= this . apply _feed ( b ) , f = this . apply _bitmask ( e , d ) } b = 15 ; switch ( this . sequencer _memory _mode & 12 ) { case 0 : b = 5 << ( a & 1 ) ; a &= - 2 ; break ; case 8 : case 12 : b = 1 << ( a & 3 ) , a &= - 4 } b &= this . plane _write _bm ; b & 1 && ( this . plane0 [ a ] = f >> 0 & 255 ) ; b & 2 && ( this . plane1 [ a ] = f >> 8 & 255 ) ; b & 4 && ( this . plane2 [ a ] = f >> 16 & 255 ) ; b & 8 && ( this . plane3 [ a ] = f >> 24 & 255 ) ; a = this . vga _addr _to _pixel ( a ) ; this . partial _replot ( a , a + 7 ) } ; N . prototype . apply _feed = function ( a ) { return a | a << 8 | a << 16 | a << 24 } ;
2024-10-02 21:03:04 +02:00
N . prototype . apply _expand = function ( a ) { return ( a & 1 ? 255 : 0 ) | ( a & 2 ? 255 : 0 ) << 8 | ( a & 4 ? 255 : 0 ) << 16 | ( a & 8 ? 255 : 0 ) << 24 } ; N . prototype . apply _rotate = function ( a ) { return ( a | a << 8 ) >>> ( this . planar _rotate _reg & 7 ) & 255 } ; N . prototype . apply _setreset = function ( a , b ) { var c = this . apply _expand ( this . planar _setreset ) ; return ( a | b & c ) & ( ~ b | c ) } ; N . prototype . apply _logical = function ( a , b ) { switch ( this . planar _rotate _reg & 24 ) { case 8 : return a & b ; case 16 : return a | b ; case 24 : return a ^ b } return a } ; N . prototype . apply _bitmask = function ( a , b ) { return b & a | ~ b & this . latch _dword } ;
2025-01-03 12:44:26 +01:00
N . prototype . text _mode _redraw = function ( ) { const a = this . scan _line _to _screen _row ( this . line _compare ) , b = Math . max ( 0 , 2 * ( 2 * this . offset _register - this . max _cols ) ) , c = this . attribute _mode & 8 , d = this . font _page _ab _enabled ? 7 : 15 , e = c ? 7 : 15 , g = this . screen . FLAG _BLINKING , f = this . screen . FLAG _FONT _PAGE _B ; let k = this . start _address << 1 ; for ( let l = 0 ; l < this . max _rows ; l ++ ) { l === a && ( k = 0 ) ; for ( let m = 0 ; m < this . max _cols ; m ++ ) { const n = this . vga _memory [ k ] , p = this . vga _memory [ k | 1 ] , q = ( c && p & 128 ? g : 0 ) | ( ! this . font _page _ab _enabled || p & 8 ? 0 : f ) ; this . bus . send ( "screen-put-char" ,
[ l , m , n ] ) ; this . screen . put _char ( l , m , n , q , this . vga256 _palette [ this . dac _mask & this . dac _map [ p >> 4 & e ] ] , this . vga256 _palette [ this . dac _mask & this . dac _map [ p & d ] ] ) ; k += 2 } k += b } } ;
2024-11-28 07:25:05 +01:00
N . prototype . vga _memory _write _text _mode = function ( a , b ) { this . vga _memory [ a ] = b ; var c = Math . max ( this . max _cols , 2 * this . offset _register ) ; let d ; if ( a >> 1 >= this . start _address ) { var e = ( a >> 1 ) - this . start _address ; d = e / c | 0 ; c = e % c } else e = a >> 1 , d = ( e / c | 0 ) + this . scan _line _to _screen _row ( this . line _compare ) , c = e % c ; if ( ! ( c >= this . max _cols || d >= this . max _rows ) ) { a & 1 ? ( e = b , b = this . vga _memory [ a & - 2 ] ) : e = this . vga _memory [ a | 1 ] ; var g = this . attribute _mode & 8 ; a = ( g && e & 128 ? this . screen . FLAG _BLINKING : 0 ) | ( ! this . font _page _ab _enabled || e & 8 ? 0 : this . screen . FLAG _FONT _PAGE _B ) ;
var f = this . font _page _ab _enabled ? 7 : 15 ; g = g ? 7 : 15 ; this . bus . send ( "screen-put-char" , [ d , c , b ] ) ; this . screen . put _char ( d , c , b , a , this . vga256 _palette [ this . dac _mask & this . dac _map [ e >> 4 & g ] ] , this . vga256 _palette [ this . dac _mask & this . dac _map [ e & f ] ] ) } } ;
N . prototype . update _cursor = function ( ) { var a = Math . max ( this . max _cols , 2 * this . offset _register ) ; let b ; this . cursor _address >= this . start _address ? ( b = ( this . cursor _address - this . start _address ) / a | 0 , a = ( this . cursor _address - this . start _address ) % a ) : ( b = ( this . cursor _address / a | 0 ) + this . scan _line _to _screen _row ( this . line _compare ) , a = this . cursor _address % a ) ; this . screen . update _cursor ( b , a ) } ;
2024-10-02 21:03:04 +02:00
N . prototype . complete _redraw = function ( ) { this . graphical _mode ? this . svga _enabled ? this . cpu . svga _mark _dirty ( ) : ( this . diff _addr _min = 0 , this . diff _addr _max = 524288 ) : this . text _mode _redraw ( ) } ; N . prototype . complete _replot = function ( ) { this . graphical _mode && ! this . svga _enabled && ( this . diff _plot _min = 0 , this . diff _plot _max = 524288 , this . complete _redraw ( ) ) } ; N . prototype . partial _redraw = function ( a , b ) { a < this . diff _addr _min && ( this . diff _addr _min = a ) ; b > this . diff _addr _max && ( this . diff _addr _max = b ) } ;
N . prototype . partial _replot = function ( a , b ) { a < this . diff _plot _min && ( this . diff _plot _min = a ) ; b > this . diff _plot _max && ( this . diff _plot _max = b ) ; this . partial _redraw ( a , b ) } ; N . prototype . reset _diffs = function ( ) { this . diff _addr _min = this . vga _memory _size ; this . diff _addr _max = 0 ; this . diff _plot _min = this . vga _memory _size ; this . diff _plot _max = 0 } ; N . prototype . destroy = function ( ) { } ; N . prototype . vga _bytes _per _line = function ( ) { var a = this . offset _register << 2 ; this . underline _location _register & 64 ? a <<= 1 : this . crtc _mode & 64 && ( a >>>= 1 ) ; return a } ;
N . prototype . vga _addr _shift _count = function ( ) { var a = 128 + ( ~ this . underline _location _register & this . crtc _mode & 64 ) ; a -= this . underline _location _register & 64 ; a -= this . attribute _mode & 64 ; return a >>> 6 } ;
N . prototype . vga _addr _to _pixel = function ( a ) { var b = this . vga _addr _shift _count ( ) ; if ( ~ this . crtc _mode & 3 ) { var c = a - this . start _address ; c &= this . crtc _mode << 13 | - 24577 ; c <<= b ; var d = c / this . virtual _width | 0 ; c %= this . virtual _width ; switch ( this . crtc _mode & 3 ) { case 2 : d = d << 1 | a >> 13 & 1 ; break ; case 1 : d = d << 1 | a >> 14 & 1 ; break ; case 0 : d = d << 2 | a >> 13 & 3 } return d * this . virtual _width + c + ( this . start _address << b ) } return a << b } ;
2024-11-28 07:25:05 +01:00
N . prototype . scan _line _to _screen _row = function ( a ) { this . max _scan _line & 128 && ( a >>>= 1 ) ; a = Math . ceil ( a / ( 1 + ( this . max _scan _line & 31 ) ) ) ; this . crtc _mode & 1 || ( a <<= 1 ) ; this . crtc _mode & 2 || ( a <<= 1 ) ; return a } ; N . prototype . set _size _text = function ( a , b ) { this . max _cols = a ; this . max _rows = b ; this . screen . set _size _text ( a , b ) ; this . bus . send ( "screen-set-size" , [ a , b , 0 ] ) } ;
N . prototype . set _size _graphical = function ( a , b , c , d , e ) { c = Math . max ( c , 1 ) ; d = Math . max ( d , 1 ) ; if ( this . screen _width !== a || this . screen _height !== b || this . virtual _width !== c || this . virtual _height !== d ) { this . screen _width = a ; this . screen _height = b ; this . virtual _width = c ; this . virtual _height = d ; if ( "undefined" !== typeof ImageData ) { const g = c * d , f = this . cpu . svga _allocate _dest _buffer ( g ) >>> 0 ; this . dest _buffet _offset = f ; this . image _data = new ImageData ( new Uint8ClampedArray ( this . cpu . wasm _memory . buffer , f , 4 * g ) , c , d ) ; this . cpu . svga _mark _dirty ( ) } this . screen . set _size _graphical ( a ,
2024-10-02 21:03:04 +02:00
b , c , d ) ; this . bus . send ( "screen-set-size" , [ a , b , e ] ) } } ;
2024-11-28 07:25:05 +01:00
N . prototype . update _vga _size = function ( ) { if ( ! this . svga _enabled ) { var a = Math . min ( 1 + this . horizontal _display _enable _end , this . horizontal _blank _start ) , b = Math . min ( 1 + this . vertical _display _enable _end , this . vertical _blank _start ) ; if ( a && b ) if ( this . graphical _mode ) { a <<= 3 ; var c = this . offset _register << 4 ; this . attribute _mode & 64 && ( a >>>= 1 , c >>>= 1 ) ; b = this . scan _line _to _screen _row ( b ) ; var d = ya [ 0 ] ; const e = this . vga _bytes _per _line ( ) ; this . set _size _graphical ( a , b , c , e ? Math . ceil ( d / e ) : b , 8 ) ; this . update _vertical _retrace ( ) ; this . update _layers ( ) } else this . max _scan _line &
2024-06-28 09:23:02 +02:00
128 && ( b >>>= 1 ) , c = b / ( 1 + ( this . max _scan _line & 31 ) ) | 0 , a && c && this . set _size _text ( a , c ) } } ;
2024-10-02 21:03:04 +02:00
N . prototype . update _layers = function ( ) { this . graphical _mode || this . text _mode _redraw ( ) ; if ( this . svga _enabled ) this . layers = [ ] ; else if ( this . virtual _width && this . screen _width ) if ( ! this . palette _source || this . clocking _mode & 32 ) this . layers = [ ] , this . screen . clear _screen ( ) ; else { var a = this . start _address _latched , b = this . horizontal _panning ; this . attribute _mode & 64 && ( b >>>= 1 ) ; var c = this . preset _row _scan >> 5 & 3 , d = this . vga _addr _to _pixel ( a + c ) ; a = d / this . virtual _width | 0 ; var e = d % this . virtual _width + b ; d = this . scan _line _to _screen _row ( 1 + this . line _compare ) ;
2024-11-28 07:25:05 +01:00
d = Math . min ( d , this . screen _height ) ; var g = this . screen _height - d ; this . layers = [ ] ; e = - e ; for ( var f = 0 ; e < this . screen _width ; e += this . virtual _width , f ++ ) this . layers . push ( { image _data : this . image _data , screen _x : e , screen _y : 0 , buffer _x : 0 , buffer _y : a + f , buffer _width : this . virtual _width , buffer _height : d } ) ; a = 0 ; this . attribute _mode & 32 || ( a = this . vga _addr _to _pixel ( c ) + b ) ; e = - a ; for ( f = 0 ; e < this . screen _width ; e += this . virtual _width , f ++ ) this . layers . push ( { image _data : this . image _data , screen _x : e , screen _y : d , buffer _x : 0 , buffer _y : f , buffer _width : this . virtual _width ,
buffer _height : g } ) } } ; N . prototype . update _vertical _retrace = function ( ) { this . port _3DA _value |= 8 ; this . start _address _latched !== this . start _address && ( this . start _address _latched = this . start _address , this . update _layers ( ) ) } ; N . prototype . update _cursor _scanline = function ( ) { var a = this . max _scan _line & 31 ; const b = Math . min ( a , this . cursor _scanline _start & 31 ) ; a = Math . min ( a , this . cursor _scanline _end & 31 ) ; this . screen . update _cursor _scanline ( b , a , ! ( this . cursor _scanline _start & 32 ) && b < a ) } ;
2025-01-03 12:44:26 +01:00
N . prototype . port3C0 _write = function ( a ) { if ( - 1 === this . attribute _controller _index ) B ( a ) , this . attribute _controller _index = a & 31 , B ( this . attribute _controller _index ) , this . palette _source !== ( a & 32 ) && ( this . palette _source = a & 32 , this . update _layers ( ) ) ; else { if ( 16 > this . attribute _controller _index ) B ( this . attribute _controller _index ) , B ( a ) , this . dac _map [ this . attribute _controller _index ] = a , this . attribute _mode & 64 || this . complete _redraw ( ) ; else switch ( this . attribute _controller _index ) { case 16 : B ( a ) ; if ( this . attribute _mode !== a ) { var b =
this . attribute _mode ; this . attribute _mode = a ; const c = 0 !== ( a & 1 ) ; this . svga _enabled || this . graphical _mode === c || ( this . graphical _mode = c , this . screen . set _mode ( this . graphical _mode ) ) ; ( b ^ a ) & 64 && this . complete _replot ( ) ; this . update _vga _size ( ) ; this . complete _redraw ( ) ; this . set _font _bitmap ( ! 1 ) } break ; case 18 : B ( a ) ; this . color _plane _enable !== a && ( this . color _plane _enable = a , this . complete _redraw ( ) ) ; break ; case 19 : B ( a ) ; this . horizontal _panning !== a && ( this . horizontal _panning = a & 15 , this . update _layers ( ) ) ; break ; case 20 : B ( a ) ; this . color _select !==
a && ( this . color _select = a , this . complete _redraw ( ) ) ; break ; default : B ( this . attribute _controller _index ) , B ( a ) } this . attribute _controller _index = - 1 } } ; N . prototype . port3C0 _read = function ( ) { return ( this . attribute _controller _index | this . palette _source ) & 255 } ; N . prototype . port3C0 _read16 = function ( ) { return this . port3C0 _read ( ) | this . port3C1 _read ( ) << 8 & 65280 } ;
N . prototype . port3C1 _read = function ( ) { if ( 16 > this . attribute _controller _index ) return B ( this . attribute _controller _index ) , B ( this . dac _map [ this . attribute _controller _index ] ) , this . dac _map [ this . attribute _controller _index ] & 255 ; switch ( this . attribute _controller _index ) { case 16 : return B ( this . attribute _mode ) , this . attribute _mode ; case 18 : return B ( this . color _plane _enable ) , this . color _plane _enable ; case 19 : return B ( this . horizontal _panning ) , this . horizontal _panning ; case 20 : return B ( this . color _select ) , this . color _select ; default : B ( this . attribute _controller _index ) } return 255 } ;
N . prototype . port3C2 _write = function ( a ) { B ( a ) ; this . miscellaneous _output _register = a } ; N . prototype . port3C4 _write = function ( a ) { this . sequencer _index = a } ; N . prototype . port3C4 _read = function ( ) { return this . sequencer _index } ;
N . prototype . port3C5 _write = function ( a ) { switch ( this . sequencer _index ) { case 1 : B ( a ) ; var b = this . clocking _mode ; this . clocking _mode = a ; ( b ^ a ) & 32 && this . update _layers ( ) ; this . set _font _bitmap ( ! 1 ) ; break ; case 2 : B ( a ) ; b = this . plane _write _bm ; this . plane _write _bm = a ; this . graphical _mode || ! ( b & 4 ) || this . plane _write _bm & 4 || this . set _font _bitmap ( ! 0 ) ; break ; case 3 : B ( a ) ; b = this . character _map _select ; this . character _map _select = a ; this . graphical _mode || b === a || this . set _font _page ( ) ; break ; case 4 : B ( a ) ; this . sequencer _memory _mode = a ; break ; default : B ( this . sequencer _index ) ,
B ( a ) } } ; N . prototype . port3C5 _read = function ( ) { B ( this . sequencer _index ) ; switch ( this . sequencer _index ) { case 1 : return this . clocking _mode ; case 2 : return this . plane _write _bm ; case 3 : return this . character _map _select ; case 4 : return this . sequencer _memory _mode ; case 6 : return 18 } return 0 } ; N . prototype . port3C6 _write = function ( a ) { this . dac _mask !== a && ( this . dac _mask = a , this . complete _redraw ( ) ) } ; N . prototype . port3C6 _read = function ( ) { return this . dac _mask } ;
N . prototype . port3C7 _write = function ( a ) { B ( a ) ; this . dac _color _index _read = 3 * a ; this . dac _state &= 0 } ; N . prototype . port3C7 _read = function ( ) { return this . dac _state } ; N . prototype . port3C8 _write = function ( a ) { this . dac _color _index _write = 3 * a ; this . dac _state |= 3 } ; N . prototype . port3C8 _read = function ( ) { return this . dac _color _index _write / 3 & 255 } ;
N . prototype . port3C9 _write = function ( a ) { var b = this . dac _color _index _write / 3 | 0 , c = this . dac _color _index _write % 3 , d = this . vga256 _palette [ b ] ; if ( 0 === ( this . dispi _enable _value & 32 ) ) { a &= 63 ; const e = a & 1 ; a = a << 2 | e << 1 | e } 0 === c ? d = d & - 16711681 | a << 16 : 1 === c ? d = d & - 65281 | a << 8 : ( d = d & - 256 | a , B ( b ) , B ( d ) ) ; this . vga256 _palette [ b ] !== d && ( this . vga256 _palette [ b ] = d , this . complete _redraw ( ) ) ; this . dac _color _index _write ++ } ;
2024-10-02 21:03:04 +02:00
N . prototype . port3C9 _read = function ( ) { var a = this . vga256 _palette [ this . dac _color _index _read / 3 | 0 ] >> 8 * ( 2 - this . dac _color _index _read % 3 ) & 255 ; this . dac _color _index _read ++ ; return this . dispi _enable _value & 32 ? a : a >> 2 } ; N . prototype . port3CC _read = function ( ) { return this . miscellaneous _output _register } ; N . prototype . port3CE _write = function ( a ) { this . graphics _index = a } ; N . prototype . port3CE _read = function ( ) { return this . graphics _index } ;
2025-01-03 12:44:26 +01:00
N . prototype . port3CF _write = function ( a ) { switch ( this . graphics _index ) { case 0 : this . planar _setreset = a ; B ( a ) ; break ; case 1 : this . planar _setreset _enable = a ; B ( a ) ; break ; case 2 : this . color _compare = a ; B ( a ) ; break ; case 3 : this . planar _rotate _reg = a ; B ( a ) ; break ; case 4 : this . plane _read = a ; B ( a ) ; break ; case 5 : var b = this . planar _mode ; this . planar _mode = a ; B ( a ) ; ( b ^ a ) & 96 && this . complete _replot ( ) ; break ; case 6 : B ( a ) ; this . miscellaneous _graphics _register !== a && ( this . miscellaneous _graphics _register = a , this . update _vga _size ( ) ) ; break ; case 7 : this . color _dont _care =
a ; B ( a ) ; break ; case 8 : this . planar _bitmap = a ; B ( a ) ; break ; default : B ( this . graphics _index ) , B ( a ) } } ; N . prototype . port3CF _read = function ( ) { B ( this . graphics _index ) ; switch ( this . graphics _index ) { case 0 : return this . planar _setreset ; case 1 : return this . planar _setreset _enable ; case 2 : return this . color _compare ; case 3 : return this . planar _rotate _reg ; case 4 : return this . plane _read ; case 5 : return this . planar _mode ; case 6 : return this . miscellaneous _graphics _register ; case 7 : return this . color _dont _care ; case 8 : return this . planar _bitmap } return 0 } ;
2024-10-02 21:03:04 +02:00
N . prototype . port3D4 _write = function ( a ) { this . index _crtc = a } ; N . prototype . port3D4 _write16 = function ( a ) { this . port3D4 _write ( a & 255 ) ; this . port3D5 _write ( a >> 8 & 255 ) } ; N . prototype . port3D4 _read = function ( ) { return this . index _crtc } ;
2025-01-03 12:44:26 +01:00
N . prototype . port3D5 _write = function ( a ) { switch ( this . index _crtc ) { case 1 : B ( a ) ; this . horizontal _display _enable _end !== a && ( this . horizontal _display _enable _end = a , this . update _vga _size ( ) ) ; break ; case 2 : this . horizontal _blank _start !== a && ( this . horizontal _blank _start = a , this . update _vga _size ( ) ) ; break ; case 7 : B ( a ) ; var b = this . vertical _display _enable _end ; this . vertical _display _enable _end &= 255 ; this . vertical _display _enable _end = this . vertical _display _enable _end | a << 3 & 512 | a << 7 & 256 ; b !== this . vertical _display _enable _end && this . update _vga _size ( ) ;
this . line _compare = this . line _compare & 767 | a << 4 & 256 ; b = this . vertical _blank _start ; this . vertical _blank _start = this . vertical _blank _start & 767 | a << 5 & 256 ; b !== this . vertical _blank _start && this . update _vga _size ( ) ; this . update _layers ( ) ; break ; case 8 : B ( a ) ; this . preset _row _scan = a ; this . update _layers ( ) ; break ; case 9 : B ( a ) ; var c = this . max _scan _line ; this . max _scan _line = a ; this . line _compare = this . line _compare & 511 | a << 3 & 512 ; b = this . vertical _blank _start ; this . vertical _blank _start = this . vertical _blank _start & 511 | a << 4 & 512 ; ( ( c ^ this . max _scan _line ) &
159 || b !== this . vertical _blank _start ) && this . update _vga _size ( ) ; this . update _cursor _scanline ( ) ; this . update _layers ( ) ; this . set _font _bitmap ( ! 1 ) ; break ; case 10 : B ( a ) ; this . cursor _scanline _start = a ; this . update _cursor _scanline ( ) ; break ; case 11 : B ( a ) ; this . cursor _scanline _end = a ; this . update _cursor _scanline ( ) ; break ; case 12 : ( this . start _address >> 8 & 255 ) !== a && ( this . start _address = this . start _address & 255 | a << 8 , this . update _layers ( ) , ~ this . crtc _mode & 3 && this . complete _replot ( ) ) ; B ( a ) ; B ( this . start _address , 4 ) ; break ; case 13 : ( this . start _address &
255 ) !== a && ( this . start _address = this . start _address & 65280 | a , this . update _layers ( ) , ~ this . crtc _mode & 3 && this . complete _replot ( ) ) ; B ( a ) ; B ( this . start _address , 4 ) ; break ; case 14 : B ( a ) ; this . cursor _address = this . cursor _address & 255 | a << 8 ; this . update _cursor ( ) ; break ; case 15 : B ( a ) ; this . cursor _address = this . cursor _address & 65280 | a ; this . update _cursor ( ) ; break ; case 18 : B ( a ) ; ( this . vertical _display _enable _end & 255 ) !== a && ( this . vertical _display _enable _end = this . vertical _display _enable _end & 768 | a , this . update _vga _size ( ) ) ; break ; case 19 : B ( a ) ;
this . offset _register !== a && ( this . offset _register = a , this . update _vga _size ( ) , ~ this . crtc _mode & 3 && this . complete _replot ( ) ) ; break ; case 20 : B ( a ) ; this . underline _location _register !== a && ( b = this . underline _location _register , this . underline _location _register = a , this . update _vga _size ( ) , ( b ^ a ) & 64 && this . complete _replot ( ) ) ; break ; case 21 : B ( a ) ; ( this . vertical _blank _start & 255 ) !== a && ( this . vertical _blank _start = this . vertical _blank _start & 768 | a , this . update _vga _size ( ) ) ; break ; case 23 : B ( a ) ; this . crtc _mode !== a && ( b = this . crtc _mode , this . crtc _mode =
a , this . update _vga _size ( ) , ( b ^ a ) & 67 && this . complete _replot ( ) ) ; break ; case 24 : B ( a ) ; this . line _compare = this . line _compare & 768 | a ; this . update _layers ( ) ; break ; default : this . index _crtc < this . crtc . length && ( this . crtc [ this . index _crtc ] = a ) , B ( this . index _crtc ) , B ( a ) } } ; N . prototype . port3D5 _write16 = function ( a ) { B ( a , 4 ) ; this . port3D5 _write ( a & 255 ) } ;
N . prototype . port3D5 _read = function ( ) { B ( this . index _crtc ) ; switch ( this . index _crtc ) { case 1 : return this . horizontal _display _enable _end ; case 2 : return this . horizontal _blank _start ; case 7 : return this . vertical _display _enable _end >> 7 & 2 | this . vertical _blank _start >> 5 & 8 | this . line _compare >> 4 & 16 | this . vertical _display _enable _end >> 3 & 64 ; case 8 : return this . preset _row _scan ; case 9 : return this . max _scan _line ; case 10 : return this . cursor _scanline _start ; case 11 : return this . cursor _scanline _end ; case 12 : return this . start _address & 255 ;
2024-10-02 21:03:04 +02:00
case 13 : return this . start _address >> 8 ; case 14 : return this . cursor _address >> 8 ; case 15 : return this . cursor _address & 255 ; case 18 : return this . vertical _display _enable _end & 255 ; case 19 : return this . offset _register ; case 20 : return this . underline _location _register ; case 21 : return this . vertical _blank _start & 255 ; case 23 : return this . crtc _mode ; case 24 : return this . line _compare & 255 } return this . index _crtc < this . crtc . length ? this . crtc [ this . index _crtc ] : 0 } ; N . prototype . port3D5 _read16 = function ( ) { return this . port3D5 _read ( ) } ;
N . prototype . port3DA _read = function ( ) { var a = this . port _3DA _value ; this . graphical _mode ? ( this . port _3DA _value ^= 1 , this . port _3DA _value &= 1 ) : ( this . port _3DA _value & 1 && ( this . port _3DA _value ^= 8 ) , this . port _3DA _value ^= 1 ) ; this . attribute _controller _index = - 1 ; return a } ; N . prototype . port1CE _write = function ( a ) { this . dispi _index = a } ;
2025-01-03 12:44:26 +01:00
N . prototype . port1CF _write = function ( a ) { B ( this . dispi _index ) ; B ( a ) ; const b = this . svga _enabled ; switch ( this . dispi _index ) { case 0 : 45248 <= a && 45253 >= a ? this . svga _version = a : B ( a ) ; break ; case 1 : this . svga _width = a ; 2560 < this . svga _width && ( this . svga _width = 2560 ) ; break ; case 2 : this . svga _height = a ; 1600 < this . svga _height && ( this . svga _height = 1600 ) ; break ; case 3 : this . svga _bpp = a ; break ; case 4 : ( this . svga _enabled = 1 === ( a & 1 ) ) && 0 === ( a & 128 ) && this . svga _memory . fill ( 0 ) ; this . dispi _enable _value = a ; break ; case 5 : B ( a << 16 ) ; this . svga _bank _offset =
a << 16 ; break ; case 8 : B ( a ) ; this . svga _offset _x !== a && ( this . svga _offset _x = a , this . svga _offset = this . svga _offset _y * this . svga _width + this . svga _offset _x , this . complete _redraw ( ) ) ; break ; case 9 : B ( a * this . svga _width ) ; B ( a ) ; this . svga _offset _y !== a && ( this . svga _offset _y = a , this . svga _offset = this . svga _offset _y * this . svga _width + this . svga _offset _x , this . complete _redraw ( ) ) ; break ; default : B ( this . dispi _index ) } ! this . svga _enabled || this . svga _width && this . svga _height || ( this . svga _enabled = ! 1 ) ; this . svga _enabled && ! b && ( this . svga _offset _y = this . svga _offset _x =
this . svga _offset = 0 , this . graphical _mode = ! 0 , this . screen . set _mode ( this . graphical _mode ) , this . set _size _graphical ( this . svga _width , this . svga _height , this . svga _width , this . svga _height , this . svga _bpp ) ) ; this . svga _enabled || ( this . svga _bank _offset = 0 ) ; this . update _layers ( ) } ; N . prototype . port1CF _read = function ( ) { B ( this . dispi _index ) ; return this . svga _register _read ( this . dispi _index ) } ;
2024-10-02 21:03:04 +02:00
N . prototype . svga _register _read = function ( a ) { switch ( a ) { case 0 : return this . svga _version ; case 1 : return this . dispi _enable _value & 2 ? 2560 : this . svga _width ; case 2 : return this . dispi _enable _value & 2 ? 1600 : this . svga _height ; case 3 : return this . dispi _enable _value & 2 ? 32 : this . svga _bpp ; case 4 : return this . dispi _enable _value ; case 5 : return this . svga _bank _offset >>> 16 ; case 6 : return this . screen _width ? this . screen _width : 1 ; case 8 : return this . svga _offset _x ; case 9 : return this . svga _offset _y ; case 10 : return this . vga _memory _size / 65536 |
2025-01-03 12:44:26 +01:00
0 ; default : B ( this . dispi _index ) } return 255 } ;
N . prototype . vga _replot = function ( ) { for ( var a = this . diff _plot _min & - 16 , b = Math . min ( this . diff _plot _max | 15 , 524287 ) , c = this . vga _addr _shift _count ( ) , d = ~ this . crtc _mode & 3 , e = this . planar _mode & 96 , g = this . attribute _mode & 64 ; a <= b ; ) { var f = a >>> c ; if ( d ) { var k = a / this . virtual _width | 0 , l = a - this . virtual _width * k ; switch ( d ) { case 1 : f = ( k & 1 ) << 13 ; k >>>= 1 ; break ; case 2 : f = ( k & 1 ) << 14 ; k >>>= 1 ; break ; case 3 : f = ( k & 3 ) << 13 , k >>>= 2 } f |= ( k * this . virtual _width + l >>> c ) + this . start _address } k = this . plane0 [ f ] ; l = this . plane1 [ f ] ; var m = this . plane2 [ f ] , n = this . plane3 [ f ] ;
f = new Uint8Array ( 8 ) ; switch ( e ) { case 0 : k <<= 0 ; l <<= 1 ; m <<= 2 ; n <<= 3 ; for ( var p = 7 ; 0 <= p ; p -- ) f [ 7 - p ] = k >> p & 1 | l >> p & 2 | m >> p & 4 | n >> p & 8 ; break ; case 32 : f [ 0 ] = k >> 6 & 3 | m >> 4 & 12 ; f [ 1 ] = k >> 4 & 3 | m >> 2 & 12 ; f [ 2 ] = k >> 2 & 3 | m >> 0 & 12 ; f [ 3 ] = k >> 0 & 3 | m << 2 & 12 ; f [ 4 ] = l >> 6 & 3 | n >> 4 & 12 ; f [ 5 ] = l >> 4 & 3 | n >> 2 & 12 ; f [ 6 ] = l >> 2 & 3 | n >> 0 & 12 ; f [ 7 ] = l >> 0 & 3 | n << 2 & 12 ; break ; case 64 : case 96 : f [ 0 ] = k >> 4 & 15 , f [ 1 ] = k >> 0 & 15 , f [ 2 ] = l >> 4 & 15 , f [ 3 ] = l >> 0 & 15 , f [ 4 ] = m >> 4 & 15 , f [ 5 ] = m >> 0 & 15 , f [ 6 ] = n >> 4 & 15 , f [ 7 ] = n >> 0 & 15 } if ( g ) for ( k = p = 0 ; 4 > p ; p ++ , a ++ , k += 2 ) this . pixel _buffer [ a ] = f [ k ] << 4 | f [ k + 1 ] ; else for ( p = 0 ; 8 > p ; p ++ ,
2024-11-28 07:25:05 +01:00
a ++ ) this . pixel _buffer [ a ] = f [ p ] } } ;
N . prototype . vga _redraw = function ( ) { var a = this . diff _addr _min , b = Math . min ( this . diff _addr _max , 524287 ) ; const c = new Int32Array ( this . cpu . wasm _memory . buffer , this . dest _buffet _offset , this . virtual _width * this . virtual _height ) ; var d = 255 , e = 0 ; this . attribute _mode & 128 && ( d &= 207 , e |= this . color _select << 4 & 48 ) ; if ( this . attribute _mode & 64 ) for ( ; a <= b ; a ++ ) { var g = this . pixel _buffer [ a ] & d | e ; g = this . vga256 _palette [ g ] ; c [ a ] = g & 65280 | g << 16 | g >> 16 | 4278190080 } else for ( d &= 63 , e |= this . color _select << 4 & 192 ; a <= b ; a ++ ) g = this . dac _map [ this . pixel _buffer [ a ] &
this . color _plane _enable ] & d | e , g = this . vga256 _palette [ g ] , c [ a ] = g & 65280 | g << 16 | g >> 16 | 4278190080 } ;
2024-10-02 21:03:04 +02:00
N . prototype . screen _fill _buffer = function ( ) { if ( this . graphical _mode ) { if ( 0 === this . image _data . data . byteLength ) { var a = new Uint8ClampedArray ( this . cpu . wasm _memory . buffer , this . dest _buffet _offset , 4 * this . virtual _width * this . virtual _height ) ; this . image _data = new ImageData ( a , this . virtual _width , this . virtual _height ) ; this . update _layers ( ) } if ( this . svga _enabled ) { a = 0 ; let d = this . svga _height ; if ( 8 === this . svga _bpp ) { const e = new Int32Array ( this . cpu . wasm _memory . buffer , this . dest _buffet _offset , this . screen _width * this . screen _height ) ,
2024-11-28 07:25:05 +01:00
g = new Uint8Array ( this . cpu . wasm _memory . buffer , this . svga _memory . byteOffset , this . vga _memory _size ) ; for ( var b = 0 ; b < e . length ; b ++ ) { var c = this . vga256 _palette [ g [ b ] ] ; e [ b ] = c & 65280 | c << 16 | c >> 16 | 4278190080 } } else this . cpu . svga _fill _pixel _buffer ( this . svga _bpp , this . svga _offset ) , b = 15 === this . svga _bpp ? 2 : this . svga _bpp / 8 , a = ( ( this . cpu . svga _dirty _bitmap _min _offset [ 0 ] / b | 0 ) - this . svga _offset ) / this . svga _width | 0 , d = ( ( ( this . cpu . svga _dirty _bitmap _max _offset [ 0 ] / b | 0 ) - this . svga _offset ) / this . svga _width | 0 ) + 1 ; a < d && ( a = Math . max ( a , 0 ) , d = Math . min ( d ,
this . svga _height ) , this . screen . update _buffer ( [ { image _data : this . image _data , screen _x : 0 , screen _y : a , buffer _x : 0 , buffer _y : a , buffer _width : this . svga _width , buffer _height : d - a } ] ) ) } else this . vga _replot ( ) , this . vga _redraw ( ) , this . screen . update _buffer ( this . layers ) ; this . reset _diffs ( ) } this . update _vertical _retrace ( ) } ;
N . prototype . set _font _bitmap = function ( a ) { const b = this . max _scan _line & 31 ; if ( b && ! this . graphical _mode ) { const c = ! ! ( this . clocking _mode & 8 ) ; this . screen . set _font _bitmap ( b + 1 , ! c && ! ( this . clocking _mode & 1 ) , c , ! ! ( this . attribute _mode & 4 ) , this . plane2 , a ) } } ;
2025-01-03 12:44:26 +01:00
N . prototype . set _font _page = function ( ) { const a = [ 0 , 2 , 4 , 6 , 1 , 3 , 5 , 7 ] , b = ( this . character _map _select & 12 ) >> 2 | ( this . character _map _select & 32 ) >> 3 , c = this . character _map _select & 3 | ( this . character _map _select & 16 ) >> 2 ; this . font _page _ab _enabled = b !== c ; this . screen . set _font _page ( a [ b ] , a [ c ] ) ; this . complete _redraw ( ) } ; function za ( a , b ) { this . cpu = a ; this . bus = b ; this . use _mouse = this . enable _mouse _stream = ! 1 ; this . have _mouse = ! 0 ; this . mouse _clicks = this . mouse _delta _y = this . mouse _delta _x = 0 ; this . have _keyboard = ! 0 ; this . next _read _resolution = this . next _read _rate = this . next _handle _scan _code _set = this . next _read _led = this . next _read _sample = this . next _is _mouse _command = this . enable _keyboard _stream = ! 1 ; this . kbd _buffer = new na ( 1024 ) ; this . last _port60 _byte = 0 ; this . sample _rate = 100 ; this . mouse _id = this . mouse _detect _state = 0 ; this . mouse _reset _workaround = ! 1 ;
2024-11-28 07:25:05 +01:00
this . wheel _movement = 0 ; this . resolution = 4 ; this . scaling2 = ! 1 ; this . last _mouse _packet = - 1 ; this . mouse _buffer = new na ( 1024 ) ; this . next _byte _is _aux = this . next _byte _is _ready = ! 1 ; this . bus . register ( "keyboard-code" , function ( c ) { this . kbd _send _code ( c ) } , this ) ; this . bus . register ( "mouse-click" , function ( c ) { this . mouse _send _click ( c [ 0 ] , c [ 1 ] , c [ 2 ] ) } , this ) ; this . bus . register ( "mouse-delta" , function ( c ) { this . mouse _send _delta ( c [ 0 ] , c [ 1 ] ) } , this ) ; this . bus . register ( "mouse-wheel" , function ( c ) { this . wheel _movement -= c [ 0 ] ; this . wheel _movement -=
2024-06-28 09:23:02 +02:00
2 * c [ 1 ] ; this . wheel _movement = Math . min ( 7 , Math . max ( - 8 , this . wheel _movement ) ) ; this . send _mouse _packet ( 0 , 0 ) } , this ) ; this . command _register = 5 ; this . controller _output _port = 0 ; this . read _controller _output _port = this . read _command _register = this . read _output _register = ! 1 ; a . io . register _read ( 96 , this , this . port60 _read ) ; a . io . register _read ( 100 , this , this . port64 _read ) ; a . io . register _write ( 96 , this , this . port60 _write ) ; a . io . register _write ( 100 , this , this . port64 _write ) }
2025-01-03 12:44:26 +01:00
za . prototype . get _state = function ( ) { var a = [ ] ; a [ 0 ] = this . enable _mouse _stream ; a [ 1 ] = this . use _mouse ; a [ 2 ] = this . have _mouse ; a [ 3 ] = this . mouse _delta _x ; a [ 4 ] = this . mouse _delta _y ; a [ 5 ] = this . mouse _clicks ; a [ 6 ] = this . have _keyboard ; a [ 7 ] = this . enable _keyboard _stream ; a [ 8 ] = this . next _is _mouse _command ; a [ 9 ] = this . next _read _sample ; a [ 10 ] = this . next _read _led ; a [ 11 ] = this . next _handle _scan _code _set ; a [ 12 ] = this . next _read _rate ; a [ 13 ] = this . next _read _resolution ; a [ 15 ] = this . last _port60 _byte ; a [ 16 ] = this . sample _rate ; a [ 17 ] = this . resolution ; a [ 18 ] = this . scaling2 ;
2024-06-28 09:23:02 +02:00
a [ 20 ] = this . command _register ; a [ 21 ] = this . read _output _register ; a [ 22 ] = this . read _command _register ; a [ 23 ] = this . controller _output _port ; a [ 24 ] = this . read _controller _output _port ; a [ 25 ] = this . mouse _id ; a [ 26 ] = this . mouse _detect _state ; a [ 27 ] = this . mouse _reset _workaround ; return a } ;
2025-01-03 12:44:26 +01:00
za . prototype . set _state = function ( a ) { this . enable _mouse _stream = a [ 0 ] ; this . use _mouse = a [ 1 ] ; this . have _mouse = a [ 2 ] ; this . mouse _delta _x = a [ 3 ] ; this . mouse _delta _y = a [ 4 ] ; this . mouse _clicks = a [ 5 ] ; this . have _keyboard = a [ 6 ] ; this . enable _keyboard _stream = a [ 7 ] ; this . next _is _mouse _command = a [ 8 ] ; this . next _read _sample = a [ 9 ] ; this . next _read _led = a [ 10 ] ; this . next _handle _scan _code _set = a [ 11 ] ; this . next _read _rate = a [ 12 ] ; this . next _read _resolution = a [ 13 ] ; this . last _port60 _byte = a [ 15 ] ; this . sample _rate = a [ 16 ] ; this . resolution = a [ 17 ] ; this . scaling2 = a [ 18 ] ;
2024-06-28 09:23:02 +02:00
this . command _register = a [ 20 ] ; this . read _output _register = a [ 21 ] ; this . read _command _register = a [ 22 ] ; this . controller _output _port = a [ 23 ] ; this . read _controller _output _port = a [ 24 ] ; this . mouse _id = a [ 25 ] || 0 ; this . mouse _detect _state = a [ 26 ] || 0 ; this . mouse _reset _workaround = a [ 27 ] || ! 1 ; this . next _byte _is _aux = this . next _byte _is _ready = ! 1 ; this . kbd _buffer . clear ( ) ; this . mouse _buffer . clear ( ) ; this . bus . send ( "mouse-enable" , this . use _mouse ) } ;
2025-01-03 12:44:26 +01:00
za . prototype . raise _irq = function ( ) { this . next _byte _is _ready || ( this . kbd _buffer . length ? this . kbd _irq ( ) : this . mouse _buffer . length && this . mouse _irq ( ) ) } ; za . prototype . mouse _irq = function ( ) { this . next _byte _is _aux = this . next _byte _is _ready = ! 0 ; this . command _register & 2 && ( this . cpu . device _lower _irq ( 12 ) , this . cpu . device _raise _irq ( 12 ) ) } ; za . prototype . kbd _irq = function ( ) { this . next _byte _is _ready = ! 0 ; this . next _byte _is _aux = ! 1 ; this . command _register & 1 && ( this . cpu . device _lower _irq ( 1 ) , this . cpu . device _raise _irq ( 1 ) ) } ;
za . prototype . kbd _send _code = function ( a ) { this . enable _keyboard _stream && ( B ( a ) , this . kbd _buffer . push ( a ) , this . raise _irq ( ) ) } ; za . prototype . mouse _send _delta = function ( a , b ) { if ( this . have _mouse && this . use _mouse ) { var c = this . resolution * this . sample _rate / 80 ; this . mouse _delta _x += a * c ; this . mouse _delta _y += b * c ; this . enable _mouse _stream && ( a = this . mouse _delta _x | 0 , b = this . mouse _delta _y | 0 , a || b ) && ( Date . now ( ) , this . mouse _delta _x -= a , this . mouse _delta _y -= b , this . send _mouse _packet ( a , b ) ) } } ;
za . prototype . mouse _send _click = function ( a , b , c ) { this . have _mouse && this . use _mouse && ( this . mouse _clicks = a | c << 1 | b << 2 , this . enable _mouse _stream && this . send _mouse _packet ( 0 , 0 ) ) } ;
za . prototype . send _mouse _packet = function ( a , b ) { var c = ( 0 > b ) << 5 | ( 0 > a ) << 4 | 8 | this . mouse _clicks ; this . last _mouse _packet = Date . now ( ) ; this . mouse _buffer . push ( c ) ; this . mouse _buffer . push ( a ) ; this . mouse _buffer . push ( b ) ; 4 === this . mouse _id ? ( this . mouse _buffer . push ( 0 | this . wheel _movement & 15 ) , this . wheel _movement = 0 ) : 3 === this . mouse _id && ( this . mouse _buffer . push ( this . wheel _movement & 255 ) , this . wheel _movement = 0 ) ; this . raise _irq ( ) } ;
za . prototype . apply _scaling2 = function ( a ) { var b = a >> 31 ; switch ( Math . abs ( a ) ) { case 0 : case 1 : case 3 : return a ; case 2 : return b ; case 4 : return 6 * b ; case 5 : return 9 * b ; default : return a << 1 } } ;
za . prototype . port60 _read = function ( ) { this . next _byte _is _ready = ! 1 ; if ( ! this . kbd _buffer . length && ! this . mouse _buffer . length ) return this . last _port60 _byte ; this . next _byte _is _aux ? ( this . cpu . device _lower _irq ( 12 ) , this . last _port60 _byte = this . mouse _buffer . shift ( ) ) : ( this . cpu . device _lower _irq ( 1 ) , this . last _port60 _byte = this . kbd _buffer . shift ( ) ) ; B ( this . last _port60 _byte ) ; ( this . kbd _buffer . length || this . mouse _buffer . length ) && this . raise _irq ( ) ; return this . last _port60 _byte } ;
za . prototype . port64 _read = function ( ) { var a = 16 ; this . next _byte _is _ready && ( a |= 1 ) ; this . next _byte _is _aux && ( a |= 32 ) ; B ( a ) ; return a } ;
za . prototype . port60 _write = function ( a ) { B ( a ) ; if ( this . read _command _register ) this . command _register = a , this . read _command _register = ! 1 , B ( this . command _register ) ; else if ( this . read _output _register ) this . read _output _register = ! 1 , this . mouse _buffer . clear ( ) , this . mouse _buffer . push ( a ) , this . mouse _irq ( ) ; else if ( this . next _read _sample ) { this . next _read _sample = ! 1 ; this . mouse _buffer . clear ( ) ; this . mouse _buffer . push ( 250 ) ; this . sample _rate = a ; switch ( this . mouse _detect _state ) { case - 1 : 60 === a ? ( this . mouse _reset _workaround = ! 0 , this . mouse _detect _state =
0 ) : ( this . mouse _reset _workaround = ! 1 , this . mouse _detect _state = 200 === a ? 1 : 0 ) ; break ; case 0 : 200 === a && ( this . mouse _detect _state = 1 ) ; break ; case 1 : this . mouse _detect _state = 100 === a ? 2 : 200 === a ? 3 : 0 ; break ; case 2 : 80 === a && ( this . mouse _id = 3 ) ; this . mouse _detect _state = - 1 ; break ; case 3 : 80 === a && ( this . mouse _id = 4 ) , this . mouse _detect _state = - 1 } B ( a ) ; B ( this . mouse _id ) ; this . sample _rate || ( this . sample _rate = 100 ) ; this . mouse _irq ( ) } else if ( this . next _read _resolution ) this . next _read _resolution = ! 1 , this . mouse _buffer . clear ( ) , this . mouse _buffer . push ( 250 ) ,
this . resolution = 3 < a ? 4 : 1 << a , this . mouse _irq ( ) ; else if ( this . next _read _led ) this . next _read _led = ! 1 , this . kbd _buffer . push ( 250 ) , this . kbd _irq ( ) ; else if ( this . next _handle _scan _code _set ) this . next _handle _scan _code _set = ! 1 , this . kbd _buffer . push ( 250 ) , this . kbd _irq ( ) , a || this . kbd _buffer . push ( 1 ) ; else if ( this . next _read _rate ) this . next _read _rate = ! 1 , this . kbd _buffer . push ( 250 ) , this . kbd _irq ( ) ; else if ( this . next _is _mouse _command ) { if ( this . next _is _mouse _command = ! 1 , B ( a ) , this . have _mouse ) { this . kbd _buffer . clear ( ) ; this . mouse _buffer . clear ( ) ;
this . mouse _buffer . push ( 250 ) ; switch ( a ) { case 230 : this . scaling2 = ! 1 ; break ; case 231 : this . scaling2 = ! 0 ; break ; case 232 : this . next _read _resolution = ! 0 ; break ; case 233 : this . send _mouse _packet ( 0 , 0 ) ; break ; case 235 : this . send _mouse _packet ( 0 , 0 ) ; break ; case 242 : B ( this . mouse _id ) ; this . mouse _buffer . push ( this . mouse _id ) ; this . mouse _clicks = this . mouse _delta _x = this . mouse _delta _y = 0 ; this . raise _irq ( ) ; break ; case 243 : this . next _read _sample = ! 0 ; break ; case 244 : this . use _mouse = this . enable _mouse _stream = ! 0 ; this . bus . send ( "mouse-enable" , ! 0 ) ;
2024-06-28 09:23:02 +02:00
this . mouse _clicks = this . mouse _delta _x = this . mouse _delta _y = 0 ; break ; case 245 : this . enable _mouse _stream = ! 1 ; break ; case 246 : this . enable _mouse _stream = ! 1 ; this . sample _rate = 100 ; this . scaling2 = ! 1 ; this . resolution = 4 ; break ; case 255 : this . mouse _buffer . push ( 170 ) ; this . mouse _buffer . push ( 0 ) ; this . use _mouse = ! 0 ; this . bus . send ( "mouse-enable" , ! 0 ) ; this . enable _mouse _stream = ! 1 ; this . sample _rate = 100 ; this . scaling2 = ! 1 ; this . resolution = 4 ; this . mouse _reset _workaround || ( this . mouse _id = 0 ) ; this . mouse _clicks = this . mouse _delta _x = this . mouse _delta _y =
2025-01-03 12:44:26 +01:00
0 ; break ; default : B ( a ) } this . mouse _irq ( ) } } else if ( this . read _controller _output _port ) this . read _controller _output _port = ! 1 , this . controller _output _port = a ; else { B ( a ) ; this . mouse _buffer . clear ( ) ; this . kbd _buffer . clear ( ) ; this . kbd _buffer . push ( 250 ) ; switch ( a ) { case 237 : this . next _read _led = ! 0 ; break ; case 240 : this . next _handle _scan _code _set = ! 0 ; break ; case 242 : this . kbd _buffer . push ( 171 ) ; this . kbd _buffer . push ( 131 ) ; break ; case 243 : this . next _read _rate = ! 0 ; break ; case 244 : this . enable _keyboard _stream = ! 0 ; break ; case 245 : this . enable _keyboard _stream =
! 1 ; break ; case 246 : break ; case 255 : this . kbd _buffer . clear ( ) ; this . kbd _buffer . push ( 250 ) ; this . kbd _buffer . push ( 170 ) ; this . kbd _buffer . push ( 0 ) ; break ; default : B ( a ) } this . kbd _irq ( ) } } ;
za . prototype . port64 _write = function ( a ) { B ( a ) ; switch ( a ) { case 32 : this . kbd _buffer . clear ( ) ; this . mouse _buffer . clear ( ) ; this . kbd _buffer . push ( this . command _register ) ; this . kbd _irq ( ) ; break ; case 96 : this . read _command _register = ! 0 ; break ; case 209 : this . read _controller _output _port = ! 0 ; break ; case 211 : this . read _output _register = ! 0 ; break ; case 212 : this . next _is _mouse _command = ! 0 ; break ; case 167 : this . command _register |= 32 ; break ; case 168 : this . command _register &= - 33 ; break ; case 169 : this . kbd _buffer . clear ( ) ; this . mouse _buffer . clear ( ) ;
this . kbd _buffer . push ( 0 ) ; this . kbd _irq ( ) ; break ; case 170 : this . kbd _buffer . clear ( ) ; this . mouse _buffer . clear ( ) ; this . kbd _buffer . push ( 85 ) ; this . kbd _irq ( ) ; break ; case 171 : this . kbd _buffer . clear ( ) ; this . mouse _buffer . clear ( ) ; this . kbd _buffer . push ( 0 ) ; this . kbd _irq ( ) ; break ; case 173 : this . command _register |= 16 ; break ; case 174 : this . command _register &= - 17 ; break ; case 254 : this . cpu . reboot _internal ( ) ; break ; default : B ( a ) } } ; function Ca ( a ) { this . cpu = a ; this . cmos _index = 0 ; this . cmos _data = new Uint8Array ( 128 ) ; this . last _update = this . rtc _time = Date . now ( ) ; this . next _interrupt _alarm = this . next _interrupt = 0 ; this . periodic _interrupt = ! 1 ; this . periodic _interrupt _time = . 9765625 ; this . cmos _a = 38 ; this . cmos _b = 2 ; this . nmi _disabled = this . cmos _c = 0 ; a . io . register _write ( 112 , this , function ( b ) { this . cmos _index = b & 127 ; this . nmi _disabled = b >> 7 } ) ; a . io . register _write ( 113 , this , this . cmos _port _write ) ; a . io . register _read ( 113 , this , this . cmos _port _read ) }
2024-11-28 07:25:05 +01:00
Ca . prototype . get _state = function ( ) { var a = [ ] ; a [ 0 ] = this . cmos _index ; a [ 1 ] = this . cmos _data ; a [ 2 ] = this . rtc _time ; a [ 3 ] = this . last _update ; a [ 4 ] = this . next _interrupt ; a [ 5 ] = this . next _interrupt _alarm ; a [ 6 ] = this . periodic _interrupt ; a [ 7 ] = this . periodic _interrupt _time ; a [ 8 ] = this . cmos _a ; a [ 9 ] = this . cmos _b ; a [ 10 ] = this . cmos _c ; a [ 11 ] = this . nmi _disabled ; return a } ;
Ca . prototype . set _state = function ( a ) { this . cmos _index = a [ 0 ] ; this . cmos _data = a [ 1 ] ; this . rtc _time = a [ 2 ] ; this . last _update = a [ 3 ] ; this . next _interrupt = a [ 4 ] ; this . next _interrupt _alarm = a [ 5 ] ; this . periodic _interrupt = a [ 6 ] ; this . periodic _interrupt _time = a [ 7 ] ; this . cmos _a = a [ 8 ] ; this . cmos _b = a [ 9 ] ; this . cmos _c = a [ 10 ] ; this . nmi _disabled = a [ 11 ] } ;
Ca . prototype . timer = function ( a ) { a = Date . now ( ) ; this . rtc _time += a - this . last _update ; this . last _update = a ; this . periodic _interrupt && this . next _interrupt < a ? ( this . cpu . device _raise _irq ( 8 ) , this . cmos _c |= 192 , this . next _interrupt += this . periodic _interrupt _time * Math . ceil ( ( a - this . next _interrupt ) / this . periodic _interrupt _time ) ) : this . next _interrupt _alarm && this . next _interrupt _alarm < a && ( this . cpu . device _raise _irq ( 8 ) , this . cmos _c |= 160 , this . next _interrupt _alarm = 0 ) ; let b = 100 ; this . periodic _interrupt && this . next _interrupt && ( b = Math . min ( b ,
Math . max ( 0 , this . next _interrupt - a ) ) ) ; this . next _interrupt _alarm && ( b = Math . min ( b , Math . max ( 0 , this . next _interrupt _alarm - a ) ) ) ; return b } ; Ca . prototype . bcd _pack = function ( a ) { for ( var b = 0 , c = 0 , d ; a ; ) d = a % 10 , c |= d << 4 * b , b ++ , a = ( a - d ) / 10 ; return c } ; Ca . prototype . bcd _unpack = function ( a ) { return ( a & 15 ) + 10 * ( a >> 4 & 15 ) } ; Ca . prototype . encode _time = function ( a ) { return this . cmos _b & 4 ? a : this . bcd _pack ( a ) } ; Ca . prototype . decode _time = function ( a ) { return this . cmos _b & 4 ? a : this . bcd _unpack ( a ) } ;
2025-01-03 12:44:26 +01:00
Ca . prototype . cmos _port _read = function ( ) { var a = this . cmos _index ; switch ( a ) { case 0 : return B ( this . encode _time ( ( new Date ( this . rtc _time ) ) . getUTCSeconds ( ) ) ) , this . encode _time ( ( new Date ( this . rtc _time ) ) . getUTCSeconds ( ) ) ; case 2 : return B ( this . encode _time ( ( new Date ( this . rtc _time ) ) . getUTCMinutes ( ) ) ) , this . encode _time ( ( new Date ( this . rtc _time ) ) . getUTCMinutes ( ) ) ; case 4 : return B ( this . encode _time ( ( new Date ( this . rtc _time ) ) . getUTCHours ( ) ) ) , this . encode _time ( ( new Date ( this . rtc _time ) ) . getUTCHours ( ) ) ; case 6 : return B ( this . encode _time ( ( new Date ( this . rtc _time ) ) . getUTCDay ( ) +
1 ) ) , this . encode _time ( ( new Date ( this . rtc _time ) ) . getUTCDay ( ) + 1 ) ; case 7 : return B ( this . encode _time ( ( new Date ( this . rtc _time ) ) . getUTCDate ( ) ) ) , this . encode _time ( ( new Date ( this . rtc _time ) ) . getUTCDate ( ) ) ; case 8 : return B ( this . encode _time ( ( new Date ( this . rtc _time ) ) . getUTCMonth ( ) + 1 ) ) , this . encode _time ( ( new Date ( this . rtc _time ) ) . getUTCMonth ( ) + 1 ) ; case 9 : return B ( this . encode _time ( ( new Date ( this . rtc _time ) ) . getUTCFullYear ( ) % 100 ) ) , this . encode _time ( ( new Date ( this . rtc _time ) ) . getUTCFullYear ( ) % 100 ) ; case 10 : return 999 <= D . microtick ( ) %
1E3 ? this . cmos _a | 128 : this . cmos _a ; case 11 : return this . cmos _b ; case 12 : return this . cpu . device _lower _irq ( 8 ) , a = this . cmos _c , this . cmos _c &= - 241 , a ; case 13 : return 0 ; case 50 : case 55 : return B ( this . encode _time ( ( new Date ( this . rtc _time ) ) . getUTCFullYear ( ) / 100 | 0 ) ) , this . encode _time ( ( new Date ( this . rtc _time ) ) . getUTCFullYear ( ) / 100 | 0 ) ; default : return B ( a ) , this . cmos _data [ this . cmos _index ] } } ;
Ca . prototype . cmos _port _write = function ( a ) { switch ( this . cmos _index ) { case 10 : this . cmos _a = a & 127 ; this . periodic _interrupt _time = 1E3 / ( 32768 >> ( this . cmos _a & 15 ) - 1 ) ; B ( this . cmos _a , 2 ) ; break ; case 11 : this . cmos _b = a ; this . cmos _b & 64 && ( this . next _interrupt = Date . now ( ) ) ; if ( this . cmos _b & 32 ) { a = new Date ; const b = this . decode _time ( this . cmos _data [ 1 ] ) , c = this . decode _time ( this . cmos _data [ 3 ] ) , d = this . decode _time ( this . cmos _data [ 5 ] ) ; this . next _interrupt _alarm = + new Date ( Date . UTC ( a . getUTCFullYear ( ) , a . getUTCMonth ( ) , a . getUTCDate ( ) , d , c , b ) ) } B ( this . cmos _b ,
2 ) ; break ; case 1 : case 3 : case 5 : this . cmos _write ( this . cmos _index , a ) ; break ; default : B ( this . cmos _index ) , B ( a ) } this . periodic _interrupt = 64 === ( this . cmos _b & 64 ) && 0 < ( this . cmos _a & 15 ) } ; Ca . prototype . cmos _read = function ( a ) { return this . cmos _data [ a ] } ; Ca . prototype . cmos _write = function ( a , b ) { B ( a ) ; B ( b ) ; this . cmos _data [ a ] = b } ; function Da ( a , b , c ) { this . bus = c ; this . cpu = a ; this . ints = 4 ; this . line _control = this . baud _rate = 0 ; this . lsr = 96 ; this . ier = this . fifo _control = 0 ; this . iir = 1 ; this . irq = this . scratch _register = this . modem _status = this . modem _control = 0 ; this . input = [ ] ; this . current _line = "" ; switch ( b ) { case 1016 : this . com = 0 ; this . irq = 4 ; break ; case 760 : this . com = 1 ; this . irq = 3 ; break ; case 1E3 : this . com = 2 ; this . irq = 4 ; break ; case 744 : this . irq = this . com = 3 ; break ; default : ta ( "Invalid serial port: " + B ( b ) , 16384 ) , this . com = 0 , this . irq = 4 } this . bus . register ( "serial" + this . com +
2024-06-28 09:23:02 +02:00
"-input" , function ( d ) { this . data _received ( d ) } , this ) ; this . bus . register ( "serial" + this . com + "-modem-status-input" , function ( d ) { this . set _modem _status ( d ) } , this ) ; this . bus . register ( "serial" + this . com + "-carrier-detect-input" , function ( d ) { this . set _modem _status ( d ? this . modem _status | 136 : this . modem _status & - 137 ) } , this ) ; this . bus . register ( "serial" + this . com + "-ring-indicator-input" , function ( d ) { this . set _modem _status ( d ? this . modem _status | 68 : this . modem _status & - 69 ) } , this ) ; this . bus . register ( "serial" + this . com + "-data-set-ready-input" ,
2025-01-03 12:44:26 +01:00
function ( d ) { this . set _modem _status ( d ? this . modem _status | 34 : this . modem _status & - 35 ) } , this ) ; this . bus . register ( "serial" + this . com + "-clear-to-send-input" , function ( d ) { this . set _modem _status ( d ? this . modem _status | 17 : this . modem _status & - 18 ) } , this ) ; a = a . io ; a . register _write ( b , this , function ( d ) { this . write _data ( d ) } , function ( d ) { this . write _data ( d & 255 ) ; this . write _data ( d >> 8 ) } ) ; a . register _write ( b | 1 , this , function ( d ) { this . line _control & 128 ? ( this . baud _rate = this . baud _rate & 255 | d << 8 , B ( this . baud _rate ) ) : ( 0 === ( this . ier & 2 ) && d & 2 && this . ThrowInterrupt ( 2 ) ,
this . ier = d & 15 , B ( d ) , this . CheckInterrupt ( ) ) } ) ; a . register _read ( b , this , function ( ) { if ( this . line _control & 128 ) return this . baud _rate & 255 ; let d = 0 ; 0 !== this . input . length && ( d = this . input . shift ( ) , B ( d ) ) ; 0 === this . input . length && ( this . lsr &= - 2 , this . ClearInterrupt ( 12 ) , this . ClearInterrupt ( 4 ) ) ; return d } ) ; a . register _read ( b | 1 , this , function ( ) { return this . line _control & 128 ? this . baud _rate >> 8 : this . ier & 15 } ) ; a . register _read ( b | 2 , this , function ( ) { var d = this . iir & 15 ; B ( this . iir ) ; 2 === this . iir && this . ClearInterrupt ( 2 ) ; this . fifo _control &
1 && ( d |= 192 ) ; return d } ) ; a . register _write ( b | 2 , this , function ( d ) { B ( d ) ; this . fifo _control = d } ) ; a . register _read ( b | 3 , this , function ( ) { B ( this . line _control ) ; return this . line _control } ) ; a . register _write ( b | 3 , this , function ( d ) { B ( d ) ; this . line _control = d } ) ; a . register _read ( b | 4 , this , function ( ) { return this . modem _control } ) ; a . register _write ( b | 4 , this , function ( d ) { B ( d ) ; this . modem _control = d } ) ; a . register _read ( b | 5 , this , function ( ) { B ( this . lsr ) ; return this . lsr } ) ; a . register _write ( b | 5 , this , function ( ) { } ) ; a . register _read ( b | 6 , this , function ( ) { B ( this . modem _status ) ;
return this . modem _status &= 240 } ) ; a . register _write ( b | 6 , this , function ( d ) { B ( d ) ; this . set _modem _status ( d ) } ) ; a . register _read ( b | 7 , this , function ( ) { return this . scratch _register } ) ; a . register _write ( b | 7 , this , function ( d ) { this . scratch _register = d } ) } Da . prototype . get _state = function ( ) { var a = [ ] ; a [ 0 ] = this . ints ; a [ 1 ] = this . baud _rate ; a [ 2 ] = this . line _control ; a [ 3 ] = this . lsr ; a [ 4 ] = this . fifo _control ; a [ 5 ] = this . ier ; a [ 6 ] = this . iir ; a [ 7 ] = this . modem _control ; a [ 8 ] = this . modem _status ; a [ 9 ] = this . scratch _register ; a [ 10 ] = this . irq ; return a } ;
2024-11-28 07:25:05 +01:00
Da . prototype . set _state = function ( a ) { this . ints = a [ 0 ] ; this . baud _rate = a [ 1 ] ; this . line _control = a [ 2 ] ; this . lsr = a [ 3 ] ; this . fifo _control = a [ 4 ] ; this . ier = a [ 5 ] ; this . iir = a [ 6 ] ; this . modem _control = a [ 7 ] ; this . modem _status = a [ 8 ] ; this . scratch _register = a [ 9 ] ; this . irq = a [ 10 ] } ;
Da . prototype . CheckInterrupt = function ( ) { this . ints & 4096 && this . ier & 1 ? ( this . iir = 12 , this . cpu . device _raise _irq ( this . irq ) ) : this . ints & 16 && this . ier & 1 ? ( this . iir = 4 , this . cpu . device _raise _irq ( this . irq ) ) : this . ints & 4 && this . ier & 2 ? ( this . iir = 2 , this . cpu . device _raise _irq ( this . irq ) ) : this . ints & 1 && this . ier & 8 ? ( this . iir = 0 , this . cpu . device _raise _irq ( this . irq ) ) : ( this . iir = 1 , this . cpu . device _lower _irq ( this . irq ) ) } ; Da . prototype . ThrowInterrupt = function ( a ) { this . ints |= 1 << a ; this . CheckInterrupt ( ) } ;
2025-01-03 12:44:26 +01:00
Da . prototype . ClearInterrupt = function ( a ) { this . ints &= ~ ( 1 << a ) ; this . CheckInterrupt ( ) } ; Da . prototype . data _received = function ( a ) { B ( a ) ; this . input . push ( a ) ; this . lsr |= 1 ; this . fifo _control & 1 ? this . ThrowInterrupt ( 12 ) : this . ThrowInterrupt ( 4 ) } ; Da . prototype . write _data = function ( a ) { this . line _control & 128 ? this . baud _rate = this . baud _rate & - 256 | a : ( B ( a ) , this . ThrowInterrupt ( 2 ) , this . bus . send ( "serial" + this . com + "-output-byte" , a ) ) } ;
Da . prototype . set _modem _status = function ( a ) { B ( a ) ; const b = this . modem _status & 15 ; let c = ( this . modem _status ^ a ) >> 4 ; this . modem _status = a ; this . modem _status = this . modem _status | c | b } ; function Ea ( a ) { this . cpu = a ; var b = a . io ; a . devices . pci . register _device ( { pci _id : 56 , pci _space : [ 134 , 128 , 19 , 113 , 7 , 0 , 128 , 2 , 8 , 0 , 128 , 6 , 0 , 0 , 128 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 9 , 1 , 0 , 0 ] , pci _bars : [ ] , name : "acpi" } ) ; this . timer _imprecision _offset = this . timer _last _value = 0 ; this . status = 1 ; this . pm1 _enable = this . pm1 _status = 0 ; this . last _timer = this . get _timer ( D . microtick ( ) ) ; this . gpe = new Uint8Array ( 4 ) ; b . register _read ( 45056 , this , void 0 , function ( ) { return this . pm1 _status } ) ;
b . register _write ( 45056 , this , void 0 , function ( c ) { B ( c , 4 ) ; this . pm1 _status &= ~ c } ) ; b . register _read ( 45058 , this , void 0 , function ( ) { return this . pm1 _enable } ) ; b . register _write ( 45058 , this , void 0 , function ( c ) { B ( c ) ; this . pm1 _enable = c } ) ; b . register _read ( 45060 , this , void 0 , function ( ) { return this . status } ) ; b . register _write ( 45060 , this , void 0 , function ( c ) { B ( c ) ; this . status = c } ) ; b . register _read ( 45064 , this , void 0 , void 0 , function ( ) { return this . get _timer ( D . microtick ( ) ) & 16777215 } ) ; b . register _read ( 45024 , this , function ( ) { return this . gpe [ 0 ] } ) ;
b . register _read ( 45025 , this , function ( ) { return this . gpe [ 1 ] } ) ; b . register _read ( 45026 , this , function ( ) { return this . gpe [ 2 ] } ) ; b . register _read ( 45027 , this , function ( ) { return this . gpe [ 3 ] } ) ; b . register _write ( 45024 , this , function ( c ) { B ( c ) ; this . gpe [ 0 ] = c } ) ; b . register _write ( 45025 , this , function ( c ) { B ( c ) ; this . gpe [ 1 ] = c } ) ; b . register _write ( 45026 , this , function ( c ) { B ( c ) ; this . gpe [ 2 ] = c } ) ; b . register _write ( 45027 , this , function ( c ) { B ( c ) ; this . gpe [ 3 ] = c } ) }
2024-11-28 07:25:05 +01:00
Ea . prototype . timer = function ( a ) { a = this . get _timer ( a ) ; var b = 0 !== ( ( a ^ this . last _timer ) & 8388608 ) ; this . pm1 _enable & 1 && b ? ( this . pm1 _status |= 1 , this . cpu . device _raise _irq ( 9 ) ) : this . cpu . device _lower _irq ( 9 ) ; this . last _timer = a ; return 100 } ;
Ea . prototype . get _timer = function ( a ) { a = Math . round ( 3579.545 * a ) ; a === this . timer _last _value ? 3579.545 > this . timer _imprecision _offset && this . timer _imprecision _offset ++ : this . timer _last _value + this . timer _imprecision _offset <= a && ( this . timer _imprecision _offset = 0 , this . timer _last _value = a ) ; return this . timer _last _value + this . timer _imprecision _offset } ; Ea . prototype . get _state = function ( ) { var a = [ ] ; a [ 0 ] = this . status ; a [ 1 ] = this . pm1 _status ; a [ 2 ] = this . pm1 _enable ; a [ 3 ] = this . gpe ; return a } ;
2025-01-03 12:44:26 +01:00
Ea . prototype . set _state = function ( a ) { this . status = a [ 0 ] ; this . pm1 _status = a [ 1 ] ; this . pm1 _enable = a [ 2 ] ; this . gpe = a [ 3 ] } ; function Fa ( a ) { this . cpu = a ; this . timer _divider = this . apic _id = 0 ; this . timer _divider _shift = 1 ; this . timer _current _count = this . timer _initial _count = 0 ; this . next _tick = D . microtick ( ) ; this . lvt _error = this . lvt _int1 = this . lvt _int0 = this . lvt _perf _counter = this . lvt _timer = 65536 ; this . icr1 = this . icr0 = this . tpr = 0 ; this . irr = new Int32Array ( 8 ) ; this . isr = new Int32Array ( 8 ) ; this . tmr = new Int32Array ( 8 ) ; this . spurious _vector = 254 ; this . destination _format = - 1 ; this . read _error = this . error = this . local _destination = 0 ; a . io . mmap _register ( 4276092928 , 1048576 ,
b => { B ( b >>> 0 ) ; var c = b & 3 ; return this . read32 ( b & - 4 ) >> 8 * c & 255 } , ( b , c ) => { B ( b ) ; B ( c ) } , b => this . read32 ( b ) , ( b , c ) => this . write32 ( b , c ) ) }
Fa . prototype . read32 = function ( a ) { a = a - 4276092928 | 0 ; switch ( a ) { case 32 : return this . apic _id ; case 48 : return 327700 ; case 128 : return this . tpr ; case 208 : return this . local _destination ; case 224 : return this . destination _format ; case 240 : return this . spurious _vector ; case 256 : case 272 : case 288 : case 304 : case 320 : case 336 : case 352 : case 368 : return a = a - 256 >> 4 , B ( this . isr [ a ] >>> 0 , 8 ) , this . isr [ a ] ; case 384 : case 400 : case 416 : case 432 : case 448 : case 464 : case 480 : case 496 : return a = a - 384 >> 4 , B ( this . tmr [ a ] >>> 0 , 8 ) , this . tmr [ a ] ; case 512 : case 528 : case 544 : case 560 : case 576 : case 592 : case 608 : case 624 : return a =
a - 512 >> 4 , B ( this . irr [ a ] >>> 0 , 8 ) , this . irr [ a ] ; case 640 : return B ( this . read _error >>> 0 , 8 ) , this . read _error ; case 768 : return this . icr0 ; case 784 : return this . icr1 ; case 800 : return this . lvt _timer ; case 832 : return this . lvt _perf _counter ; case 848 : return this . lvt _int0 ; case 864 : return this . lvt _int1 ; case 880 : return this . lvt _error ; case 992 : return this . timer _divider ; case 896 : return this . timer _initial _count ; case 912 : return B ( this . timer _current _count >>> 0 , 8 ) , this . timer _current _count ; default : return B ( a ) , 0 } } ;
Fa . prototype . write32 = function ( a , b ) { a = a - 4276092928 | 0 ; switch ( a ) { case 32 : B ( b >>> 8 , 8 ) ; this . apic _id = b ; break ; case 48 : B ( b >>> 0 , 8 ) ; break ; case 128 : this . tpr = b & 255 ; this . check _vector ( ) ; break ; case 176 : b = this . highest _isr ( ) ; - 1 !== b && ( this . register _clear _bit ( this . isr , b ) , this . register _get _bit ( this . tmr , b ) && this . cpu . devices . ioapic . remote _eoi ( b ) , this . check _vector ( ) ) ; break ; case 208 : B ( b >>> 0 , 8 ) ; this . local _destination = b & 4278190080 ; break ; case 224 : B ( b >>> 0 , 8 ) ; this . destination _format = b | 16777215 ; break ; case 240 : B ( b >>> 0 , 8 ) ; this . spurious _vector =
b ; break ; case 640 : B ( b >>> 0 , 8 ) ; this . read _error = this . error ; this . error = 0 ; break ; case 768 : a = b & 255 ; var c = b >> 8 & 7 , d = b >> 11 & 1 , e = b >> 15 & 1 , g = b >> 18 & 3 , f = this . icr1 >>> 24 ; B ( b , 8 ) ; B ( a , 2 ) ; this . icr0 = b & - 4097 ; 0 === g ? this . route ( a , c , e , f , d ) : 1 === g ? this . deliver ( a , 0 , e ) : 2 === g && this . deliver ( a , c , e ) ; break ; case 784 : B ( b >>> 0 , 8 ) ; this . icr1 = b ; break ; case 800 : B ( b >>> 0 , 8 ) ; this . lvt _timer = b ; break ; case 832 : B ( b >>> 0 , 8 ) ; this . lvt _perf _counter = b ; break ; case 848 : B ( b >>> 0 , 8 ) ; this . lvt _int0 = b ; break ; case 864 : B ( b >>> 0 , 8 ) ; this . lvt _int1 = b ; break ; case 880 : B ( b >>> 0 ,
8 ) ; this . lvt _error = b ; break ; case 992 : B ( b >>> 0 , 8 ) ; this . timer _divider = b ; b = b & 3 | ( b & 8 ) >> 1 ; this . timer _divider _shift = 7 === b ? 0 : b + 1 ; break ; case 896 : B ( b >>> 0 , 8 ) ; this . timer _initial _count = b >>> 0 ; this . timer _current _count = b >>> 0 ; this . next _tick = D . microtick ( ) ; this . timer _active = ! 0 ; break ; case 912 : B ( b >>> 0 , 8 ) ; break ; default : B ( a ) , B ( b >>> 0 , 8 ) } } ;
2024-11-28 07:25:05 +01:00
Fa . prototype . timer = function ( a ) { if ( 0 === this . timer _current _count ) return 100 ; const b = 1E6 / ( 1 << this . timer _divider _shift ) ; a = ( a - this . next _tick ) * b >>> 0 ; this . next _tick += a / b ; this . timer _current _count -= a ; 0 >= this . timer _current _count && ( a = this . lvt _timer & 393216 , 131072 === a ? ( this . timer _current _count %= this . timer _initial _count , 0 >= this . timer _current _count && ( this . timer _current _count += this . timer _initial _count ) , 0 === ( this . lvt _timer & 65536 ) && this . deliver ( this . lvt _timer & 255 , 0 , ! 1 ) ) : 0 === a && ( this . timer _current _count = 0 , 0 === ( this . lvt _timer &
2025-01-03 12:44:26 +01:00
65536 ) && this . deliver ( this . lvt _timer & 255 , 0 , ! 1 ) ) ) ; return Math . max ( 0 , this . timer _current _count / b ) } ; Fa . prototype . route = function ( a , b , c ) { this . deliver ( a , b , c ) } ; Fa . prototype . deliver = function ( a , b , c ) { 5 !== b && 4 !== b && ( this . register _get _bit ( this . irr , a ) ? B ( a , 2 ) : ( this . register _set _bit ( this . irr , a ) , c ? this . register _set _bit ( this . tmr , a ) : this . register _clear _bit ( this . tmr , a ) , this . check _vector ( ) ) ) } ; Fa . prototype . highest _irr = function ( ) { return this . register _get _highest _bit ( this . irr ) } ; Fa . prototype . highest _isr = function ( ) { return this . register _get _highest _bit ( this . isr ) } ;
2024-11-28 07:25:05 +01:00
Fa . prototype . check _vector = function ( ) { var a = this . highest _irr ( ) ; - 1 !== a && ( this . highest _isr ( ) >= a || ( a & 240 ) <= ( this . tpr & 240 ) || this . cpu . handle _irqs ( ) ) } ; Fa . prototype . acknowledge _irq = function ( ) { var a = this . highest _irr ( ) ; if ( - 1 === a || this . highest _isr ( ) >= a || ( a & 240 ) <= ( this . tpr & 240 ) ) return - 1 ; this . register _clear _bit ( this . irr , a ) ; this . register _set _bit ( this . isr , a ) ; this . check _vector ( ) ; return a } ;
Fa . prototype . get _state = function ( ) { var a = [ ] ; a [ 0 ] = this . apic _id ; a [ 1 ] = this . timer _divider ; a [ 2 ] = this . timer _divider _shift ; a [ 3 ] = this . timer _initial _count ; a [ 4 ] = this . timer _current _count ; a [ 5 ] = this . next _tick ; a [ 6 ] = this . lvt _timer ; a [ 7 ] = this . lvt _perf _counter ; a [ 8 ] = this . lvt _int0 ; a [ 9 ] = this . lvt _int1 ; a [ 10 ] = this . lvt _error ; a [ 11 ] = this . tpr ; a [ 12 ] = this . icr0 ; a [ 13 ] = this . icr1 ; a [ 14 ] = this . irr ; a [ 15 ] = this . isr ; a [ 16 ] = this . tmr ; a [ 17 ] = this . spurious _vector ; a [ 18 ] = this . destination _format ; a [ 19 ] = this . local _destination ; a [ 20 ] = this . error ; a [ 21 ] =
2024-06-28 09:23:02 +02:00
this . read _error ; return a } ;
2024-11-28 07:25:05 +01:00
Fa . prototype . set _state = function ( a ) { this . apic _id = a [ 0 ] ; this . timer _divider = a [ 1 ] ; this . timer _divider _shift = a [ 2 ] ; this . timer _initial _count = a [ 3 ] ; this . timer _current _count = a [ 4 ] ; this . next _tick = a [ 5 ] ; this . lvt _timer = a [ 6 ] ; this . lvt _perf _counter = a [ 7 ] ; this . lvt _int0 = a [ 8 ] ; this . lvt _int1 = a [ 9 ] ; this . lvt _error = a [ 10 ] ; this . tpr = a [ 11 ] ; this . icr0 = a [ 12 ] ; this . icr1 = a [ 13 ] ; this . irr = a [ 14 ] ; this . isr = a [ 15 ] ; this . tmr = a [ 16 ] ; this . spurious _vector = a [ 17 ] ; this . destination _format = a [ 18 ] ; this . local _destination = a [ 19 ] ; this . error = a [ 20 ] ; this . read _error =
2025-01-03 12:44:26 +01:00
a [ 21 ] } ; Fa . prototype . register _get _bit = function ( a , b ) { return a [ b >> 5 ] >> ( b & 31 ) & 1 } ; Fa . prototype . register _set _bit = function ( a , b ) { a [ b >> 5 ] |= 1 << ( b & 31 ) } ; Fa . prototype . register _clear _bit = function ( a , b ) { a [ b >> 5 ] &= ~ ( 1 << ( b & 31 ) ) } ; Fa . prototype . register _get _highest _bit = function ( a ) { for ( var b = 7 ; 0 <= b ; b -- ) { var c = a [ b ] ; if ( c ) return h . int _log2 ( c >>> 0 ) | b << 5 } return - 1 } ; function Ga ( a ) { this . cpu = a ; this . ioredtbl _config = new Int32Array ( 24 ) ; this . ioredtbl _destination = new Int32Array ( 24 ) ; for ( var b = 0 ; b < this . ioredtbl _config . length ; b ++ ) this . ioredtbl _config [ b ] = 65536 ; this . irq _value = this . irr = this . ioapic _id = this . ioregsel = 0 ; a . io . mmap _register ( 4273995776 , 131072 , c => { c = c - 4273995776 | 0 ; if ( 16 <= c && 20 > c ) return c -= 16 , B ( this . ioregsel ) , this . read ( this . ioregsel ) >> 8 * c & 255 ; B ( c >>> 0 ) ; return 0 } , c => { B ( c >>> 0 ) } , c => { c = c - 4273995776 | 0 ; if ( 0 === c ) return this . ioregsel ; if ( 16 === c ) return this . read ( this . ioregsel ) ;
B ( c >>> 0 ) ; return 0 } , ( c , d ) => { c = c - 4273995776 | 0 ; 0 === c ? this . ioregsel = d : 16 === c ? this . write ( this . ioregsel , d ) : ( B ( c >>> 0 ) , B ( d >>> 0 , 8 ) ) } ) } Ga . prototype . remote _eoi = function ( a ) { for ( var b = 0 ; 24 > b ; b ++ ) { var c = this . ioredtbl _config [ b ] ; ( c & 255 ) === a && c & 16384 && ( B ( b ) , this . ioredtbl _config [ b ] &= - 16385 , this . check _irq ( b ) ) } } ;
Ga . prototype . check _irq = function ( a ) { var b = 1 << a ; if ( 0 !== ( this . irr & b ) ) { var c = this . ioredtbl _config [ a ] ; if ( 0 === ( c & 65536 ) ) { var d = c >> 8 & 7 , e = this . ioredtbl _destination [ a ] >>> 24 ; if ( 0 === ( c & 32768 ) ) this . irr &= ~ b ; else if ( this . ioredtbl _config [ a ] |= 16384 , c & 16384 ) return ; 0 !== d && 1 !== d || this . cpu . devices . apic . route ( c & 255 , d , 32768 === ( c & 32768 ) , e , c >> 11 & 1 ) ; this . ioredtbl _config [ a ] &= - 4097 } } } ;
Ga . prototype . set _irq = function ( a ) { if ( ! ( 24 <= a ) ) { var b = 1 << a ; 0 === ( this . irq _value & b ) && ( this . irq _value |= b , 65536 !== ( this . ioredtbl _config [ a ] & 98304 ) && ( this . irr |= b , this . check _irq ( a ) ) ) } } ; Ga . prototype . clear _irq = function ( a ) { if ( ! ( 24 <= a ) ) { var b = 1 << a ; ( this . irq _value & b ) === b && ( this . irq _value &= ~ b , this . ioredtbl _config [ a ] & 32768 && ( this . irr &= ~ b ) ) } } ;
Ga . prototype . read = function ( a ) { if ( 0 === a ) return this . ioapic _id << 24 ; if ( 1 === a ) return 1507345 ; if ( 2 === a ) return this . ioapic _id << 24 ; if ( 16 <= a && 64 > a ) { var b = a - 16 >> 1 ; a = a & 1 ? this . ioredtbl _destination [ b ] : this . ioredtbl _config [ b ] ; B ( b ) ; B ( a , 8 ) ; return a } B ( a ) ; return 0 } ;
Ga . prototype . write = function ( a , b ) { if ( 0 === a ) this . ioapic _id = b >>> 24 & 15 ; else if ( 1 !== a && 2 !== a ) if ( 16 <= a && 64 > a ) { var c = a - 16 >> 1 ; a & 1 ? ( this . ioredtbl _destination [ c ] = b & 4278190080 , B ( b >>> 0 , 8 ) , B ( c ) , B ( b >>> 24 , 2 ) ) : ( this . ioredtbl _config [ c ] = b & 110591 | this . ioredtbl _config [ c ] & - 110592 , a = b & 255 , B ( b >>> 0 , 8 ) , B ( c ) , B ( a , 2 ) , this . check _irq ( c ) ) } else B ( a ) , B ( b >>> 0 , 8 ) } ;
Ga . prototype . get _state = function ( ) { var a = [ ] ; a [ 0 ] = this . ioredtbl _config ; a [ 1 ] = this . ioredtbl _destination ; a [ 2 ] = this . ioregsel ; a [ 3 ] = this . ioapic _id ; a [ 4 ] = this . irr ; a [ 5 ] = this . irq _value ; return a } ; Ga . prototype . set _state = function ( a ) { this . ioredtbl _config = a [ 0 ] ; this . ioredtbl _destination = a [ 1 ] ; this . ioregsel = a [ 2 ] ; this . ioapic _id = a [ 3 ] ; this . irr = a [ 4 ] ; this . irq _value = a [ 5 ] } ; function Ja ( a ) { this . message = a } Ja . prototype = Error ( ) ; const Ka = { Uint8Array , Int8Array , Uint16Array , Int16Array , Uint32Array , Int32Array , Float32Array , Float64Array } ;
2024-11-28 07:25:05 +01:00
function La ( a , b ) { if ( "object" !== typeof a || null === a ) return a ; if ( a instanceof Array ) return a . map ( e => La ( e , b ) ) ; a . constructor === Object && console . log ( a ) ; if ( a . BYTES _PER _ELEMENT ) { var c = new Uint8Array ( a . buffer , a . byteOffset , a . length * a . BYTES _PER _ELEMENT ) ; return { _ _state _type _ _ : a . constructor . name . replace ( "bound " , "" ) , buffer _id : b . push ( c ) - 1 } } a = a . get _state ( ) ; c = [ ] ; for ( var d = 0 ; d < a . length ; d ++ ) c [ d ] = La ( a [ d ] , b ) ; return c }
2025-01-03 12:44:26 +01:00
function Ma ( a , b ) { if ( "object" !== typeof a || null === a ) return a ; if ( a instanceof Array ) { for ( let c = 0 ; c < a . length ; c ++ ) a [ c ] = Ma ( a [ c ] , b ) ; return a } return new Ka [ a . _ _state _type _ _ ] ( b [ a . buffer _id ] ) }
G . prototype . save _state = function ( ) { for ( var a = [ ] , b = La ( this , a ) , c = [ ] , d = 0 , e = 0 ; e < a . length ; e ++ ) { var g = a [ e ] . byteLength ; c [ e ] = { offset : d , length : g } ; d += g ; d = d + 3 & - 4 } e = JSON . stringify ( { buffer _infos : c , state : b } ) ; e = ( new TextEncoder ) . encode ( e ) ; b = 16 + e . length ; b = b + 3 & - 4 ; g = b + d ; d = new ArrayBuffer ( g ) ; var f = new Int32Array ( d , 0 , 4 ) ; ( new Uint8Array ( d , 16 , e . length ) ) . set ( e ) ; b = new Uint8Array ( d , b ) ; f [ 0 ] = - 2039052682 ; f [ 1 ] = 6 ; f [ 2 ] = g ; f [ 3 ] = e . length ; for ( e = 0 ; e < a . length ; e ++ ) b . set ( a [ e ] , c [ e ] . offset ) ; return d } ;
G . prototype . restore _state = function ( a ) { function b ( p , q ) { const r = p . length ; if ( 16 > r ) throw new Ja ( "Invalid length: " + r ) ; p = new Int32Array ( p . buffer , p . byteOffset , 4 ) ; if ( - 2039052682 !== p [ 0 ] ) throw new Ja ( "Invalid header: " + B ( p [ 0 ] >>> 0 ) ) ; if ( 6 !== p [ 1 ] ) throw new Ja ( "Version mismatch: dump=" + p [ 1 ] + " we=6" ) ; if ( q && p [ 2 ] !== r ) throw new Ja ( "Length doesn't match header: real=" + r + " header=" + p [ 2 ] ) ; return p [ 3 ] } function c ( p ) { p = ( new TextDecoder ) . decode ( p ) ; return JSON . parse ( p ) } a = new Uint8Array ( a ) ; if ( 4247762216 === ( new Uint32Array ( a . buffer ,
0 , 1 ) ) [ 0 ] ) { var d = this . zstd _create _ctx ( a . length ) ; ( new Uint8Array ( this . wasm _memory . buffer , this . zstd _get _src _ptr ( d ) , a . length ) ) . set ( a ) ; var e = this . zstd _read ( d , 16 ) , g = new Uint8Array ( this . wasm _memory . buffer , e , 16 ) , f = b ( g , ! 1 ) ; this . zstd _read _free ( e , 16 ) ; e = this . zstd _read ( d , f ) ; g = new Uint8Array ( this . wasm _memory . buffer , e , f ) ; g = c ( g ) ; this . zstd _read _free ( e , f ) ; e = g . state ; var k = g . buffer _infos ; g = [ ] ; f = 16 + f ; for ( var l of k ) { k = ( f + 3 & - 4 ) - f ; if ( 1048576 < l . length ) { var m = this . zstd _read ( d , k ) ; this . zstd _read _free ( m , k ) ; m = new Uint8Array ( l . length ) ;
g . push ( m . buffer ) ; for ( var n = 0 ; n < l . length ; ) { const p = Math . min ( l . length - n , 1048576 ) , q = this . zstd _read ( d , p ) ; m . set ( new Uint8Array ( this . wasm _memory . buffer , q , p ) , n ) ; this . zstd _read _free ( q , p ) ; n += p } } else m = this . zstd _read ( d , k + l . length ) , n = m + k , g . push ( this . wasm _memory . buffer . slice ( n , n + l . length ) ) , this . zstd _read _free ( m , k + l . length ) ; f += k + l . length } e = Ma ( e , g ) ; this . set _state ( e ) ; this . zstd _free _ctx ( d ) } else { d = b ( a , ! 0 ) ; if ( 0 > d || d + 12 >= a . length ) throw new Ja ( "Invalid info block length: " + d ) ; l = a . subarray ( 16 , 16 + d ) ; e = c ( l ) ; l = e . state ; e =
e . buffer _infos ; let p = 16 + d ; p = p + 3 & - 4 ; d = e . map ( q => { const r = p + q . offset ; return a . buffer . slice ( r , r + q . length ) } ) ; l = Ma ( l , d ) ; this . set _state ( l ) } } ; function Oa ( a , b , c ) { a [ 0 ] === b [ 0 ] && a [ 1 ] === b [ 1 ] && a [ 2 ] === b [ 2 ] && a [ 3 ] === b [ 3 ] && a [ 4 ] === b [ 4 ] && a [ 5 ] === b [ 5 ] && ( a [ 0 ] = c [ 0 ] , a [ 1 ] = c [ 1 ] , a [ 2 ] = c [ 2 ] , a [ 3 ] = c [ 3 ] , a [ 4 ] = c [ 4 ] , a [ 5 ] = c [ 5 ] ) ; a [ 6 ] === b [ 0 ] && a [ 7 ] === b [ 1 ] && a [ 8 ] === b [ 2 ] && a [ 9 ] === b [ 3 ] && a [ 10 ] === b [ 4 ] && a [ 11 ] === b [ 5 ] && ( a [ 6 ] = c [ 0 ] , a [ 7 ] = c [ 1 ] , a [ 8 ] = c [ 2 ] , a [ 9 ] = c [ 3 ] , a [ 10 ] = c [ 4 ] , a [ 11 ] = c [ 5 ] ) ; var d = a [ 12 ] << 8 | a [ 13 ] ; if ( 2048 === d ) { if ( a = a . subarray ( 14 ) , 4 === a [ 0 ] >> 4 && 17 === a [ 9 ] ) { a = a . subarray ( 20 ) ; d = a [ 0 ] << 8 | a [ 1 ] ; var e = a [ 2 ] << 8 | a [ 3 ] ; B ( a [ 6 ] << 8 | a [ 7 ] , 4 ) ; if ( 67 === d || 67 === e ) if ( d = a . subarray ( 8 ) , e = d [ 236 ] << 24 | d [ 237 ] <<
16 | d [ 238 ] << 8 | d [ 239 ] , 1669485411 !== e ) B ( e , 8 ) ; else for ( d [ 28 ] === b [ 0 ] && d [ 29 ] === b [ 1 ] && d [ 30 ] === b [ 2 ] && d [ 31 ] === b [ 3 ] && d [ 32 ] === b [ 4 ] && d [ 33 ] === b [ 5 ] && ( d [ 28 ] = c [ 0 ] , d [ 29 ] = c [ 1 ] , d [ 30 ] = c [ 2 ] , d [ 31 ] = c [ 3 ] , d [ 32 ] = c [ 4 ] , d [ 33 ] = c [ 5 ] , a [ 6 ] = a [ 7 ] = 0 ) , e = 240 ; e < d . length ; ) { const g = d [ e ++ ] ; if ( 255 === g ) break ; const f = d [ e ++ ] ; 61 === g && 1 === d [ e + 0 ] && d [ e + 1 ] === b [ 0 ] && d [ e + 2 ] === b [ 1 ] && d [ e + 3 ] === b [ 2 ] && d [ e + 4 ] === b [ 3 ] && d [ e + 5 ] === b [ 4 ] && d [ e + 6 ] === b [ 5 ] && ( d [ e + 1 ] = c [ 0 ] , d [ e + 2 ] = c [ 1 ] , d [ e + 3 ] = c [ 2 ] , d [ e + 4 ] = c [ 3 ] , d [ e + 5 ] = c [ 4 ] , d [ e + 6 ] = c [ 5 ] , a [ 6 ] = a [ 7 ] = 0 ) ; e += f } } } else 2054 === d && ( a =
2024-11-28 07:25:05 +01:00
a . subarray ( 14 ) , Pa ( a . subarray ( 8 , 14 ) ) , Pa ( a . subarray ( 18 , 24 ) ) , a [ 8 ] === b [ 0 ] && a [ 9 ] === b [ 1 ] && a [ 10 ] === b [ 2 ] && a [ 11 ] === b [ 3 ] && a [ 12 ] === b [ 4 ] && a [ 13 ] === b [ 5 ] && ( a [ 8 ] = c [ 0 ] , a [ 9 ] = c [ 1 ] , a [ 10 ] = c [ 2 ] , a [ 11 ] = c [ 3 ] , a [ 12 ] = c [ 4 ] , a [ 13 ] = c [ 5 ] ) ) } function Pa ( a ) { return [ a [ 0 ] . toString ( 16 ) . padStart ( 2 , "0" ) , a [ 1 ] . toString ( 16 ) . padStart ( 2 , "0" ) , a [ 2 ] . toString ( 16 ) . padStart ( 2 , "0" ) , a [ 3 ] . toString ( 16 ) . padStart ( 2 , "0" ) , a [ 4 ] . toString ( 16 ) . padStart ( 2 , "0" ) , a [ 5 ] . toString ( 16 ) . padStart ( 2 , "0" ) ] . join ( ":" ) }
function Qa ( a , b , c , d , e ) { this . cpu = a ; this . pci = a . devices . pci ; this . id = e || 0 ; this . preserve _mac _from _state _image = c ; this . mac _address _translation = d ; this . bus = b ; this . bus . register ( "net" + this . id + "-receive" , function ( g ) { this . receive ( g ) } , this ) ; this . port = 768 + 256 * this . id ; this . name = "ne2k" ; this . pci _space = [ 236 , 16 , 41 , 128 , 3 , 1 , 0 , 0 , 0 , 0 , 0 , 2 , 0 , 0 , 0 , 0 , this . port & 255 | 1 , this . port >> 8 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 244 , 26 , 0 , 17 , 0 , 0 , 184 , 254 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 1 , 0 , 0 ] ; this . pci _id = ( 0 === this . id ? 5 : 7 + this . id ) << 3 ; this . pci _bars =
[ { size : 32 } ] ; this . imr = this . isr = 0 ; this . cr = 1 ; this . tpsr = this . tcnt = this . rcnt = this . dcfg = 0 ; this . memory = new Uint8Array ( 32768 ) ; this . txcr = this . rxcr = 0 ; this . tsr = 1 ; this . mac = new Uint8Array ( [ 0 , 34 , 21 , 255 * Math . random ( ) | 0 , 255 * Math . random ( ) | 0 , 255 * Math . random ( ) | 0 ] ) ; this . bus . send ( "net" + this . id + "-mac" , Pa ( this . mac ) ) ; this . mar = Uint8Array . of ( 255 , 255 , 255 , 255 , 255 , 255 , 255 , 255 ) ; this . mac _address _in _state = null ; for ( b = 0 ; 6 > b ; b ++ ) this . memory [ b << 1 ] = this . memory [ b << 1 | 1 ] = this . mac [ b ] ; this . memory [ 28 ] = this . memory [ 29 ] = 87 ; this . memory [ 30 ] = this . memory [ 31 ] =
2025-01-03 12:44:26 +01:00
87 ; ta ( "Mac: " + Pa ( this . mac ) , 1048576 ) ; this . rsar = 0 ; this . pstart = 64 ; this . pstop = 128 ; this . boundary = this . curpg = 76 ; b = a . io ; b . register _read ( this . port | 0 , this , function ( ) { return this . cr } ) ; b . register _write ( this . port | 0 , this , function ( g ) { this . cr = g ; B ( g , 2 ) ; B ( this . txcr , 2 ) ; this . cr & 1 || ( g & 24 && 0 === this . rcnt && this . do _interrupt ( 64 ) , g & 4 && ( g = this . tpsr << 8 , g = this . memory . subarray ( g , g + this . tcnt ) , this . mac _address _in _state && ( g = new Uint8Array ( g ) , Oa ( g , this . mac _address _in _state , this . mac ) ) , this . bus . send ( "net" + this . id + "-send" , g ) , this . bus . send ( "eth-transmit-end" ,
[ g . length ] ) , this . cr &= - 5 , this . do _interrupt ( 2 ) , B ( g . byteLength ) ) ) } ) ; b . register _read ( this . port | 13 , this , function ( ) { return 1 === this . get _page ( ) ? this . mar [ 5 ] : 0 } ) ; b . register _read ( this . port | 14 , this , function ( ) { return 1 === this . get _page ( ) ? this . mar [ 6 ] : 0 } , function ( ) { this . get _page ( ) ; return 0 } ) ; b . register _read ( this . port | 15 , this , function ( ) { return 1 === this . get _page ( ) ? this . mar [ 7 ] : 0 } ) ; b . register _read ( this . port | 31 , this , function ( ) { this . get _page ( ) ; this . do _interrupt ( 128 ) ; return 0 } ) ; b . register _write ( this . port | 31 , this , function ( g ) { this . get _page ( ) ;
B ( g , 2 ) } ) ; b . register _read ( this . port | 1 , this , function ( ) { var g = this . get _page ( ) ; return 0 === g ? this . pstart : 1 === g ? this . mac [ 0 ] : 2 === g ? this . pstart : 0 } ) ; b . register _write ( this . port | 1 , this , function ( g ) { var f = this . get _page ( ) ; 0 === f ? ( B ( g , 2 ) , this . pstart = g ) : 1 === f ? ( B ( g ) , this . mac [ 0 ] = g ) : B ( g ) } ) ; b . register _read ( this . port | 2 , this , function ( ) { var g = this . get _page ( ) ; return 0 === g ? this . pstop : 1 === g ? this . mac [ 1 ] : 2 === g ? this . pstop : 0 } ) ; b . register _write ( this . port | 2 , this , function ( g ) { var f = this . get _page ( ) ; 0 === f ? ( B ( g , 2 ) , g > this . memory . length >>
8 && ( g = this . memory . length >> 8 , B ( g ) ) , this . pstop = g ) : 1 === f ? ( B ( g ) , this . mac [ 1 ] = g ) : B ( g ) } ) ; b . register _read ( this . port | 7 , this , function ( ) { var g = this . get _page ( ) ; return 0 === g ? ( B ( this . isr , 2 ) , this . isr ) : 1 === g ? ( B ( this . curpg , 2 ) , this . curpg ) : 0 } ) ; b . register _write ( this . port | 7 , this , function ( g ) { var f = this . get _page ( ) ; 0 === f ? ( B ( g , 2 ) , this . isr &= ~ g , this . update _irq ( ) ) : 1 === f && ( B ( g , 2 ) , this . curpg = g ) } ) ; b . register _write ( this . port | 13 , this , function ( g ) { 0 === this . get _page ( ) && ( this . txcr = g ) ; B ( g , 2 ) } ) ; b . register _write ( this . port | 14 , this , function ( g ) { 0 ===
this . get _page ( ) ? ( B ( g , 2 ) , this . dcfg = g ) : B ( g , 2 ) } ) ; b . register _read ( this . port | 10 , this , function ( ) { var g = this . get _page ( ) ; return 0 === g ? 80 : 1 === g ? this . mar [ 2 ] : 0 } ) ; b . register _write ( this . port | 10 , this , function ( g ) { 0 === this . get _page ( ) ? ( B ( g , 2 ) , this . rcnt = this . rcnt & 65280 | g & 255 ) : B ( g , 2 ) } ) ; b . register _read ( this . port | 11 , this , function ( ) { var g = this . get _page ( ) ; return 0 === g ? 67 : 1 === g ? this . mar [ 3 ] : 0 } ) ; b . register _write ( this . port | 11 , this , function ( g ) { 0 === this . get _page ( ) ? ( B ( g , 2 ) , this . rcnt = this . rcnt & 255 | g << 8 & 65280 ) : B ( g , 2 ) } ) ; b . register _read ( this . port |
8 , this , function ( ) { var g = this . get _page ( ) ; return 0 === g ? this . rsar & 255 : 1 === g ? this . mar [ 0 ] : 0 } ) ; b . register _write ( this . port | 8 , this , function ( g ) { 0 === this . get _page ( ) ? ( B ( g , 2 ) , this . rsar = this . rsar & 65280 | g & 255 ) : B ( g , 2 ) } ) ; b . register _read ( this . port | 9 , this , function ( ) { var g = this . get _page ( ) ; return 0 === g ? this . rsar >> 8 & 255 : 1 === g ? this . mar [ 1 ] : 0 } ) ; b . register _write ( this . port | 9 , this , function ( g ) { 0 === this . get _page ( ) ? ( B ( g , 2 ) , this . rsar = this . rsar & 255 | g << 8 & 65280 ) : B ( g , 2 ) } ) ; b . register _write ( this . port | 15 , this , function ( g ) { 0 === this . get _page ( ) ?
( B ( g , 2 ) , B ( this . isr , 2 ) , this . imr = g , this . update _irq ( ) ) : B ( g , 2 ) } ) ; b . register _read ( this . port | 3 , this , function ( ) { var g = this . get _page ( ) ; return 0 === g ? ( B ( this . boundary , 2 ) , this . boundary ) : 1 === g ? this . mac [ 2 ] : 0 } ) ; b . register _write ( this . port | 3 , this , function ( g ) { var f = this . get _page ( ) ; 0 === f ? ( B ( g , 2 ) , this . boundary = g ) : 1 === f ? ( B ( g ) , this . mac [ 2 ] = g ) : B ( g ) } ) ; b . register _read ( this . port | 4 , this , function ( ) { var g = this . get _page ( ) ; return 0 === g ? this . tsr : 1 === g ? this . mac [ 3 ] : 0 } ) ; b . register _write ( this . port | 4 , this , function ( g ) { var f = this . get _page ( ) ;
0 === f ? ( B ( g , 2 ) , this . tpsr = g ) : 1 === f ? ( B ( g ) , this . mac [ 3 ] = g ) : B ( g ) } ) ; b . register _read ( this . port | 5 , this , function ( ) { var g = this . get _page ( ) ; return 0 === g ? 0 : 1 === g ? this . mac [ 4 ] : 0 } ) ; b . register _write ( this . port | 5 , this , function ( g ) { var f = this . get _page ( ) ; 0 === f ? ( B ( g , 2 ) , this . tcnt = this . tcnt & - 256 | g ) : 1 === f ? ( B ( g ) , this . mac [ 4 ] = g ) : B ( g ) } ) ; b . register _read ( this . port | 6 , this , function ( ) { var g = this . get _page ( ) ; return 0 === g ? 0 : 1 === g ? this . mac [ 5 ] : 0 } ) ; b . register _write ( this . port | 6 , this , function ( g ) { var f = this . get _page ( ) ; 0 === f ? ( B ( g , 2 ) , this . tcnt =
this . tcnt & 255 | g << 8 ) : 1 === f ? ( B ( g ) , this . mac [ 5 ] = g ) : B ( g ) } ) ; b . register _read ( this . port | 12 , this , function ( ) { var g = this . get _page ( ) ; return 0 === g ? 9 : 1 === g ? this . mar [ 4 ] : 0 } ) ; b . register _write ( this . port | 12 , this , function ( g ) { 0 === this . get _page ( ) ? ( B ( g , 2 ) , this . rxcr = g ) : B ( g ) } ) ; b . register _read ( this . port | 16 , this , this . data _port _read8 , this . data _port _read16 , this . data _port _read32 ) ; b . register _write ( this . port | 16 , this , this . data _port _write16 , this . data _port _write16 , this . data _port _write32 ) ; a . devices . pci . register _device ( this ) }
2024-11-28 07:25:05 +01:00
Qa . prototype . get _state = function ( ) { var a = [ ] ; a [ 0 ] = this . isr ; a [ 1 ] = this . imr ; a [ 2 ] = this . cr ; a [ 3 ] = this . dcfg ; a [ 4 ] = this . rcnt ; a [ 5 ] = this . tcnt ; a [ 6 ] = this . tpsr ; a [ 7 ] = this . rsar ; a [ 8 ] = this . pstart ; a [ 9 ] = this . curpg ; a [ 10 ] = this . boundary ; a [ 11 ] = this . pstop ; a [ 12 ] = this . rxcr ; a [ 13 ] = this . txcr ; a [ 14 ] = this . tsr ; a [ 15 ] = this . mac ; a [ 16 ] = this . memory ; return a } ;
Qa . prototype . set _state = function ( a ) { this . isr = a [ 0 ] ; this . imr = a [ 1 ] ; this . cr = a [ 2 ] ; this . dcfg = a [ 3 ] ; this . rcnt = a [ 4 ] ; this . tcnt = a [ 5 ] ; this . tpsr = a [ 6 ] ; this . rsar = a [ 7 ] ; this . pstart = a [ 8 ] ; this . curpg = a [ 9 ] ; this . boundary = a [ 10 ] ; this . pstop = a [ 11 ] ; this . rxcr = a [ 12 ] ; this . txcr = a [ 13 ] ; this . tsr = a [ 14 ] ; this . preserve _mac _from _state _image ? ( this . mac = a [ 15 ] , this . memory = a [ 16 ] ) : this . mac _address _translation && ( this . mac _address _in _state = a [ 15 ] , this . memory = a [ 16 ] , Pa ( this . mac _address _in _state ) , Pa ( this . mac ) ) ; this . bus . send ( "net" + this . id + "-mac" , Pa ( this . mac ) ) } ;
2025-01-03 12:44:26 +01:00
Qa . prototype . do _interrupt = function ( a ) { B ( a , 2 ) ; this . isr |= a ; this . update _irq ( ) } ; Qa . prototype . update _irq = function ( ) { this . imr & this . isr ? this . pci . raise _irq ( this . pci _id ) : this . pci . lower _irq ( this . pci _id ) } ; Qa . prototype . data _port _write = function ( a ) { if ( 16 >= this . rsar || 16384 <= this . rsar && 32768 > this . rsar ) this . memory [ this . rsar ] = a ; this . rsar ++ ; this . rcnt -- ; this . rsar >= this . pstop << 8 && ( this . rsar += this . pstart - this . pstop << 8 ) ; 0 === this . rcnt && this . do _interrupt ( 64 ) } ;
2024-11-28 07:25:05 +01:00
Qa . prototype . data _port _write16 = function ( a ) { this . data _port _write ( a ) ; this . dcfg & 1 && this . data _port _write ( a >> 8 ) } ; Qa . prototype . data _port _write32 = function ( a ) { this . data _port _write ( a ) ; this . data _port _write ( a >> 8 ) ; this . data _port _write ( a >> 16 ) ; this . data _port _write ( a >> 24 ) } ; Qa . prototype . data _port _read = function ( ) { let a = 0 ; 32768 > this . rsar && ( a = this . memory [ this . rsar ] ) ; this . rsar ++ ; this . rcnt -- ; this . rsar >= this . pstop << 8 && ( this . rsar += this . pstart - this . pstop << 8 ) ; 0 === this . rcnt && this . do _interrupt ( 64 ) ; return a } ;
Qa . prototype . data _port _read8 = function ( ) { return this . data _port _read16 ( ) & 255 } ; Qa . prototype . data _port _read16 = function ( ) { return this . dcfg & 1 ? this . data _port _read ( ) | this . data _port _read ( ) << 8 : this . data _port _read ( ) } ; Qa . prototype . data _port _read32 = function ( ) { return this . data _port _read ( ) | this . data _port _read ( ) << 8 | this . data _port _read ( ) << 16 | this . data _port _read ( ) << 24 } ;
Qa . prototype . receive = function ( a ) { if ( ! ( this . cr & 1 ) && ( this . bus . send ( "eth-receive-end" , [ a . length ] ) , this . rxcr & 16 || this . rxcr & 4 && 255 === a [ 0 ] && 255 === a [ 1 ] && 255 === a [ 2 ] && 255 === a [ 3 ] && 255 === a [ 4 ] && 255 === a [ 5 ] || ! ( this . rxcr & 8 && 1 === ( a [ 0 ] & 1 ) || a [ 0 ] !== this . mac [ 0 ] || a [ 1 ] !== this . mac [ 1 ] || a [ 2 ] !== this . mac [ 2 ] || a [ 3 ] !== this . mac [ 3 ] || a [ 4 ] !== this . mac [ 4 ] || a [ 5 ] !== this . mac [ 5 ] ) ) ) { this . mac _address _in _state && ( a = new Uint8Array ( a ) , Oa ( a , this . mac , this . mac _address _in _state ) ) ; var b = this . curpg << 8 , c = Math . max ( 60 , a . length ) + 4 , d = b + 4 , e = this . curpg + 1 +
2025-01-03 12:44:26 +01:00
( c >> 8 ) , g = b + c , f = 1 + ( c >> 8 ) , k = this . boundary > this . curpg ? this . boundary - this . curpg : this . pstop - this . curpg + this . boundary - this . pstart ; k < f && 0 !== this . boundary ? ( B ( this . pstart ) , B ( this . pstop ) , B ( this . curpg ) , B ( f ) , B ( this . boundary ) , B ( k ) ) : ( g > this . pstop << 8 ? ( g = ( this . pstop << 8 ) - d , this . memory . set ( a . subarray ( 0 , g ) , d ) , this . memory . set ( a . subarray ( g ) , this . pstart << 8 ) , B ( g ) ) : ( this . memory . set ( a , d ) , 60 > a . length && this . memory . fill ( 0 , d + a . length , d + 60 ) ) , e >= this . pstop && ( e += this . pstart - this . pstop ) , this . memory [ b ] = 1 , this . memory [ b + 1 ] = e , this . memory [ b +
2 ] = c , this . memory [ b + 3 ] = c >> 8 , this . curpg = e , B ( b ) , B ( c ) , B ( e ) , this . do _interrupt ( 1 ) ) } } ; Qa . prototype . get _page = function ( ) { return this . cr >> 6 & 3 } ; var Ra = new Uint8Array ( 256 ) , Sa = [ ] , Ta = [ ] , Ua = [ ] , Va = new Uint8Array ( 256 ) , Wa = [ ] ;
2024-11-28 07:25:05 +01:00
function Q ( a , b ) { this . cpu = a ; this . bus = b ; this . write _buffer = new na ( 64 ) ; this . read _buffer = new na ( 64 ) ; this . mixer _current _address = this . command _size = this . command = this . read _buffer _lastvalue = 0 ; this . mixer _registers = new Uint8Array ( 256 ) ; this . mixer _reset ( ) ; this . dummy _speaker _enabled = ! 1 ; this . test _register = 0 ; this . dsp _signed = this . dsp _16bit = this . dsp _stereo = this . dsp _highspeed = ! 1 ; this . dac _buffers = [ new oa ( 65536 ) , new oa ( 65536 ) ] ; this . dma = a . devices . dma ; this . dma _channel = this . dma _irq = this . dma _bytes _block = this . dma _bytes _left =
2025-01-03 12:44:26 +01:00
this . dma _bytes _count = this . dma _sample _count = 0 ; this . dma _channel _8bit = 1 ; this . dma _channel _16bit = 5 ; this . dma _autoinit = ! 1 ; this . dma _buffer = new ArrayBuffer ( 65536 ) ; this . dma _buffer _int8 = new Int8Array ( this . dma _buffer ) ; this . dma _buffer _uint8 = new Uint8Array ( this . dma _buffer ) ; this . dma _buffer _int16 = new Int16Array ( this . dma _buffer ) ; this . dma _buffer _uint16 = new Uint16Array ( this . dma _buffer ) ; this . dma _syncbuffer = new h . SyncBuffer ( this . dma _buffer ) ; this . dma _paused = this . dma _waiting _transfer = ! 1 ; this . sampling _rate = 22050 ; b . send ( "dac-tell-sampling-rate" ,
2024-11-28 07:25:05 +01:00
this . sampling _rate ) ; this . bytes _per _sample = 1 ; this . e2 _value = 170 ; this . e2 _count = 0 ; this . asp _registers = new Uint8Array ( 256 ) ; this . mpu _read _buffer = new na ( 64 ) ; this . fm _current _address1 = this . fm _current _address0 = this . mpu _read _buffer _lastvalue = 0 ; this . fm _waveform _select _enable = ! 1 ; this . irq = 5 ; this . irq _triggered = new Uint8Array ( 16 ) ; a . io . register _read _consecutive ( 544 , this , this . port2x0 _read , this . port2x1 _read , this . port2x2 _read , this . port2x3 _read ) ; a . io . register _read _consecutive ( 904 , this , this . port2x0 _read , this . port2x1 _read ) ;
2024-06-28 09:23:02 +02:00
a . io . register _read _consecutive ( 548 , this , this . port2x4 _read , this . port2x5 _read ) ; a . io . register _read ( 550 , this , this . port2x6 _read ) ; a . io . register _read ( 551 , this , this . port2x7 _read ) ; a . io . register _read ( 552 , this , this . port2x8 _read ) ; a . io . register _read ( 553 , this , this . port2x9 _read ) ; a . io . register _read ( 554 , this , this . port2xA _read ) ; a . io . register _read ( 555 , this , this . port2xB _read ) ; a . io . register _read ( 556 , this , this . port2xC _read ) ; a . io . register _read ( 557 , this , this . port2xD _read ) ; a . io . register _read _consecutive ( 558 , this , this . port2xE _read ,
this . port2xF _read ) ; a . io . register _write _consecutive ( 544 , this , this . port2x0 _write , this . port2x1 _write , this . port2x2 _write , this . port2x3 _write ) ; a . io . register _write _consecutive ( 904 , this , this . port2x0 _write , this . port2x1 _write ) ; a . io . register _write _consecutive ( 548 , this , this . port2x4 _write , this . port2x5 _write ) ; a . io . register _write ( 550 , this , this . port2x6 _write ) ; a . io . register _write ( 551 , this , this . port2x7 _write ) ; a . io . register _write _consecutive ( 552 , this , this . port2x8 _write , this . port2x9 _write ) ; a . io . register _write ( 554 , this ,
this . port2xA _write ) ; a . io . register _write ( 555 , this , this . port2xB _write ) ; a . io . register _write ( 556 , this , this . port2xC _write ) ; a . io . register _write ( 557 , this , this . port2xD _write ) ; a . io . register _write ( 558 , this , this . port2xE _write ) ; a . io . register _write ( 559 , this , this . port2xF _write ) ; a . io . register _read _consecutive ( 816 , this , this . port3x0 _read , this . port3x1 _read ) ; a . io . register _write _consecutive ( 816 , this , this . port3x0 _write , this . port3x1 _write ) ; this . dma . on _unmask ( this . dma _on _unmask , this ) ; b . register ( "dac-request-data" , function ( ) { this . dac _handle _request ( ) } ,
this ) ; b . register ( "speaker-has-initialized" , function ( ) { this . mixer _reset ( ) } , this ) ; b . send ( "speaker-confirm-initialized" ) ; this . dsp _reset ( ) }
2024-11-28 07:25:05 +01:00
Q . prototype . dsp _reset = function ( ) { this . write _buffer . clear ( ) ; this . read _buffer . clear ( ) ; this . command _size = this . command = 0 ; this . dummy _speaker _enabled = ! 1 ; this . test _register = 0 ; this . dsp _signed = this . dsp _16bit = this . dsp _stereo = this . dsp _highspeed = ! 1 ; this . dac _buffers [ 0 ] . clear ( ) ; this . dac _buffers [ 1 ] . clear ( ) ; this . dma _channel = this . dma _irq = this . dma _bytes _block = this . dma _bytes _left = this . dma _bytes _count = this . dma _sample _count = 0 ; this . dma _autoinit = ! 1 ; this . dma _buffer _uint8 . fill ( 0 ) ; this . dma _paused = this . dma _waiting _transfer =
2024-06-28 09:23:02 +02:00
! 1 ; this . e2 _value = 170 ; this . e2 _count = 0 ; this . sampling _rate = 22050 ; this . bytes _per _sample = 1 ; this . lower _irq ( 1 ) ; this . irq _triggered . fill ( 0 ) ; this . asp _registers . fill ( 0 ) ; this . asp _registers [ 5 ] = 1 ; this . asp _registers [ 9 ] = 248 } ;
2024-11-28 07:25:05 +01:00
Q . prototype . get _state = function ( ) { var a = [ ] ; a [ 2 ] = this . read _buffer _lastvalue ; a [ 3 ] = this . command ; a [ 4 ] = this . command _size ; a [ 5 ] = this . mixer _current _address ; a [ 6 ] = this . mixer _registers ; a [ 7 ] = this . dummy _speaker _enabled ; a [ 8 ] = this . test _register ; a [ 9 ] = this . dsp _highspeed ; a [ 10 ] = this . dsp _stereo ; a [ 11 ] = this . dsp _16bit ; a [ 12 ] = this . dsp _signed ; a [ 15 ] = this . dma _sample _count ; a [ 16 ] = this . dma _bytes _count ; a [ 17 ] = this . dma _bytes _left ; a [ 18 ] = this . dma _bytes _block ; a [ 19 ] = this . dma _irq ; a [ 20 ] = this . dma _channel ; a [ 21 ] = this . dma _channel _8bit ; a [ 22 ] =
2024-06-28 09:23:02 +02:00
this . dma _channel _16bit ; a [ 23 ] = this . dma _autoinit ; a [ 24 ] = this . dma _buffer _uint8 ; a [ 25 ] = this . dma _waiting _transfer ; a [ 26 ] = this . dma _paused ; a [ 27 ] = this . sampling _rate ; a [ 28 ] = this . bytes _per _sample ; a [ 29 ] = this . e2 _value ; a [ 30 ] = this . e2 _count ; a [ 31 ] = this . asp _registers ; a [ 33 ] = this . mpu _read _buffer _last _value ; a [ 34 ] = this . irq ; a [ 35 ] = this . irq _triggered ; return a } ;
2024-11-28 07:25:05 +01:00
Q . prototype . set _state = function ( a ) { this . read _buffer _lastvalue = a [ 2 ] ; this . command = a [ 3 ] ; this . command _size = a [ 4 ] ; this . mixer _current _address = a [ 5 ] ; this . mixer _registers = a [ 6 ] ; this . mixer _full _update ( ) ; this . dummy _speaker _enabled = a [ 7 ] ; this . test _register = a [ 8 ] ; this . dsp _highspeed = a [ 9 ] ; this . dsp _stereo = a [ 10 ] ; this . dsp _16bit = a [ 11 ] ; this . dsp _signed = a [ 12 ] ; this . dma _sample _count = a [ 15 ] ; this . dma _bytes _count = a [ 16 ] ; this . dma _bytes _left = a [ 17 ] ; this . dma _bytes _block = a [ 18 ] ; this . dma _irq = a [ 19 ] ; this . dma _channel = a [ 20 ] ; this . dma _channel _8bit =
2024-06-28 09:23:02 +02:00
a [ 21 ] ; this . dma _channel _16bit = a [ 22 ] ; this . dma _autoinit = a [ 23 ] ; this . dma _buffer _uint8 = a [ 24 ] ; this . dma _waiting _transfer = a [ 25 ] ; this . dma _paused = a [ 26 ] ; this . sampling _rate = a [ 27 ] ; this . bytes _per _sample = a [ 28 ] ; this . e2 _value = a [ 29 ] ; this . e2 _count = a [ 30 ] ; this . asp _registers = a [ 31 ] ; this . mpu _read _buffer _last _value = a [ 33 ] ; this . irq = a [ 34 ] ; this . irq _triggered = a [ 35 ] ; this . dma _buffer = this . dma _buffer _uint8 . buffer ; this . dma _buffer _int8 = new Int8Array ( this . dma _buffer ) ; this . dma _buffer _int16 = new Int16Array ( this . dma _buffer ) ; this . dma _buffer _uint16 =
2025-01-03 12:44:26 +01:00
new Uint16Array ( this . dma _buffer ) ; this . dma _syncbuffer = new h . SyncBuffer ( this . dma _buffer ) ; this . dma _paused ? this . bus . send ( "dac-disable" ) : this . bus . send ( "dac-enable" ) } ; Q . prototype . port2x0 _read = function ( ) { return 255 } ; Q . prototype . port2x1 _read = function ( ) { return 255 } ; Q . prototype . port2x2 _read = function ( ) { return 255 } ; Q . prototype . port2x3 _read = function ( ) { return 255 } ; Q . prototype . port2x4 _read = function ( ) { return this . mixer _current _address } ; Q . prototype . port2x5 _read = function ( ) { return this . mixer _read ( this . mixer _current _address ) } ;
Q . prototype . port2x6 _read = function ( ) { return 255 } ; Q . prototype . port2x7 _read = function ( ) { return 255 } ; Q . prototype . port2x8 _read = function ( ) { return 255 } ; Q . prototype . port2x9 _read = function ( ) { return 255 } ; Q . prototype . port2xA _read = function ( ) { this . read _buffer . length && ( this . read _buffer _lastvalue = this . read _buffer . shift ( ) ) ; B ( this . read _buffer _lastvalue ) ; String . fromCharCode ( this . read _buffer _lastvalue ) ; return this . read _buffer _lastvalue } ; Q . prototype . port2xB _read = function ( ) { return 255 } ; Q . prototype . port2xC _read = function ( ) { return 127 } ;
Q . prototype . port2xD _read = function ( ) { return 255 } ; Q . prototype . port2xE _read = function ( ) { this . irq _triggered [ 1 ] && this . lower _irq ( 1 ) ; return ( this . read _buffer . length && ! this . dsp _highspeed ) << 7 | 127 } ; Q . prototype . port2xF _read = function ( ) { this . lower _irq ( 2 ) ; return 0 } ; Q . prototype . port2x0 _write = function ( a ) { B ( a ) ; this . fm _current _address0 = 0 } ; Q . prototype . port2x1 _write = function ( a ) { B ( a ) ; var b = Wa [ this . fm _current _address0 ] ; b || ( b = this . fm _default _write ) ; b . call ( this , a , 0 , this . fm _current _address0 ) } ;
Q . prototype . port2x2 _write = function ( a ) { B ( a ) ; this . fm _current _address1 = 0 } ; Q . prototype . port2x3 _write = function ( a ) { B ( a ) ; var b = Wa [ this . fm _current _address1 ] ; b || ( b = this . fm _default _write ) ; b . call ( this , a , 1 , this . fm _current _address1 ) } ; Q . prototype . port2x4 _write = function ( a ) { B ( a ) ; this . mixer _current _address = a } ; Q . prototype . port2x5 _write = function ( a ) { B ( a ) ; this . mixer _write ( this . mixer _current _address , a ) } ;
Q . prototype . port2x6 _write = function ( a ) { B ( a ) ; this . dsp _highspeed ? this . dsp _highspeed = ! 1 : a && this . dsp _reset ( ) ; this . read _buffer . clear ( ) ; this . read _buffer . push ( 170 ) } ; Q . prototype . port2x7 _write = function ( ) { } ; Q . prototype . port2x8 _write = function ( ) { } ; Q . prototype . port2x9 _write = function ( ) { } ; Q . prototype . port2xA _write = function ( ) { } ; Q . prototype . port2xB _write = function ( ) { } ;
Q . prototype . port2xC _write = function ( a ) { 0 === this . command ? ( B ( a ) , this . command = a , this . write _buffer . clear ( ) , this . command _size = Ra [ a ] ) : ( B ( a ) , this . write _buffer . push ( a ) ) ; this . write _buffer . length >= this . command _size && this . command _do ( ) } ; Q . prototype . port2xD _write = function ( ) { } ; Q . prototype . port2xE _write = function ( ) { } ; Q . prototype . port2xF _write = function ( ) { } ;
Q . prototype . port3x0 _read = function ( ) { this . mpu _read _buffer . length && ( this . mpu _read _buffer _lastvalue = this . mpu _read _buffer . shift ( ) ) ; B ( this . mpu _read _buffer _lastvalue ) ; return this . mpu _read _buffer _lastvalue } ; Q . prototype . port3x0 _write = function ( a ) { B ( a ) } ; Q . prototype . port3x1 _read = function ( ) { return 0 | 128 * ! this . mpu _read _buffer . length } ; Q . prototype . port3x1 _write = function ( a ) { B ( a ) ; 255 === a && ( this . mpu _read _buffer . clear ( ) , this . mpu _read _buffer . push ( 254 ) ) } ;
Q . prototype . command _do = function ( ) { var a = Sa [ this . command ] ; a || ( a = this . dsp _default _handler ) ; a . call ( this ) ; this . command _size = this . command = 0 ; this . write _buffer . clear ( ) } ; Q . prototype . dsp _default _handler = function ( ) { B ( this . command ) } ; function U ( a , b , c ) { c || ( c = Q . prototype . dsp _default _handler ) ; for ( var d = 0 ; d < a . length ; d ++ ) Ra [ a [ d ] ] = b , Sa [ a [ d ] ] = c } function Xa ( a ) { for ( var b = [ ] , c = 0 ; 16 > c ; c ++ ) b . push ( a + c ) ; return b } U ( [ 14 ] , 2 , function ( ) { this . asp _registers [ this . write _buffer . shift ( ) ] = this . write _buffer . shift ( ) } ) ;
2024-11-28 07:25:05 +01:00
U ( [ 15 ] , 1 , function ( ) { this . read _buffer . clear ( ) ; this . read _buffer . push ( this . asp _registers [ this . write _buffer . shift ( ) ] ) } ) ; U ( [ 16 ] , 1 , function ( ) { var a = this . write _buffer . shift ( ) ; a = Ya ( a / 127.5 + - 1 , - 1 , 1 ) ; this . dac _buffers [ 0 ] . push ( a ) ; this . dac _buffers [ 1 ] . push ( a ) ; this . bus . send ( "dac-enable" ) } ) ; U ( [ 20 , 21 ] , 2 , function ( ) { this . dma _irq = 1 ; this . dma _channel = this . dma _channel _8bit ; this . dsp _highspeed = this . dsp _16bit = this . dsp _signed = this . dma _autoinit = ! 1 ; this . dma _transfer _size _set ( ) ; this . dma _transfer _start ( ) } ) ; U ( [ 22 ] , 2 ) ; U ( [ 23 ] , 2 ) ;
U ( [ 28 ] , 0 , function ( ) { this . dma _irq = 1 ; this . dma _channel = this . dma _channel _8bit ; this . dma _autoinit = ! 0 ; this . dsp _highspeed = this . dsp _16bit = this . dsp _signed = ! 1 ; this . dma _transfer _start ( ) } ) ; U ( [ 31 ] , 0 ) ; U ( [ 32 ] , 0 , function ( ) { this . read _buffer . clear ( ) ; this . read _buffer . push ( 127 ) } ) ; U ( [ 36 ] , 2 ) ; U ( [ 44 ] , 0 ) ; U ( [ 48 ] , 0 ) ; U ( [ 49 ] , 0 ) ; U ( [ 52 ] , 0 ) ; U ( [ 53 ] , 0 ) ; U ( [ 54 ] , 0 ) ; U ( [ 55 ] , 0 ) ; U ( [ 56 ] , 0 ) ; U ( [ 64 ] , 1 , function ( ) { this . sampling _rate _change ( 1E6 / ( 256 - this . write _buffer . shift ( ) ) / this . get _channel _count ( ) ) } ) ;
U ( [ 65 , 66 ] , 2 , function ( ) { this . sampling _rate _change ( this . write _buffer . shift ( ) << 8 | this . write _buffer . shift ( ) ) } ) ; U ( [ 72 ] , 2 , function ( ) { this . dma _transfer _size _set ( ) } ) ; U ( [ 116 ] , 2 ) ; U ( [ 117 ] , 2 ) ; U ( [ 118 ] , 2 ) ; U ( [ 119 ] , 2 ) ; U ( [ 125 ] , 0 ) ; U ( [ 127 ] , 0 ) ; U ( [ 128 ] , 2 ) ; U ( [ 144 ] , 0 , function ( ) { this . dma _irq = 1 ; this . dma _channel = this . dma _channel _8bit ; this . dma _autoinit = ! 0 ; this . dsp _signed = ! 1 ; this . dsp _highspeed = ! 0 ; this . dsp _16bit = ! 1 ; this . dma _transfer _start ( ) } ) ; U ( [ 145 ] , 0 ) ; U ( [ 152 ] , 0 ) ; U ( [ 153 ] , 0 ) ; U ( [ 160 ] , 0 ) ; U ( [ 168 ] , 0 ) ;
U ( Xa ( 176 ) , 3 , function ( ) { if ( this . command & 8 ) this . dsp _default _handler ( ) ; else { var a = this . write _buffer . shift ( ) ; this . dma _irq = 2 ; this . dma _channel = this . dma _channel _16bit ; this . dma _autoinit = ! ! ( this . command & 4 ) ; this . dsp _signed = ! ! ( a & 16 ) ; this . dsp _stereo = ! ! ( a & 32 ) ; this . dsp _16bit = ! 0 ; this . dma _transfer _size _set ( ) ; this . dma _transfer _start ( ) } } ) ;
U ( Xa ( 192 ) , 3 , function ( ) { if ( this . command & 8 ) this . dsp _default _handler ( ) ; else { var a = this . write _buffer . shift ( ) ; this . dma _irq = 1 ; this . dma _channel = this . dma _channel _8bit ; this . dma _autoinit = ! ! ( this . command & 4 ) ; this . dsp _signed = ! ! ( a & 16 ) ; this . dsp _stereo = ! ! ( a & 32 ) ; this . dsp _16bit = ! 1 ; this . dma _transfer _size _set ( ) ; this . dma _transfer _start ( ) } } ) ; U ( [ 208 ] , 0 , function ( ) { this . dma _paused = ! 0 ; this . bus . send ( "dac-disable" ) } ) ; U ( [ 209 ] , 0 , function ( ) { this . dummy _speaker _enabled = ! 0 } ) ; U ( [ 211 ] , 0 , function ( ) { this . dummy _speaker _enabled = ! 1 } ) ;
U ( [ 212 ] , 0 , function ( ) { this . dma _paused = ! 1 ; this . bus . send ( "dac-enable" ) } ) ; U ( [ 213 ] , 0 , function ( ) { this . dma _paused = ! 0 ; this . bus . send ( "dac-disable" ) } ) ; U ( [ 214 ] , 0 , function ( ) { this . dma _paused = ! 1 ; this . bus . send ( "dac-enable" ) } ) ; U ( [ 216 ] , 0 , function ( ) { this . read _buffer . clear ( ) ; this . read _buffer . push ( 255 * this . dummy _speaker _enabled ) } ) ; U ( [ 217 , 218 ] , 0 , function ( ) { this . dma _autoinit = ! 1 } ) ; U ( [ 224 ] , 1 , function ( ) { this . read _buffer . clear ( ) ; this . read _buffer . push ( ~ this . write _buffer . shift ( ) ) } ) ;
U ( [ 225 ] , 0 , function ( ) { this . read _buffer . clear ( ) ; this . read _buffer . push ( 4 ) ; this . read _buffer . push ( 5 ) } ) ; U ( [ 226 ] , 1 ) ; U ( [ 227 ] , 0 , function ( ) { this . read _buffer . clear ( ) ; for ( var a = 0 ; 44 > a ; a ++ ) this . read _buffer . push ( "COPYRIGHT (C) CREATIVE TECHNOLOGY LTD, 1992." . charCodeAt ( a ) ) ; this . read _buffer . push ( 0 ) } ) ; U ( [ 228 ] , 1 , function ( ) { this . test _register = this . write _buffer . shift ( ) } ) ; U ( [ 232 ] , 0 , function ( ) { this . read _buffer . clear ( ) ; this . read _buffer . push ( this . test _register ) } ) ; U ( [ 242 , 243 ] , 0 , function ( ) { this . raise _irq ( ) } ) ; var Za = new Uint8Array ( 256 ) ;
2025-01-03 12:44:26 +01:00
Za [ 14 ] = 255 ; Za [ 15 ] = 7 ; Za [ 55 ] = 56 ; U ( [ 249 ] , 1 , function ( ) { var a = this . write _buffer . shift ( ) ; this . read _buffer . clear ( ) ; this . read _buffer . push ( Za [ a ] ) } ) ; Q . prototype . mixer _read = function ( a ) { var b = Ta [ a ] ; b ? b = b . call ( this ) : ( b = this . mixer _registers [ a ] , B ( a ) , B ( b ) ) ; return b } ; Q . prototype . mixer _write = function ( a , b ) { var c = Ua [ a ] ; c ? c . call ( this , b ) : ( B ( a ) , B ( b ) ) } ; Q . prototype . mixer _default _read = function ( ) { B ( this . mixer _current _address ) ; return this . mixer _registers [ this . mixer _current _address ] } ;
Q . prototype . mixer _default _write = function ( a ) { B ( this . mixer _current _address ) ; B ( a ) ; this . mixer _registers [ this . mixer _current _address ] = a } ;
2024-11-28 07:25:05 +01:00
Q . prototype . mixer _reset = function ( ) { this . mixer _registers [ 4 ] = 204 ; this . mixer _registers [ 34 ] = 204 ; this . mixer _registers [ 38 ] = 204 ; this . mixer _registers [ 40 ] = 0 ; this . mixer _registers [ 46 ] = 0 ; this . mixer _registers [ 10 ] = 0 ; this . mixer _registers [ 48 ] = 192 ; this . mixer _registers [ 49 ] = 192 ; this . mixer _registers [ 50 ] = 192 ; this . mixer _registers [ 51 ] = 192 ; this . mixer _registers [ 52 ] = 192 ; this . mixer _registers [ 53 ] = 192 ; this . mixer _registers [ 54 ] = 0 ; this . mixer _registers [ 55 ] = 0 ; this . mixer _registers [ 56 ] = 0 ; this . mixer _registers [ 57 ] = 0 ; this . mixer _registers [ 59 ] =
0 ; this . mixer _registers [ 60 ] = 31 ; this . mixer _registers [ 61 ] = 21 ; this . mixer _registers [ 62 ] = 11 ; this . mixer _registers [ 63 ] = 0 ; this . mixer _registers [ 64 ] = 0 ; this . mixer _registers [ 65 ] = 0 ; this . mixer _registers [ 66 ] = 0 ; this . mixer _registers [ 67 ] = 0 ; this . mixer _registers [ 68 ] = 128 ; this . mixer _registers [ 69 ] = 128 ; this . mixer _registers [ 70 ] = 128 ; this . mixer _registers [ 71 ] = 128 ; this . mixer _full _update ( ) } ; Q . prototype . mixer _full _update = function ( ) { for ( var a = 1 ; a < this . mixer _registers . length ; a ++ ) Va [ a ] || this . mixer _write ( a , this . mixer _registers [ a ] ) } ;
function $a ( a , b ) { b || ( b = Q . prototype . mixer _default _read ) ; Ta [ a ] = b } function ab ( a , b ) { b || ( b = Q . prototype . mixer _default _write ) ; Ua [ a ] = b } function bb ( a , b , c ) { Va [ a ] = 1 ; Ta [ a ] = function ( ) { return this . mixer _registers [ b ] & 240 | this . mixer _registers [ c ] >>> 4 } ; Ua [ a ] = function ( d ) { this . mixer _registers [ a ] = d ; var e = d << 4 & 240 | this . mixer _registers [ c ] & 15 ; this . mixer _write ( b , d & 240 | this . mixer _registers [ b ] & 15 ) ; this . mixer _write ( c , e ) } }
2025-01-03 12:44:26 +01:00
function cb ( a , b , c ) { Ta [ a ] = Q . prototype . mixer _default _read ; Ua [ a ] = function ( d ) { this . mixer _registers [ a ] = d ; this . bus . send ( "mixer-volume" , [ b , c , ( d >>> 2 ) - 62 ] ) } } $a ( 0 , function ( ) { this . mixer _reset ( ) ; return 0 } ) ; ab ( 0 ) ; bb ( 4 , 50 , 51 ) ; bb ( 34 , 48 , 49 ) ; bb ( 38 , 52 , 53 ) ; bb ( 40 , 54 , 55 ) ; bb ( 46 , 56 , 57 ) ; cb ( 48 , 0 , 0 ) ; cb ( 49 , 0 , 1 ) ; cb ( 50 , 2 , 0 ) ; cb ( 51 , 2 , 1 ) ; $a ( 59 ) ; ab ( 59 , function ( a ) { this . mixer _registers [ 59 ] = a ; this . bus . send ( "mixer-volume" , [ 1 , 2 , 6 * ( a >>> 6 ) - 18 ] ) } ) ; $a ( 65 ) ;
2024-10-02 21:03:04 +02:00
ab ( 65 , function ( a ) { this . mixer _registers [ 65 ] = a ; this . bus . send ( "mixer-gain-left" , 6 * ( a >>> 6 ) ) } ) ; $a ( 66 ) ; ab ( 66 , function ( a ) { this . mixer _registers [ 66 ] = a ; this . bus . send ( "mixer-gain-right" , 6 * ( a >>> 6 ) ) } ) ; $a ( 68 ) ; ab ( 68 , function ( a ) { this . mixer _registers [ 68 ] = a ; a >>>= 3 ; this . bus . send ( "mixer-treble-left" , a - ( 16 > a ? 14 : 16 ) ) } ) ; $a ( 69 ) ; ab ( 69 , function ( a ) { this . mixer _registers [ 69 ] = a ; a >>>= 3 ; this . bus . send ( "mixer-treble-right" , a - ( 16 > a ? 14 : 16 ) ) } ) ; $a ( 70 ) ;
ab ( 70 , function ( a ) { this . mixer _registers [ 70 ] = a ; a >>>= 3 ; this . bus . send ( "mixer-bass-right" , a - ( 16 > a ? 14 : 16 ) ) } ) ; $a ( 71 ) ; ab ( 71 , function ( a ) { this . mixer _registers [ 71 ] = a ; a >>>= 3 ; this . bus . send ( "mixer-bass-right" , a - ( 16 > a ? 14 : 16 ) ) } ) ; $a ( 128 , function ( ) { switch ( this . irq ) { case 2 : return 1 ; case 5 : return 2 ; case 7 : return 4 ; case 10 : return 8 ; default : return 0 } } ) ; ab ( 128 , function ( a ) { a & 1 && ( this . irq = 2 ) ; a & 2 && ( this . irq = 5 ) ; a & 4 && ( this . irq = 7 ) ; a & 8 && ( this . irq = 10 ) } ) ;
$a ( 129 , function ( ) { var a = 0 ; switch ( this . dma _channel _8bit ) { case 0 : a |= 1 ; break ; case 1 : a |= 2 ; break ; case 3 : a |= 8 } switch ( this . dma _channel _16bit ) { case 5 : a |= 32 ; break ; case 6 : a |= 64 ; break ; case 7 : a |= 128 } return a } ) ; ab ( 129 , function ( a ) { a & 1 && ( this . dma _channel _8bit = 0 ) ; a & 2 && ( this . dma _channel _8bit = 1 ) ; a & 8 && ( this . dma _channel _8bit = 3 ) ; a & 32 && ( this . dma _channel _16bit = 5 ) ; a & 64 && ( this . dma _channel _16bit = 6 ) ; a & 128 && ( this . dma _channel _16bit = 7 ) } ) ; $a ( 130 , function ( ) { for ( var a = 32 , b = 0 ; 16 > b ; b ++ ) a |= b * this . irq _triggered [ b ] ; return a } ) ;
2025-01-03 12:44:26 +01:00
Q . prototype . fm _default _write = function ( a , b , c ) { B ( c ) ; B ( a ) } ; function ib ( a , b ) { b || ( b = Q . prototype . fm _default _write ) ; for ( var c = 0 ; c < a . length ; c ++ ) Wa [ a [ c ] ] = b } function jb ( a , b ) { for ( var c = [ ] ; a <= b ; a ++ ) c . push ( a ) ; return c } var kb = new Uint8Array ( 32 ) ; kb [ 0 ] = 0 ; kb [ 1 ] = 1 ; kb [ 2 ] = 2 ; kb [ 3 ] = 3 ; kb [ 4 ] = 4 ; kb [ 5 ] = 5 ; kb [ 8 ] = 6 ; kb [ 9 ] = 7 ; kb [ 10 ] = 8 ; kb [ 11 ] = 9 ; kb [ 12 ] = 10 ; kb [ 13 ] = 11 ; kb [ 16 ] = 12 ; kb [ 17 ] = 13 ; kb [ 18 ] = 14 ; kb [ 19 ] = 15 ; kb [ 20 ] = 16 ; kb [ 21 ] = 17 ; ib ( [ 1 ] , function ( a , b ) { this . fm _waveform _select _enable [ b ] = a & 1 ; this . fm _update _waveforms ( ) } ) ; ib ( [ 2 ] ) ; ib ( [ 3 ] ) ;
2024-11-28 07:25:05 +01:00
ib ( [ 4 ] , function ( ) { } ) ; ib ( [ 5 ] , function ( a , b , c ) { 0 === b && this . fm _default _write ( a , b , c ) } ) ; ib ( [ 8 ] , function ( ) { } ) ; ib ( jb ( 32 , 53 ) , function ( ) { } ) ; ib ( jb ( 64 , 85 ) , function ( ) { } ) ; ib ( jb ( 96 , 117 ) , function ( ) { } ) ; ib ( jb ( 128 , 149 ) , function ( ) { } ) ; ib ( jb ( 160 , 168 ) , function ( ) { } ) ; ib ( jb ( 176 , 184 ) , function ( ) { } ) ; ib ( [ 189 ] , function ( ) { } ) ; ib ( jb ( 192 , 200 ) , function ( ) { } ) ; ib ( jb ( 224 , 245 ) , function ( ) { } ) ; Q . prototype . fm _update _waveforms = function ( ) { } ;
Q . prototype . sampling _rate _change = function ( a ) { this . sampling _rate = a ; this . bus . send ( "dac-tell-sampling-rate" , a ) } ; Q . prototype . get _channel _count = function ( ) { return this . dsp _stereo ? 2 : 1 } ; Q . prototype . dma _transfer _size _set = function ( ) { this . dma _sample _count = 1 + ( this . write _buffer . shift ( ) << 0 ) + ( this . write _buffer . shift ( ) << 8 ) } ;
Q . prototype . dma _transfer _start = function ( ) { this . bytes _per _sample = 1 ; this . dsp _16bit && ( this . bytes _per _sample *= 2 ) ; this . dma _bytes _count = this . dma _sample _count * this . bytes _per _sample ; this . dma _bytes _block = 1024 * this . bytes _per _sample ; this . dma _bytes _block = Math . min ( Math . max ( this . dma _bytes _count >> 2 & - 4 , 32 ) , this . dma _bytes _block ) ; this . dma _waiting _transfer = ! 0 ; this . dma . channel _mask [ this . dma _channel ] || this . dma _on _unmask ( this . dma _channel ) } ;
Q . prototype . dma _on _unmask = function ( a ) { a === this . dma _channel && this . dma _waiting _transfer && ( this . dma _waiting _transfer = ! 1 , this . dma _bytes _left = this . dma _bytes _count , this . dma _paused = ! 1 , this . bus . send ( "dac-enable" ) ) } ;
Q . prototype . dma _transfer _next = function ( ) { var a = Math . min ( this . dma _bytes _left , this . dma _bytes _block ) , b = Math . floor ( a / this . bytes _per _sample ) ; this . dma . do _write ( this . dma _syncbuffer , 0 , a , this . dma _channel , c => { c || ( this . dma _to _dac ( b ) , this . dma _bytes _left -= a , this . dma _bytes _left || ( this . raise _irq ( this . dma _irq ) , this . dma _autoinit && ( this . dma _bytes _left = this . dma _bytes _count ) ) ) } ) } ;
2025-01-03 12:44:26 +01:00
Q . prototype . dma _to _dac = function ( a ) { var b = this . dsp _16bit ? 32767.5 : 127.5 , c = this . dsp _signed ? 0 : - 1 , d = this . dsp _stereo ? 1 : 2 ; var e = this . dsp _16bit ? this . dsp _signed ? this . dma _buffer _int16 : this . dma _buffer _uint16 : this . dsp _signed ? this . dma _buffer _int8 : this . dma _buffer _uint8 ; for ( var g = 0 , f = 0 ; f < a ; f ++ ) for ( var k = Ya ( e [ f ] / b + c , - 1 , 1 ) , l = 0 ; l < d ; l ++ ) this . dac _buffers [ g ] . push ( k ) , g ^= 1 ; this . dac _send ( ) } ; Q . prototype . dac _handle _request = function ( ) { ! this . dma _bytes _left || this . dma _paused ? this . dac _send ( ) : this . dma _transfer _next ( ) } ;
Q . prototype . dac _send = function ( ) { if ( this . dac _buffers [ 0 ] . length ) { var a = this . dac _buffers [ 0 ] . shift _block ( this . dac _buffers [ 0 ] . length ) , b = this . dac _buffers [ 1 ] . shift _block ( this . dac _buffers [ 1 ] . length ) ; this . bus . send ( "dac-send-data" , [ a , b ] , [ a . buffer , b . buffer ] ) } } ; Q . prototype . raise _irq = function ( a ) { this . irq _triggered [ a ] = 1 ; this . cpu . device _raise _irq ( this . irq ) } ; Q . prototype . lower _irq = function ( a ) { this . irq _triggered [ a ] = 0 ; this . cpu . device _lower _irq ( this . irq ) } ; function Ya ( a , b , c ) { return ( a < b ) * b + ( a > c ) * c + ( b <= a && a <= c ) * a } ; function da ( a , b ) { this . cpu = a ; this . pci = a . devices . pci ; this . device _id = b . device _id ; this . pci _space = [ 244 , 26 , b . device _id & 255 , b . device _id >> 8 , 7 , 5 , 16 , 0 , 1 , 0 , 2 , 0 , 0 , 0 , 0 , 0 , 1 , 168 , 0 , 0 , 0 , 16 , 191 , 254 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 244 , 26 , b . subsystem _device _id & 255 , b . subsystem _device _id >> 8 , 0 , 0 , 0 , 0 , 64 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 1 , 0 , 0 ] ; this . pci _space = this . pci _space . concat ( h . zeros ( 256 - this . pci _space . length ) ) ; this . pci _id = b . pci _id ; this . pci _bars = [ ] ; this . name = b . name ; this . driver _feature _select = this . device _feature _select = 0 ; this . device _feature =
2024-11-28 07:25:05 +01:00
new Uint32Array ( 4 ) ; this . driver _feature = new Uint32Array ( 4 ) ; for ( var c of b . common . features ) this . device _feature [ c >>> 5 ] |= 1 << ( c & 31 ) , this . driver _feature [ c >>> 5 ] |= 1 << ( c & 31 ) ; b . common . features . includes ( 32 ) ; this . features _ok = ! 0 ; this . device _status = 0 ; this . config _has _changed = ! 1 ; this . config _generation = 0 ; this . queues = [ ] ; for ( const d of b . common . queues ) this . queues . push ( new V ( a , this , d ) ) ; this . queue _select = 0 ; this . queue _selected = this . queues [ 0 ] ; this . isr _status = 0 ; c = [ ] ; c . push ( this . create _common _capability ( b . common ) ) ; c . push ( this . create _notification _capability ( b . notification ) ) ;
2024-06-28 09:23:02 +02:00
c . push ( this . create _isr _capability ( b . isr _status ) ) ; b . device _specific && c . push ( this . create _device _specific _capability ( b . device _specific ) ) ; this . init _capabilities ( c ) ; a . devices . pci . register _device ( this ) ; this . reset ( ) }
2024-11-28 07:25:05 +01:00
da . prototype . create _common _capability = function ( a ) { return { type : 1 , bar : 0 , port : a . initial _port , use _mmio : ! 1 , offset : 0 , extra : new Uint8Array ( 0 ) , struct : [ { bytes : 4 , name : "device_feature_select" , read : ( ) => this . device _feature _select , write : b => { this . device _feature _select = b } } , { bytes : 4 , name : "device_feature" , read : ( ) => this . device _feature [ this . device _feature _select ] || 0 , write : ( ) => { } } , { bytes : 4 , name : "driver_feature_select" , read : ( ) => this . driver _feature _select , write : b => { this . driver _feature _select = b } } , { bytes : 4 , name : "driver_feature" ,
2024-06-28 09:23:02 +02:00
read : ( ) => this . driver _feature [ this . driver _feature _select ] || 0 , write : b => { const c = this . device _feature [ this . driver _feature _select ] ; this . driver _feature _select < this . driver _feature . length && ( this . driver _feature [ this . driver _feature _select ] = b & c ) ; this . features _ok = this . features _ok && ! ( b & ~ c ) } } , { bytes : 2 , name : "msix_config" , read : ( ) => 65535 , write : ( ) => { } } , { bytes : 2 , name : "num_queues" , read : ( ) => this . queues . length , write : ( ) => { } } , { bytes : 1 , name : "device_status" , read : ( ) => this . device _status , write : b => { 0 === b && this . reset ( ) ; b & ~ this . device _status &
4 && this . device _status & 64 && this . notify _config _changes ( ) ; this . features _ok || ( b &= - 9 ) ; this . device _status = b ; if ( b & ~ this . device _status & 4 ) a . on _driver _ok ( ) } } , { bytes : 1 , name : "config_generation" , read : ( ) => this . config _generation , write : ( ) => { } } , { bytes : 2 , name : "queue_select" , read : ( ) => this . queue _select , write : b => { this . queue _select = b ; this . queue _selected = this . queue _select < this . queues . length ? this . queues [ this . queue _select ] : null } } , { bytes : 2 , name : "queue_size" , read : ( ) => this . queue _selected ? this . queue _selected . size : 0 , write : b =>
2025-01-03 12:44:26 +01:00
{ this . queue _selected && ( b & b - 1 && ( b = 1 << h . int _log2 ( b - 1 ) + 1 ) , b > this . queue _selected . size _supported && ( b = this . queue _selected . size _supported ) , this . queue _selected . set _size ( b ) ) } } , { bytes : 2 , name : "queue_msix_vector" , read : ( ) => 65535 , write : ( ) => { } } , { bytes : 2 , name : "queue_enable" , read : ( ) => this . queue _selected ? this . queue _selected . enabled | 0 : 0 , write : b => { this . queue _selected && 1 === b && this . queue _selected . is _configured ( ) && this . queue _selected . enable ( ) } } , { bytes : 2 , name : "queue_notify_off" , read : ( ) => this . queue _selected ? this . queue _selected . notify _offset :
2024-06-28 09:23:02 +02:00
0 , write : ( ) => { } } , { bytes : 4 , name : "queue_desc (low dword)" , read : ( ) => this . queue _selected ? this . queue _selected . desc _addr : 0 , write : b => { this . queue _selected && ( this . queue _selected . desc _addr = b ) } } , { bytes : 4 , name : "queue_desc (high dword)" , read : ( ) => 0 , write : ( ) => { } } , { bytes : 4 , name : "queue_avail (low dword)" , read : ( ) => this . queue _selected ? this . queue _selected . avail _addr : 0 , write : b => { this . queue _selected && ( this . queue _selected . avail _addr = b ) } } , { bytes : 4 , name : "queue_avail (high dword)" , read : ( ) => 0 , write : ( ) => { } } , { bytes : 4 , name : "queue_used (low dword)" ,
read : ( ) => this . queue _selected ? this . queue _selected . used _addr : 0 , write : b => { this . queue _selected && ( this . queue _selected . used _addr = b ) } } , { bytes : 4 , name : "queue_used (high dword)" , read : ( ) => 0 , write : ( ) => { } } ] } } ;
2024-11-28 07:25:05 +01:00
da . prototype . create _notification _capability = function ( a ) { const b = [ ] ; let c ; c = a . single _handler ? 0 : 2 ; for ( const [ d , e ] of a . handlers . entries ( ) ) b . push ( { bytes : 2 , name : "notify" + d , read : ( ) => 65535 , write : e || ( ( ) => { } ) } ) ; return { type : 2 , bar : 1 , port : a . initial _port , use _mmio : ! 1 , offset : 0 , extra : new Uint8Array ( [ c & 255 , c >> 8 & 255 , c >> 16 & 255 , c >> 24 ] ) , struct : b } } ;
da . prototype . create _isr _capability = function ( a ) { return { type : 3 , bar : 2 , port : a . initial _port , use _mmio : ! 1 , offset : 0 , extra : new Uint8Array ( 0 ) , struct : [ { bytes : 1 , name : "isr_status" , read : ( ) => { const b = this . isr _status ; this . lower _irq ( ) ; return b } , write : ( ) => { } } ] } } ; da . prototype . create _device _specific _capability = function ( a ) { return { type : 4 , bar : 3 , port : a . initial _port , use _mmio : ! 1 , offset : 0 , extra : new Uint8Array ( 0 ) , struct : a . struct } } ;
2025-01-03 12:44:26 +01:00
da . prototype . init _capabilities = function ( a ) { let b = this . pci _space [ 52 ] = 64 ; var c = b ; for ( const e of a ) { a = 16 + e . extra . length ; c = b ; b = c + a ; var d = e . struct . reduce ( ( g , f ) => g + f . bytes , 0 ) ; d += e . offset ; d = 16 > d ? 16 : 1 << h . int _log2 ( d - 1 ) + 1 ; this . pci _bars [ e . bar ] = { size : d } ; this . pci _space [ c ] = 9 ; this . pci _space [ c + 1 ] = b ; this . pci _space [ c + 2 ] = a ; this . pci _space [ c + 3 ] = e . type ; this . pci _space [ c + 4 ] = e . bar ; this . pci _space [ c + 5 ] = 0 ; this . pci _space [ c + 6 ] = 0 ; this . pci _space [ c + 7 ] = 0 ; this . pci _space [ c + 8 ] = e . offset & 255 ; this . pci _space [ c + 9 ] = e . offset >>> 8 & 255 ; this . pci _space [ c +
2024-11-28 07:25:05 +01:00
10 ] = e . offset >>> 16 & 255 ; this . pci _space [ c + 11 ] = e . offset >>> 24 ; this . pci _space [ c + 12 ] = d & 255 ; this . pci _space [ c + 13 ] = d >>> 8 & 255 ; this . pci _space [ c + 14 ] = d >>> 16 & 255 ; this . pci _space [ c + 15 ] = d >>> 24 ; for ( const [ g , f ] of e . extra . entries ( ) ) this . pci _space [ c + 16 + g ] = f ; c = 16 + 4 * e . bar ; this . pci _space [ c ] = e . port & 254 | ! e . use _mmio ; this . pci _space [ c + 1 ] = e . port >>> 8 & 255 ; this . pci _space [ c + 2 ] = e . port >>> 16 & 255 ; this . pci _space [ c + 3 ] = e . port >>> 24 & 255 ; c = e . port + e . offset ; for ( const g of e . struct ) { let f = g . read ; a = g . write ; if ( ! e . use _mmio ) { d = function ( l ) { return f ( l &
2025-01-03 12:44:26 +01:00
- 2 ) >> ( ( l & 1 ) << 3 ) & 255 } ; const k = function ( l ) { return f ( l & - 4 ) >> ( ( l & 3 ) << 3 ) & 255 } ; switch ( g . bytes ) { case 4 : this . cpu . io . register _read ( c , this , k , void 0 , f ) ; this . cpu . io . register _write ( c , this , void 0 , void 0 , a ) ; break ; case 2 : this . cpu . io . register _read ( c , this , d , f ) ; this . cpu . io . register _write ( c , this , void 0 , a ) ; break ; case 1 : this . cpu . io . register _read ( c , this , f ) , this . cpu . io . register _write ( c , this , a ) } } c += g . bytes } } this . pci _space [ b ] = 9 ; this . pci _space [ b + 1 ] = 0 ; this . pci _space [ b + 2 ] = 20 ; this . pci _space [ b + 3 ] = 5 ; this . pci _space [ b + 4 ] = 0 ; this . pci _space [ b +
2024-06-28 09:23:02 +02:00
5 ] = 0 ; this . pci _space [ b + 6 ] = 0 ; this . pci _space [ b + 7 ] = 0 ; this . pci _space [ b + 8 ] = 0 ; this . pci _space [ b + 9 ] = 0 ; this . pci _space [ b + 10 ] = 0 ; this . pci _space [ b + 11 ] = 0 ; this . pci _space [ b + 12 ] = 0 ; this . pci _space [ b + 13 ] = 0 ; this . pci _space [ b + 14 ] = 0 ; this . pci _space [ b + 15 ] = 0 ; this . pci _space [ b + 16 ] = 0 ; this . pci _space [ b + 17 ] = 0 ; this . pci _space [ b + 18 ] = 0 ; this . pci _space [ b + 19 ] = 0 } ;
2024-11-28 07:25:05 +01:00
da . prototype . get _state = function ( ) { let a = [ ] ; a [ 0 ] = this . device _feature _select ; a [ 1 ] = this . driver _feature _select ; a [ 2 ] = this . device _feature ; a [ 3 ] = this . driver _feature ; a [ 4 ] = this . features _ok ; a [ 5 ] = this . device _status ; a [ 6 ] = this . config _has _changed ; a [ 7 ] = this . config _generation ; a [ 8 ] = this . isr _status ; a [ 9 ] = this . queue _select ; return a = a . concat ( this . queues ) } ;
da . prototype . set _state = function ( a ) { this . device _feature _select = a [ 0 ] ; this . driver _feature _select = a [ 1 ] ; this . device _feature = a [ 2 ] ; this . driver _feature = a [ 3 ] ; this . features _ok = a [ 4 ] ; this . device _status = a [ 5 ] ; this . config _has _changed = a [ 6 ] ; this . config _generation = a [ 7 ] ; this . isr _status = a [ 8 ] ; this . queue _select = a [ 9 ] ; let b = 0 ; for ( const c of a . slice ( 10 ) ) this . queues [ b ] . set _state ( c ) , b ++ ; this . queue _selected = this . queues [ this . queue _select ] || null } ;
da . prototype . reset = function ( ) { this . driver _feature _select = this . device _feature _select = 0 ; this . driver _feature . set ( this . device _feature ) ; this . features _ok = ! 0 ; this . queue _select = this . device _status = 0 ; this . queue _selected = this . queues [ 0 ] ; for ( const a of this . queues ) a . reset ( ) ; this . config _has _changed = ! 1 ; this . config _generation = 0 ; this . lower _irq ( ) } ; da . prototype . notify _config _changes = function ( ) { this . config _has _changed = ! 0 ; this . device _status & 4 && this . raise _irq ( 2 ) } ;
2025-01-03 12:44:26 +01:00
da . prototype . update _config _generation = function ( ) { this . config _has _changed && ( this . config _generation ++ , this . config _generation &= 255 , this . config _has _changed = ! 1 ) } ; da . prototype . is _feature _negotiated = function ( a ) { return 0 < ( this . driver _feature [ a >>> 5 ] & 1 << ( a & 31 ) ) } ; da . prototype . needs _reset = function ( ) { this . device _status |= 64 ; this . device _status & 4 && this . notify _config _changes ( ) } ; da . prototype . raise _irq = function ( a ) { B ( a ) ; this . isr _status |= a ; this . pci . raise _irq ( this . pci _id ) } ;
2024-11-28 07:25:05 +01:00
da . prototype . lower _irq = function ( ) { this . isr _status = 0 ; this . pci . lower _irq ( this . pci _id ) } ; function V ( a , b , c ) { this . cpu = a ; this . virtio = b ; this . size _supported = this . size = c . size _supported ; this . mask = this . size - 1 ; this . enabled = ! 1 ; this . notify _offset = c . notify _offset ; this . num _staged _replies = this . used _addr = this . avail _last _idx = this . avail _addr = this . desc _addr = 0 ; this . reset ( ) }
V . prototype . get _state = function ( ) { const a = [ ] ; a [ 0 ] = this . size ; a [ 1 ] = this . size _supported ; a [ 2 ] = this . enabled ; a [ 3 ] = this . notify _offset ; a [ 4 ] = this . desc _addr ; a [ 5 ] = this . avail _addr ; a [ 6 ] = this . avail _last _idx ; a [ 7 ] = this . used _addr ; a [ 8 ] = this . num _staged _replies ; return a } ;
V . prototype . set _state = function ( a ) { this . size = a [ 0 ] ; this . size _supported = a [ 1 ] ; this . enabled = a [ 2 ] ; this . notify _offset = a [ 3 ] ; this . desc _addr = a [ 4 ] ; this . avail _addr = a [ 5 ] ; this . avail _last _idx = a [ 6 ] ; this . used _addr = a [ 7 ] ; this . num _staged _replies = a [ 8 ] ; this . mask = this . size - 1 } ; V . prototype . reset = function ( ) { this . enabled = ! 1 ; this . num _staged _replies = this . used _addr = this . avail _last _idx = this . avail _addr = this . desc _addr = 0 ; this . set _size ( this . size _supported ) } ;
V . prototype . is _configured = function ( ) { return this . desc _addr && this . avail _addr && this . used _addr } ; V . prototype . enable = function ( ) { this . is _configured ( ) ; this . enabled = ! 0 } ; V . prototype . set _size = function ( a ) { this . size = a ; this . mask = a - 1 } ; V . prototype . count _requests = function ( ) { return this . avail _get _idx ( ) - this . avail _last _idx & this . mask } ; V . prototype . has _request = function ( ) { return ( this . avail _get _idx ( ) & this . mask ) !== this . avail _last _idx } ;
V . prototype . pop _request = function ( ) { this . has _request ( ) ; var a = this . avail _get _entry ( this . avail _last _idx ) ; a = new lb ( this , a ) ; this . avail _last _idx = this . avail _last _idx + 1 & this . mask ; return a } ; V . prototype . push _reply = function ( a ) { const b = this . used _get _idx ( ) + this . num _staged _replies & this . mask ; this . used _set _entry ( b , a . head _idx , a . length _written ) ; this . num _staged _replies ++ } ;
V . prototype . flush _replies = function ( ) { if ( 0 !== this . num _staged _replies ) { var a = this . used _get _idx ( ) + this . num _staged _replies & 65535 ; this . used _set _idx ( a ) ; this . num _staged _replies = 0 ; this . virtio . is _feature _negotiated ( 29 ) ? ( this . avail _get _used _event ( ) , this . virtio . raise _irq ( 1 ) ) : ~ this . avail _get _flags ( ) & 1 && this . virtio . raise _irq ( 1 ) } } ; V . prototype . notify _me _after = function ( a ) { a = this . avail _get _idx ( ) + a & 65535 ; this . used _set _avail _event ( a ) } ;
V . prototype . get _descriptor = function ( a , b ) { return { addr _low : this . cpu . read32s ( a + 16 * b ) , addr _high : this . cpu . read32s ( a + 16 * b + 4 ) , len : this . cpu . read32s ( a + 16 * b + 8 ) , flags : this . cpu . read16 ( a + 16 * b + 12 ) , next : this . cpu . read16 ( a + 16 * b + 14 ) } } ; V . prototype . avail _get _flags = function ( ) { return this . cpu . read16 ( this . avail _addr ) } ; V . prototype . avail _get _idx = function ( ) { return this . cpu . read16 ( this . avail _addr + 2 ) } ; V . prototype . avail _get _entry = function ( a ) { return this . cpu . read16 ( this . avail _addr + 4 + 2 * a ) } ;
V . prototype . avail _get _used _event = function ( ) { return this . cpu . read16 ( this . avail _addr + 4 + 2 * this . size ) } ; V . prototype . used _get _flags = function ( ) { return this . cpu . read16 ( this . used _addr ) } ; V . prototype . used _set _flags = function ( a ) { this . cpu . write16 ( this . used _addr , a ) } ; V . prototype . used _get _idx = function ( ) { return this . cpu . read16 ( this . used _addr + 2 ) } ; V . prototype . used _set _idx = function ( a ) { this . cpu . write16 ( this . used _addr + 2 , a ) } ;
V . prototype . used _set _entry = function ( a , b , c ) { this . cpu . write32 ( this . used _addr + 4 + 8 * a , b ) ; this . cpu . write32 ( this . used _addr + 8 + 8 * a , c ) } ; V . prototype . used _set _avail _event = function ( a ) { this . cpu . write16 ( this . used _addr + 4 + 8 * this . size , a ) } ;
2025-01-03 12:44:26 +01:00
function lb ( a , b ) { this . cpu = a . cpu ; this . virtio = a . virtio ; this . head _idx = b ; this . read _buffers = [ ] ; this . length _readable = this . read _buffer _offset = this . read _buffer _idx = 0 ; this . write _buffers = [ ] ; this . length _writable = this . length _written = this . write _buffer _offset = this . write _buffer _idx = 0 ; let c = a . desc _addr , d = 0 , e = a . size , g = ! 1 ; const f = this . virtio . is _feature _negotiated ( 28 ) ; do { const k = a . get _descriptor ( c , b ) ; B ( k . addr _high , 8 ) ; B ( k . addr _low , 8 ) ; B ( k . len , 8 ) ; B ( k . flags , 4 ) ; B ( k . next , 4 ) ; if ( f && k . flags & 4 ) c = k . addr _low , d = b = 0 , e = k . len / 16 ; else { if ( k . flags &
2 ) g = ! 0 , this . write _buffers . push ( k ) , this . length _writable += k . len ; else { if ( g ) break ; this . read _buffers . push ( k ) ; this . length _readable += k . len } d ++ ; if ( d > e ) break ; if ( k . flags & 1 ) b = k . next ; else break } } while ( 1 ) }
2024-11-28 07:25:05 +01:00
lb . prototype . get _next _blob = function ( a ) { let b = 0 , c = a . length ; for ( ; c && this . read _buffer _idx !== this . read _buffers . length ; ) { var d = this . read _buffers [ this . read _buffer _idx ] ; const e = d . addr _low + this . read _buffer _offset ; d = d . len - this . read _buffer _offset ; d > c ? ( d = c , this . read _buffer _offset += c ) : ( this . read _buffer _idx ++ , this . read _buffer _offset = 0 ) ; a . set ( this . cpu . read _blob ( e , d ) , b ) ; b += d ; c -= d } return b } ;
lb . prototype . set _next _blob = function ( a ) { let b = 0 , c = a . length ; for ( ; c && this . write _buffer _idx !== this . write _buffers . length ; ) { var d = this . write _buffers [ this . write _buffer _idx ] ; const e = d . addr _low + this . write _buffer _offset ; d = d . len - this . write _buffer _offset ; d > c ? ( d = c , this . write _buffer _offset += c ) : ( this . write _buffer _idx ++ , this . write _buffer _offset = 0 ) ; this . cpu . write _blob ( a . subarray ( b , b + d ) , e ) ; b += d ; c -= d } this . length _written += b ; return b } ; function mb ( a , b ) { this . bus = b ; this . rows = 25 ; this . cols = 80 ; this . ports = 4 ; b = [ { size _supported : 16 , notify _offset : 0 } , { size _supported : 16 , notify _offset : 1 } , { size _supported : 16 , notify _offset : 2 } , { size _supported : 16 , notify _offset : 3 } ] ; for ( let c = 1 ; c < this . ports ; ++ c ) b . push ( { size _supported : 16 , notify _offset : 0 } ) , b . push ( { size _supported : 8 , notify _offset : 1 } ) ; this . virtio = new da ( a , { name : "virtio-console" , pci _id : 56 , device _id : 4163 , subsystem _device _id : 3 , common : { initial _port : 47104 , queues : b , features : [ 0 , 1 , 32 ] , on _driver _ok : ( ) => { } } , notification : { initial _port : 47360 ,
single _handler : ! 1 , handlers : [ c => { for ( c = this . virtio . queues [ c ] ; c . count _requests ( ) > c . size - 2 ; ) c . pop _request ( ) } , c => { const d = this . virtio . queues [ c ] , e = 3 < c ? c - 3 >> 1 : 0 ; for ( ; d . has _request ( ) ; ) { const g = d . pop _request ( ) , f = new Uint8Array ( g . length _readable ) ; g . get _next _blob ( f ) ; this . bus . send ( "virtio-console" + e + "-output-bytes" , f ) ; this . Ack ( c , g ) } } , c => { if ( 2 === c ) for ( c = this . virtio . queues [ c ] ; c . count _requests ( ) > c . size - 2 ; ) c . pop _request ( ) } , c => { if ( 3 === c ) for ( var d = this . virtio . queues [ c ] ; d . has _request ( ) ; ) { var e = d . pop _request ( ) , g = new Uint8Array ( e . length _readable ) ;
2025-01-03 12:44:26 +01:00
e . get _next _blob ( g ) ; var f = t . Unmarshall ( [ "w" , "h" , "h" ] , g , { offset : 0 } ) ; g = f [ 0 ] ; f = f [ 1 ] ; this . Ack ( c , e ) ; switch ( f ) { case 0 : for ( e = 0 ; e < this . ports ; ++ e ) this . SendEvent ( e , 1 , 0 ) ; break ; case 3 : this . Ack ( c , e ) ; this . SendEvent ( g , 4 , 1 ) ; this . SendName ( g , "virtio-" + g ) ; this . SendEvent ( g , 6 , 1 ) ; break ; case 6 : this . Ack ( c , e ) ; 0 === g && this . SendWindowSize ( g ) ; break ; default : return } } } ] } , isr _status : { initial _port : 46848 } , device _specific : { initial _port : 46592 , struct : [ { bytes : 2 , name : "cols" , read : ( ) => this . cols , write : ( ) => { } } , { bytes : 2 , name : "rows" , read : ( ) =>
2024-11-28 07:25:05 +01:00
this . rows , write : ( ) => { } } , { bytes : 4 , name : "max_nr_ports" , read : ( ) => this . ports , write : ( ) => { } } , { bytes : 4 , name : "emerg_wr" , read : ( ) => 0 , write : ( ) => { } } ] } } ) ; for ( let c = 0 ; c < this . ports ; ++ c ) { const d = 0 === c ? 0 : 2 * c + 2 ; this . bus . register ( "virtio-console" + c + "-input-bytes" , function ( e ) { var g = this . virtio . queues [ d ] ; g . has _request ( ) && ( g = g . pop _request ( ) , this . Send ( d , g , new Uint8Array ( e ) ) ) } , this ) ; this . bus . register ( "virtio-console" + c + "-resize" , function ( e ) { this . cols = e [ 0 ] ; this . rows = e [ 1 ] ; this . virtio . queues [ 2 ] . is _configured ( ) && this . virtio . queues [ 2 ] . has _request ( ) &&
2025-01-03 12:44:26 +01:00
this . SendWindowSize ( c ) } , this ) } } mb . prototype . SendWindowSize = function ( a ) { const b = this . virtio . queues [ 2 ] . pop _request ( ) , c = new Uint8Array ( 12 ) ; t . Marshall ( [ "w" , "h" , "h" , "h" , "h" ] , [ a , 5 , 0 , this . rows , this . cols ] , c , 0 ) ; this . Send ( 2 , b , c ) } ; mb . prototype . SendName = function ( a , b ) { const c = this . virtio . queues [ 2 ] . pop _request ( ) ; b = ( new TextEncoder ) . encode ( b ) ; const d = new Uint8Array ( 8 + b . length + 1 ) ; t . Marshall ( [ "w" , "h" , "h" ] , [ a , 7 , 1 ] , d , 0 ) ; for ( a = 0 ; a < b . length ; ++ a ) d [ a + 8 ] = b [ a ] ; d [ 8 + b . length ] = 0 ; this . Send ( 2 , c , d ) } ;
mb . prototype . get _state = function ( ) { const a = [ ] ; a [ 0 ] = this . virtio ; a [ 1 ] = this . rows ; a [ 2 ] = this . cols ; a [ 3 ] = this . ports ; return a } ; mb . prototype . set _state = function ( a ) { this . virtio . set _state ( a [ 0 ] ) ; this . rows = a [ 1 ] ; this . cols = a [ 2 ] ; this . ports = a [ 3 ] } ; mb . prototype . reset = function ( ) { this . virtio . reset ( ) } ; mb . prototype . SendEvent = function ( a , b , c ) { const d = this . virtio . queues [ 2 ] . pop _request ( ) , e = new Uint8Array ( 8 ) ; t . Marshall ( [ "w" , "h" , "h" ] , [ a , b , c ] , e , 0 ) ; this . Send ( 2 , d , e ) } ;
2024-11-28 07:25:05 +01:00
mb . prototype . Send = function ( a , b , c ) { b . set _next _blob ( c ) ; this . virtio . queues [ a ] . push _reply ( b ) ; this . virtio . queues [ a ] . flush _replies ( ) } ; mb . prototype . Ack = function ( a , b ) { b . set _next _blob ( new Uint8Array ( 0 ) ) ; this . virtio . queues [ a ] . push _reply ( b ) ; this . virtio . queues [ a ] . flush _replies ( ) } ; function nb ( a , b , c ) { this . bus = b ; this . id = a . devices . net ? 1 : 0 ; this . status = this . pairs = 1 ; this . preserve _mac _from _state _image = c ; this . mac = new Uint8Array ( [ 0 , 34 , 21 , 255 * Math . random ( ) | 0 , 255 * Math . random ( ) | 0 , 255 * Math . random ( ) | 0 ] ) ; this . bus . send ( "net" + this . id + "-mac" , Pa ( this . mac ) ) ; b = [ ] ; for ( c = 0 ; c < this . pairs ; ++ c ) b . push ( { size _supported : 32 , notify _offset : 0 } ) , b . push ( { size _supported : 32 , notify _offset : 1 } ) ; b . push ( { size _supported : 16 , notify _offset : 2 } ) ; this . virtio = new da ( a , { name : "virtio-net" , pci _id : 80 , device _id : 4161 , subsystem _device _id : 1 ,
common : { initial _port : 51200 , queues : b , features : [ 5 , 16 , 22 , 3 , 17 , 23 , 32 ] , on _driver _ok : ( ) => { } } , notification : { initial _port : 51456 , single _handler : ! 1 , handlers : [ d => { d = this . virtio . queues [ d ] ; var e = d . avail _get _entry ( d . avail _last _idx ) ; e = new lb ( d , e ) ; d . avail _last _idx = d . avail _last _idx + 1 & d . mask ; this . virtio . queues [ 0 ] . push _reply ( e ) ; this . virtio . queues [ 0 ] . flush _replies ( ) } , d => { const e = this . virtio . queues [ d ] ; for ( ; e . has _request ( ) ; ) { const g = e . pop _request ( ) , f = new Uint8Array ( g . length _readable ) ; g . get _next _blob ( f ) ; this . bus . send ( "net" +
2025-01-03 12:44:26 +01:00
this . id + "-send" , f . subarray ( 12 ) ) ; this . bus . send ( "eth-transmit-end" , [ f . length - 12 ] ) ; this . virtio . queues [ d ] . push _reply ( g ) } this . virtio . queues [ d ] . flush _replies ( ) } , d => { if ( d === 2 * this . pairs ) for ( var e = this . virtio . queues [ d ] ; e . has _request ( ) ; ) { const g = e . pop _request ( ) , f = new Uint8Array ( g . length _readable ) ; g . get _next _blob ( f ) ; const k = t . Unmarshall ( [ "b" , "b" ] , f , { offset : 0 } ) ; switch ( k [ 0 ] << 8 | k [ 1 ] ) { case 1024 : t . Unmarshall ( [ "h" ] , f , { offset : 2 } ) ; this . Send ( d , g , new Uint8Array ( [ 0 ] ) ) ; break ; case 257 : this . mac = f . subarray ( 2 , 8 ) ; this . Send ( d ,
2024-11-28 07:25:05 +01:00
g , new Uint8Array ( [ 0 ] ) ) ; this . bus . send ( "net" + this . id + "-mac" , Pa ( this . mac ) ) ; break ; default : this . Send ( d , g , new Uint8Array ( [ 1 ] ) ) ; return } } } ] } , isr _status : { initial _port : 50944 } , device _specific : { initial _port : 50688 , struct : [ 0 , 1 , 2 , 3 , 4 , 5 ] . map ( ( d , e ) => ( { bytes : 1 , name : "mac_" + e , read : ( ) => this . mac [ e ] , write : ( ) => { } } ) ) . concat ( [ { bytes : 2 , name : "status" , read : ( ) => this . status , write : ( ) => { } } , { bytes : 2 , name : "max_pairs" , read : ( ) => this . pairs , write : ( ) => { } } , { bytes : 2 , name : "mtu" , read : ( ) => 1500 , write : ( ) => { } } ] ) } } ) ; this . bus . register ( "net" + this . id +
2024-10-02 21:03:04 +02:00
"-receive" , d => { this . bus . send ( "eth-receive-end" , [ d . length ] ) ; const e = new Uint8Array ( 12 + d . byteLength ) ; ( new DataView ( e . buffer , e . byteOffset , e . byteLength ) ) . setInt16 ( 10 , 1 ) ; e . set ( d , 12 ) ; d = this . virtio . queues [ 0 ] ; d . has _request ( ) ? ( d = d . pop _request ( ) , d . set _next _blob ( e ) , this . virtio . queues [ 0 ] . push _reply ( d ) , this . virtio . queues [ 0 ] . flush _replies ( ) ) : console . log ( "No buffer to write into!" ) } , this ) }
2025-01-03 12:44:26 +01:00
nb . prototype . get _state = function ( ) { const a = [ ] ; a [ 0 ] = this . virtio ; a [ 1 ] = this . id ; this . preserve _mac _from _state _image && ( this . mac = a [ 2 ] , this . bus . send ( "net" + this . id + "-mac" , Pa ( this . mac ) ) ) ; return a } ; nb . prototype . set _state = function ( a ) { this . virtio . set _state ( a [ 0 ] ) } ; nb . prototype . reset = function ( ) { this . virtio . reset ( ) } ; nb . prototype . Send = function ( a , b , c ) { b . set _next _blob ( c ) ; this . virtio . queues [ a ] . push _reply ( b ) ; this . virtio . queues [ a ] . flush _replies ( ) } ; nb . prototype . Ack = function ( a , b ) { this . virtio . queues [ a ] . push _reply ( b ) ; this . virtio . queues [ a ] . flush _replies ( ) } ; var ob = { } ; function pb ( ) { this . listeners = { } ; this . pair = void 0 } pb . prototype . register = function ( a , b , c ) { var d = this . listeners [ a ] ; void 0 === d && ( d = this . listeners [ a ] = [ ] ) ; d . push ( { fn : b , this _value : c } ) } ; pb . prototype . unregister = function ( a , b ) { var c = this . listeners [ a ] ; void 0 !== c && ( this . listeners [ a ] = c . filter ( function ( d ) { return d . fn !== b } ) ) } ; pb . prototype . send = function ( a , b ) { if ( this . pair && ( a = this . pair . listeners [ a ] , void 0 !== a ) ) for ( var c = 0 ; c < a . length ; c ++ ) { var d = a [ c ] ; d . fn . call ( d . this _value , b ) } } ;
pb . prototype . send _async = function ( a , b ) { setTimeout ( this . send . bind ( this , a , b ) , 0 ) } ; ob . create = function ( ) { var a = new pb , b = new pb ; a . pair = b ; b . pair = a ; return [ a , b ] } ; function ta ( ) { } function ua ( ) { } ; function G ( a , b , c ) { this . stop _idling = c ; this . wm = b ; this . wasm _patch ( ) ; this . create _jit _imports ( ) ; this . wasm _memory = b = this . wm . exports . memory ; this . memory _size = h . view ( Uint32Array , b , 812 , 1 ) ; this . mem8 = new Uint8Array ( 0 ) ; this . mem32s = new Int32Array ( this . mem8 . buffer ) ; this . segment _is _null = h . view ( Uint8Array , b , 724 , 8 ) ; this . segment _offsets = h . view ( Int32Array , b , 736 , 8 ) ; this . segment _limits = h . view ( Uint32Array , b , 768 , 8 ) ; this . segment _access _bytes = h . view ( Uint8Array , b , 512 , 8 ) ; this . protected _mode = h . view ( Int32Array , b , 800 , 1 ) ; this . idtr _size =
h . view ( Int32Array , b , 564 , 1 ) ; this . idtr _offset = h . view ( Int32Array , b , 568 , 1 ) ; this . gdtr _size = h . view ( Int32Array , b , 572 , 1 ) ; this . gdtr _offset = h . view ( Int32Array , b , 576 , 1 ) ; this . tss _size _32 = h . view ( Int32Array , b , 1128 , 1 ) ; this . page _fault = h . view ( Uint32Array , b , 540 , 8 ) ; this . cr = h . view ( Int32Array , b , 580 , 8 ) ; this . cpl = h . view ( Uint8Array , b , 612 , 1 ) ; this . is _32 = h . view ( Int32Array , b , 804 , 1 ) ; this . stack _size _32 = h . view ( Int32Array , b , 808 , 1 ) ; this . in _hlt = h . view ( Uint8Array , b , 616 , 1 ) ; this . last _virt _eip = h . view ( Int32Array , b , 620 , 1 ) ; this . eip _phys = h . view ( Int32Array ,
b , 624 , 1 ) ; this . sysenter _cs = h . view ( Int32Array , b , 636 , 1 ) ; this . sysenter _esp = h . view ( Int32Array , b , 640 , 1 ) ; this . sysenter _eip = h . view ( Int32Array , b , 644 , 1 ) ; this . prefixes = h . view ( Int32Array , b , 648 , 1 ) ; this . flags = h . view ( Int32Array , b , 120 , 1 ) ; this . flags _changed = h . view ( Int32Array , b , 100 , 1 ) ; this . last _op _size = h . view ( Int32Array , b , 96 , 1 ) ; this . last _op1 = h . view ( Int32Array , b , 104 , 1 ) ; this . last _result = h . view ( Int32Array , b , 112 , 1 ) ; this . current _tsc = h . view ( Uint32Array , b , 960 , 2 ) ; this . devices = { } ; this . instruction _pointer = h . view ( Int32Array ,
b , 556 , 1 ) ; this . previous _ip = h . view ( Int32Array , b , 560 , 1 ) ; this . apic _enabled = h . view ( Uint8Array , b , 548 , 1 ) ; this . acpi _enabled = h . view ( Uint8Array , b , 552 , 1 ) ; this . memory _map _read8 = [ ] ; this . memory _map _write8 = [ ] ; this . memory _map _read32 = [ ] ; this . memory _map _write32 = [ ] ; this . bios = { main : null , vga : null } ; this . instruction _counter = h . view ( Uint32Array , b , 664 , 1 ) ; this . reg32 = h . view ( Int32Array , b , 64 , 8 ) ; this . fpu _st = h . view ( Int32Array , b , 1152 , 32 ) ; this . fpu _stack _empty = h . view ( Uint8Array , b , 816 , 1 ) ; this . fpu _stack _empty [ 0 ] = 255 ; this . fpu _stack _ptr =
h . view ( Uint8Array , b , 1032 , 1 ) ; this . fpu _stack _ptr [ 0 ] = 0 ; this . fpu _control _word = h . view ( Uint16Array , b , 1036 , 1 ) ; this . fpu _control _word [ 0 ] = 895 ; this . fpu _status _word = h . view ( Uint16Array , b , 1040 , 1 ) ; this . fpu _status _word [ 0 ] = 0 ; this . fpu _ip = h . view ( Int32Array , b , 1048 , 1 ) ; this . fpu _ip [ 0 ] = 0 ; this . fpu _ip _selector = h . view ( Int32Array , b , 1052 , 1 ) ; this . fpu _ip _selector [ 0 ] = 0 ; this . fpu _opcode = h . view ( Int32Array , b , 1044 , 1 ) ; this . fpu _opcode [ 0 ] = 0 ; this . fpu _dp = h . view ( Int32Array , b , 1056 , 1 ) ; this . fpu _dp [ 0 ] = 0 ; this . fpu _dp _selector = h . view ( Int32Array ,
b , 1060 , 1 ) ; this . fpu _dp _selector [ 0 ] = 0 ; this . reg _xmm32s = h . view ( Int32Array , b , 832 , 32 ) ; this . mxcsr = h . view ( Int32Array , b , 824 , 1 ) ; this . sreg = h . view ( Uint16Array , b , 668 , 8 ) ; this . dreg = h . view ( Int32Array , b , 684 , 8 ) ; this . reg _pdpte = h . view ( Int32Array , b , 968 , 8 ) ; this . svga _dirty _bitmap _min _offset = h . view ( Uint32Array , b , 716 , 1 ) ; this . svga _dirty _bitmap _max _offset = h . view ( Uint32Array , b , 720 , 1 ) ; this . fw _value = [ ] ; this . fw _pointer = 0 ; this . option _roms = [ ] ; this . io = void 0 ; this . bus = a ; this . set _tsc ( 0 , 0 ) ; this . debug _init ( ) }
G . prototype . clear _opstats = function ( ) { ( new Uint8Array ( this . wasm _memory . buffer , 32768 , 131072 ) ) . fill ( 0 ) ; this . wm . exports . profiler _init ( ) } ; G . prototype . create _jit _imports = function ( ) { const a = Object . create ( null ) ; a . m = this . wm . exports . memory ; for ( const b of Object . keys ( this . wm . exports ) ) b . startsWith ( "_" ) || b . startsWith ( "zstd" ) || b . endsWith ( "_js" ) || ( a [ b ] = this . wm . exports [ b ] ) ; this . jit _imports = a } ;
G . prototype . wasm _patch = function ( ) { const a = c => this . wm . exports [ c ] , b = c => { const d = a ( c ) ; console . assert ( d , "Missing import: " + c ) ; return d } ; this . reset _cpu = b ( "reset_cpu" ) ; this . getiopl = b ( "getiopl" ) ; this . get _eflags = b ( "get_eflags" ) ; this . handle _irqs = b ( "handle_irqs" ) ; this . main _loop = b ( "main_loop" ) ; this . set _jit _config = b ( "set_jit_config" ) ; this . read8 = b ( "read8" ) ; this . read16 = b ( "read16" ) ; this . read32s = b ( "read32s" ) ; this . write8 = b ( "write8" ) ; this . write16 = b ( "write16" ) ; this . write32 = b ( "write32" ) ; this . in _mapped _range = b ( "in_mapped_range" ) ;
2024-06-28 09:23:02 +02:00
this . fpu _load _tag _word = b ( "fpu_load_tag_word" ) ; this . fpu _load _status _word = b ( "fpu_load_status_word" ) ; this . fpu _get _sti _f64 = b ( "fpu_get_sti_f64" ) ; this . translate _address _system _read = b ( "translate_address_system_read_js" ) ; this . get _seg _cs = b ( "get_seg_cs" ) ; this . get _real _eip = b ( "get_real_eip" ) ; this . clear _tlb = b ( "clear_tlb" ) ; this . full _clear _tlb = b ( "full_clear_tlb" ) ; this . update _state _flags = b ( "update_state_flags" ) ; this . set _tsc = b ( "set_tsc" ) ; this . store _current _tsc = b ( "store_current_tsc" ) ; this . set _cpuid _level = b ( "set_cpuid_level" ) ;
this . pic _set _irq = b ( "pic_set_irq" ) ; this . pic _clear _irq = b ( "pic_clear_irq" ) ; this . jit _clear _cache = b ( "jit_clear_cache_js" ) ; this . jit _dirty _cache = b ( "jit_dirty_cache" ) ; this . codegen _finalize _finished = b ( "codegen_finalize_finished" ) ; this . allocate _memory = b ( "allocate_memory" ) ; this . zero _memory = b ( "zero_memory" ) ; this . svga _allocate _memory = b ( "svga_allocate_memory" ) ; this . svga _allocate _dest _buffer = b ( "svga_allocate_dest_buffer" ) ; this . svga _fill _pixel _buffer = b ( "svga_fill_pixel_buffer" ) ; this . svga _mark _dirty = b ( "svga_mark_dirty" ) ;
this . get _pic _addr _master = b ( "get_pic_addr_master" ) ; this . get _pic _addr _slave = b ( "get_pic_addr_slave" ) ; this . zstd _create _ctx = b ( "zstd_create_ctx" ) ; this . zstd _get _src _ptr = b ( "zstd_get_src_ptr" ) ; this . zstd _free _ctx = b ( "zstd_free_ctx" ) ; this . zstd _read = b ( "zstd_read" ) ; this . zstd _read _free = b ( "zstd_read_free" ) ; this . port20 _read = b ( "port20_read" ) ; this . port21 _read = b ( "port21_read" ) ; this . portA0 _read = b ( "portA0_read" ) ; this . portA1 _read = b ( "portA1_read" ) ; this . port20 _write = b ( "port20_write" ) ; this . port21 _write = b ( "port21_write" ) ; this . portA0 _write =
2025-01-03 12:44:26 +01:00
b ( "portA0_write" ) ; this . portA1 _write = b ( "portA1_write" ) ; this . port4D0 _read = b ( "port4D0_read" ) ; this . port4D1 _read = b ( "port4D1_read" ) ; this . port4D0 _write = b ( "port4D0_write" ) ; this . port4D1 _write = b ( "port4D1_write" ) } ; G . prototype . jit _force _generate = function ( a ) { this . jit _force _generate _unsafe && this . jit _force _generate _unsafe ( a ) } ; G . prototype . jit _clear _func = function ( a ) { this . wm . wasm _table . set ( a + 1024 , null ) } ; G . prototype . jit _clear _all _funcs = function ( ) { const a = this . wm . wasm _table ; for ( let b = 0 ; 900 > b ; b ++ ) a . set ( 1024 + b , null ) } ;
G . prototype . get _state = function ( ) { var a = [ ] ; a [ 0 ] = this . memory _size [ 0 ] ; a [ 1 ] = new Uint8Array ( [ ... this . segment _is _null , ... this . segment _access _bytes ] ) ; a [ 2 ] = this . segment _offsets ; a [ 3 ] = this . segment _limits ; a [ 4 ] = this . protected _mode [ 0 ] ; a [ 5 ] = this . idtr _offset [ 0 ] ; a [ 6 ] = this . idtr _size [ 0 ] ; a [ 7 ] = this . gdtr _offset [ 0 ] ; a [ 8 ] = this . gdtr _size [ 0 ] ; a [ 9 ] = this . page _fault [ 0 ] ; a [ 10 ] = this . cr ; a [ 11 ] = this . cpl [ 0 ] ; a [ 13 ] = this . is _32 [ 0 ] ; a [ 16 ] = this . stack _size _32 [ 0 ] ; a [ 17 ] = this . in _hlt [ 0 ] ; a [ 18 ] = this . last _virt _eip [ 0 ] ; a [ 19 ] = this . eip _phys [ 0 ] ; a [ 22 ] = this . sysenter _cs [ 0 ] ;
2024-06-28 09:23:02 +02:00
a [ 23 ] = this . sysenter _eip [ 0 ] ; a [ 24 ] = this . sysenter _esp [ 0 ] ; a [ 25 ] = this . prefixes [ 0 ] ; a [ 26 ] = this . flags [ 0 ] ; a [ 27 ] = this . flags _changed [ 0 ] ; a [ 28 ] = this . last _op1 [ 0 ] ; a [ 30 ] = this . last _op _size [ 0 ] ; a [ 37 ] = this . instruction _pointer [ 0 ] ; a [ 38 ] = this . previous _ip [ 0 ] ; a [ 39 ] = this . reg32 ; a [ 40 ] = this . sreg ; a [ 41 ] = this . dreg ; a [ 42 ] = this . reg _pdpte ; this . store _current _tsc ( ) ; a [ 43 ] = this . current _tsc ; a [ 45 ] = this . devices . virtio _9p ; a [ 46 ] = this . devices . apic ; a [ 47 ] = this . devices . rtc ; a [ 48 ] = this . devices . pci ; a [ 49 ] = this . devices . dma ; a [ 50 ] = this . devices . acpi ; a [ 52 ] =
this . devices . vga ; a [ 53 ] = this . devices . ps2 ; a [ 54 ] = this . devices . uart0 ; a [ 55 ] = this . devices . fdc ; a [ 56 ] = this . devices . cdrom ; a [ 57 ] = this . devices . hda ; a [ 58 ] = this . devices . pit ; a [ 59 ] = this . devices . net ; a [ 60 ] = this . get _state _pic ( ) ; a [ 61 ] = this . devices . sb16 ; a [ 62 ] = this . fw _value ; a [ 63 ] = this . devices . ioapic ; a [ 64 ] = this . tss _size _32 [ 0 ] ; a [ 66 ] = this . reg _xmm32s ; a [ 67 ] = this . fpu _st ; a [ 68 ] = this . fpu _stack _empty [ 0 ] ; a [ 69 ] = this . fpu _stack _ptr [ 0 ] ; a [ 70 ] = this . fpu _control _word [ 0 ] ; a [ 71 ] = this . fpu _ip [ 0 ] ; a [ 72 ] = this . fpu _ip _selector [ 0 ] ; a [ 73 ] = this . fpu _dp [ 0 ] ;
2024-10-02 21:03:04 +02:00
a [ 74 ] = this . fpu _dp _selector [ 0 ] ; a [ 75 ] = this . fpu _opcode [ 0 ] ; const { packed _memory : b , bitmap : c } = this . pack _memory ( ) ; a [ 77 ] = b ; a [ 78 ] = new Uint8Array ( c . get _buffer ( ) ) ; a [ 79 ] = this . devices . uart1 ; a [ 80 ] = this . devices . uart2 ; a [ 81 ] = this . devices . uart3 ; a [ 82 ] = this . devices . virtio _console ; a [ 83 ] = this . devices . virtio _net ; return a } ;
2025-01-03 12:44:26 +01:00
G . prototype . get _state _pic = function ( ) { const a = new Uint8Array ( this . wasm _memory . buffer , this . get _pic _addr _master ( ) , 13 ) , b = new Uint8Array ( this . wasm _memory . buffer , this . get _pic _addr _slave ( ) , 13 ) , c = [ ] , d = [ ] ; c [ 0 ] = a [ 0 ] ; c [ 1 ] = a [ 1 ] ; c [ 2 ] = a [ 2 ] ; c [ 3 ] = a [ 3 ] ; c [ 4 ] = a [ 4 ] ; c [ 5 ] = d ; c [ 6 ] = a [ 6 ] ; c [ 7 ] = a [ 7 ] ; c [ 8 ] = a [ 8 ] ; c [ 9 ] = a [ 9 ] ; c [ 10 ] = a [ 10 ] ; c [ 11 ] = a [ 11 ] ; c [ 12 ] = a [ 12 ] ; d [ 0 ] = b [ 0 ] ; d [ 1 ] = b [ 1 ] ; d [ 2 ] = b [ 2 ] ; d [ 3 ] = b [ 3 ] ; d [ 4 ] = b [ 4 ] ; d [ 5 ] = null ; d [ 6 ] = b [ 6 ] ; d [ 7 ] = b [ 7 ] ; d [ 8 ] = b [ 8 ] ; d [ 9 ] = b [ 9 ] ; d [ 10 ] = b [ 10 ] ; d [ 11 ] = b [ 11 ] ; d [ 12 ] = b [ 12 ] ; return c } ;
G . prototype . set _state = function ( a ) { this . memory _size [ 0 ] = a [ 0 ] ; this . mem8 . length !== this . memory _size [ 0 ] && console . warn ( "Note: Memory size mismatch. we=" + this . mem8 . length + " state=" + this . memory _size [ 0 ] ) ; 8 === a [ 1 ] . length ? ( this . segment _is _null . set ( a [ 1 ] ) , this . segment _access _bytes . fill ( 242 ) , this . segment _access _bytes [ 1 ] = 250 ) : 16 === a [ 1 ] . length && ( this . segment _is _null . set ( a [ 1 ] . subarray ( 0 , 8 ) ) , this . segment _access _bytes . set ( a [ 1 ] . subarray ( 8 , 16 ) ) ) ; this . segment _offsets . set ( a [ 2 ] ) ; this . segment _limits . set ( a [ 3 ] ) ; this . protected _mode [ 0 ] =
2024-06-28 09:23:02 +02:00
a [ 4 ] ; this . idtr _offset [ 0 ] = a [ 5 ] ; this . idtr _size [ 0 ] = a [ 6 ] ; this . gdtr _offset [ 0 ] = a [ 7 ] ; this . gdtr _size [ 0 ] = a [ 8 ] ; this . page _fault [ 0 ] = a [ 9 ] ; this . cr . set ( a [ 10 ] ) ; this . cpl [ 0 ] = a [ 11 ] ; this . is _32 [ 0 ] = a [ 13 ] ; this . stack _size _32 [ 0 ] = a [ 16 ] ; this . in _hlt [ 0 ] = a [ 17 ] ; this . last _virt _eip [ 0 ] = a [ 18 ] ; this . eip _phys [ 0 ] = a [ 19 ] ; this . sysenter _cs [ 0 ] = a [ 22 ] ; this . sysenter _eip [ 0 ] = a [ 23 ] ; this . sysenter _esp [ 0 ] = a [ 24 ] ; this . prefixes [ 0 ] = a [ 25 ] ; this . flags [ 0 ] = a [ 26 ] ; this . flags _changed [ 0 ] = a [ 27 ] ; this . last _op1 [ 0 ] = a [ 28 ] ; this . last _op _size [ 0 ] = a [ 30 ] ; this . instruction _pointer [ 0 ] =
a [ 37 ] ; this . previous _ip [ 0 ] = a [ 38 ] ; this . reg32 . set ( a [ 39 ] ) ; this . sreg . set ( a [ 40 ] ) ; this . dreg . set ( a [ 41 ] ) ; a [ 42 ] && this . reg _pdpte . set ( a [ 42 ] ) ; this . set _tsc ( a [ 43 ] [ 0 ] , a [ 43 ] [ 1 ] ) ; this . devices . virtio _9p && this . devices . virtio _9p . set _state ( a [ 45 ] ) ; this . devices . apic && this . devices . apic . set _state ( a [ 46 ] ) ; this . devices . rtc && this . devices . rtc . set _state ( a [ 47 ] ) ; this . devices . pci && this . devices . pci . set _state ( a [ 48 ] ) ; this . devices . dma && this . devices . dma . set _state ( a [ 49 ] ) ; this . devices . acpi && this . devices . acpi . set _state ( a [ 50 ] ) ; this . devices . vga &&
this . devices . vga . set _state ( a [ 52 ] ) ; this . devices . ps2 && this . devices . ps2 . set _state ( a [ 53 ] ) ; this . devices . uart0 && this . devices . uart0 . set _state ( a [ 54 ] ) ; this . devices . fdc && this . devices . fdc . set _state ( a [ 55 ] ) ; this . devices . cdrom && this . devices . cdrom . set _state ( a [ 56 ] ) ; this . devices . hda && this . devices . hda . set _state ( a [ 57 ] ) ; this . devices . pit && this . devices . pit . set _state ( a [ 58 ] ) ; this . devices . net && this . devices . net . set _state ( a [ 59 ] ) ; this . set _state _pic ( a [ 60 ] ) ; this . devices . sb16 && this . devices . sb16 . set _state ( a [ 61 ] ) ; this . devices . uart1 &&
2024-10-02 21:03:04 +02:00
this . devices . uart1 . set _state ( a [ 79 ] ) ; this . devices . uart2 && this . devices . uart2 . set _state ( a [ 80 ] ) ; this . devices . uart3 && this . devices . uart3 . set _state ( a [ 81 ] ) ; this . devices . virtio _console && this . devices . virtio _console . set _state ( a [ 82 ] ) ; this . devices . virtio _net && this . devices . virtio _net . set _state ( a [ 83 ] ) ; this . fw _value = a [ 62 ] ; this . devices . ioapic && this . devices . ioapic . set _state ( a [ 63 ] ) ; this . tss _size _32 [ 0 ] = a [ 64 ] ; this . reg _xmm32s . set ( a [ 66 ] ) ; this . fpu _st . set ( a [ 67 ] ) ; this . fpu _stack _empty [ 0 ] = a [ 68 ] ; this . fpu _stack _ptr [ 0 ] = a [ 69 ] ; this . fpu _control _word [ 0 ] =
2025-01-03 12:44:26 +01:00
a [ 70 ] ; this . fpu _ip [ 0 ] = a [ 71 ] ; this . fpu _ip _selector [ 0 ] = a [ 72 ] ; this . fpu _dp [ 0 ] = a [ 73 ] ; this . fpu _dp _selector [ 0 ] = a [ 74 ] ; this . fpu _opcode [ 0 ] = a [ 75 ] ; const b = new h . Bitmap ( a [ 78 ] . buffer ) ; this . unpack _memory ( b , a [ 77 ] ) ; this . update _state _flags ( ) ; this . full _clear _tlb ( ) ; this . jit _clear _cache ( ) } ;
G . prototype . set _state _pic = function ( a ) { const b = new Uint8Array ( this . wasm _memory . buffer , this . get _pic _addr _master ( ) , 13 ) , c = new Uint8Array ( this . wasm _memory . buffer , this . get _pic _addr _slave ( ) , 13 ) ; b [ 0 ] = a [ 0 ] ; b [ 1 ] = a [ 1 ] ; b [ 2 ] = a [ 2 ] ; b [ 3 ] = a [ 3 ] ; b [ 4 ] = a [ 4 ] ; const d = a [ 5 ] ; b [ 6 ] = a [ 6 ] ; b [ 7 ] = a [ 7 ] ; b [ 8 ] = a [ 8 ] ; b [ 9 ] = a [ 9 ] ; b [ 10 ] = a [ 10 ] ; b [ 11 ] = a [ 11 ] ; b [ 12 ] = a [ 12 ] ; c [ 0 ] = d [ 0 ] ; c [ 1 ] = d [ 1 ] ; c [ 2 ] = d [ 2 ] ; c [ 3 ] = d [ 3 ] ; c [ 4 ] = d [ 4 ] ; c [ 6 ] = d [ 6 ] ; c [ 7 ] = d [ 7 ] ; c [ 8 ] = d [ 8 ] ; c [ 9 ] = d [ 9 ] ; c [ 10 ] = d [ 10 ] ; c [ 11 ] = d [ 11 ] ; c [ 12 ] = d [ 12 ] } ;
G . prototype . pack _memory = function ( ) { var a = this . mem8 . length >> 12 , b = [ ] ; for ( var c = 0 ; c < a ; c ++ ) { var d = c << 12 ; d = this . mem32s . subarray ( d >> 2 , d + 4096 >> 2 ) ; let e = ! 0 ; for ( let g = 0 ; g < d . length ; g ++ ) if ( 0 !== d [ g ] ) { e = ! 1 ; break } e || b . push ( c ) } a = new h . Bitmap ( a ) ; c = new Uint8Array ( b . length << 12 ) ; for ( const [ e , g ] of b . entries ( ) ) a . set ( g , 1 ) , b = g << 12 , b = this . mem8 . subarray ( b , b + 4096 ) , c . set ( b , e << 12 ) ; return { bitmap : a , packed _memory : c } } ;
G . prototype . unpack _memory = function ( a , b ) { this . zero _memory ( this . memory _size [ 0 ] ) ; const c = this . memory _size [ 0 ] >> 12 ; let d = 0 ; for ( let g = 0 ; g < c ; g ++ ) if ( a . get ( g ) ) { var e = d << 12 ; e = b . subarray ( e , e + 4096 ) ; this . mem8 . set ( e , g << 12 ) ; d ++ } } ; G . prototype . reboot _internal = function ( ) { this . reset _cpu ( ) ; this . fw _value = [ ] ; this . devices . virtio _9p && this . devices . virtio _9p . reset ( ) ; this . devices . virtio _console && this . devices . virtio _console . reset ( ) ; this . devices . virtio _net && this . devices . virtio _net . reset ( ) ; this . load _bios ( ) } ;
G . prototype . reset _memory = function ( ) { this . mem8 . fill ( 0 ) } ; G . prototype . create _memory = function ( a , b ) { a < b ? a = b : 0 > ( a | 0 ) && ( a = Math . pow ( 2 , 31 ) - 131072 ) ; a = ( a - 1 | 131071 ) + 1 | 0 ; console . assert ( 0 === this . memory _size [ 0 ] , "Expected uninitialised memory" ) ; this . memory _size [ 0 ] = a ; b = this . allocate _memory ( a ) ; this . mem8 = h . view ( Uint8Array , this . wasm _memory , b , a ) ; this . mem32s = h . view ( Uint32Array , this . wasm _memory , b , a >> 2 ) } ;
G . prototype . init = function ( a , b ) { this . create _memory ( a . memory _size || 67108864 , a . initrd ? 67108864 : 1048576 ) ; a . disable _jit && this . set _jit _config ( 0 , 1 ) ; a . cpuid _level && this . set _cpuid _level ( a . cpuid _level ) ; this . acpi _enabled [ 0 ] = + a . acpi ; this . reset _cpu ( ) ; var c = new C ( this ) ; this . io = c ; this . bios . main = a . bios ; this . bios . vga = a . vga _bios ; this . load _bios ( ) ; if ( a . bzimage ) { const e = qb ( this . mem8 , a . bzimage , a . initrd , a . cmdline || "" ) ; e && this . option _roms . push ( e ) } c . register _read ( 179 , this , function ( ) { return 0 } ) ; var d = 0 ; c . register _read ( 146 ,
this , function ( ) { return d } ) ; c . register _write ( 146 , this , function ( e ) { d = e } ) ; c . register _read ( 1297 , this , function ( ) { return this . fw _pointer < this . fw _value . length ? this . fw _value [ this . fw _pointer ++ ] : 0 } ) ; c . register _write ( 1296 , this , void 0 , function ( e ) { function g ( l ) { return new Uint8Array ( Int32Array . of ( l ) . buffer ) } function f ( l ) { return l >> 8 | l << 8 & 65280 } function k ( l ) { return l << 24 | l << 8 & 16711680 | l >> 8 & 65280 | l >>> 24 } ta ( "bios config port, index=" + B ( e ) ) ; this . fw _pointer = 0 ; if ( 0 === e ) this . fw _value = g ( 1431127377 ) ; else if ( 1 === e ) this . fw _value =
g ( 0 ) ; else if ( 3 === e ) this . fw _value = g ( this . memory _size [ 0 ] ) ; else if ( 5 === e ) this . fw _value = g ( 1 ) ; else if ( 15 === e ) this . fw _value = g ( 1 ) ; else if ( 13 === e ) this . fw _value = new Uint8Array ( 16 ) ; else if ( 25 === e ) { e = new Int32Array ( 4 + 64 * this . option _roms . length ) ; const l = new Uint8Array ( e . buffer ) ; e [ 0 ] = k ( this . option _roms . length ) ; for ( let m = 0 ; m < this . option _roms . length ; m ++ ) { const { name : n , data : p } = this . option _roms [ m ] , q = 4 + 64 * m ; e [ q + 0 >> 2 ] = k ( p . length ) ; e [ q + 4 >> 2 ] = f ( 49152 + m ) ; for ( let r = 0 ; r < n . length ; r ++ ) l [ q + 8 + r ] = n . charCodeAt ( r ) } this . fw _value =
l } else 32768 <= e && 49152 > e ? this . fw _value = g ( 0 ) : 49152 <= e && e - 49152 < this . option _roms . length ? this . fw _value = this . option _roms [ e - 49152 ] . data : ( ta ( "Warning: Unimplemented fw index: " + B ( e ) ) , this . fw _value = g ( 0 ) ) } ) ; c . register _read ( 32 , this , this . port20 _read ) ; c . register _read ( 33 , this , this . port21 _read ) ; c . register _read ( 160 , this , this . portA0 _read ) ; c . register _read ( 161 , this , this . portA1 _read ) ; c . register _write ( 32 , this , this . port20 _write ) ; c . register _write ( 33 , this , this . port21 _write ) ; c . register _write ( 160 , this , this . portA0 _write ) ;
c . register _write ( 161 , this , this . portA1 _write ) ; c . register _read ( 1232 , this , this . port4D0 _read ) ; c . register _read ( 1233 , this , this . port4D1 _read ) ; c . register _write ( 1232 , this , this . port4D0 _write ) ; c . register _write ( 1233 , this , this . port4D1 _write ) ; this . devices = { } ; a . load _devices && ( this . devices . pci = new va ( this ) , this . acpi _enabled [ 0 ] && ( this . devices . ioapic = new Ga ( this ) , this . devices . apic = new Fa ( this ) , this . devices . acpi = new Ea ( this ) ) , this . devices . rtc = new Ca ( this ) , this . fill _cmos ( this . devices . rtc , a ) , this . devices . dma = new M ( this ) ,
this . devices . vga = new N ( this , b , a . screen , a . vga _memory _size || 8388608 ) , this . devices . ps2 = new za ( this , b ) , this . devices . uart0 = new Da ( this , 1016 , b ) , a . uart1 && ( this . devices . uart1 = new Da ( this , 760 , b ) ) , a . uart2 && ( this . devices . uart2 = new Da ( this , 1E3 , b ) ) , a . uart3 && ( this . devices . uart3 = new Da ( this , 744 , b ) ) , this . devices . fdc = new L ( this , a . fda , a . fdb ) , c = 0 , a . hda && ( this . devices . hda = new ra ( this , a . hda , a . hdb , ! 1 , c ++ , b ) ) , a . cdrom && ( this . devices . cdrom = new ra ( this , a . cdrom , void 0 , ! 0 , c ++ , b ) ) , this . devices . pit = new wa ( this , b ) , "ne2k" === a . net _device . type ?
2024-11-28 07:25:05 +01:00
this . devices . net = new Qa ( this , b , a . preserve _mac _from _state _image , a . mac _address _translation ) : "virtio" === a . net _device . type && ( this . devices . virtio _net = new nb ( this , b , a . preserve _mac _from _state _image ) ) , a . fs9p && ( this . devices . virtio _9p = new ca ( a . fs9p , this , b ) ) , a . virtio _console && ( this . devices . virtio _console = new mb ( this , b ) ) , this . devices . sb16 = new Q ( this , b ) ) ; a . multiboot && ( a = this . load _multiboot _option _rom ( a . multiboot , a . initrd , a . cmdline ) ) && ( this . bios . main ? this . option _roms . push ( a ) : this . reg32 [ 0 ] = this . io . port _read32 ( 244 ) ) } ;
2025-01-03 12:44:26 +01:00
G . prototype . load _multiboot = function ( a ) { this . load _multiboot _option _rom ( a , void 0 , "" ) && ( this . reg32 [ 0 ] = this . io . port _read32 ( 244 ) ) } ;
G . prototype . load _multiboot _option _rom = function ( a , b , c ) { if ( 8192 > a . byteLength ) { var d = new Int32Array ( 2048 ) ; ( new Uint8Array ( d . buffer ) ) . set ( new Uint8Array ( a ) ) } else d = new Int32Array ( a , 0 , 2048 ) ; for ( var e = 0 ; 8192 > e ; e += 4 ) { if ( 464367618 === d [ e >> 2 ] ) { var g = d [ e + 4 >> 2 ] ; if ( 464367618 + g + d [ e + 8 >> 2 ] | 0 ) continue } else continue ; ta ( "Multiboot magic found, flags: " + B ( g >>> 0 , 8 ) , 2 ) ; var f = this ; this . io . register _read ( 244 , this , function ( ) { return 0 } , function ( ) { return 0 } , function ( ) { var n = 31860 , p = 0 ; if ( c ) { p |= 4 ; f . write32 ( 31760 , n ) ; c += "\x00" ;
var q = ( new TextEncoder ) . encode ( c ) ; f . write _blob ( q , n ) ; n += q . length } if ( g & 2 ) { p |= 64 ; q = 0 ; f . write32 ( 31788 , 0 ) ; f . write32 ( 31792 , n ) ; var r = 0 ; var A = ! 1 ; for ( let u = 0 ; 4294967296 > u ; u += 131072 ) A && void 0 !== f . memory _map _read8 [ u >>> 17 ] ? ( f . write32 ( n , 20 ) , f . write32 ( n + 4 , r ) , f . write32 ( n + 8 , 0 ) , f . write32 ( n + 12 , u - r ) , f . write32 ( n + 16 , 0 ) , f . write32 ( n + 20 , 1 ) , n += 24 , q += 24 , A = ! 1 ) : A || void 0 !== f . memory _map _read8 [ u >>> 17 ] || ( r = u , A = ! 0 ) ; f . write32 ( 31788 , q ) } f . write32 ( 31744 , p ) ; q = p = 0 ; if ( g & 65536 ) { A = d [ e + 12 >> 2 ] ; p = d [ e + 16 >> 2 ] ; var z = d [ e + 20 >> 2 ] ; q = d [ e + 24 >> 2 ] ; r =
d [ e + 28 >> 2 ] ; B ( A , 8 ) ; B ( p , 8 ) ; B ( z , 8 ) ; B ( q , 8 ) ; B ( r , 8 ) ; A = new Uint8Array ( a , e - ( A - p ) , 0 === z ? void 0 : z - p ) ; f . write _blob ( A , p ) ; p = r | 0 ; q = Math . max ( z , q ) } else if ( 1179403647 === d [ 0 ] ) { r = new DataView ( a ) ; const [ u , F ] = Ab ( r , Bb ) ; console . assert ( 52 === F ) ; console . assert ( 1179403647 === u . magic , "Bad magic" ) ; console . assert ( 1 === u . class , "Unimplemented: 64 bit elf" ) ; console . assert ( 1 === u . data , "Unimplemented: big endian" ) ; console . assert ( 1 === u . version0 , "Bad version0" ) ; console . assert ( 2 === u . type , "Unimplemented type" ) ; console . assert ( 1 === u . version1 ,
"Bad version1" ) ; console . assert ( 52 === u . ehsize , "Bad header size" ) ; console . assert ( 32 === u . phentsize , "Bad program header size" ) ; console . assert ( 40 === u . shentsize , "Bad section header size" ) ; [ p ] = Cb ( new DataView ( r . buffer , r . byteOffset + u . phoff , u . phentsize * u . phnum ) , Db , u . phnum ) ; Cb ( new DataView ( r . buffer , r . byteOffset + u . shoff , u . shentsize * u . shnum ) , Eb , u . shnum ) ; r = u ; A = p ; p = r . entry ; for ( z of A ) 0 !== z . type && ( 1 === z . type ? z . paddr + z . memsz < f . memory _size [ 0 ] ? ( z . filesz && ( A = new Uint8Array ( a , z . offset , z . filesz ) , f . write _blob ( A , z . paddr ) ) ,
q = Math . max ( q , z . paddr + z . memsz ) , p === r . entry && z . vaddr <= p && z . vaddr + z . memsz > p && ( p = p - z . vaddr + z . paddr ) ) : B ( z . paddr ) : 2 === z . type || 3 === z . type || 4 === z . type || 6 === z . type || 7 === z . type || 1685382480 === z . type || 1685382481 === z . type || 1685382482 === z . type || 1685382483 === z . type || B ( z . type ) ) } b && ( f . write32 ( 31764 , 1 ) , f . write32 ( 31768 , n ) , z = q , 0 !== ( z & 4095 ) && ( z = ( z & - 4096 ) + 4096 ) , q = z + b . byteLength , f . write32 ( n , z ) , f . write32 ( n + 4 , q ) , f . write32 ( n + 8 , 0 ) , f . write32 ( n + 12 , 0 ) , f . write _blob ( new Uint8Array ( b ) , z ) ) ; f . reg32 [ 3 ] = 31744 ; f . cr [ 0 ] = 1 ; f . protected _mode [ 0 ] =
1 ; f . flags [ 0 ] = 2 ; f . is _32 [ 0 ] = 1 ; f . stack _size _32 [ 0 ] = 1 ; for ( n = 0 ; 6 > n ; n ++ ) f . segment _is _null [ n ] = 0 , f . segment _offsets [ n ] = 0 , f . segment _limits [ n ] = 4294967295 , f . sreg [ n ] = 45058 ; f . instruction _pointer [ 0 ] = f . get _seg _cs ( ) + p | 0 ; f . update _state _flags ( ) ; f . debug . dump _state ( ) ; f . debug . dump _regs ( ) ; return 732803074 } ) ; this . io . register _write _consecutive ( 244 , this , function ( n ) { console . log ( "Test exited with code " + B ( n , 2 ) ) ; throw "HALT" ; } , function ( ) { } , function ( ) { } , function ( ) { } ) ; for ( let n = 0 ; 15 >= n ; n ++ ) { function p ( q ) { B ( n ) ; B ( q , 2 ) ; q ? this . device _raise _irq ( n ) :
this . device _lower _irq ( n ) } this . io . register _write ( 8192 + n , this , p , p , p ) } const l = new Uint8Array ( 512 ) ; ( new Uint16Array ( l . buffer ) ) [ 0 ] = 43605 ; l [ 2 ] = 1 ; var k = 3 ; l [ k ++ ] = 102 ; l [ k ++ ] = 229 ; l [ k ++ ] = 244 ; let m = l [ k ] = 0 ; for ( let n = 0 ; n < l . length ; n ++ ) m += l [ n ] ; l [ k ] = - m ; return { name : "genroms/multiboot.bin" , data : l } } } ;
G . prototype . fill _cmos = function ( a , b ) { var c = b . boot _order || 291 ; a . cmos _write ( 56 , 1 | c >> 4 & 240 ) ; a . cmos _write ( 61 , c & 255 ) ; a . cmos _write ( 21 , 128 ) ; a . cmos _write ( 22 , 2 ) ; c = 0 ; 1048576 <= this . memory _size [ 0 ] && ( c = this . memory _size [ 0 ] - 1048576 >> 10 , c = Math . min ( c , 65535 ) ) ; a . cmos _write ( 23 , c & 255 ) ; a . cmos _write ( 24 , c >> 8 & 255 ) ; a . cmos _write ( 48 , c & 255 ) ; a . cmos _write ( 49 , c >> 8 & 255 ) ; c = 0 ; 16777216 <= this . memory _size [ 0 ] && ( c = this . memory _size [ 0 ] - 16777216 >> 16 , c = Math . min ( c , 65535 ) ) ; a . cmos _write ( 52 , c & 255 ) ; a . cmos _write ( 53 , c >> 8 & 255 ) ; a . cmos _write ( 91 , 0 ) ; a . cmos _write ( 92 ,
2024-06-28 09:23:02 +02:00
0 ) ; a . cmos _write ( 93 , 0 ) ; a . cmos _write ( 20 , 47 ) ; a . cmos _write ( 95 , 0 ) ; b . fastboot && a . cmos _write ( 63 , 1 ) } ;
2025-01-03 12:44:26 +01:00
G . prototype . load _bios = function ( ) { var a = this . bios . main , b = this . bios . vga ; if ( a ) { var c = new Uint8Array ( a ) ; this . write _blob ( c , 1048576 - a . byteLength ) ; if ( b ) { var d = new Uint8Array ( b ) ; this . write _blob ( d , 786432 ) ; this . io . mmap _register ( 4272947200 , 1048576 , function ( e ) { e = e - 4272947200 | 0 ; return e < d . length ? d [ e ] : 0 } , function ( ) { } ) } this . io . mmap _register ( 4293918720 , 1048576 , function ( e ) { return this . mem8 [ e & 1048575 ] } . bind ( this ) , function ( e , g ) { this . mem8 [ e & 1048575 ] = g } . bind ( this ) ) } } ;
G . prototype . codegen _finalize = function ( a , b , c , d , e ) { const g = new Uint8Array ( this . wasm _memory . buffer , d >>> 0 , e >>> 0 ) ; WebAssembly . instantiate ( g , { e : this . jit _imports } ) . then ( f => { this . wm . wasm _table . set ( a + 1024 , f . instance . exports . f ) ; this . codegen _finalize _finished ( a , b , c ) ; this . test _hook _did _finalize _wasm && this . test _hook _did _finalize _wasm ( g ) } ) } ; G . prototype . log _uncompiled _code = function ( ) { } ; G . prototype . dump _function _code = function ( ) { } ;
G . prototype . run _hardware _timers = function ( a , b ) { const c = this . devices . pit . timer ( b , ! 1 ) , d = this . devices . rtc . timer ( b , ! 1 ) ; let e = 100 , g = 100 ; a && ( e = this . devices . acpi . timer ( b ) , g = this . devices . apic . timer ( b ) ) ; return Math . min ( c , d , e , g ) } ; G . prototype . device _raise _irq = function ( a ) { this . pic _set _irq ( a ) ; this . devices . ioapic && this . devices . ioapic . set _irq ( a ) } ; G . prototype . device _lower _irq = function ( a ) { this . pic _clear _irq ( a ) ; this . devices . ioapic && this . devices . ioapic . clear _irq ( a ) } ; G . prototype . debug _init = function ( ) { var a = this , b = { } ; this . debug = b ; b . init = function ( ) { } ; b . get _regs _short = function ( ) { } ; b . dump _regs = function ( ) { } ; b . get _state = function ( ) { } ; b . dump _state = function ( ) { } ; b . dump _stack = function ( ) { } ; b . dump _page _structures = function ( ) { if ( a . cr [ 4 ] & 32 ) for ( var g = 0 ; 4 > g ; g ++ ) a . read32s ( a . cr [ 3 ] + 8 * g ) } ; b . dump _gdt _ldt = function ( ) { } ; b . dump _idt = function ( ) { } ; b . get _memory _dump = function ( ) { } ; b . memory _hex _dump = function ( ) { } ; b . used _memory _dump = function ( ) { } ; b . debug _interrupt = function ( ) { } ; let c , d ; b . dump _code =
function ( g , f , k ) { if ( ! d ) { if ( void 0 === c && ( c = "function" === typeof require ? require ( "./capstone-x86.min.js" ) : window . cs , void 0 === c ) ) return ; d = [ new c . Capstone ( c . ARCH _X86 , c . MODE _16 ) , new c . Capstone ( c . ARCH _X86 , c . MODE _32 ) ] } try { d [ g ] . disasm ( f , k ) . forEach ( function ( l ) { ta ( B ( l . address >>> 0 ) + ": " + h . pads ( l . bytes . map ( m => B ( m , 2 ) . slice ( - 2 ) ) . join ( " " ) , 20 ) + " " + l . mnemonic + " " + l . op _str ) } ) } catch ( l ) { ta ( "Could not disassemble: " + Array . from ( f ) . map ( m => B ( m , 2 ) ) . join ( " " ) ) } } ; let e ; b . dump _wasm = function ( g ) { if ( void 0 === e && ( e = "function" ===
typeof require ? require ( "./libwabt.js" ) : new window . WabtModule , void 0 === e ) ) return ; g = g . slice ( ) ; try { var f = e . readWasm ( g , { readDebugNames : ! 1 } ) ; f . generateNames ( ) ; f . applyNames ( ) ; f . toText ( { foldExprs : ! 0 , inlineExport : ! 0 } ) } catch ( m ) { var k = new Blob ( [ g ] ) , l = document . createElement ( "a" ) ; l . download = "failed.wasm" ; l . href = window . URL . createObjectURL ( k ) ; l . dataset . downloadurl = [ "application/octet-stream" , l . download , l . href ] . join ( ":" ) ; l . click ( ) ; window . URL . revokeObjectURL ( l . src ) ; console . log ( m . toString ( ) ) } finally { f && f . destroy ( ) } } } ; const Fb = DataView . prototype , Gb = { size : 1 , get : Fb . getUint8 , set : Fb . setUint8 } , Hb = { size : 2 , get : Fb . getUint16 , set : Fb . setUint16 } , W = { size : 4 , get : Fb . getUint32 , set : Fb . setUint32 } , Bb = Ib ( [ { magic : W } , { class : Gb } , { data : Gb } , { version0 : Gb } , { osabi : Gb } , { abiversion : Gb } , { pad0 : function ( a ) { return { size : a , get : ( ) => - 1 } } ( 7 ) } , { type : Hb } , { machine : Hb } , { version1 : W } , { entry : W } , { phoff : W } , { shoff : W } , { flags : W } , { ehsize : Hb } , { phentsize : Hb } , { phnum : Hb } , { shentsize : Hb } , { shnum : Hb } , { shstrndx : Hb } ] ) ; console . assert ( 52 === Bb . reduce ( ( a , b ) => a + b . size , 0 ) ) ;
2024-11-28 07:25:05 +01:00
const Db = Ib ( [ { type : W } , { offset : W } , { vaddr : W } , { paddr : W } , { filesz : W } , { memsz : W } , { flags : W } , { align : W } ] ) ; console . assert ( 32 === Db . reduce ( ( a , b ) => a + b . size , 0 ) ) ; const Eb = Ib ( [ { name : W } , { type : W } , { flags : W } , { addr : W } , { offset : W } , { size : W } , { link : W } , { info : W } , { addralign : W } , { entsize : W } ] ) ; console . assert ( 40 === Eb . reduce ( ( a , b ) => a + b . size , 0 ) ) ; function Ib ( a ) { return a . map ( function ( b ) { var c = Object . keys ( b ) ; console . assert ( 1 === c . length ) ; c = c [ 0 ] ; b = b [ c ] ; console . assert ( 0 < b . size ) ; return { name : c , type : b , size : b . size , get : b . get , set : b . set } } ) }
2025-01-03 12:44:26 +01:00
function Ab ( a , b ) { const c = { } ; let d = 0 ; for ( const e of b ) b = e . get . call ( a , d , ! 0 ) , console . assert ( void 0 === c [ e . name ] ) , c [ e . name ] = b , d += e . size ; return [ c , d ] } function Cb ( a , b , c ) { const d = [ ] ; let e = 0 ; for ( var g = 0 ; g < c ; g ++ ) { const [ f , k ] = Ab ( new DataView ( a . buffer , a . byteOffset + e , void 0 ) , b ) ; d . push ( f ) ; e += k } return [ d , e ] } ; function qb ( a , b , c , d ) { var e = new Uint8Array ( b ) ; const g = new Uint16Array ( b ) ; var f = new Uint32Array ( b ) , k = e [ 497 ] || 4 , l = g [ 255 ] ; if ( 43605 !== l ) B ( l ) ; else if ( l = g [ 257 ] | g [ 258 ] << 16 , 1400005704 !== l ) B ( l ) ; else { l = g [ 259 ] ; var m = e [ 529 ] , n = g [ 283 ] , p = f [ 139 ] , q = f [ 140 ] , r = e [ 565 ] , A = 518 <= l ? f [ 142 ] : 255 , z = f [ 146 ] , u = f [ 147 ] , F = f [ 150 ] , y = f [ 151 ] , I = f [ 152 ] ; B ( l ) ; B ( m ) ; B ( n ) ; B ( f [ 133 ] ) ; B ( p ) ; B ( q ) ; B ( r ) ; B ( A ) ; B ( z ) ; B ( u ) ; B ( y ) ; B ( F ) ; B ( I ) ; e [ 528 ] = 255 ; e [ 529 ] = m & - 97 | 128 ; g [ 274 ] = 56832 ; g [ 253 ] = 65535 ; B ( 56832 ) ; d += "\x00" ; B ( 581632 ) ; f [ 138 ] = 581632 ; for ( e = 0 ; e < d . length ; e ++ ) a [ 581632 +
e ] = d . charCodeAt ( e ) ; k = 512 * ( k + 1 ) ; B ( k ) ; d = new Uint8Array ( b , 0 , k ) ; b = new Uint8Array ( b , k ) ; e = k = 0 ; c && ( k = 67108864 , e = c . byteLength , a . set ( new Uint8Array ( c ) , k ) ) ; f [ 134 ] = k ; f [ 135 ] = e ; a . set ( d , 524288 ) ; a . set ( b , 1048576 ) ; a = new Uint8Array ( 512 ) ; ( new Uint16Array ( a . buffer ) ) [ 0 ] = 43605 ; a [ 2 ] = 1 ; c = 3 ; a [ c ++ ] = 250 ; a [ c ++ ] = 184 ; a [ c ++ ] = 32768 ; a [ c ++ ] = 128 ; a [ c ++ ] = 142 ; a [ c ++ ] = 192 ; a [ c ++ ] = 142 ; a [ c ++ ] = 216 ; a [ c ++ ] = 142 ; a [ c ++ ] = 224 ; a [ c ++ ] = 142 ; a [ c ++ ] = 232 ; a [ c ++ ] = 142 ; a [ c ++ ] = 208 ; a [ c ++ ] = 188 ; a [ c ++ ] = 57344 ; a [ c ++ ] = 224 ; a [ c ++ ] = 234 ; a [ c ++ ] = 0 ; a [ c ++ ] = 0 ; a [ c ++ ] = 32800 ; a [ c ++ ] =
128 ; f = a [ c ] = 0 ; for ( b = 0 ; b < a . length ; b ++ ) f += a [ b ] ; a [ c ] = - f ; return { name : "genroms/kernel.bin" , data : a } } } ; const Jb = "undefined" !== typeof window && 0 <= window . navigator . platform . toString ( ) . toLowerCase ( ) . search ( "win" ) ;
function Kb ( a ) { function b ( y ) { return y . shiftKey && y . ctrlKey && ( 73 === y . keyCode || 74 === y . keyCode || 75 === y . keyCode ) || ! r . emu _enabled ? ! 1 : y . target ? y . target . classList . contains ( "phone_keyboard" ) || "INPUT" !== y . target . nodeName && "TEXTAREA" !== y . target . nodeName : ! 0 } function c ( y ) { ! y . altKey && m [ 56 ] && k ( 56 , ! 1 ) ; return g ( y , ! 1 ) } function d ( y ) { ! y . altKey && m [ 56 ] && k ( 56 , ! 1 ) ; return g ( y , ! 0 ) } function e ( ) { for ( var y = Object . keys ( m ) , I , R = 0 ; R < y . length ; R ++ ) I = + y [ R ] , m [ I ] && k ( I , ! 1 ) ; m = { } } function g ( y , I ) { if ( r . bus && b ( y ) ) { y . preventDefault && y . preventDefault ( ) ;
if ( Jb && ( n && ( clearTimeout ( q ) , y . getModifierState && y . getModifierState ( "AltGraph" ) && p === I && "ControlLeft" === n . code && "AltRight" === y . code || f ( n , p ) , n = null ) , "ControlLeft" === y . code ) ) return n = y , p = I , q = setTimeout ( ( ) => { f ( n , p ) ; n = null } , 10 ) , ! 1 ; f ( y , I ) ; return ! 1 } } function f ( y , I ) { a : { if ( void 0 !== y . code ) { var R = F [ y . code ] ; if ( void 0 !== R ) break a } R = A [ y . keyCode ] } R ? k ( R , I , y . repeat ) : console . log ( "Missing char in map: keyCode=" + ( y . keyCode || - 1 ) . toString ( 16 ) + " code=" + y . code ) } function k ( y , I , R ) { if ( I ) m [ y ] && ! R && k ( y , ! 1 ) ; else if ( ! m [ y ] ) return ;
( m [ y ] = I ) || ( y |= 128 ) ; 255 < y ? ( l ( y >> 8 ) , l ( y & 255 ) ) : l ( y ) } function l ( y ) { r . bus . send ( "keyboard-code" , y ) } var m = { } , n = null , p = ! 1 , q = 0 , r = this ; this . emu _enabled = ! 0 ; var A = new Uint16Array ( [ 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 14 , 15 , 0 , 0 , 0 , 28 , 0 , 0 , 42 , 29 , 56 , 0 , 58 , 0 , 0 , 0 , 0 , 0 , 0 , 1 , 0 , 0 , 0 , 0 , 57 , 57417 , 57425 , 57423 , 57415 , 57419 , 57416 , 57421 , 80 , 0 , 0 , 0 , 0 , 82 , 83 , 0 , 11 , 2 , 3 , 4 , 5 , 6 , 7 , 8 , 9 , 10 , 0 , 39 , 0 , 13 , 0 , 0 , 0 , 30 , 48 , 46 , 32 , 18 , 33 , 34 , 35 , 23 , 36 , 37 , 38 , 50 , 49 , 24 , 25 , 16 , 19 , 31 , 20 , 22 , 47 , 17 , 45 , 21 , 44 , 57435 , 57436 , 57437 , 0 , 0 , 82 , 79 , 80 , 81 , 75 , 76 , 77 , 71 , 72 , 73 , 0 , 0 , 0 , 0 , 0 , 0 , 59 , 60 , 61 , 62 , 63 , 64 ,
2024-11-28 07:25:05 +01:00
65 , 66 , 67 , 68 , 87 , 88 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 69 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 12 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 39 , 13 , 51 , 12 , 52 , 53 , 41 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 26 , 43 , 27 , 40 , 0 , 57435 , 57400 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 ] ) , z = { 8 : 8 , 10 : 13 , 32 : 32 , 39 : 222 , 44 : 188 , 45 : 189 , 46 : 190 , 47 : 191 , 48 : 48 , 49 : 49 , 50 : 50 , 51 : 51 , 52 : 52 , 53 : 53 , 54 : 54 , 55 : 55 , 56 : 56 , 57 : 57 , 59 : 186 , 61 : 187 , 91 : 219 , 92 : 220 , 93 : 221 , 96 : 192 , 97 : 65 , 98 : 66 , 99 : 67 , 100 : 68 , 101 : 69 , 102 : 70 , 103 : 71 , 104 : 72 , 105 : 73 , 106 : 74 , 107 : 75 ,
2025-01-03 12:44:26 +01:00
108 : 76 , 109 : 77 , 110 : 78 , 111 : 79 , 112 : 80 , 113 : 81 , 114 : 82 , 115 : 83 , 116 : 84 , 117 : 85 , 118 : 86 , 119 : 87 , 120 : 88 , 121 : 89 , 122 : 90 } , u = { 33 : 49 , 34 : 222 , 35 : 51 , 36 : 52 , 37 : 53 , 38 : 55 , 40 : 57 , 41 : 48 , 42 : 56 , 43 : 187 , 58 : 186 , 60 : 188 , 62 : 190 , 63 : 191 , 64 : 50 , 65 : 65 , 66 : 66 , 67 : 67 , 68 : 68 , 69 : 69 , 70 : 70 , 71 : 71 , 72 : 72 , 73 : 73 , 74 : 74 , 75 : 75 , 76 : 76 , 77 : 77 , 78 : 78 , 79 : 79 , 80 : 80 , 81 : 81 , 82 : 82 , 83 : 83 , 84 : 84 , 85 : 85 , 86 : 86 , 87 : 87 , 88 : 88 , 89 : 89 , 90 : 90 , 94 : 54 , 95 : 189 , 123 : 219 , 124 : 220 , 125 : 221 , 126 : 192 } , F = { Escape : 1 , Digit1 : 2 , Digit2 : 3 , Digit3 : 4 , Digit4 : 5 , Digit5 : 6 , Digit6 : 7 , Digit7 : 8 , Digit8 : 9 , Digit9 : 10 ,
2024-10-02 21:03:04 +02:00
Digit0 : 11 , Minus : 12 , Equal : 13 , Backspace : 14 , Tab : 15 , KeyQ : 16 , KeyW : 17 , KeyE : 18 , KeyR : 19 , KeyT : 20 , KeyY : 21 , KeyU : 22 , KeyI : 23 , KeyO : 24 , KeyP : 25 , BracketLeft : 26 , BracketRight : 27 , Enter : 28 , ControlLeft : 29 , KeyA : 30 , KeyS : 31 , KeyD : 32 , KeyF : 33 , KeyG : 34 , KeyH : 35 , KeyJ : 36 , KeyK : 37 , KeyL : 38 , Semicolon : 39 , Quote : 40 , Backquote : 41 , ShiftLeft : 42 , Backslash : 43 , KeyZ : 44 , KeyX : 45 , KeyC : 46 , KeyV : 47 , KeyB : 48 , KeyN : 49 , KeyM : 50 , Comma : 51 , Period : 52 , Slash : 53 , IntlRo : 53 , ShiftRight : 54 , NumpadMultiply : 55 , AltLeft : 56 , Space : 57 , CapsLock : 58 , F1 : 59 , F2 : 60 , F3 : 61 , F4 : 62 , F5 : 63 ,
F6 : 64 , F7 : 65 , F8 : 66 , F9 : 67 , F10 : 68 , NumLock : 69 , ScrollLock : 70 , Numpad7 : 71 , Numpad8 : 72 , Numpad9 : 73 , NumpadSubtract : 74 , Numpad4 : 75 , Numpad5 : 76 , Numpad6 : 77 , NumpadAdd : 78 , Numpad1 : 79 , Numpad2 : 80 , Numpad3 : 81 , Numpad0 : 82 , NumpadDecimal : 83 , IntlBackslash : 86 , F11 : 87 , F12 : 88 , NumpadEnter : 57372 , ControlRight : 57373 , NumpadDivide : 57397 , AltRight : 57400 , Home : 57415 , ArrowUp : 57416 , PageUp : 57417 , ArrowLeft : 57419 , ArrowRight : 57421 , End : 57423 , ArrowDown : 57424 , PageDown : 57425 , Insert : 57426 , Delete : 57427 , OSLeft : 57435 , OSRight : 57436 , ContextMenu : 57437 } ; this . bus =
2024-11-28 07:25:05 +01:00
a ; this . destroy = function ( ) { "undefined" !== typeof window && ( window . removeEventListener ( "keyup" , c , ! 1 ) , window . removeEventListener ( "keydown" , d , ! 1 ) , window . removeEventListener ( "blur" , e , ! 1 ) ) } ; this . init = function ( ) { "undefined" !== typeof window && ( this . destroy ( ) , window . addEventListener ( "keyup" , c , ! 1 ) , window . addEventListener ( "keydown" , d , ! 1 ) , window . addEventListener ( "blur" , e , ! 1 ) ) } ; this . init ( ) ; this . simulate _press = function ( y ) { y = { keyCode : y } ; g ( y , ! 0 ) ; g ( y , ! 1 ) } ; this . simulate _char = function ( y ) { var I = y . charCodeAt ( 0 ) ; I in z ? this . simulate _press ( z [ I ] ) :
2025-01-03 12:44:26 +01:00
I in u ? ( l ( 42 ) , this . simulate _press ( u [ I ] ) , l ( 170 ) ) : console . log ( "ascii -> keyCode not found: " , I , y ) } } ; function Rb ( a , b ) { function c ( u ) { if ( ! z . enabled || ! z . emu _enabled ) return ! 1 ; var F = b || document . body , y ; if ( ! ( y = document . pointerLockElement ) ) a : { for ( u = u . target ; u . parentNode ; ) { if ( u === F ) { y = ! 0 ; break a } u = u . parentNode } y = ! 1 } return y } function d ( u ) { c ( u ) && ( u = u . changedTouches ) && u . length && ( u = u [ u . length - 1 ] , r = u . clientX , A = u . clientY ) } function e ( ) { if ( n || q || p ) z . bus . send ( "mouse-click" , [ ! 1 , ! 1 , ! 1 ] ) , n = q = p = ! 1 } function g ( u ) { if ( z . bus && c ( u ) && z . is _running ) { var F = 0 , y = 0 , I = u . changedTouches ; I ? I . length && ( I = I [ I . length - 1 ] , F = I . clientX - r , y = I . clientY -
A , r = I . clientX , A = I . clientY , u . preventDefault ( ) ) : "number" === typeof u . movementX ? ( F = u . movementX , y = u . movementY ) : "number" === typeof u . webkitMovementX ? ( F = u . webkitMovementX , y = u . webkitMovementY ) : "number" === typeof u . mozMovementX ? ( F = u . mozMovementX , y = u . mozMovementY ) : ( F = u . clientX - r , y = u . clientY - A , r = u . clientX , A = u . clientY ) ; z . bus . send ( "mouse-delta" , [ . 15 * F , - ( . 15 * y ) ] ) ; b && z . bus . send ( "mouse-absolute" , [ u . pageX - b . offsetLeft , u . pageY - b . offsetTop , b . offsetWidth , b . offsetHeight ] ) } } function f ( u ) { c ( u ) && l ( u , ! 0 ) } function k ( u ) { c ( u ) &&
l ( u , ! 1 ) } function l ( u , F ) { z . bus && ( 1 === u . which ? n = F : 2 === u . which ? q = F : 3 === u . which && ( p = F ) , z . bus . send ( "mouse-click" , [ n , q , p ] ) , u . preventDefault ( ) ) } function m ( u ) { if ( c ( u ) ) { var F = u . wheelDelta || - u . detail ; 0 > F ? F = - 1 : 0 < F && ( F = 1 ) ; z . bus . send ( "mouse-wheel" , [ F , 0 ] ) ; u . preventDefault ( ) } } var n = ! 1 , p = ! 1 , q = ! 1 , r = 0 , A = 0 , z = this ; this . enabled = ! 1 ; this . emu _enabled = ! 0 ; this . bus = a ; this . bus . register ( "mouse-enable" , function ( u ) { this . enabled = u } , this ) ; this . is _running = ! 1 ; this . bus . register ( "emulator-stopped" , function ( ) { this . is _running = ! 1 } , this ) ;
this . bus . register ( "emulator-started" , function ( ) { this . is _running = ! 0 } , this ) ; this . destroy = function ( ) { "undefined" !== typeof window && ( window . removeEventListener ( "touchstart" , d , ! 1 ) , window . removeEventListener ( "touchend" , e , ! 1 ) , window . removeEventListener ( "touchmove" , g , ! 1 ) , window . removeEventListener ( "mousemove" , g , ! 1 ) , window . removeEventListener ( "mousedown" , f , ! 1 ) , window . removeEventListener ( "mouseup" , k , ! 1 ) , window . removeEventListener ( "wheel" , m , { passive : ! 1 } ) ) } ; this . init = function ( ) { "undefined" !== typeof window && ( this . destroy ( ) ,
window . addEventListener ( "touchstart" , d , ! 1 ) , window . addEventListener ( "touchend" , e , ! 1 ) , window . addEventListener ( "touchmove" , g , ! 1 ) , window . addEventListener ( "mousemove" , g , ! 1 ) , window . addEventListener ( "mousedown" , f , ! 1 ) , window . addEventListener ( "mouseup" , k , ! 1 ) , window . addEventListener ( "wheel" , m , { passive : ! 1 } ) ) } ; this . init ( ) } ; function Sb ( a ) { if ( "undefined" !== typeof window ) if ( window . AudioContext || window . webkitAudioContext ) { var b = window . AudioWorklet ? Tb : Ub ; this . bus = a ; this . audio _context = window . AudioContext ? new AudioContext : new webkitAudioContext ; this . mixer = new Vb ( a , this . audio _context ) ; this . pcspeaker = new Wb ( a , this . audio _context , this . mixer ) ; this . dac = new b ( a , this . audio _context , this . mixer ) ; this . pcspeaker . start ( ) ; a . register ( "emulator-stopped" , function ( ) { this . audio _context . suspend ( ) } , this ) ; a . register ( "emulator-started" , function ( ) { this . audio _context . resume ( ) } ,
2024-11-28 07:25:05 +01:00
this ) ; a . register ( "speaker-confirm-initialized" , function ( ) { a . send ( "speaker-has-initialized" ) } , this ) ; a . send ( "speaker-has-initialized" ) } else console . warn ( "Web browser doesn't support Web Audio API" ) } Sb . prototype . destroy = function ( ) { this . audio _context && this . audio _context . close ( ) ; this . audio _context = null ; this . dac && this . dac . node _processor && this . dac . node _processor . port . close ( ) ; this . dac = null } ;
function Vb ( a , b ) { function c ( d ) { return function ( e ) { d . gain . setValueAtTime ( e , this . audio _context . currentTime ) } } this . audio _context = b ; this . sources = new Map ; this . gain _right = this . gain _left = this . volume _right = this . volume _left = this . volume _both = 1 ; this . node _treble _left = this . audio _context . createBiquadFilter ( ) ; this . node _treble _right = this . audio _context . createBiquadFilter ( ) ; this . node _treble _left . type = "highshelf" ; this . node _treble _right . type = "highshelf" ; this . node _treble _left . frequency . setValueAtTime ( 2E3 , this . audio _context . currentTime ) ;
2024-06-28 09:23:02 +02:00
this . node _treble _right . frequency . setValueAtTime ( 2E3 , this . audio _context . currentTime ) ; this . node _bass _left = this . audio _context . createBiquadFilter ( ) ; this . node _bass _right = this . audio _context . createBiquadFilter ( ) ; this . node _bass _left . type = "lowshelf" ; this . node _bass _right . type = "lowshelf" ; this . node _bass _left . frequency . setValueAtTime ( 200 , this . audio _context . currentTime ) ; this . node _bass _right . frequency . setValueAtTime ( 200 , this . audio _context . currentTime ) ; this . node _gain _left = this . audio _context . createGain ( ) ; this . node _gain _right =
this . audio _context . createGain ( ) ; this . node _merger = this . audio _context . createChannelMerger ( 2 ) ; this . input _left = this . node _treble _left ; this . input _right = this . node _treble _right ; this . node _treble _left . connect ( this . node _bass _left ) ; this . node _bass _left . connect ( this . node _gain _left ) ; this . node _gain _left . connect ( this . node _merger , 0 , 0 ) ; this . node _treble _right . connect ( this . node _bass _right ) ; this . node _bass _right . connect ( this . node _gain _right ) ; this . node _gain _right . connect ( this . node _merger , 0 , 1 ) ; this . node _merger . connect ( this . audio _context . destination ) ;
2024-11-28 07:25:05 +01:00
a . register ( "mixer-connect" , function ( d ) { this . connect _source ( d [ 0 ] , d [ 1 ] ) } , this ) ; a . register ( "mixer-disconnect" , function ( d ) { this . disconnect _source ( d [ 0 ] , d [ 1 ] ) } , this ) ; a . register ( "mixer-volume" , function ( d ) { var e = d [ 0 ] , g = d [ 1 ] ; d = Math . pow ( 10 , d [ 2 ] / 20 ) ; e = 0 === e ? this : this . sources . get ( e ) ; void 0 === e || e . set _volume ( d , g ) } , this ) ; a . register ( "mixer-gain-left" , function ( d ) { this . gain _left = Math . pow ( 10 , d / 20 ) ; this . update ( ) } , this ) ; a . register ( "mixer-gain-right" , function ( d ) { this . gain _right = Math . pow ( 10 , d / 20 ) ; this . update ( ) } , this ) ;
a . register ( "mixer-treble-left" , c ( this . node _treble _left ) , this ) ; a . register ( "mixer-treble-right" , c ( this . node _treble _right ) , this ) ; a . register ( "mixer-bass-left" , c ( this . node _bass _left ) , this ) ; a . register ( "mixer-bass-right" , c ( this . node _bass _right ) , this ) } Vb . prototype . add _source = function ( a , b ) { a = new Xb ( this . audio _context , a , this . input _left , this . input _right ) ; this . sources . has ( b ) ; this . sources . set ( b , a ) ; return a } ; Vb . prototype . connect _source = function ( a , b ) { a = this . sources . get ( a ) ; void 0 === a || a . connect ( b ) } ;
Vb . prototype . disconnect _source = function ( a , b ) { a = this . sources . get ( a ) ; void 0 === a || a . disconnect ( b ) } ; Vb . prototype . set _volume = function ( a , b ) { void 0 === b && ( b = 2 ) ; switch ( b ) { case 0 : this . volume _left = a ; break ; case 1 : this . volume _right = a ; break ; case 2 : this . volume _both = a ; break ; default : return } this . update ( ) } ;
Vb . prototype . update = function ( ) { var a = this . volume _both * this . volume _right * this . gain _right ; this . node _gain _left . gain . setValueAtTime ( this . volume _both * this . volume _left * this . gain _left , this . audio _context . currentTime ) ; this . node _gain _right . gain . setValueAtTime ( a , this . audio _context . currentTime ) } ;
function Xb ( a , b , c , d ) { this . audio _context = a ; this . connected _right = this . connected _left = ! 0 ; this . volume _right = this . volume _left = this . volume _both = this . gain _hidden = 1 ; this . node _splitter = a . createChannelSplitter ( 2 ) ; this . node _gain _left = a . createGain ( ) ; this . node _gain _right = a . createGain ( ) ; b . connect ( this . node _splitter ) ; this . node _splitter . connect ( this . node _gain _left , 0 ) ; this . node _gain _left . connect ( c ) ; this . node _splitter . connect ( this . node _gain _right , 1 ) ; this . node _gain _right . connect ( d ) }
Xb . prototype . update = function ( ) { var a = this . connected _right * this . gain _hidden * this . volume _both * this . volume _right ; this . node _gain _left . gain . setValueAtTime ( this . connected _left * this . gain _hidden * this . volume _both * this . volume _left , this . audio _context . currentTime ) ; this . node _gain _right . gain . setValueAtTime ( a , this . audio _context . currentTime ) } ; Xb . prototype . connect = function ( a ) { var b = ! a || 2 === a ; if ( b || 0 === a ) this . connected _left = ! 0 ; if ( b || 1 === a ) this . connected _right = ! 0 ; this . update ( ) } ;
Xb . prototype . disconnect = function ( a ) { var b = ! a || 2 === a ; if ( b || 0 === a ) this . connected _left = ! 1 ; if ( b || 1 === a ) this . connected _right = ! 1 ; this . update ( ) } ; Xb . prototype . set _volume = function ( a , b ) { void 0 === b && ( b = 2 ) ; switch ( b ) { case 0 : this . volume _left = a ; break ; case 1 : this . volume _right = a ; break ; case 2 : this . volume _both = a ; break ; default : return } this . update ( ) } ; Xb . prototype . set _gain _hidden = function ( a ) { this . gain _hidden = a } ;
function Wb ( a , b , c ) { this . node _oscillator = b . createOscillator ( ) ; this . node _oscillator . type = "square" ; this . node _oscillator . frequency . setValueAtTime ( 440 , b . currentTime ) ; this . mixer _connection = c . add _source ( this . node _oscillator , 1 ) ; this . mixer _connection . disconnect ( ) ; a . register ( "pcspeaker-enable" , function ( ) { c . connect _source ( 1 ) } , this ) ; a . register ( "pcspeaker-disable" , function ( ) { c . disconnect _source ( 1 ) } , this ) ; a . register ( "pcspeaker-update" , function ( d ) { var e = d [ 1 ] , g = 0 ; 3 === d [ 0 ] && ( g = Math . min ( 1193181.6665999999 / e , this . node _oscillator . frequency . maxValue ) ,
g = Math . max ( g , 0 ) ) ; this . node _oscillator . frequency . setValueAtTime ( g , b . currentTime ) } , this ) } Wb . prototype . start = function ( ) { this . node _oscillator . start ( ) } ;
2025-01-03 12:44:26 +01:00
function Tb ( a , b , c ) { this . bus = a ; this . audio _context = b ; this . enabled = ! 1 ; this . sampling _rate = 48E3 ; b = function ( ) { function f ( m ) { if ( 0 === m ) return 1 ; m *= Math . PI ; return Math . sin ( m ) / m } function k ( ) { var m = Reflect . construct ( AudioWorkletProcessor , [ ] , k ) ; m . kernel _size = 3 ; m . queue _data = Array ( 1024 ) ; m . queue _start = 0 ; m . queue _end = 0 ; m . queue _length = 0 ; m . queue _size = m . queue _data . length ; m . queued _samples = 0 ; m . source _buffer _previous = l ; m . source _buffer _current = l ; m . source _samples _per _destination = 1 ; m . source _block _start = 0 ; m . source _time = 0 ; m . source _offset =
0 ; m . port . onmessage = n => { switch ( n . data . type ) { case "queue" : m . queue _push ( n . data . value ) ; break ; case "sampling-rate" : m . source _samples _per _destination = n . data . value / sampleRate } } ; return m } var l = [ new Float32Array ( 256 ) , new Float32Array ( 256 ) ] ; Reflect . setPrototypeOf ( k . prototype , AudioWorkletProcessor . prototype ) ; Reflect . setPrototypeOf ( k , AudioWorkletProcessor ) ; k . prototype . process = k . prototype . process = function ( m , n ) { for ( m = 0 ; m < n [ 0 ] [ 0 ] . length ; m ++ ) { for ( var p = 0 , q = 0 , r = this . source _offset + this . kernel _size , A = this . source _offset -
this . kernel _size + 1 ; A <= r ; A ++ ) { var z = this . source _block _start + A ; p += this . get _sample ( z , 0 ) * this . kernel ( this . source _time - A ) ; q += this . get _sample ( z , 1 ) * this . kernel ( this . source _time - A ) } if ( isNaN ( p ) || isNaN ( q ) ) p = q = 0 , this . dbg _log ( "ERROR: NaN values! Ignoring for now." ) ; n [ 0 ] [ 0 ] [ m ] = p ; n [ 0 ] [ 1 ] [ m ] = q ; this . source _time += this . source _samples _per _destination ; this . source _offset = Math . floor ( this . source _time ) } n = this . source _offset ; n += this . kernel _size + 2 ; this . source _time -= this . source _offset ; this . source _block _start += this . source _offset ;
this . source _offset = 0 ; this . ensure _enough _data ( n ) ; return ! 0 } ; k . prototype . kernel = function ( m ) { return f ( m ) * f ( m / this . kernel _size ) } ; k . prototype . get _sample = function ( m , n ) { return 0 > m ? ( m += this . source _buffer _previous [ 0 ] . length , this . source _buffer _previous [ n ] [ m ] ) : this . source _buffer _current [ n ] [ m ] } ; k . prototype . ensure _enough _data = function ( m ) { var n = this . source _buffer _current [ 0 ] . length ; n - this . source _block _start < m && ( this . prepare _next _buffer ( ) , this . source _block _start -= n ) } ; k . prototype . prepare _next _buffer = function ( ) { 256 >
2024-06-28 09:23:02 +02:00
this . queued _samples && this . queue _length && this . dbg _log ( "Not enough samples - should not happen during midway of playback" ) ; this . source _buffer _previous = this . source _buffer _current ; this . source _buffer _current = this . queue _shift ( ) ; var m = this . source _buffer _current [ 0 ] . length ; if ( 256 > m ) { for ( var n = this . queue _start , p = 0 ; 256 > m && p < this . queue _length ; ) m += this . queue _data [ n ] [ 0 ] . length , n = n + 1 & this . queue _size - 1 , p ++ ; m = Math . max ( m , 256 ) ; m = [ new Float32Array ( m ) , new Float32Array ( m ) ] ; m [ 0 ] . set ( this . source _buffer _current [ 0 ] ) ; m [ 1 ] . set ( this . source _buffer _current [ 1 ] ) ;
2025-01-03 12:44:26 +01:00
n = this . source _buffer _current [ 0 ] . length ; for ( var q = 0 ; q < p ; q ++ ) { var r = this . queue _shift ( ) ; m [ 0 ] . set ( r [ 0 ] , n ) ; m [ 1 ] . set ( r [ 1 ] , n ) ; n += r [ 0 ] . length } this . source _buffer _current = m } this . pump ( ) } ; k . prototype . pump = function ( ) { 1024 > this . queued _samples / this . source _samples _per _destination && this . port . postMessage ( { type : "pump" } ) } ; k . prototype . queue _push = function ( m ) { this . queue _length < this . queue _size && ( this . queue _data [ this . queue _end ] = m , this . queue _end = this . queue _end + 1 & this . queue _size - 1 , this . queue _length ++ , this . queued _samples += m [ 0 ] . length ,
this . pump ( ) ) } ; k . prototype . queue _shift = function ( ) { if ( ! this . queue _length ) return l ; var m = this . queue _data [ this . queue _start ] ; this . queue _data [ this . queue _start ] = null ; this . queue _start = this . queue _start + 1 & this . queue _size - 1 ; this . queue _length -- ; this . queued _samples -= m [ 0 ] . length ; return m } ; k . prototype . dbg _log = function ( ) { } ; registerProcessor ( "dac-processor" , k ) } . toString ( ) ; var d = b . indexOf ( "{" ) + 1 , e = b . lastIndexOf ( "}" ) ; b = b . substring ( d , e ) ; b = new Blob ( [ b ] , { type : "application/javascript" } ) ; var g = URL . createObjectURL ( b ) ; this . node _processor =
2024-11-28 07:25:05 +01:00
null ; this . node _output = this . audio _context . createGain ( ) ; this . audio _context . audioWorklet . addModule ( g ) . then ( ( ) => { URL . revokeObjectURL ( g ) ; this . node _processor = new AudioWorkletNode ( this . audio _context , "dac-processor" , { numberOfInputs : 0 , numberOfOutputs : 1 , outputChannelCount : [ 2 ] , parameterData : { } , processorOptions : { } } ) ; this . node _processor . port . postMessage ( { type : "sampling-rate" , value : this . sampling _rate } ) ; this . node _processor . port . onmessage = f => { switch ( f . data . type ) { case "pump" : this . pump ( ) } } ; this . node _processor . connect ( this . node _output ) } ) ;
this . mixer _connection = c . add _source ( this . node _output , 2 ) ; this . mixer _connection . set _gain _hidden ( 3 ) ; a . register ( "dac-send-data" , function ( f ) { this . queue ( f ) } , this ) ; a . register ( "dac-enable" , function ( ) { this . enabled = ! 0 } , this ) ; a . register ( "dac-disable" , function ( ) { this . enabled = ! 1 } , this ) ; a . register ( "dac-tell-sampling-rate" , function ( f ) { this . sampling _rate = f ; this . node _processor && this . node _processor . port . postMessage ( { type : "sampling-rate" , value : f } ) } , this ) }
Tb . prototype . queue = function ( a ) { this . node _processor && this . node _processor . port . postMessage ( { type : "queue" , value : a } , [ a [ 0 ] . buffer , a [ 1 ] . buffer ] ) } ; Tb . prototype . pump = function ( ) { this . enabled && this . bus . send ( "dac-request-data" ) } ;
function Ub ( a , b , c ) { this . bus = a ; this . audio _context = b ; this . enabled = ! 1 ; this . sampling _rate = 22050 ; this . buffered _time = 0 ; this . rate _ratio = 1 ; this . node _lowpass = this . audio _context . createBiquadFilter ( ) ; this . node _lowpass . type = "lowpass" ; this . node _output = this . node _lowpass ; this . mixer _connection = c . add _source ( this . node _output , 2 ) ; this . mixer _connection . set _gain _hidden ( 3 ) ; a . register ( "dac-send-data" , function ( d ) { this . queue ( d ) } , this ) ; a . register ( "dac-enable" , function ( ) { this . enabled = ! 0 ; this . pump ( ) } , this ) ; a . register ( "dac-disable" ,
2024-06-28 09:23:02 +02:00
function ( ) { this . enabled = ! 1 } , this ) ; a . register ( "dac-tell-sampling-rate" , function ( d ) { this . sampling _rate = d ; this . rate _ratio = Math . ceil ( 8E3 / d ) ; this . node _lowpass . frequency . setValueAtTime ( d / 2 , this . audio _context . currentTime ) } , this ) }
2025-01-03 12:44:26 +01:00
Ub . prototype . queue = function ( a ) { var b = a [ 0 ] . length , c = b / this . sampling _rate ; if ( 1 < this . rate _ratio ) { var d = this . audio _context . createBuffer ( 2 , b * this . rate _ratio , this . sampling _rate * this . rate _ratio ) ; for ( var e = d . getChannelData ( 0 ) , g = d . getChannelData ( 1 ) , f = 0 , k = 0 ; k < b ; k ++ ) for ( var l = 0 ; l < this . rate _ratio ; l ++ , f ++ ) e [ f ] = a [ 0 ] [ k ] , g [ f ] = a [ 1 ] [ k ] } else d = this . audio _context . createBuffer ( 2 , b , this . sampling _rate ) , d . copyToChannel ? ( d . copyToChannel ( a [ 0 ] , 0 ) , d . copyToChannel ( a [ 1 ] , 1 ) ) : ( d . getChannelData ( 0 ) . set ( a [ 0 ] ) , d . getChannelData ( 1 ) . set ( a [ 1 ] ) ) ;
a = this . audio _context . createBufferSource ( ) ; a . buffer = d ; a . connect ( this . node _lowpass ) ; a . addEventListener ( "ended" , this . pump . bind ( this ) ) ; d = this . audio _context . currentTime ; if ( this . buffered _time < d ) for ( this . buffered _time = d , d = . 2 - c , b = 0 ; b <= d ; ) b += c , this . buffered _time += c , setTimeout ( ( ) => this . pump ( ) , 1E3 * b ) ; a . start ( this . buffered _time ) ; this . buffered _time += c ; setTimeout ( ( ) => this . pump ( ) , 0 ) } ; Ub . prototype . pump = function ( ) { this . enabled && ( . 2 < this . buffered _time - this . audio _context . currentTime || this . bus . send ( "dac-request-data" ) ) } ; function Yb ( a , b ) { function c ( k ) { f . bus && f . enabled && ( f . send _char ( k . which ) , k . preventDefault ( ) ) } function d ( k ) { var l = k . which ; 8 === l ? ( f . send _char ( 127 ) , k . preventDefault ( ) ) : 9 === l && ( f . send _char ( 9 ) , k . preventDefault ( ) ) } function e ( k ) { if ( f . enabled ) { for ( var l = k . clipboardData . getData ( "text/plain" ) , m = 0 ; m < l . length ; m ++ ) f . send _char ( l . charCodeAt ( m ) ) ; k . preventDefault ( ) } } function g ( k ) { k . target !== a && a . blur ( ) } var f = this ; this . enabled = ! 0 ; this . bus = b ; this . text = "" ; this . text _new _line = ! 1 ; this . last _update = 0 ; this . bus . register ( "serial0-output-byte" ,
function ( k ) { k = String . fromCharCode ( k ) ; this . show _char ( k ) } , this ) ; this . destroy = function ( ) { a . removeEventListener ( "keypress" , c , ! 1 ) ; a . removeEventListener ( "keydown" , d , ! 1 ) ; a . removeEventListener ( "paste" , e , ! 1 ) ; window . removeEventListener ( "mousedown" , g , ! 1 ) } ; this . init = function ( ) { this . destroy ( ) ; a . style . display = "block" ; a . addEventListener ( "keypress" , c , ! 1 ) ; a . addEventListener ( "keydown" , d , ! 1 ) ; a . addEventListener ( "paste" , e , ! 1 ) ; window . addEventListener ( "mousedown" , g , ! 1 ) } ; this . init ( ) ; this . show _char = function ( k ) { "\b" === k ? ( this . text =
this . text . slice ( 0 , - 1 ) , this . update ( ) ) : "\r" !== k && ( this . text += k , "\n" === k && ( this . text _new _line = ! 0 ) , this . update ( ) ) } ; this . update = function ( ) { var k = Date . now ( ) , l = k - this . last _update ; 16 > l ? void 0 === this . update _timer && ( this . update _timer = setTimeout ( ( ) => { this . update _timer = void 0 ; this . last _update = Date . now ( ) ; this . render ( ) } , 16 - l ) ) : ( void 0 !== this . update _timer && ( clearTimeout ( this . update _timer ) , this . update _timer = void 0 ) , this . last _update = k , this . render ( ) ) } ; this . render = function ( ) { a . value = this . text ; this . text _new _line && ( this . text _new _line =
! 1 , a . scrollTop = 1E9 ) } ; this . send _char = function ( k ) { f . bus && f . bus . send ( "serial0-input" , k ) } }
function Zb ( a , b ) { this . element = a ; if ( window . Terminal ) { var c = this . term = new window . Terminal ( { logLevel : "off" } ) ; c . write ( "This is the serial console. Whatever you type or paste here will be sent to COM1" ) ; var d = c . onData ( function ( e ) { for ( let g = 0 ; g < e . length ; g ++ ) b . send ( "serial0-input" , e . charCodeAt ( g ) ) } ) ; b . register ( "serial0-output-byte" , function ( e ) { c . write ( Uint8Array . of ( e ) ) } , this ) ; this . destroy = function ( ) { d . dispose ( ) ; c . dispose ( ) } } } Zb . prototype . show = function ( ) { this . term && this . term . open ( this . element ) } ; function $b ( a , b , c ) { this . bus = b ; this . socket = void 0 ; this . id = c || 0 ; this . send _queue = [ ] ; this . url = a ; this . reconnect _interval = 1E4 ; this . last _connect _attempt = Date . now ( ) - this . reconnect _interval ; this . send _queue _limit = 64 ; this . destroyed = ! 1 ; this . bus . register ( "net" + this . id + "-send" , function ( d ) { this . send ( d ) } , this ) } $b . prototype . handle _message = function ( a ) { this . bus && this . bus . send ( "net" + this . id + "-receive" , new Uint8Array ( a . data ) ) } ;
$b . prototype . handle _close = function ( ) { this . destroyed || ( this . connect ( ) , setTimeout ( this . connect . bind ( this ) , this . reconnect _interval ) ) } ; $b . prototype . handle _open = function ( ) { for ( var a = 0 ; a < this . send _queue . length ; a ++ ) this . send ( this . send _queue [ a ] ) ; this . send _queue = [ ] } ; $b . prototype . handle _error = function ( ) { } ; $b . prototype . destroy = function ( ) { this . destroyed = ! 0 ; this . socket && this . socket . close ( ) } ;
2024-11-28 07:25:05 +01:00
$b . prototype . connect = function ( ) { if ( "undefined" !== typeof WebSocket ) { if ( this . socket ) { var a = this . socket . readyState ; if ( 0 === a || 1 === a ) return } a = Date . now ( ) ; if ( ! ( this . last _connect _attempt + this . reconnect _interval > a ) ) { this . last _connect _attempt = Date . now ( ) ; try { this . socket = new WebSocket ( this . url ) } catch ( b ) { console . error ( b ) ; return } this . socket . binaryType = "arraybuffer" ; this . socket . onopen = this . handle _open . bind ( this ) ; this . socket . onmessage = this . handle _message . bind ( this ) ; this . socket . onclose = this . handle _close . bind ( this ) ;
2025-01-03 12:44:26 +01:00
this . socket . onerror = this . handle _error . bind ( this ) } } } ; $b . prototype . send = function ( a ) { this . socket && 1 === this . socket . readyState ? this . socket . send ( a ) : ( this . send _queue . push ( a ) , this . send _queue . length > 2 * this . send _queue _limit && ( this . send _queue = this . send _queue . slice ( - this . send _queue _limit ) ) , this . connect ( ) ) } ; $b . prototype . change _proxy = function ( a ) { this . url = a ; this . socket && ( this . socket . onclose = function ( ) { } , this . socket . onerror = function ( ) { } , this . socket . close ( ) , this . socket = void 0 ) } ; function X ( a ) { this . cpu _is _running = ! 1 ; this . cpu _exception _hook = function ( ) { } ; var b = ob . create ( ) ; this . bus = b [ 0 ] ; this . emulator _bus = b [ 1 ] ; var c , d ; const e = new WebAssembly . Table ( { element : "anyfunc" , initial : 1924 } ) ; b = { cpu _exception _hook : f => this . cpu _exception _hook ( f ) , run _hardware _timers : function ( f , k ) { return c . run _hardware _timers ( f , k ) } , cpu _event _halt : ( ) => { this . emulator _bus . send ( "cpu-event-halt" ) } , abort : function ( ) { } , microtick : D . microtick , get _rand _int : function ( ) { return h . get _rand _int ( ) } , apic _acknowledge _irq : function ( ) { return c . devices . apic . acknowledge _irq ( ) } ,
stop _idling : function ( ) { return c . stop _idling ( ) } , io _port _read8 : function ( f ) { return c . io . port _read8 ( f ) } , io _port _read16 : function ( f ) { return c . io . port _read16 ( f ) } , io _port _read32 : function ( f ) { return c . io . port _read32 ( f ) } , io _port _write8 : function ( f , k ) { c . io . port _write8 ( f , k ) } , io _port _write16 : function ( f , k ) { c . io . port _write16 ( f , k ) } , io _port _write32 : function ( f , k ) { c . io . port _write32 ( f , k ) } , mmap _read8 : function ( f ) { return c . mmap _read8 ( f ) } , mmap _read16 : function ( f ) { return c . mmap _read16 ( f ) } , mmap _read32 : function ( f ) { return c . mmap _read32 ( f ) } ,
mmap _write8 : function ( f , k ) { c . mmap _write8 ( f , k ) } , mmap _write16 : function ( f , k ) { c . mmap _write16 ( f , k ) } , mmap _write32 : function ( f , k ) { c . mmap _write32 ( f , k ) } , mmap _write64 : function ( f , k , l ) { c . mmap _write64 ( f , k , l ) } , mmap _write128 : function ( f , k , l , m , n ) { c . mmap _write128 ( f , k , l , m , n ) } , log _from _wasm : function ( f , k ) { h . read _sized _string _from _mem ( d , f , k ) } , console _log _from _wasm : function ( f , k ) { f = h . read _sized _string _from _mem ( d , f , k ) ; console . error ( f ) } , dbg _trace _from _wasm : function ( ) { } , codegen _finalize : ( f , k , l , m , n ) => { c . codegen _finalize ( f , k , l ,
m , n ) } , jit _clear _func : f => c . jit _clear _func ( f ) , jit _clear _all _funcs : ( ) => c . jit _clear _all _funcs ( ) , _ _indirect _function _table : e } ; let g = a . wasm _fn ; g || ( g = f => new Promise ( k => { let l = "v86.wasm" , m = "v86-fallback.wasm" ; if ( a . wasm _path ) { l = a . wasm _path ; const n = l . lastIndexOf ( "/" ) ; m = ( - 1 === n ? "" : l . substr ( 0 , n ) ) + "/" + m } else "undefined" === typeof window && "string" === typeof _ _dirname ? ( l = _ _dirname + "/" + l , m = _ _dirname + "/" + m ) : ( l = "build/" + l , m = "build/" + m ) ; h . load _file ( l , { done : async n => { try { const { instance : p } = await WebAssembly . instantiate ( n ,
f ) ; this . wasm _source = n ; k ( p . exports ) } catch ( p ) { h . load _file ( m , { done : async q => { const { instance : r } = await WebAssembly . instantiate ( q , f ) ; this . wasm _source = q ; k ( r . exports ) } } ) } } , progress : n => { this . emulator _bus . send ( "download-progress" , { file _index : 0 , file _count : 1 , file _name : l , lengthComputable : n . lengthComputable , total : n . total , loaded : n . loaded } ) } } ) } ) ) ; g ( { env : b } ) . then ( f => { d = f . memory ; f . rust _init ( ) ; f = this . v86 = new D ( this . emulator _bus , { exports : f , wasm _table : e } ) ; c = f . cpu ; this . continue _init ( f , a ) } ) ; this . zstd _worker = null ; this . zstd _worker _request _id =
2024-06-28 09:23:02 +02:00
0 }
2025-01-03 12:44:26 +01:00
X . prototype . continue _init = async function ( a , b ) { function c ( q , r ) { switch ( q ) { case "hda" : e . hda = this . disk _images . hda = r ; break ; case "hdb" : e . hdb = this . disk _images . hdb = r ; break ; case "cdrom" : e . cdrom = this . disk _images . cdrom = r ; break ; case "fda" : e . fda = this . disk _images . fda = r ; break ; case "fdb" : e . fdb = this . disk _images . fdb = r ; break ; case "multiboot" : e . multiboot = this . disk _images . multiboot = r . buffer ; break ; case "bzimage" : e . bzimage = this . disk _images . bzimage = r . buffer ; break ; case "initrd" : e . initrd = this . disk _images . initrd = r . buffer ; break ;
case "bios" : e . bios = r . buffer ; break ; case "vga_bios" : e . vga _bios = r . buffer ; break ; case "initial_state" : e . initial _state = r . buffer ; break ; case "fs9p_json" : e . fs9p _json = r } } async function d ( ) { if ( e . fs9p && e . fs9p _json && ! e . initial _state && ( e . fs9p . load _from _json ( e . fs9p _json ) , b . bzimage _initrd _from _filesystem ) ) { const { bzimage _path : q , initrd _path : r } = this . get _bzimage _initrd _from _filesystem ( e . fs9p ) , [ A , z ] = await Promise . all ( [ e . fs9p . read _file ( r ) , e . fs9p . read _file ( q ) ] ) ; c . call ( this , "initrd" , new h . SyncBuffer ( A . buffer ) ) ; c . call ( this ,
"bzimage" , new h . SyncBuffer ( z . buffer ) ) } this . serial _adapter && this . serial _adapter . show && this . serial _adapter . show ( ) ; this . v86 . init ( e ) ; e . initial _state && ( a . restore _state ( e . initial _state ) , e . initial _state = void 0 ) ; b . autostart && this . v86 . run ( ) ; this . emulator _bus . send ( "emulator-loaded" ) } this . bus . register ( "emulator-stopped" , function ( ) { this . cpu _is _running = ! 1 ; this . screen _adapter . pause ( ) } , this ) ; this . bus . register ( "emulator-started" , function ( ) { this . cpu _is _running = ! 0 ; this . screen _adapter . continue ( ) } , this ) ; var e = { } ; this . disk _images =
2024-11-28 07:25:05 +01:00
{ fda : void 0 , fdb : void 0 , hda : void 0 , hdb : void 0 , cdrom : void 0 } ; var g = b . boot _order ? b . boot _order : b . fda ? 801 : b . hda ? 786 : 291 ; e . acpi = b . acpi ; e . disable _jit = b . disable _jit ; e . load _devices = ! 0 ; e . memory _size = b . memory _size || 67108864 ; e . vga _memory _size = b . vga _memory _size || 8388608 ; e . boot _order = g ; e . fastboot = b . fastboot || ! 1 ; e . fda = void 0 ; e . fdb = void 0 ; e . uart1 = b . uart1 ; e . uart2 = b . uart2 ; e . uart3 = b . uart3 ; e . cmdline = b . cmdline ; e . preserve _mac _from _state _image = b . preserve _mac _from _state _image ; e . mac _address _translation = b . mac _address _translation ;
2025-01-03 12:44:26 +01:00
e . cpuid _level = b . cpuid _level ; e . virtio _console = b . virtio _console ; e . virtio _net = b . virtio _net ; e . screen _options = b . screen _options ; if ( g = b . network _relay _url || b . net _device && b . net _device . relay _url ) "fetch" === g ? this . network _adapter = new ac ( this . bus , b . net _device ) : g . startsWith ( "wisp://" ) || g . startsWith ( "wisps://" ) ? this . network _adapter = new bc ( g , this . bus , b . net _device ) : this . network _adapter = new $b ( g , this . bus ) ; e . net _device = b . net _device || { type : "ne2k" } ; g = b . screen || { } ; b . screen _container && ( g . container = b . screen _container ) ; b . disable _keyboard ||
( this . keyboard _adapter = new Kb ( this . bus ) ) ; b . disable _mouse || ( this . mouse _adapter = new Rb ( this . bus , g . container ) ) ; this . screen _adapter = g . container ? new aa ( g , ( ) => this . v86 . cpu . devices . vga && this . v86 . cpu . devices . vga . screen _fill _buffer ( ) ) : new cc ; e . screen = this . screen _adapter ; e . screen _options = g ; b . serial _container && ( this . serial _adapter = new Yb ( b . serial _container , this . bus ) ) ; b . serial _container _xtermjs && ( this . serial _adapter = new Zb ( b . serial _container _xtermjs , this . bus ) ) ; b . disable _speaker || ( this . speaker _adapter = new Sb ( this . bus ) ) ;
var f = [ ] ; g = ( q , r ) => { if ( r ) if ( r . get && r . set && r . load ) f . push ( { name : q , loadable : r } ) ; else { if ( "bios" === q || "vga_bios" === q || "initial_state" === q || "multiboot" === q || "bzimage" === q || "initrd" === q ) r . async = ! 1 ; if ( "fda" === q || "fdb" === q ) r . async = ! 1 ; r . url && ! r . async ? f . push ( { name : q , url : r . url , size : r . size } ) : f . push ( { name : q , loadable : h . buffer _from _object ( r , this . zstd _decompress _worker . bind ( this ) ) } ) } } ; b . state && console . warn ( "Warning: Unknown option 'state'. Did you mean 'initial_state'?" ) ; g ( "bios" , b . bios ) ; g ( "vga_bios" , b . vga _bios ) ; g ( "cdrom" ,
b . cdrom ) ; g ( "hda" , b . hda ) ; g ( "hdb" , b . hdb ) ; g ( "fda" , b . fda ) ; g ( "fdb" , b . fdb ) ; g ( "initial_state" , b . initial _state ) ; g ( "multiboot" , b . multiboot ) ; g ( "bzimage" , b . bzimage ) ; g ( "initrd" , b . initrd ) ; if ( b . filesystem ) { g = b . filesystem . basefs ; var k = b . filesystem . baseurl ; let q = new dc ; k && ( q = new ec ( q , k ) ) ; e . fs9p = this . fs9p = new Z ( q ) ; if ( g ) { if ( "object" === typeof g ) { var l = g . size ; g = g . url } f . push ( { name : "fs9p_json" , url : g , size : l , as _json : ! 0 } ) } } var m = this , n = f . length , p = function ( q ) { if ( q === n ) setTimeout ( d . bind ( this ) , 0 ) ; else { var r = f [ q ] ; r . loadable ?
( r . loadable . onload = function ( ) { c . call ( this , r . name , r . loadable ) ; p ( q + 1 ) } . bind ( this ) , r . loadable . load ( ) ) : h . load _file ( r . url , { done : function ( A ) { r . url . endsWith ( ".zst" ) && "initial_state" !== r . name && ( A = this . zstd _decompress ( r . size , new Uint8Array ( A ) ) ) ; c . call ( this , r . name , r . as _json ? A : new h . SyncBuffer ( A ) ) ; p ( q + 1 ) } . bind ( this ) , progress : function ( A ) { 200 === A . target . status ? m . emulator _bus . send ( "download-progress" , { file _index : q , file _count : n , file _name : r . url , lengthComputable : A . lengthComputable , total : A . total || r . size , loaded : A . loaded } ) :
m . emulator _bus . send ( "download-error" , { file _index : q , file _count : n , file _name : r . url , request : A . target } ) } , as _json : r . as _json } ) } } . bind ( this ) ; p ( 0 ) } ; X . prototype . zstd _decompress = function ( a , b ) { const c = this . v86 . cpu ; this . zstd _context = c . zstd _create _ctx ( b . length ) ; ( new Uint8Array ( c . wasm _memory . buffer ) ) . set ( b , c . zstd _get _src _ptr ( this . zstd _context ) ) ; b = c . zstd _read ( this . zstd _context , a ) ; const d = c . wasm _memory . buffer . slice ( b , b + a ) ; c . zstd _read _free ( b , a ) ; c . zstd _free _ctx ( this . zstd _context ) ; this . zstd _context = null ; return d } ;
X . prototype . zstd _decompress _worker = async function ( a , b ) { if ( ! this . zstd _worker ) { const c = URL . createObjectURL ( new Blob ( [ "(" + function ( ) { let d ; globalThis . onmessage = function ( e ) { if ( d ) { var { src : g , decompressed _size : f , id : k } = e . data ; e = d . exports ; var l = e . zstd _create _ctx ( g . length ) ; ( new Uint8Array ( e . memory . buffer ) ) . set ( g , e . zstd _get _src _ptr ( l ) ) ; var m = e . zstd _read ( l , f ) , n = e . memory . buffer . slice ( m , m + f ) ; e . zstd _read _free ( m , f ) ; e . zstd _free _ctx ( l ) ; postMessage ( { result : n , id : k } , [ n ] ) } else l = Object . fromEntries ( "cpu_exception_hook run_hardware_timers cpu_event_halt microtick get_rand_int apic_acknowledge_irq stop_idling io_port_read8 io_port_read16 io_port_read32 io_port_write8 io_port_write16 io_port_write32 mmap_read8 mmap_read16 mmap_read32 mmap_write8 mmap_write16 mmap_write32 mmap_write64 mmap_write128 codegen_finalize jit_clear_func jit_clear_all_funcs" . split ( " " ) . map ( p =>
2024-10-02 21:03:04 +02:00
[ p , ( ) => console . error ( "zstd worker unexpectedly called " + p ) ] ) ) , l . _ _indirect _function _table = new WebAssembly . Table ( { element : "anyfunc" , initial : 1024 } ) , l . abort = ( ) => { throw Error ( "zstd worker aborted" ) ; } , l . log _from _wasm = l . console _log _from _wasm = ( p , q ) => { console . log ( String . fromCharCode ( ... ( new Uint8Array ( d . exports . memory . buffer , p , q ) ) ) ) } , l . dbg _trace _from _wasm = ( ) => console . trace ( ) , d = new WebAssembly . Instance ( new WebAssembly . Module ( e . data ) , { env : l } ) } } . toString ( ) + ")()" ] , { type : "text/javascript" } ) ) ; this . zstd _worker =
2024-11-28 07:25:05 +01:00
new Worker ( c ) ; URL . revokeObjectURL ( c ) ; this . zstd _worker . postMessage ( this . wasm _source , [ this . wasm _source ] ) } return new Promise ( c => { const d = this . zstd _worker _request _id ++ , e = async g => { g . data . id === d && ( this . zstd _worker . removeEventListener ( "message" , e ) , c ( g . data . result ) ) } ; this . zstd _worker . addEventListener ( "message" , e ) ; this . zstd _worker . postMessage ( { src : b , decompressed _size : a , id : d } , [ b . buffer ] ) } ) } ;
2025-01-03 12:44:26 +01:00
X . prototype . get _bzimage _initrd _from _filesystem = function ( a ) { const b = ( a . read _dir ( "/" ) || [ ] ) . map ( e => "/" + e ) ; a = ( a . read _dir ( "/boot/" ) || [ ] ) . map ( e => "/boot/" + e ) ; let c , d ; for ( const e of [ ] . concat ( b , a ) ) { const g = /old/i . test ( e ) || /fallback/i . test ( e ) , f = /vmlinuz/i . test ( e ) || /bzimage/i . test ( e ) , k = /initrd/i . test ( e ) || /initramfs/i . test ( e ) ; ! f || d && g || ( d = e ) ; ! k || c && g || ( c = e ) } c && d || ( console . log ( "Failed to find bzimage or initrd in filesystem. Files:" ) , console . log ( b . join ( " " ) ) , console . log ( a . join ( " " ) ) ) ; return { initrd _path : c , bzimage _path : d } } ;
2024-10-02 21:03:04 +02:00
X . prototype . run = async function ( ) { this . v86 . run ( ) } ; H . exportProperty ( X . prototype , "run" , X . prototype . run ) ; X . prototype . stop = async function ( ) { this . cpu _is _running && await new Promise ( a => { const b = ( ) => { this . remove _listener ( "emulator-stopped" , b ) ; a ( ) } ; this . add _listener ( "emulator-stopped" , b ) ; this . v86 . stop ( ) } ) } ; H . exportProperty ( X . prototype , "stop" , X . prototype . stop ) ;
X . prototype . destroy = async function ( ) { await this . stop ( ) ; this . v86 . destroy ( ) ; this . keyboard _adapter && this . keyboard _adapter . destroy ( ) ; this . network _adapter && this . network _adapter . destroy ( ) ; this . mouse _adapter && this . mouse _adapter . destroy ( ) ; this . screen _adapter && this . screen _adapter . destroy ( ) ; this . serial _adapter && this . serial _adapter . destroy ( ) ; this . speaker _adapter && this . speaker _adapter . destroy ( ) } ; H . exportProperty ( X . prototype , "destroy" , X . prototype . destroy ) ; X . prototype . restart = function ( ) { this . v86 . restart ( ) } ;
H . exportProperty ( X . prototype , "restart" , X . prototype . restart ) ; X . prototype . add _listener = function ( a , b ) { this . bus . register ( a , b , this ) } ; H . exportProperty ( X . prototype , "add_listener" , X . prototype . add _listener ) ; X . prototype . remove _listener = function ( a , b ) { this . bus . unregister ( a , b ) } ; H . exportProperty ( X . prototype , "remove_listener" , X . prototype . remove _listener ) ; X . prototype . restore _state = async function ( a ) { this . v86 . restore _state ( a ) } ; H . exportProperty ( X . prototype , "restore_state" , X . prototype . restore _state ) ;
X . prototype . save _state = async function ( ) { return this . v86 . save _state ( ) } ; H . exportProperty ( X . prototype , "save_state" , X . prototype . save _state ) ; X . prototype . get _instruction _counter = function ( ) { return this . v86 ? this . v86 . cpu . instruction _counter [ 0 ] >>> 0 : 0 } ; H . exportProperty ( X . prototype , "get_instruction_counter" , X . prototype . get _instruction _counter ) ; X . prototype . is _running = function ( ) { return this . cpu _is _running } ; H . exportProperty ( X . prototype , "is_running" , X . prototype . is _running ) ;
2025-01-03 12:44:26 +01:00
X . prototype . set _fda = async function ( a ) { if ( a . url && ! a . async ) h . load _file ( a . url , { done : b => { this . v86 . cpu . devices . fdc . set _fda ( new h . SyncBuffer ( b ) ) } } ) ; else { const b = h . buffer _from _object ( a , this . zstd _decompress _worker . bind ( this ) ) ; b . onload = ( ) => { this . v86 . cpu . devices . fdc . set _fda ( b ) } ; await b . load ( ) } } ; H . exportProperty ( X . prototype , "set_fda" , X . prototype . set _fda ) ; X . prototype . eject _fda = function ( ) { this . v86 . cpu . devices . fdc . eject _fda ( ) } ; H . exportProperty ( X . prototype , "eject_fda" , X . prototype . eject _fda ) ;
2024-10-02 21:03:04 +02:00
X . prototype . keyboard _send _scancodes = function ( a ) { for ( var b = 0 ; b < a . length ; b ++ ) this . bus . send ( "keyboard-code" , a [ b ] ) } ; H . exportProperty ( X . prototype , "keyboard_send_scancodes" , X . prototype . keyboard _send _scancodes ) ; X . prototype . keyboard _send _keys = function ( a ) { for ( var b = 0 ; b < a . length ; b ++ ) this . keyboard _adapter . simulate _press ( a [ b ] ) } ; H . exportProperty ( X . prototype , "keyboard_send_keys" , X . prototype . keyboard _send _keys ) ; X . prototype . keyboard _send _text = function ( a ) { for ( var b = 0 ; b < a . length ; b ++ ) this . keyboard _adapter . simulate _char ( a [ b ] ) } ;
H . exportProperty ( X . prototype , "keyboard_send_text" , X . prototype . keyboard _send _text ) ; X . prototype . screen _make _screenshot = function ( ) { return this . screen _adapter ? this . screen _adapter . make _screenshot ( ) : null } ; H . exportProperty ( X . prototype , "screen_make_screenshot" , X . prototype . screen _make _screenshot ) ; X . prototype . screen _set _scale = function ( a , b ) { this . screen _adapter && this . screen _adapter . set _scale ( a , b ) } ; H . exportProperty ( X . prototype , "screen_set_scale" , X . prototype . screen _set _scale ) ;
X . prototype . screen _go _fullscreen = function ( ) { if ( this . screen _adapter ) { var a = document . getElementById ( "screen_container" ) ; if ( a ) { var b = a . requestFullScreen || a . webkitRequestFullscreen || a . mozRequestFullScreen || a . msRequestFullScreen ; b && ( b . call ( a ) , ( a = document . getElementsByClassName ( "phone_keyboard" ) [ 0 ] ) && a . focus ( ) ) ; try { navigator . keyboard . lock ( ) } catch ( c ) { } this . lock _mouse ( ) } } } ; H . exportProperty ( X . prototype , "screen_go_fullscreen" , X . prototype . screen _go _fullscreen ) ;
X . prototype . lock _mouse = function ( ) { var a = document . body , b = a . requestPointerLock || a . mozRequestPointerLock || a . webkitRequestPointerLock ; b && b . call ( a ) } ; H . exportProperty ( X . prototype , "lock_mouse" , X . prototype . lock _mouse ) ; X . prototype . mouse _set _status = function ( a ) { this . mouse _adapter && ( this . mouse _adapter . emu _enabled = a ) } ; X . prototype . keyboard _set _status = function ( a ) { this . keyboard _adapter && ( this . keyboard _adapter . emu _enabled = a ) } ; H . exportProperty ( X . prototype , "keyboard_set_status" , X . prototype . keyboard _set _status ) ;
X . prototype . serial0 _send = function ( a ) { for ( var b = 0 ; b < a . length ; b ++ ) this . bus . send ( "serial0-input" , a . charCodeAt ( b ) ) } ; H . exportProperty ( X . prototype , "serial0_send" , X . prototype . serial0 _send ) ; X . prototype . serial _send _bytes = function ( a , b ) { for ( var c = 0 ; c < b . length ; c ++ ) this . bus . send ( "serial" + a + "-input" , b [ c ] ) } ; H . exportProperty ( X . prototype , "serial_send_bytes" , X . prototype . serial _send _bytes ) ; X . prototype . serial _set _modem _status = function ( a , b ) { this . bus . send ( "serial" + a + "-modem-status-input" , b ) } ;
X . prototype . serial _set _carrier _detect = function ( a , b ) { this . bus . send ( "serial" + a + "-carrier-detect-input" , b ) } ; X . prototype . serial _set _ring _indicator = function ( a , b ) { this . bus . send ( "serial" + a + "-ring-indicator-input" , b ) } ; X . prototype . serial _set _data _set _ready = function ( a , b ) { this . bus . send ( "serial" + a + "-data-set-ready-input" , b ) } ; X . prototype . serial _set _clear _to _send = function ( a , b ) { this . bus . send ( "serial" + a + "-clear-to-send-input" , b ) } ;
2024-11-28 07:25:05 +01:00
X . prototype . mount _fs = async function ( a , b , c ) { var d = new dc ; b && ( d = new ec ( d , b ) ) ; d = new Z ( d , this . fs9p . qidcounter ) ; b && d . load _from _json ( c ) ; a = this . fs9p . Mount ( a , d ) ; if ( - 2 === a ) throw new fc ; if ( - 17 === a ) throw new gc ; if ( 0 > a ) throw Error ( "Failed to mount. Error number: " + - a ) ; } ; H . exportProperty ( X . prototype , "mount_fs" , X . prototype . mount _fs ) ; X . prototype . create _file = async function ( a , b ) { var c = this . fs9p ; if ( c ) { var d = a . split ( "/" ) ; d = d [ d . length - 1 ] ; a = c . SearchPath ( a ) . parentid ; if ( "" !== d && - 1 !== a ) await c . CreateBinaryFile ( d , a , b ) ; else return Promise . reject ( new fc ) } } ;
H . exportProperty ( X . prototype , "create_file" , X . prototype . create _file ) ; X . prototype . read _file = async function ( a ) { var b = this . fs9p ; if ( b ) return ( a = await b . read _file ( a ) ) ? a : Promise . reject ( new fc ) } ; H . exportProperty ( X . prototype , "read_file" , X . prototype . read _file ) ;
2024-10-02 21:03:04 +02:00
X . prototype . automatically = function ( a ) { const b = c => { const d = c [ 0 ] ; if ( d ) { var e = c . slice ( 1 ) ; d . sleep ? setTimeout ( ( ) => b ( e ) , 1E3 * d . sleep ) : d . vga _text ? this . wait _until _vga _screen _contains ( d . vga _text ) . then ( ( ) => b ( e ) ) : d . keyboard _send ? ( d . keyboard _send instanceof Array ? this . keyboard _send _scancodes ( d . keyboard _send ) : this . keyboard _send _text ( d . keyboard _send ) , b ( e ) ) : d . call && ( d . call ( ) , b ( e ) ) } } ; b ( a ) } ;
2025-01-03 12:44:26 +01:00
X . prototype . wait _until _vga _screen _contains = function ( a ) { return new Promise ( b => { function c ( f ) { return "string" === typeof a ? f . includes ( a ) : a . test ( f ) } function d ( f ) { [ f ] = f ; e . add ( f ) } for ( const f of this . screen _adapter . get _text _screen ( ) ) if ( c ( f ) ) { b ( ! 0 ) ; return } const e = new Set , g = ( ) => { for ( const f of e ) { const k = this . screen _adapter . get _text _row ( f ) ; if ( c ( k ) ) { this . remove _listener ( "screen-put-char" , d ) ; b ( ) ; return } } e . clear ( ) ; setTimeout ( g , 100 ) } ; g ( ) ; this . add _listener ( "screen-put-char" , d ) } ) } ;
2024-11-28 07:25:05 +01:00
X . prototype . read _memory = function ( a , b ) { return this . v86 . cpu . read _blob ( a , b ) } ; X . prototype . write _memory = function ( a , b ) { this . v86 . cpu . write _blob ( a , b ) } ; X . prototype . set _serial _container _xtermjs = function ( a ) { this . serial _adapter && this . serial _adapter . destroy && this . serial _adapter . destroy ( ) ; this . serial _adapter = new Zb ( a , this . bus ) ; this . serial _adapter . show ( ) } ; function gc ( a ) { this . message = a || "File already exists" } gc . prototype = Error . prototype ; function fc ( a ) { this . message = a || "File not found" } fc . prototype = Error . prototype ;
"undefined" !== typeof module && "undefined" !== typeof module . exports ? module . exports . V86 = X : "undefined" !== typeof window ? window . V86 = X : "function" === typeof importScripts && ( self . V86 = X ) ; var hc = { Connector : function ( a ) { this . listeners = { } ; this . pair = a ; a . addEventListener ( "message" , function ( b ) { b = b . data ; for ( var c = this . listeners [ b [ 0 ] ] , d = 0 ; d < c . length ; d ++ ) { var e = c [ d ] ; e . fn . call ( e . this _value , b [ 1 ] ) } } . bind ( this ) , ! 1 ) } } ; hc . Connector . prototype . register = function ( a , b , c ) { var d = this . listeners [ a ] ; void 0 === d && ( d = this . listeners [ a ] = [ ] ) ; d . push ( { fn : b , this _value : c } ) } ; hc . Connector . prototype . send = function ( a , b , c ) { this . pair && this . pair . postMessage ( [ a , b ] , c ) } ; hc . init = function ( a ) { return new hc . Connector ( a ) } ; function cc ( ) { var a , b = 0 , c = 0 ; this . put _char = function ( d , e , g ) { a [ d * b + e ] = g } ; this . destroy = function ( ) { } ; this . pause = function ( ) { } ; this . continue = function ( ) { } ; this . set _mode = function ( ) { } ; this . set _font _bitmap = function ( ) { } ; this . set _font _page = function ( ) { } ; this . clear _screen = function ( ) { } ; this . set _size _text = function ( d , e ) { if ( d !== b || e !== c ) a = new Uint8Array ( d * e ) , b = d , c = e } ; this . set _size _graphical = function ( ) { } ; this . set _scale = function ( ) { } ; this . update _cursor _scanline = function ( ) { } ; this . update _cursor = function ( ) { } ; this . update _buffer =
function ( ) { } ; this . get _text _screen = function ( ) { for ( var d = [ ] , e = 0 ; e < c ; e ++ ) d . push ( this . get _text _row ( e ) ) ; return d } ; this . get _text _row = function ( d ) { d *= b ; return String . fromCharCode . apply ( String , a . subarray ( d , d + b ) ) } ; this . set _size _text ( 80 , 25 ) } ; const ic = ( new Date ( "1970-01-01T00:00:00Z" ) ) . getTime ( ) , jc = ( new Date ( "1900-01-01T00:00:00Z" ) ) . getTime ( ) , kc = ic - jc , lc = Math . pow ( 2 , 32 ) , mc = [ 118 , 56 , 54 ] ; function nc ( a ) { return [ 0 , 1 , 2 , 3 , 4 , 5 ] . map ( b => a [ b ] . toString ( 16 ) ) . map ( b => 1 === b . length ? "0" + b : b ) . join ( ":" ) } function oc ( a ) { return a [ 0 ] << 24 | a [ 1 ] << 16 | a [ 2 ] << 8 | a [ 3 ] }
2025-01-03 12:44:26 +01:00
class pc { constructor ( a , b ) { a = Math . min ( a , 16 ) ; this . maximum _capacity = b ? Math . max ( b , a ) : 0 ; this . length = this . head = this . tail = 0 ; this . buffer = new Uint8Array ( a ) } write ( a ) { const b = a . length ; var c = this . length + b ; let d = this . buffer . length ; if ( d < c ) { for ( ; d < c ; ) d *= 2 ; if ( this . maximum _capacity && d > this . maximum _capacity ) throw Error ( "stream capacity overflow in GrowableRingbuffer.write(), package dropped" ) ; c = new Uint8Array ( d ) ; this . peek ( c ) ; this . tail = 0 ; this . head = this . length ; this . buffer = c } c = this . buffer ; const e = this . head + b ; if ( e > d ) { const g =
d - this . head ; c . set ( a . subarray ( 0 , g ) , this . head ) ; c . set ( a . subarray ( g ) ) } else c . set ( a , this . head ) ; this . head = e % d ; this . length += b } peek ( a ) { const b = Math . min ( this . length , a . length ) ; if ( b ) { const e = this . buffer ; var c = e . length , d = this . tail + b ; d > c ? ( d %= c , c -= this . tail , a . set ( e . subarray ( this . tail ) ) , a . set ( e . subarray ( 0 , d ) , c ) ) : a . set ( e . subarray ( this . tail , d ) ) } return b } remove ( a ) { a > this . length && ( a = this . length ) ; a && ( this . tail = ( this . tail + a ) % this . buffer . length , this . length -= a ) ; return a } }
function qc ( ) { const a = new Uint8Array ( 1518 ) , b = a . buffer , c = a . byteOffset ; return { eth _frame : a , eth _frame _view : new DataView ( b ) , eth _payload _view : new DataView ( b , c + 14 , 1500 ) , ipv4 _payload _view : new DataView ( b , c + 34 , 1480 ) , udp _payload _view : new DataView ( b , c + 42 , 1472 ) , text _encoder : new TextEncoder } } function rc ( a , b , c , d ) { d . eth _frame . set ( b , c . byteOffset + a ) ; return b . length }
function sc ( a , b , c , d ) { const e = c . byteOffset + ( a & - 2 ) ; d = d . eth _frame ; for ( c = c . byteOffset ; c < e ; c += 2 ) b += d [ c ] << 8 | d [ c + 1 ] ; for ( a & 1 && ( b += d [ e ] << 8 ) ; b >> 16 ; ) b = ( b & 65535 ) + ( b >> 16 ) ; return ~ b & 65535 }
function tc ( a , b ) { a . eth _frame . fill ( 0 ) ; var c = a . eth _frame , d = c . subarray , e = a . eth _frame _view ; rc ( 0 , b . eth . dest , e , a ) ; rc ( 6 , b . eth . src , e , a ) ; e . setUint16 ( 12 , b . eth . ethertype ) ; e = 14 ; if ( b . arp ) { var g = a . eth _payload _view ; g . setUint16 ( 0 , b . arp . htype ) ; g . setUint16 ( 2 , b . arp . ptype ) ; g . setUint8 ( 4 , b . arp . sha . length ) ; g . setUint8 ( 5 , b . arp . spa . length ) ; g . setUint16 ( 6 , b . arp . oper ) ; rc ( 8 , b . arp . sha , g , a ) ; rc ( 14 , b . arp . spa , g , a ) ; rc ( 18 , b . arp . tha , g , a ) ; rc ( 24 , b . arp . tpa , g , a ) ; e += 28 } else if ( b . ipv4 ) { g = a . eth _payload _view ; var f = 20 ; if ( b . icmp ) { var k = a . ipv4 _payload _view ;
k . setUint8 ( 0 , b . icmp . type ) ; k . setUint8 ( 1 , b . icmp . code ) ; k . setUint16 ( 2 , 0 ) ; var l = 4 + rc ( 4 , b . icmp . data , k , a ) ; k . setUint16 ( 2 , sc ( l , 0 , k , a ) ) ; f += l } else if ( b . udp ) { k = a . ipv4 _payload _view ; var m = 8 ; if ( b . dhcp ) { l = m ; var n = a . udp _payload _view ; n . setUint8 ( 0 , b . dhcp . op ) ; n . setUint8 ( 1 , b . dhcp . htype ) ; n . setUint8 ( 2 , b . dhcp . hlen ) ; n . setUint8 ( 3 , b . dhcp . hops ) ; n . setUint32 ( 4 , b . dhcp . xid ) ; n . setUint16 ( 8 , b . dhcp . secs ) ; n . setUint16 ( 10 , b . dhcp . flags ) ; n . setUint32 ( 12 , b . dhcp . ciaddr ) ; n . setUint32 ( 16 , b . dhcp . yiaddr ) ; n . setUint32 ( 20 , b . dhcp . siaddr ) ; n . setUint32 ( 24 ,
b . dhcp . giaddr ) ; rc ( 28 , b . dhcp . chaddr , n , a ) ; n . setUint32 ( 236 , 1669485411 ) ; m = 240 ; for ( var p of b . dhcp . options ) m += rc ( m , p , n , a ) ; l += m } else if ( b . dns ) { p = m ; m = a . udp _payload _view ; m . setUint16 ( 0 , b . dns . id ) ; m . setUint16 ( 2 , b . dns . flags ) ; m . setUint16 ( 4 , b . dns . questions . length ) ; m . setUint16 ( 6 , b . dns . answers . length ) ; let A = 12 ; for ( var q = 0 ; q < b . dns . questions . length ; ++ q ) { var r = b . dns . questions [ q ] ; for ( n of r . name ) { const z = a . text _encoder . encodeInto ( n , a . eth _frame . subarray ( m . byteOffset + ( A + 1 ) ) ) . written ; m . setUint8 ( A , z ) ; A += 1 + z } m . setUint16 ( A ,
r . type ) ; A += 2 ; m . setUint16 ( A , r . class ) ; A += 2 } for ( q = 0 ; q < b . dns . answers . length ; ++ q ) { n = b . dns . answers [ q ] ; for ( l of n . name ) r = a . text _encoder . encodeInto ( l , a . eth _frame . subarray ( m . byteOffset + ( A + 1 ) ) ) . written , m . setUint8 ( A , r ) , A += 1 + r ; m . setUint16 ( A , n . type ) ; A += 2 ; m . setUint16 ( A , n . class ) ; A += 2 ; m . setUint32 ( A , n . ttl ) ; A += 4 ; m . setUint16 ( A , n . data . length ) ; A += 2 ; A += rc ( A , n . data , m , a ) } l = p + A } else b . ntp ? ( l = m , n = a . udp _payload _view , n . setUint8 ( 0 , b . ntp . flags ) , n . setUint8 ( 1 , b . ntp . stratum ) , n . setUint8 ( 2 , b . ntp . poll ) , n . setUint8 ( 3 , b . ntp . precision ) ,
n . setUint32 ( 4 , b . ntp . root _delay ) , n . setUint32 ( 8 , b . ntp . root _disp ) , n . setUint32 ( 12 , b . ntp . ref _id ) , n . setUint32 ( 16 , b . ntp . ref _ts _i ) , n . setUint32 ( 20 , b . ntp . ref _ts _f ) , n . setUint32 ( 24 , b . ntp . ori _ts _i ) , n . setUint32 ( 28 , b . ntp . ori _ts _f ) , n . setUint32 ( 32 , b . ntp . rec _ts _i ) , n . setUint32 ( 36 , b . ntp . rec _ts _f ) , n . setUint32 ( 40 , b . ntp . trans _ts _i ) , n . setUint32 ( 44 , b . ntp . trans _ts _f ) , l += 48 ) : l = m + rc ( 0 , b . udp . data , a . udp _payload _view , a ) ; m = l ; k . setUint16 ( 0 , b . udp . sport ) ; k . setUint16 ( 2 , b . udp . dport ) ; k . setUint16 ( 4 , m ) ; k . setUint16 ( 6 , 0 ) ; k . setUint16 ( 6 , sc ( m ,
( b . ipv4 . src [ 0 ] << 8 | b . ipv4 . src [ 1 ] ) + ( b . ipv4 . src [ 2 ] << 8 | b . ipv4 . src [ 3 ] ) + ( b . ipv4 . dest [ 0 ] << 8 | b . ipv4 . dest [ 1 ] ) + ( b . ipv4 . dest [ 2 ] << 8 | b . ipv4 . dest [ 3 ] ) + 17 + m , k , a ) ) ; f += m } else b . tcp && ( k = a . ipv4 _payload _view , l = 0 , n = b . tcp , n . fin && ( l |= 1 ) , n . syn && ( l |= 2 ) , n . rst && ( l |= 4 ) , n . psh && ( l |= 8 ) , n . ack && ( l |= 16 ) , n . urg && ( l |= 32 ) , n . ece && ( l |= 64 ) , n . cwr && ( l |= 128 ) , k . setUint16 ( 0 , n . sport ) , k . setUint16 ( 2 , n . dport ) , k . setUint32 ( 4 , n . seq ) , k . setUint32 ( 8 , n . ackn ) , k . setUint8 ( 12 , 80 ) , k . setUint8 ( 13 , l ) , k . setUint16 ( 14 , n . winsize ) , k . setUint16 ( 16 , 0 ) , k . setUint16 ( 18 , n . urgent ||
0 ) , l = 20 , b . tcp _data && ( l += rc ( 20 , b . tcp _data , k , a ) ) , k . setUint16 ( 16 , sc ( l , ( b . ipv4 . src [ 0 ] << 8 | b . ipv4 . src [ 1 ] ) + ( b . ipv4 . src [ 2 ] << 8 | b . ipv4 . src [ 3 ] ) + ( b . ipv4 . dest [ 0 ] << 8 | b . ipv4 . dest [ 1 ] ) + ( b . ipv4 . dest [ 2 ] << 8 | b . ipv4 . dest [ 3 ] ) + 6 + l , k , a ) ) , f += l ) ; g . setUint8 ( 0 , 69 ) ; g . setUint8 ( 1 , b . ipv4 . tos || 0 ) ; g . setUint16 ( 2 , f ) ; g . setUint16 ( 4 , b . ipv4 . id || 0 ) ; g . setUint8 ( 6 , 64 ) ; g . setUint8 ( 8 , b . ipv4 . ttl || 32 ) ; g . setUint8 ( 9 , b . ipv4 . proto ) ; g . setUint16 ( 10 , 0 ) ; rc ( 12 , b . ipv4 . src , g , a ) ; rc ( 16 , b . ipv4 . dest , g , a ) ; g . setUint16 ( 10 , sc ( 20 , 0 , g , a ) ) ; e += f } return d . call ( c , 0 , e ) }
function uc ( a , b ) { fetch ( ` https:// ${ b . doh _server || "cloudflare-dns.com" } /dns-query ` , { method : "POST" , headers : [ [ "content-type" , "application/dns-message" ] ] , body : a . udp . data } ) . then ( async c => { c = { eth : { ethertype : 2048 , src : b . router _mac , dest : a . eth . src } , ipv4 : { proto : 17 , src : b . router _ip , dest : a . ipv4 . src } , udp : { sport : 53 , dport : a . udp . sport , data : new Uint8Array ( await c . arrayBuffer ( ) ) } } ; b . receive ( tc ( b . eth _encoder _buf , c ) ) } ) ; return ! 0 }
function vc ( a , b ) { let c = { } ; c . eth = { ethertype : 2048 , src : b . router _mac , dest : a . eth . src } ; c . ipv4 = { proto : 17 , src : b . router _ip , dest : b . vm _ip } ; c . udp = { sport : 67 , dport : 68 } ; c . dhcp = { htype : 1 , hlen : 6 , hops : 0 , xid : a . dhcp . xid , secs : 0 , flags : 0 , ciaddr : 0 , yiaddr : oc ( b . vm _ip ) , siaddr : oc ( b . router _ip ) , giaddr : oc ( b . router _ip ) , chaddr : a . dhcp . chaddr } ; let d = [ ] , e = a . dhcp . options . find ( function ( g ) { return 53 === g [ 0 ] } ) ; e && 3 === e [ 2 ] && ( a . dhcp . op = 3 ) ; 1 === a . dhcp . op && ( c . dhcp . op = 2 , d . push ( new Uint8Array ( [ 53 , 1 , 2 ] ) ) ) ; 3 === a . dhcp . op && ( c . dhcp . op = 2 , d . push ( new Uint8Array ( [ 53 ,
1 , 5 ] ) ) , d . push ( new Uint8Array ( [ 51 , 4 , 8 , 0 , 0 , 0 ] ) ) ) ; a = [ b . router _ip [ 0 ] , b . router _ip [ 1 ] , b . router _ip [ 2 ] , b . router _ip [ 3 ] ] ; d . push ( new Uint8Array ( [ 1 , 4 , 255 , 255 , 255 , 0 ] ) ) ; b . masquerade && ( d . push ( new Uint8Array ( [ 3 , 4 ] . concat ( a ) ) ) , d . push ( new Uint8Array ( [ 6 , 4 ] . concat ( a ) ) ) ) ; d . push ( new Uint8Array ( [ 54 , 4 ] . concat ( a ) ) ) ; d . push ( new Uint8Array ( [ 60 , 3 ] . concat ( mc ) ) ) ; d . push ( new Uint8Array ( [ 255 , 0 ] ) ) ; c . dhcp . options = d ; b . receive ( tc ( b . eth _encoder _buf , c ) ) }
function wc ( a , b ) { let c = { } ; var d = ( new DataView ( a . buffer , a . byteOffset , a . byteLength ) ) . getUint16 ( 12 ) , e = { ethertype : d , dest : a . subarray ( 0 , 6 ) , dest _s : nc ( a . subarray ( 0 , 6 ) ) , src : a . subarray ( 6 , 12 ) , src _s : nc ( a . subarray ( 6 , 12 ) ) } ; c . eth = e ; a = a . subarray ( 14 , a . length ) ; if ( 2048 === d ) { var g = new DataView ( a . buffer , a . byteOffset , a . byteLength ) , f = a [ 0 ] >> 4 & 15 ; e = a [ 0 ] & 15 ; var k = g . getUint8 ( 1 ) , l = g . getUint16 ( 2 ) ; let m = g . getUint8 ( 8 ) ; d = g . getUint8 ( 9 ) ; g = g . getUint16 ( 10 ) ; f = { version : f , ihl : e , tos : k , len : l , ttl : m , proto : d , ip _checksum : g , src : a . subarray ( 12 ,
16 ) , dest : a . subarray ( 16 , 20 ) } ; c . ipv4 = f ; e = a . subarray ( 4 * e , l ) ; if ( 1 === d ) a = new DataView ( e . buffer , e . byteOffset , e . byteLength ) , a = { type : a . getUint8 ( 0 ) , code : a . getUint8 ( 1 ) , checksum : a . getUint16 ( 2 ) , data : e . subarray ( 4 ) } , c . icmp = a ; else if ( 6 === d ) d = new DataView ( e . buffer , e . byteOffset , e . byteLength ) , a = { sport : d . getUint16 ( 0 ) , dport : d . getUint16 ( 2 ) , seq : d . getUint32 ( 4 ) , ackn : d . getUint32 ( 8 ) , doff : d . getUint8 ( 12 ) >> 4 , winsize : d . getUint16 ( 14 ) , checksum : d . getUint16 ( 16 ) , urgent : d . getUint16 ( 18 ) } , d = d . getUint8 ( 13 ) , a . fin = ! ! ( d & 1 ) , a . syn = ! ! ( d & 2 ) ,
a . rst = ! ! ( d & 4 ) , a . psh = ! ! ( d & 8 ) , a . ack = ! ! ( d & 16 ) , a . urg = ! ! ( d & 32 ) , a . ece = ! ! ( d & 64 ) , a . cwr = ! ! ( d & 128 ) , c . tcp = a , c . tcp _data = e . subarray ( 4 * a . doff ) ; else if ( 17 === d ) { a = new DataView ( e . buffer , e . byteOffset , e . byteLength ) ; a = { sport : a . getUint16 ( 0 ) , dport : a . getUint16 ( 2 ) , len : a . getUint16 ( 4 ) , checksum : a . getUint16 ( 6 ) , data : e . subarray ( 8 ) , data _s : ( new TextDecoder ) . decode ( e . subarray ( 8 ) ) } ; if ( 67 === a . dport || 67 === a . sport ) { e = e . subarray ( 8 ) ; d = new DataView ( e . buffer , e . byteOffset , e . byteLength ) ; e . subarray ( 44 , 236 ) ; d = { op : d . getUint8 ( 0 ) , htype : d . getUint8 ( 1 ) ,
hlen : d . getUint8 ( 2 ) , hops : d . getUint8 ( 3 ) , xid : d . getUint32 ( 4 ) , secs : d . getUint16 ( 8 ) , flags : d . getUint16 ( 10 ) , ciaddr : d . getUint32 ( 12 ) , yiaddr : d . getUint32 ( 16 ) , siaddr : d . getUint32 ( 20 ) , giaddr : d . getUint32 ( 24 ) , chaddr : e . subarray ( 28 , 44 ) , magic : d . getUint32 ( 236 ) , options : [ ] } ; e = e . subarray ( 240 ) ; for ( l = 0 ; l < e . length ; ++ l ) f = l , 0 !== e [ l ] && ( ++ l , k = e [ l ] , l += k , d . options . push ( e . subarray ( f , f + k + 2 ) ) ) ; c . dhcp = d ; c . dhcp _options = d . options } else 53 === a . dport || 53 === a . sport ? xc ( e . subarray ( 8 ) , c ) : 123 === a . dport && ( d = e . subarray ( 8 ) , d = new DataView ( d . buffer ,
d . byteOffset , d . byteLength ) , c . ntp = { flags : d . getUint8 ( 0 ) , stratum : d . getUint8 ( 1 ) , poll : d . getUint8 ( 2 ) , precision : d . getUint8 ( 3 ) , root _delay : d . getUint32 ( 4 ) , root _disp : d . getUint32 ( 8 ) , ref _id : d . getUint32 ( 12 ) , ref _ts _i : d . getUint32 ( 16 ) , ref _ts _f : d . getUint32 ( 20 ) , ori _ts _i : d . getUint32 ( 24 ) , ori _ts _f : d . getUint32 ( 28 ) , rec _ts _i : d . getUint32 ( 32 ) , rec _ts _f : d . getUint32 ( 36 ) , trans _ts _i : d . getUint32 ( 40 ) , trans _ts _f : d . getUint32 ( 44 ) } ) ; c . udp = a } } else 2054 === d ? ( d = new DataView ( a . buffer , a . byteOffset , a . byteLength ) , a = { htype : d . getUint16 ( 0 ) , ptype : d . getUint16 ( 2 ) ,
oper : d . getUint16 ( 6 ) , sha : a . subarray ( 8 , 14 ) , spa : a . subarray ( 14 , 18 ) , tha : a . subarray ( 18 , 24 ) , tpa : a . subarray ( 24 , 28 ) } , c . arp = a ) : 34525 !== d && B ( d ) ; if ( c . ipv4 ) if ( c . tcp ) { if ( a = ` ${ c . ipv4 . src . join ( "." ) } : ${ c . tcp . sport } : ${ c . ipv4 . dest . join ( "." ) } : ${ c . tcp . dport } ` , ! c . tcp . syn || ! b . on _tcp _connection ( c , a ) ) if ( b . tcp _conn [ a ] ) b . tcp _conn [ a ] . process ( c ) ; else { a = c . tcp . ackn ; if ( c . tcp . fin || c . tcp . syn ) a += 1 ; d = { } ; d . eth = { ethertype : 2048 , src : b . router _mac , dest : c . eth . src } ; d . ipv4 = { proto : 6 , src : c . ipv4 . dest , dest : c . ipv4 . src } ; d . tcp = { sport : c . tcp . dport , dport : c . tcp . sport ,
seq : a , ackn : c . tcp . seq + ( c . tcp . syn ? 1 : 0 ) , winsize : c . tcp . winsize , rst : ! 0 , ack : c . tcp . syn } ; b . receive ( tc ( b . eth _encoder _buf , d ) ) } } else if ( c . udp ) if ( c . dns ) if ( "static" === b . dns _method ) { a = { } ; a . eth = { ethertype : 2048 , src : b . router _mac , dest : c . eth . src } ; a . ipv4 = { proto : 17 , src : b . router _ip , dest : c . ipv4 . src } ; a . udp = { sport : 53 , dport : c . udp . sport } ; d = [ ] ; for ( e = 0 ; e < c . dns . questions . length ; ++ e ) switch ( l = c . dns . questions [ e ] , l . type ) { case 1 : d . push ( { name : l . name , type : l . type , class : l . class , ttl : 600 , data : [ 192 , 168 , 87 , 1 ] } ) } a . dns = { id : c . dns . id , flags : 33152 ,
questions : c . dns . questions , answers : d } ; b . receive ( tc ( b . eth _encoder _buf , a ) ) } else uc ( c , b ) ; else c . dhcp ? vc ( c , b ) : c . ntp ? ( a = Date . now ( ) + kc , d = a % 1E3 / 1E3 * lc , e = { } , e . eth = { ethertype : 2048 , src : b . router _mac , dest : c . eth . src } , e . ipv4 = { proto : 17 , src : c . ipv4 . dest , dest : c . ipv4 . src } , e . udp = { sport : 123 , dport : c . udp . sport } , e . ntp = Object . assign ( { } , c . ntp ) , e . ntp . flags = 36 , e . ntp . poll = 10 , e . ntp . ori _ts _i = c . ntp . trans _ts _i , e . ntp . ori _ts _f = c . ntp . trans _ts _f , e . ntp . rec _ts _i = a / 1E3 , e . ntp . rec _ts _f = d , e . ntp . trans _ts _i = a / 1E3 , e . ntp . trans _ts _f = d , e . ntp . stratum =
2 , b . receive ( tc ( b . eth _encoder _buf , e ) ) ) : 8 === c . udp . dport && ( a = { } , a . eth = { ethertype : 2048 , src : b . router _mac , dest : c . eth . src } , a . ipv4 = { proto : 17 , src : c . ipv4 . dest , dest : c . ipv4 . src } , a . udp = { sport : c . udp . dport , dport : c . udp . sport , data : ( new TextEncoder ) . encode ( c . udp . data _s ) } , b . receive ( tc ( b . eth _encoder _buf , a ) ) ) ; else c . icmp && 8 === c . icmp . type && ( a = { } , a . eth = { ethertype : 2048 , src : b . router _mac , dest : c . eth . src } , a . ipv4 = { proto : 1 , src : b . router _ip , dest : c . ipv4 . src } , a . icmp = { type : 0 , code : c . icmp . code , data : c . icmp . data } , b . receive ( tc ( b . eth _encoder _buf ,
a ) ) ) ; else c . arp && 1 === c . arp . oper && 2048 === c . arp . ptype && ( a = oc ( c . arp . tpa ) & 4294967040 , d = oc ( b . router _ip ) & 4294967040 , ! b . masquerade && a !== d || a === d && 99 < c . arp . tpa [ 3 ] || ( a = { } , a . eth = { ethertype : 2054 , src : b . router _mac , dest : c . eth . src } , a . arp = { htype : 1 , ptype : 2048 , oper : 2 , sha : b . router _mac , spa : c . arp . tpa , tha : c . eth . src , tpa : c . arp . spa } , b . receive ( tc ( b . eth _encoder _buf , a ) ) ) ) }
function xc ( a , b ) { function c ( ) { let m = [ ] , n ; do n = d . getUint8 ( k ) , m . push ( ( new TextDecoder ) . decode ( a . subarray ( k + 1 , k + 1 + n ) ) ) , k += n + 1 ; while ( 0 < n ) ; return m } let d = new DataView ( a . buffer , a . byteOffset , a . byteLength ) , e = { id : d . getUint16 ( 0 ) , flags : d . getUint16 ( 2 ) , questions : [ ] , answers : [ ] } ; var g = d . getUint16 ( 4 ) ; let f = d . getUint16 ( 6 ) ; d . getUint16 ( 8 ) ; d . getUint16 ( 10 ) ; let k = 12 ; for ( var l = 0 ; l < g ; l ++ ) e . questions . push ( { name : c ( ) , type : d . getInt16 ( k ) , class : d . getInt16 ( k + 2 ) } ) , k += 4 ; for ( g = 0 ; g < f ; g ++ ) { l = { name : c ( ) , type : d . getInt16 ( k ) , class : d . getUint16 ( k +
2 ) , ttl : d . getUint32 ( k + 4 ) } ; k += 8 ; let m = d . getUint16 ( k ) ; k += 2 ; l . data = a . subarray ( k , k + m ) ; k += m ; e . answers . push ( l ) } b . dns = e } function yc ( ) { this . state = "closed" ; this . send _buffer = new pc ( 2048 , 0 ) ; this . send _chunk _buf = new Uint8Array ( 1460 ) ; this . delayed _send _fin = this . in _active _close = ! 1 ; this . delayed _state = void 0 }
yc . prototype . ipv4 _reply = function ( ) { let a = { } ; a . eth = { ethertype : 2048 , src : this . hsrc , dest : this . hdest } ; a . ipv4 = { proto : 6 , src : this . psrc , dest : this . pdest } ; a . tcp = { sport : this . sport , dport : this . dport , winsize : this . winsize , ackn : this . ack , seq : this . seq , ack : ! 0 } ; return a } ; yc . prototype . packet _reply = function ( a , b ) { a = { sport : a . tcp . dport , dport : a . tcp . sport , winsize : a . tcp . winsize , ackn : this . ack , seq : this . seq } ; if ( b ) for ( const c in b ) a [ c ] = b [ c ] ; b = this . ipv4 _reply ( ) ; b . tcp = a ; return b } ;
yc . prototype . accept = function ( a ) { this . seq = 1338 ; this . ack = a . tcp . seq + 1 ; this . start _seq = a . tcp . seq ; this . hsrc = this . net . router _mac ; this . psrc = a . ipv4 . dest ; this . sport = a . tcp . dport ; this . hdest = a . eth . src ; this . dport = a . tcp . sport ; this . pdest = a . ipv4 . src ; this . winsize = a . tcp . winsize ; let b = this . ipv4 _reply ( ) ; b . tcp = { sport : this . sport , dport : this . dport , seq : 1337 , ackn : this . ack , winsize : a . tcp . winsize , syn : ! 0 , ack : ! 0 } ; this . state = "established" ; this . net . receive ( tc ( this . net . eth _encoder _buf , b ) ) } ;
yc . prototype . process = function ( a ) { if ( "closed" === this . state ) a = this . packet _reply ( a , { rst : ! 0 } ) , this . net . receive ( tc ( this . net . eth _encoder _buf , a ) ) ; else if ( a . tcp . rst ) this . on _close ( ) , this . release ( ) ; else if ( a . tcp . syn ) "syn-sent" === this . state && a . tcp . ack && ( this . ack = a . tcp . seq + 1 , this . start _seq = a . tcp . seq , this . last _received _ackn = a . tcp . ackn , a = this . ipv4 _reply ( ) , this . net . receive ( tc ( this . net . eth _encoder _buf , a ) ) , this . state = "established" , this . on _connect && this . on _connect . call ( this ) ) ; else { if ( a . tcp . ack ) if ( "syn-received" ===
this . state ) this . state = "established" ; else if ( "fin-wait-1" === this . state ) a . tcp . fin || ( this . state = "fin-wait-2" ) ; else if ( "closing" === this . state || "last-ack" === this . state ) { this . release ( ) ; return } if ( void 0 === this . last _received _ackn ) this . last _received _ackn = a . tcp . ackn ; else { var b = a . tcp . ackn - this . last _received _ackn ; if ( 0 < b ) { if ( this . last _received _ackn = a . tcp . ackn , this . send _buffer . remove ( b ) , this . seq += b , this . pending = ! 1 , this . delayed _send _fin && ! this . send _buffer . length ) { this . delayed _send _fin = ! 1 ; this . state = this . delayed _state ;
a = this . ipv4 _reply ( ) ; a . tcp . fin = ! 0 ; this . net . receive ( tc ( this . net . eth _encoder _buf , a ) ) ; return } } else if ( 0 > b ) { a = this . packet _reply ( a , { rst : ! 0 } ) ; this . net . receive ( tc ( this . net . eth _encoder _buf , a ) ) ; this . on _close ( ) ; this . release ( ) ; return } } a . tcp . fin ? ( ++ this . ack , b = this . packet _reply ( a , { } ) , "established" === this . state ? ( b . tcp . ack = ! 0 , this . state = "close-wait" , this . on _shutdown ( ) ) : "fin-wait-1" === this . state ? ( a . tcp . ack ? this . release ( ) : this . state = "closing" , b . tcp . ack = ! 0 ) : "fin-wait-2" === this . state ? ( this . release ( ) , b . tcp . ack = ! 0 ) : ( this . release ( ) ,
this . on _close ( ) , b . tcp . rst = ! 0 ) , this . net . receive ( tc ( this . net . eth _encoder _buf , b ) ) ) : this . ack !== a . tcp . seq ? ( a = this . packet _reply ( a , { ack : ! 0 } ) , this . net . receive ( tc ( this . net . eth _encoder _buf , a ) ) ) : a . tcp . ack && 0 < a . tcp _data . length && ( this . ack += a . tcp _data . length , b = this . ipv4 _reply ( ) , this . net . receive ( tc ( this . net . eth _encoder _buf , b ) ) , this . on _data ( a . tcp _data ) ) ; this . pump ( ) } } ; yc . prototype . write = function ( a ) { this . in _active _close || this . send _buffer . write ( a ) ; this . pump ( ) } ;
yc . prototype . writev = function ( a ) { if ( ! this . in _active _close ) for ( const b of a ) this . send _buffer . write ( b ) ; this . pump ( ) } ;
yc . prototype . close = function ( ) { if ( ! this . in _active _close ) { this . in _active _close = ! 0 ; if ( "established" === this . state || "syn-received" === this . state ) var a = "fin-wait-1" ; else if ( "close-wait" === this . state ) a = "last-ack" ; else { this . release ( ) ; return } this . send _buffer . length || this . pending ? ( this . delayed _send _fin = ! 0 , this . delayed _state = a ) : ( this . state = a , a = this . ipv4 _reply ( ) , a . tcp . fin = ! 0 , this . net . receive ( tc ( this . net . eth _encoder _buf , a ) ) ) } this . pump ( ) } ; yc . prototype . on _shutdown = function ( ) { } ; yc . prototype . on _close = function ( ) { } ;
yc . prototype . release = function ( ) { this . net . tcp _conn [ this . tuple ] && ( this . state = "closed" , delete this . net . tcp _conn [ this . tuple ] ) } ; yc . prototype . pump = function ( ) { if ( this . send _buffer . length && ! this . pending ) { const a = this . send _chunk _buf , b = this . send _buffer . peek ( a ) , c = this . ipv4 _reply ( ) ; c . tcp . psh = ! 0 ; c . tcp _data = a . subarray ( 0 , b ) ; this . net . receive ( tc ( this . net . eth _encoder _buf , c ) ) ; this . pending = ! 0 } } ; function bc ( a , b , c ) { this . register _ws ( a ) ; this . last _stream = 1 ; this . connections = { 0 : { congestion : 0 } } ; this . congested _buffer = [ ] ; c = c || { } ; this . bus = b ; this . id = c . id || 0 ; this . router _mac = new Uint8Array ( ( c . router _mac || "52:54:0:1:2:3" ) . split ( ":" ) . map ( function ( d ) { return parseInt ( d , 16 ) } ) ) ; this . router _ip = new Uint8Array ( ( c . router _ip || "192.168.86.1" ) . split ( "." ) . map ( function ( d ) { return parseInt ( d , 10 ) } ) ) ; this . vm _ip = new Uint8Array ( ( c . vm _ip || "192.168.86.100" ) . split ( "." ) . map ( function ( d ) { return parseInt ( d , 10 ) } ) ) ; this . masquerade =
void 0 === c . masquerade || ! ! c . masquerade ; this . vm _mac = new Uint8Array ( 6 ) ; this . dns _method = c . dns _method || "doh" ; this . doh _server = c . doh _server ; this . tcp _conn = { } ; this . eth _encoder _buf = qc ( ) ; this . bus . register ( "net" + this . id + "-mac" , function ( d ) { this . vm _mac = new Uint8Array ( d . split ( ":" ) . map ( function ( e ) { return parseInt ( e , 16 ) } ) ) } , this ) ; this . bus . register ( "net" + this . id + "-send" , function ( d ) { this . send ( d ) } , this ) }
2024-11-28 07:25:05 +01:00
bc . prototype . register _ws = function ( a ) { this . wispws = new WebSocket ( a . replace ( "wisp://" , "ws://" ) . replace ( "wisps://" , "wss://" ) ) ; this . wispws . binaryType = "arraybuffer" ; this . wispws . onmessage = b => { this . process _incoming _wisp _frame ( new Uint8Array ( b . data ) ) } ; this . wispws . onclose = ( ) => { setTimeout ( ( ) => { this . register _ws ( a ) } , 1E4 ) } } ;
2025-01-03 12:44:26 +01:00
bc . prototype . send _packet = function ( a , b , c ) { this . connections [ c ] && ( 0 < this . connections [ c ] . congestion ? ( "DATA" === b && this . connections [ c ] . congestion -- , this . wispws . send ( a ) ) : ( this . connections [ c ] . congested = ! 0 , this . congested _buffer . push ( { data : a , type : b } ) ) ) } ;
2024-11-28 07:25:05 +01:00
bc . prototype . process _incoming _wisp _frame = function ( a ) { const b = new DataView ( a . buffer ) , c = b . getUint32 ( 1 , ! 0 ) ; switch ( a [ 0 ] ) { case 2 : if ( this . connections [ c ] ) this . connections [ c ] . data _callback ( a . slice ( 5 ) ) ; else throw Error ( "Got a DATA packet but stream not registered. ID: " + c ) ; break ; case 3 : this . connections [ c ] && ( this . connections [ c ] . congestion = b . getUint32 ( 5 , ! 0 ) ) ; if ( this . connections [ c ] . congested ) { for ( const d of this . congested _buffer ) this . send _packet ( d . data , d . type , c ) ; this . connections [ c ] . congested = ! 1 } break ; case 4 : this . connections [ c ] &&
2024-10-02 21:03:04 +02:00
this . connections [ c ] . close _callback ( b . getUint8 ( 5 ) ) , delete this . connections [ c ] } } ;
2024-11-28 07:25:05 +01:00
bc . prototype . send _wisp _frame = function ( a ) { let b , c ; switch ( a . type ) { case "CONNECT" : const d = ( new TextEncoder ) . encode ( a . hostname ) ; b = new Uint8Array ( 8 + d . length ) ; c = new DataView ( b . buffer ) ; c . setUint8 ( 0 , 1 ) ; c . setUint32 ( 1 , a . stream _id , ! 0 ) ; c . setUint8 ( 5 , 1 ) ; c . setUint16 ( 6 , a . port , ! 0 ) ; b . set ( d , 8 ) ; this . connections [ a . stream _id ] = { data _callback : a . data _callback , close _callback : a . close _callback , congestion : this . connections [ 0 ] . congestion } ; break ; case "DATA" : b = new Uint8Array ( 5 + a . data . length ) ; c = new DataView ( b . buffer ) ; c . setUint8 ( 0 ,
2 ) ; c . setUint32 ( 1 , a . stream _id , ! 0 ) ; b . set ( a . data , 5 ) ; break ; case "CLOSE" : b = new Uint8Array ( 6 ) , c = new DataView ( b . buffer ) , c . setUint8 ( 0 , 4 ) , c . setUint32 ( 1 , a . stream _id , ! 0 ) , c . setUint8 ( 5 , a . reason ) } this . send _packet ( b , a . type , a . stream _id ) } ; bc . prototype . destroy = function ( ) { this . wispws && ( this . wispws . onmessage = null , this . wispws . onclose = null , this . wispws . close ( ) , this . wispws = null ) } ;
2025-01-03 12:44:26 +01:00
bc . prototype . on _tcp _connection = function ( a , b ) { let c = new yc ; c . state = "syn-received" ; c . net = this ; c . tuple = b ; c . stream _id = this . last _stream ++ ; this . tcp _conn [ b ] = c ; c . on _data = d => { 0 !== d . length && this . send _wisp _frame ( { type : "DATA" , stream _id : c . stream _id , data : d } ) } ; c . on _close = ( ) => { this . send _wisp _frame ( { type : "CLOSE" , stream _id : c . stream _id , reason : 2 } ) } ; c . on _shutdown = c . on _close ; this . send _wisp _frame ( { type : "CONNECT" , stream _id : c . stream _id , hostname : a . ipv4 . dest . join ( "." ) , port : a . tcp . dport , data _callback : d => { c . write ( d ) } , close _callback : ( ) =>
{ c . close ( ) } } ) ; c . accept ( a ) ; return ! 0 } ; bc . prototype . send = function ( a ) { wc ( a , this ) } ; bc . prototype . receive = function ( a ) { this . bus . send ( "net" + this . id + "-receive" , new Uint8Array ( a ) ) } ; function ac ( a , b ) { b = b || { } ; this . bus = a ; this . id = b . id || 0 ; this . router _mac = new Uint8Array ( ( b . router _mac || "52:54:0:1:2:3" ) . split ( ":" ) . map ( function ( c ) { return parseInt ( c , 16 ) } ) ) ; this . router _ip = new Uint8Array ( ( b . router _ip || "192.168.86.1" ) . split ( "." ) . map ( function ( c ) { return parseInt ( c , 10 ) } ) ) ; this . vm _ip = new Uint8Array ( ( b . vm _ip || "192.168.86.100" ) . split ( "." ) . map ( function ( c ) { return parseInt ( c , 10 ) } ) ) ; this . masquerade = void 0 === b . masquerade || ! ! b . masquerade ; this . vm _mac = new Uint8Array ( 6 ) ; this . dns _method = b . dns _method || "static" ;
this . doh _server = b . doh _server ; this . tcp _conn = { } ; this . eth _encoder _buf = qc ( ) ; this . cors _proxy = b . cors _proxy ; this . bus . register ( "net" + this . id + "-mac" , function ( c ) { this . vm _mac = new Uint8Array ( c . split ( ":" ) . map ( function ( d ) { return parseInt ( d , 16 ) } ) ) } , this ) ; this . bus . register ( "net" + this . id + "-send" , function ( c ) { this . send ( c ) } , this ) } ac . prototype . destroy = function ( ) { } ;
ac . prototype . on _tcp _connection = function ( a , b ) { if ( 80 === a . tcp . dport ) { let c = new yc ; c . state = "syn-received" ; c . net = this ; c . on _data = zc ; c . tuple = b ; c . accept ( a ) ; this . tcp _conn [ b ] = c ; return ! 0 } return ! 1 } ;
async function zc ( a ) { this . read = this . read || "" ; if ( ( this . read += ( new TextDecoder ) . decode ( a ) ) && - 1 !== this . read . indexOf ( "\r\n\r\n" ) ) { var b = this . read . indexOf ( "\r\n\r\n" ) ; a = this . read . substring ( 0 , b ) . split ( /\r\n/ ) ; b = this . read . substring ( b + 4 ) ; this . read = "" ; let c = a [ 0 ] . split ( " " ) , d ; d = /^https?:/ . test ( c [ 1 ] ) ? new URL ( c [ 1 ] ) : new URL ( "http://host" + c [ 1 ] ) ; "undefined" !== typeof window && "http:" === d . protocol && "https:" === window . location . protocol && ( d . protocol = "https:" ) ; let e = new Headers ; for ( let l = 1 ; l < a . length ; ++ l ) { const m = this . net . parse _http _header ( a [ l ] ) ;
if ( ! m ) { console . warn ( 'The request contains an invalid header: "%s"' , a [ l ] ) ; this . write ( ( new TextEncoder ) . encode ( "HTTP/1.1 400 Bad Request\r\nContent-Length: 0" ) ) ; return } "host" === m . key . toLowerCase ( ) ? d . host = m . value : e . append ( m . key , m . value ) } this . name = d . href ; a = { method : c [ 0 ] , headers : e } ; - 1 !== [ "put" , "post" ] . indexOf ( a . method . toLowerCase ( ) ) && ( a . body = b ) ; const g = this . net . cors _proxy ? this . net . cors _proxy + encodeURIComponent ( d . href ) : d . href , f = new TextEncoder ; let k = ! 1 ; fetch ( g , a ) . then ( l => { const m = [ ` HTTP/1.1 ${ l . status } ${ l . statusText } ` ,
` x-was-fetch-redirected: ${ ! ! l . redirected } ` , ` x-fetch-resp-url: ${ l . url } ` , "Connection: closed" ] ; for ( const [ q , r ] of l . headers . entries ( ) ) [ "content-encoding" , "connection" , "content-length" , "transfer-encoding" ] . includes ( q . toLowerCase ( ) ) || m . push ( ` ${ q } : ${ r } ` ) ; this . write ( f . encode ( m . join ( "\r\n" ) + "\r\n\r\n" ) ) ; k = ! 0 ; const n = l . body . getReader ( ) , p = ( { value : q , done : r } ) => { q && this . write ( q ) ; if ( r ) this . close ( ) ; else return n . read ( ) . then ( p ) } ; n . read ( ) . then ( p ) } ) . catch ( l => { console . warn ( "Fetch Failed: " + g + "\n" + l ) ; k || ( l = f . encode ( ` Fetch ${ g } failed: \n \n ${ l . stack ||
l . message } ` ),this.writev([f.encode(["HTTP/1.1 502 Fetch Error","Content-Type: text/plain", ` Content - Length : $ { l . length } ` ,"Connection: closed"].join(" \r \n ")+" \r \n \r \n "),l]));this.close()})}}
2024-11-28 07:25:05 +01:00
ac . prototype . fetch = async function ( a , b ) { this . cors _proxy && ( a = this . cors _proxy + encodeURIComponent ( a ) ) ; try { const c = await fetch ( a , b ) , d = await c . arrayBuffer ( ) ; return [ c , d ] } catch ( c ) { return console . warn ( "Fetch Failed: " + a + "\n" + c ) , b = new Headers , b . set ( "Content-Type" , "text/plain" ) , [ { status : 502 , statusText : "Fetch Error" , headers : b } , ( new TextEncoder ) . encode ( ` Fetch ${ a } failed: \n \n ${ c . stack } ` ) . buffer ] } } ;
2025-01-03 12:44:26 +01:00
ac . prototype . parse _http _header = function ( a ) { var b = a . match ( /^([^:]*):(.*)$/ ) ; if ( b && ( a = b [ 1 ] , b = b [ 2 ] . trim ( ) , 0 !== a . length && 0 !== b . length && /^[\w-]+$/ . test ( a ) && /^[\x20-\x7E]+$/ . test ( b ) ) ) return { key : a , value : b } } ; ac . prototype . send = function ( a ) { wc ( a , this ) } ; ac . prototype . receive = function ( a ) { this . bus . send ( "net" + this . id + "-receive" , new Uint8Array ( a ) ) } ; "undefined" !== typeof module && "undefined" !== typeof module . exports && ( module . exports . FetchNetworkAdapter = ac ) ; const Ac = { stats _to _string : function ( a ) { return Ac . print _misc _stats ( a ) + Ac . print _instruction _counts ( a ) } , print _misc _stats : function ( a ) { let b = "" ; var c = "COMPILE COMPILE_SKIPPED_NO_NEW_ENTRY_POINTS COMPILE_WRONG_ADDRESS_SPACE COMPILE_CUT_OFF_AT_END_OF_PAGE COMPILE_WITH_LOOP_SAFETY COMPILE_PAGE COMPILE_PAGE/COMPILE COMPILE_BASIC_BLOCK COMPILE_DUPLICATED_BASIC_BLOCK COMPILE_WASM_BLOCK COMPILE_WASM_LOOP COMPILE_DISPATCHER COMPILE_ENTRY_POINT COMPILE_WASM_TOTAL_BYTES COMPILE_WASM_TOTAL_BYTES/COMPILE_PAGE RUN_INTERPRETED RUN_INTERPRETED_NEW_PAGE RUN_INTERPRETED_PAGE_HAS_CODE RUN_INTERPRETED_PAGE_HAS_ENTRY_AFTER_PAGE_WALK RUN_INTERPRETED_NEAR_END_OF_PAGE RUN_INTERPRETED_DIFFERENT_STATE RUN_INTERPRETED_DIFFERENT_STATE_CPL3 RUN_INTERPRETED_DIFFERENT_STATE_FLAT RUN_INTERPRETED_DIFFERENT_STATE_IS32 RUN_INTERPRETED_DIFFERENT_STATE_SS32 RUN_INTERPRETED_MISSED_COMPILED_ENTRY_RUN_INTERPRETED RUN_INTERPRETED_STEPS RUN_FROM_CACHE RUN_FROM_CACHE_STEPS RUN_FROM_CACHE_STEPS/RUN_FROM_CACHE RUN_FROM_CACHE_STEPS/RUN_INTERPRETED_STEPS DIRECT_EXIT INDIRECT_JUMP INDIRECT_JUMP_NO_ENTRY NORMAL_PAGE_CHANGE NORMAL_FALLTHRU NORMAL_FALLTHRU_WITH_TARGET_BLOCK NORMAL_BRANCH NORMAL_BRANCH_WITH_TARGET_BLOCK CONDITIONAL_JUMP CONDITIONAL_JUMP_PAGE_CHANGE CONDITIONAL_JUMP_EXIT CONDITIONAL_JUMP_FALLTHRU CONDITIONAL_JUMP_FALLTHRU_WITH_TARGET_BLOCK CONDITIONAL_JUMP_BRANCH CONDITIONAL_JUMP_BRANCH_WITH_TARGET_BLOCK DISPATCHER_SMALL DISPATCHER_LARGE LOOP LOOP_SAFETY CONDITION_OPTIMISED CONDITION_UNOPTIMISED CONDITION_UNOPTIMISED_PF CONDITION_UNOPTIMISED_UNHANDLED_L CONDITION_UNOPTIMISED_UNHANDLED_LE FAILED_PAGE_CHANGE SAFE_READ_FAST SAFE_READ_SLOW_PAGE_CROSSED SAFE_READ_SLOW_NOT_VALID SAFE_READ_SLOW_NOT_USER SAFE_READ_SLOW_IN_MAPPED_RANGE SAFE_WRITE_FAST SAFE_WRITE_SLOW_PAGE_CROSSED SAFE_WRITE_SLOW_NOT_VALID SAFE_WRITE_SLOW_NOT_USER SAFE_WRITE_SLOW_IN_MAPPED_RANGE SAFE_WRITE_SLOW_READ_ONLY SAFE_WRITE_SLOW_HAS_CODE SAFE_READ_WRITE_FAST SAFE_READ_WRITE_SLOW_PAGE_CROSSED SAFE_READ_WRITE_SLOW_NOT_VALID SAFE_READ_WRITE_SLOW_NOT_USER SAFE_READ_WRITE_SLOW_IN_MAPPED_RANGE SAFE_READ_WRITE_SLOW_READ_ONLY SAFE_READ_WRITE_SLOW_HAS_CODE PAGE_FAULT TLB_MISS MAIN_LOOP MAIN_LOOP_IDLE DO_MANY_CYCLES CYCLE_INTERNAL INVALIDATE_ALL_MODULES_NO_FREE_WASM_INDICES INVALIDATE_MODULE_WRITTEN_WHILE_COMPILED INVALIDATE_MODULE_UNUSED_AFTER_OVERWRITE INVALIDATE_MODULE_DIRTY_PAGE INVALIDATE_PAGE_HAD_CODE INVALIDATE_PAGE_HAD_ENTRY_POINTS DIRTY_PAGE_DID_NOT_HAVE_CODE RUN_FROM_CACHE_EXIT_SAME_PAGE RUN_FROM_CACHE_EXIT_NEAR_END_OF_PAGE RUN_FROM_CACHE_EXIT_DIFFERENT_PAGE CLEAR_TLB FULL_CLEAR_TLB TLB_FULL TLB_GLOBAL_FULL MODRM_SIMPLE_REG MODRM_SIMPLE_REG_WITH_OFFSET MODRM_SIMPLE_CONST_OFFSET MODRM_COMPLEX SEG_OFFSET_OPTIMISED SEG_OFFSET_NOT_OPTIMISED SEG_OFFSET_NOT_OPTIMISED_ES SEG_OFFSET_NOT_OPTIMISED_FS SEG_OFFSET_NOT_OPTIMISED_GS SEG_OFFSET_NOT_OPTIMISED_NOT_FLAT" . split ( " " ) ,
d = 0 ; const e = { } ; for ( let f = 0 ; f < c . length ; f ++ ) { const k = c [ f ] ; var g = void 0 ; if ( k . includes ( "/" ) ) { d ++ ; const [ l , m ] = k . split ( "/" ) ; g = e [ l ] / e [ m ] } else g = e [ k ] = a . wm . exports . profiler _stat _get ( f - d ) , g = 1E8 <= g ? Math . round ( g / 1E6 ) + "m" : 1E5 <= g ? Math . round ( g / 1E3 ) + "k" : g ; b += k + "=" + g + "\n" } b += "\n" ; c = a . wm . exports . get _valid _tlb _entries _count ( ) ; d = a . wm . exports . get _valid _global _tlb _entries _count ( ) ; b = b + ( "TLB_ENTRIES=" + c + " (" + d + " global, " + ( c - d ) + " non-global)\nWASM_TABLE_FREE=" ) + ( a . wm . exports . jit _get _wasm _table _index _free _list _count ( ) + "\n" ) ;
b += "JIT_CACHE_SIZE=" + a . wm . exports . jit _get _cache _size ( ) + "\n" ; b += "FLAT_SEGMENTS=" + a . wm . exports . has _flat _segmentation ( ) + "\n" ; b += "wasm memory size: " + ( a . wasm _memory . buffer . byteLength >> 20 ) + "m\n" ; b = b + "Config:\nJIT_DISABLED=" + ( a . wm . exports . get _jit _config ( 0 ) + "\n" ) ; b += "MAX_PAGES=" + a . wm . exports . get _jit _config ( 1 ) + "\n" ; b += "JIT_USE_LOOP_SAFETY=" + ! ! a . wm . exports . get _jit _config ( 2 ) + "\n" ; return b += "MAX_EXTRA_BASIC_BLOCKS=" + a . wm . exports . get _jit _config ( 3 ) + "\n" } , print _instruction _counts : function ( a ) { return [ Ac . print _instruction _counts _offset ( a ,
! 1 , ! 1 , ! 1 , ! 1 ) , Ac . print _instruction _counts _offset ( a , ! 0 , ! 1 , ! 1 , ! 1 ) , Ac . print _instruction _counts _offset ( a , ! 1 , ! 0 , ! 1 , ! 1 ) , Ac . print _instruction _counts _offset ( a , ! 1 , ! 1 , ! 0 , ! 1 ) , Ac . print _instruction _counts _offset ( a , ! 1 , ! 1 , ! 1 , ! 0 ) ] . join ( "\n\n" ) } , print _instruction _counts _offset : function ( a , b , c , d , e ) { let g = "" ; var f = [ ] , k = b ? "compiled" : c ? "jit exit" : d ? "unguarded register" : e ? "wasm size" : "executed" ; for ( let n = 0 ; 256 > n ; n ++ ) for ( let p = 0 ; 8 > p ; p ++ ) for ( const q of [ ! 1 , ! 0 ] ) { var l = a . wm . exports . get _opstats _buffer ( b , c , d , e , n , ! 1 , q , p ) ; f . push ( { opcode : n ,
2024-11-28 07:25:05 +01:00
count : l , is _mem : q , fixed _g : p } ) ; l = a . wm . exports . get _opstats _buffer ( b , c , d , e , n , ! 0 , q , p ) ; f . push ( { opcode : 3840 | n , count : l , is _mem : q , fixed _g : p } ) } a = 0 ; b = new Set ( [ 38 , 46 , 54 , 62 , 100 , 101 , 102 , 103 , 240 , 242 , 243 ] ) ; for ( const { count : n , opcode : p } of f ) b . has ( p ) || ( a += n ) ; if ( 0 === a ) return "" ; c = new Uint32Array ( 256 ) ; b = new Uint32Array ( 256 ) ; for ( const { opcode : n , count : p } of f ) 3840 === ( n & 65280 ) ? b [ n & 255 ] += p : c [ n & 255 ] += p ; g = g + "------------------\nTotal: " + ( a + "\n" ) ; const m = 1E7 < a ? 1E3 : 1 ; d = Math . max . apply ( Math , f . map ( ( { count : n } ) => Math . round ( n / m ) ) ) ; d =
2025-01-03 12:44:26 +01:00
String ( d ) . length ; g += ` Instruction counts ${ k } (in ${ m } ): \n ` ; for ( e = 0 ; 256 > e ; e ++ ) g += e . toString ( 16 ) . padStart ( 2 , "0" ) + ":" + h . pads ( Math . round ( c [ e ] / m ) , d ) , g = 15 === e % 16 ? g + "\n" : g + " " ; g = g + "\n" + ` Instruction counts ${ k } (0f, in ${ m } ): \n ` ; for ( k = 0 ; 256 > k ; k ++ ) g += ( k & 255 ) . toString ( 16 ) . padStart ( 2 , "0" ) + ":" + h . pads ( Math . round ( b [ k ] / m ) , d ) , g = 15 === k % 16 ? g + "\n" : g + " " ; g += "\n" ; f = f . filter ( ( { count : n } ) => n ) . sort ( ( { count : n } , { count : p } ) => p - n ) ; for ( const { opcode : n , is _mem : p , fixed _g : q , count : r } of f . slice ( 0 , 200 ) ) f = n . toString ( 16 ) + "_" + q + ( p ? "_m" :
"_r" ) , g += f + ":" + ( r / a * 100 ) . toFixed ( 2 ) + " " ; return g + "\n" } } ; "undefined" !== typeof module && "undefined" !== typeof module . exports && ( module . exports . print _stats = Ac ) ; function dc ( ) { this . filedata = new Map } dc . prototype . read = async function ( a , b , c ) { return ( a = this . filedata . get ( a ) ) ? a . subarray ( b , b + c ) : null } ; dc . prototype . cache = async function ( a , b ) { this . filedata . set ( a , b ) } ; dc . prototype . uncache = function ( a ) { this . filedata . delete ( a ) } ; function ec ( a , b ) { b . endsWith ( "/" ) || ( b += "/" ) ; this . storage = a ; this . baseurl = b } ec . prototype . load _from _server = function ( a ) { return new Promise ( b => { h . load _file ( this . baseurl + a , { done : async c => { c = new Uint8Array ( c ) ; await this . cache ( a , c ) ; b ( c ) } } ) } ) } ;
2024-11-28 07:25:05 +01:00
ec . prototype . read = async function ( a , b , c ) { const d = await this . storage . read ( a , b , c ) ; return d ? d : ( await this . load _from _server ( a ) ) . subarray ( b , b + c ) } ; ec . prototype . cache = async function ( a , b ) { return await this . storage . cache ( a , b ) } ; ec . prototype . uncache = function ( a ) { this . storage . uncache ( a ) } ; var ia = 32768 , fa = 16384 , ja = 4 ; function Z ( a , b ) { this . inodes = [ ] ; this . events = [ ] ; this . storage = a ; this . qidcounter = b || { last _qidnumber : 0 } ; this . inodedata = { } ; this . total _size = 274877906944 ; this . used _size = 0 ; this . mounts = [ ] ; this . CreateDirectory ( "" , - 1 ) } Z . prototype . get _state = function ( ) { let a = [ ] ; a [ 0 ] = this . inodes ; a [ 1 ] = this . qidcounter . last _qidnumber ; a [ 2 ] = [ ] ; for ( const [ b , c ] of Object . entries ( this . inodedata ) ) 0 === ( this . inodes [ b ] . mode & fa ) && a [ 2 ] . push ( [ b , c ] ) ; a [ 3 ] = this . total _size ; a [ 4 ] = this . used _size ; return a = a . concat ( this . mounts ) } ;
2025-01-03 12:44:26 +01:00
Z . prototype . set _state = function ( a ) { this . inodes = a [ 0 ] . map ( b => { const c = new Bc ( 0 ) ; c . set _state ( b ) ; return c } ) ; this . qidcounter . last _qidnumber = a [ 1 ] ; this . inodedata = { } ; for ( let [ b , c ] of a [ 2 ] ) c . buffer . byteLength !== c . byteLength && ( c = c . slice ( ) ) , this . inodedata [ b ] = c ; this . total _size = a [ 3 ] ; this . used _size = a [ 4 ] ; this . mounts = a . slice ( 5 ) } ; Z . prototype . AddEvent = function ( a , b ) { var c = this . inodes [ a ] ; 0 === c . status || 2 === c . status ? b ( ) : this . is _forwarder ( c ) ? this . follow _fs ( c ) . AddEvent ( c . foreign _id , b ) : this . events . push ( { id : a , OnEvent : b } ) } ;
2024-10-02 21:03:04 +02:00
Z . prototype . HandleEvent = function ( a ) { var b = this . inodes [ a ] ; this . is _forwarder ( b ) && this . follow _fs ( b ) . HandleEvent ( b . foreign _id ) ; b = [ ] ; for ( var c = 0 ; c < this . events . length ; c ++ ) this . events [ c ] . id === a ? this . events [ c ] . OnEvent ( ) : b . push ( this . events [ c ] ) ; this . events = b } ;
Z . prototype . load _from _json = function ( a ) { if ( 3 !== a . version ) throw "The filesystem JSON format has changed. Please update your fs2json (https://github.com/copy/fs2json) and recreate the filesystem JSON." ; var b = a . fsroot ; this . used _size = a . size ; for ( a = 0 ; a < b . length ; a ++ ) this . LoadRecursive ( b [ a ] , 0 ) } ;
2025-01-03 12:44:26 +01:00
Z . prototype . LoadRecursive = function ( a , b ) { var c = this . CreateInode ( ) ; const d = a [ 0 ] ; c . size = a [ 1 ] ; c . mtime = a [ 2 ] ; c . ctime = c . mtime ; c . atime = c . mtime ; c . mode = a [ 3 ] ; c . uid = a [ 4 ] ; c . gid = a [ 5 ] ; var e = c . mode & 61440 ; e === fa ? ( this . PushInode ( c , b , d ) , this . LoadDir ( this . inodes . length - 1 , a [ 6 ] ) ) : e === ia ? ( c . status = 2 , c . sha256sum = a [ 6 ] , this . PushInode ( c , b , d ) ) : 40960 === e ? ( c . symlink = a [ 6 ] , this . PushInode ( c , b , d ) ) : 49152 !== e && B ( e ) } ; Z . prototype . LoadDir = function ( a , b ) { for ( var c = 0 ; c < b . length ; c ++ ) this . LoadRecursive ( b [ c ] , a ) } ;
2024-06-28 09:23:02 +02:00
Z . prototype . should _be _linked = function ( a ) { return ! this . is _forwarder ( a ) || 0 === a . foreign _id } ; Z . prototype . link _under _dir = function ( a , b , c ) { const d = this . inodes [ b ] , e = this . inodes [ a ] ; this . is _forwarder ( e ) ; this . IsDirectory ( a ) ; this . should _be _linked ( d ) ; e . direntries . has ( c ) ; e . direntries . set ( c , b ) ; d . nlinks ++ ; this . IsDirectory ( b ) && ( d . direntries . has ( ".." ) , d . direntries . has ( "." ) || d . nlinks ++ , d . direntries . set ( "." , b ) , d . direntries . set ( ".." , a ) , e . nlinks ++ ) } ;
Z . prototype . unlink _from _dir = function ( a , b ) { const c = this . Search ( a , b ) , d = this . inodes [ c ] , e = this . inodes [ a ] ; this . is _forwarder ( e ) ; this . IsDirectory ( a ) ; e . direntries . delete ( b ) && ( d . nlinks -- , this . IsDirectory ( c ) && ( d . direntries . get ( ".." ) , d . direntries . delete ( ".." ) , e . nlinks -- ) ) } ;
2024-11-28 07:25:05 +01:00
Z . prototype . PushInode = function ( a , b , c ) { - 1 !== b ? ( this . inodes . push ( a ) , a . fid = this . inodes . length - 1 , this . link _under _dir ( b , a . fid , c ) ) : 0 === this . inodes . length ? ( this . inodes . push ( a ) , a . direntries . set ( "." , 0 ) , a . direntries . set ( ".." , 0 ) , a . nlinks = 2 ) : ( w . Debug ( "Error in Filesystem: Pushed inode with name = " + c + " has no parent" ) , w . Abort ( ) ) } ;
2025-01-03 12:44:26 +01:00
function Bc ( a ) { this . direntries = new Map ; this . minor = this . major = this . mtime = this . atime = this . ctime = this . fid = this . gid = this . uid = this . size = this . status = 0 ; this . symlink = "" ; this . mode = 493 ; this . qid = { type : 0 , version : 0 , path : a } ; this . caps = void 0 ; this . nlinks = 0 ; this . sha256sum = "" ; this . locks = [ ] ; this . foreign _id = this . mount _id = - 1 }
Bc . prototype . get _state = function ( ) { const a = [ ] ; a [ 0 ] = this . mode ; a [ 1 ] = ( this . mode & 61440 ) === fa ? [ ... this . direntries ] : ( this . mode & 61440 ) === ia ? this . sha256sum : 40960 === ( this . mode & 61440 ) ? this . symlink : 49152 === ( this . mode & 61440 ) ? [ this . minor , this . major ] : null ; a [ 2 ] = this . locks ; a [ 3 ] = this . status ; a [ 4 ] = this . size ; a [ 5 ] = this . uid ; a [ 6 ] = this . gid ; a [ 7 ] = this . fid ; a [ 8 ] = this . ctime ; a [ 9 ] = this . atime ; a [ 10 ] = this . mtime ; a [ 11 ] = this . qid . version ; a [ 12 ] = this . qid . path ; a [ 13 ] = this . nlinks ; return a } ;
Bc . prototype . set _state = function ( a ) { this . mode = a [ 0 ] ; if ( ( this . mode & 61440 ) === fa ) { this . direntries = new Map ; for ( const [ b , c ] of a [ 1 ] ) this . direntries . set ( b , c ) } else ( this . mode & 61440 ) === ia ? this . sha256sum = a [ 1 ] : 40960 === ( this . mode & 61440 ) ? this . symlink = a [ 1 ] : 49152 === ( this . mode & 61440 ) && ( [ this . minor , this . major ] = a [ 1 ] ) ; this . locks = [ ] ; for ( const b of a [ 2 ] ) { const c = new Cc ; c . set _state ( b ) ; this . locks . push ( c ) } this . status = a [ 3 ] ; this . size = a [ 4 ] ; this . uid = a [ 5 ] ; this . gid = a [ 6 ] ; this . fid = a [ 7 ] ; this . ctime = a [ 8 ] ; this . atime = a [ 9 ] ; this . mtime = a [ 10 ] ;
2024-06-28 09:23:02 +02:00
this . qid . type = ( this . mode & 61440 ) >> 8 ; this . qid . version = a [ 11 ] ; this . qid . path = a [ 12 ] ; this . nlinks = a [ 13 ] } ;
2025-01-03 12:44:26 +01:00
Z . prototype . divert = function ( a , b ) { const c = this . Search ( a , b ) , d = this . inodes [ c ] , e = new Bc ( - 1 ) ; this . IsDirectory ( c ) ; Object . assign ( e , d ) ; const g = this . inodes . length ; this . inodes . push ( e ) ; e . fid = g ; this . is _forwarder ( d ) && this . mounts [ d . mount _id ] . backtrack . set ( d . foreign _id , g ) ; this . should _be _linked ( d ) && ( this . unlink _from _dir ( a , b ) , this . link _under _dir ( a , g , b ) ) ; if ( this . IsDirectory ( c ) && ! this . is _forwarder ( d ) ) for ( const [ f , k ] of e . direntries ) "." !== f && ".." !== f && this . IsDirectory ( k ) && this . inodes [ k ] . direntries . set ( ".." , g ) ; this . inodedata [ g ] =
this . inodedata [ c ] ; delete this . inodedata [ c ] ; d . direntries = new Map ; d . nlinks = 0 ; return g } ; Z . prototype . copy _inode = function ( a , b ) { Object . assign ( b , a , { fid : b . fid , direntries : b . direntries , nlinks : b . nlinks } ) } ; Z . prototype . CreateInode = function ( ) { const a = Math . round ( Date . now ( ) / 1E3 ) , b = new Bc ( ++ this . qidcounter . last _qidnumber ) ; b . atime = b . ctime = b . mtime = a ; return b } ;
2024-11-28 07:25:05 +01:00
Z . prototype . CreateDirectory = function ( a , b ) { var c = this . inodes [ b ] ; if ( 0 <= b && this . is _forwarder ( c ) ) return b = c . foreign _id , a = this . follow _fs ( c ) . CreateDirectory ( a , b ) , this . create _forwarder ( c . mount _id , a ) ; c = this . CreateInode ( ) ; c . mode = 511 | fa ; 0 <= b && ( c . uid = this . inodes [ b ] . uid , c . gid = this . inodes [ b ] . gid , c . mode = this . inodes [ b ] . mode & 511 | fa ) ; c . qid . type = fa >> 8 ; this . PushInode ( c , b , a ) ; this . NotifyListeners ( this . inodes . length - 1 , "newdir" ) ; return this . inodes . length - 1 } ;
Z . prototype . CreateFile = function ( a , b ) { var c = this . inodes [ b ] ; if ( this . is _forwarder ( c ) ) return b = c . foreign _id , a = this . follow _fs ( c ) . CreateFile ( a , b ) , this . create _forwarder ( c . mount _id , a ) ; c = this . CreateInode ( ) ; c . uid = this . inodes [ b ] . uid ; c . gid = this . inodes [ b ] . gid ; c . qid . type = ia >> 8 ; c . mode = this . inodes [ b ] . mode & 438 | ia ; this . PushInode ( c , b , a ) ; this . NotifyListeners ( this . inodes . length - 1 , "newfile" ) ; return this . inodes . length - 1 } ;
2024-06-28 09:23:02 +02:00
Z . prototype . CreateNode = function ( a , b , c , d ) { var e = this . inodes [ b ] ; if ( this . is _forwarder ( e ) ) return b = e . foreign _id , a = this . follow _fs ( e ) . CreateNode ( a , b , c , d ) , this . create _forwarder ( e . mount _id , a ) ; e = this . CreateInode ( ) ; e . major = c ; e . minor = d ; e . uid = this . inodes [ b ] . uid ; e . gid = this . inodes [ b ] . gid ; e . qid . type = 192 ; e . mode = this . inodes [ b ] . mode & 438 ; this . PushInode ( e , b , a ) ; return this . inodes . length - 1 } ;
Z . prototype . CreateSymlink = function ( a , b , c ) { var d = this . inodes [ b ] ; if ( this . is _forwarder ( d ) ) return b = d . foreign _id , a = this . follow _fs ( d ) . CreateSymlink ( a , b , c ) , this . create _forwarder ( d . mount _id , a ) ; d = this . CreateInode ( ) ; d . uid = this . inodes [ b ] . uid ; d . gid = this . inodes [ b ] . gid ; d . qid . type = 160 ; d . symlink = c ; d . mode = 40960 ; this . PushInode ( d , b , a ) ; return this . inodes . length - 1 } ;
Z . prototype . CreateTextFile = async function ( a , b , c ) { var d = this . inodes [ b ] ; if ( this . is _forwarder ( d ) ) return b = d . foreign _id , c = await this . follow _fs ( d ) . CreateTextFile ( a , b , c ) , this . create _forwarder ( d . mount _id , c ) ; d = this . CreateFile ( a , b ) ; b = this . inodes [ d ] ; a = new Uint8Array ( c . length ) ; b . size = c . length ; for ( b = 0 ; b < c . length ; b ++ ) a [ b ] = c . charCodeAt ( b ) ; await this . set _data ( d , a ) ; return d } ;
Z . prototype . CreateBinaryFile = async function ( a , b , c ) { var d = this . inodes [ b ] ; if ( this . is _forwarder ( d ) ) return b = d . foreign _id , c = await this . follow _fs ( d ) . CreateBinaryFile ( a , b , c ) , this . create _forwarder ( d . mount _id , c ) ; d = this . CreateFile ( a , b ) ; a = this . inodes [ d ] ; b = new Uint8Array ( c . length ) ; b . set ( c ) ; await this . set _data ( d , b ) ; a . size = c . length ; return d } ;
2024-11-28 07:25:05 +01:00
Z . prototype . OpenInode = function ( a , b ) { var c = this . inodes [ a ] ; if ( this . is _forwarder ( c ) ) return this . follow _fs ( c ) . OpenInode ( c . foreign _id , b ) ; ( c . mode & 61440 ) === fa && this . FillDirectory ( a ) ; return ! 0 } ; Z . prototype . CloseInode = async function ( a ) { var b = this . inodes [ a ] ; if ( this . is _forwarder ( b ) ) return await this . follow _fs ( b ) . CloseInode ( b . foreign _id ) ; 2 === b . status && this . storage . uncache ( b . sha256sum ) ; b . status === ja && ( b . status = - 1 , await this . DeleteData ( a ) ) } ;
2025-01-03 12:44:26 +01:00
Z . prototype . Rename = async function ( a , b , c , d ) { if ( a === c && b === d ) return 0 ; var e = this . Search ( a , b ) ; if ( - 1 === e ) return - 2 ; var g = this . GetFullPath ( a ) + "/" + b ; if ( - 1 !== this . Search ( c , d ) ) { var f = this . Unlink ( c , d ) ; if ( 0 > f ) return f } var k = this . inodes [ e ] , l = this . inodes [ a ] ; f = this . inodes [ c ] ; if ( this . is _forwarder ( l ) || this . is _forwarder ( f ) ) if ( this . is _forwarder ( l ) && l . mount _id === f . mount _id ) { if ( a = await this . follow _fs ( l ) . Rename ( l . foreign _id , b , f . foreign _id , d ) , 0 > a ) return a } else { if ( this . is _a _root ( e ) || ! this . IsDirectory ( e ) && 1 < this . GetInode ( e ) . nlinks ) return - 1 ;
l = this . divert ( a , b ) ; const m = this . GetInode ( e ) , n = await this . Read ( l , 0 , m . size ) ; this . is _forwarder ( f ) ? ( c = this . follow _fs ( f ) , d = this . IsDirectory ( l ) ? c . CreateDirectory ( d , f . foreign _id ) : c . CreateFile ( d , f . foreign _id ) , c = c . GetInode ( d ) , this . copy _inode ( m , c ) , this . set _forwarder ( e , f . mount _id , d ) ) : ( this . delete _forwarder ( k ) , this . copy _inode ( m , k ) , this . link _under _dir ( c , e , d ) ) ; await this . ChangeSize ( e , m . size ) ; n && n . length && await this . Write ( e , 0 , n . length , n ) ; if ( this . IsDirectory ( e ) ) for ( const p of this . GetChildren ( l ) ) if ( f = await this . Rename ( l ,
p , e , p ) , 0 > f ) return f ; await this . DeleteData ( l ) ; a = this . Unlink ( a , b ) ; if ( 0 > a ) return a } else this . unlink _from _dir ( a , b ) , this . link _under _dir ( c , e , d ) , k . qid . version ++ ; this . NotifyListeners ( e , "rename" , { oldpath : g } ) ; return 0 } ;
2024-11-28 07:25:05 +01:00
Z . prototype . Write = async function ( a , b , c , d ) { this . NotifyListeners ( a , "write" ) ; var e = this . inodes [ a ] ; if ( this . is _forwarder ( e ) ) a = e . foreign _id , await this . follow _fs ( e ) . Write ( a , b , c , d ) ; else { var g = await this . get _buffer ( a ) ; ! g || g . length < b + c ? ( await this . ChangeSize ( a , Math . floor ( 3 * ( b + c ) / 2 ) ) , e . size = b + c , g = await this . get _buffer ( a ) ) : e . size < b + c && ( e . size = b + c ) ; d && g . set ( d . subarray ( 0 , c ) , b ) ; await this . set _data ( a , g ) } } ;
2024-06-28 09:23:02 +02:00
Z . prototype . Read = async function ( a , b , c ) { const d = this . inodes [ a ] ; return this . is _forwarder ( d ) ? ( a = d . foreign _id , await this . follow _fs ( d ) . Read ( a , b , c ) ) : await this . get _data ( a , b , c ) } ; Z . prototype . Search = function ( a , b ) { a = this . inodes [ a ] ; if ( this . is _forwarder ( a ) ) { const c = a . foreign _id ; b = this . follow _fs ( a ) . Search ( c , b ) ; return - 1 === b ? - 1 : this . get _forwarder ( a . mount _id , b ) } b = a . direntries . get ( b ) ; return void 0 === b ? - 1 : b } ;
Z . prototype . CountUsedInodes = function ( ) { let a = this . inodes . length ; for ( const { fs : b , backtrack : c } of this . mounts ) a += b . CountUsedInodes ( ) , a -= c . size ; return a } ; Z . prototype . CountFreeInodes = function ( ) { let a = 1048576 ; for ( const { fs : b } of this . mounts ) a += b . CountFreeInodes ( ) ; return a } ; Z . prototype . GetTotalSize = function ( ) { let a = this . used _size ; for ( const { fs : b } of this . mounts ) a += b . GetTotalSize ( ) ; return a } ; Z . prototype . GetSpace = function ( ) { let a = this . total _size ; for ( const { fs : b } of this . mounts ) a += b . GetSpace ( ) ; return this . total _size } ;
2024-10-02 21:03:04 +02:00
Z . prototype . GetDirectoryName = function ( a ) { const b = this . inodes [ this . GetParent ( a ) ] ; if ( this . is _forwarder ( b ) ) return this . follow _fs ( b ) . GetDirectoryName ( this . inodes [ a ] . foreign _id ) ; if ( ! b ) return "" ; for ( const [ c , d ] of b . direntries ) if ( d === a ) return c ; return "" } ; Z . prototype . GetFullPath = function ( a ) { this . IsDirectory ( a ) ; for ( var b = "" ; 0 !== a ; ) b = "/" + this . GetDirectoryName ( a ) + b , a = this . GetParent ( a ) ; return b . substring ( 1 ) } ;
2024-06-28 09:23:02 +02:00
Z . prototype . Link = function ( a , b , c ) { if ( this . IsDirectory ( b ) ) return - 1 ; const d = this . inodes [ a ] , e = this . inodes [ b ] ; if ( this . is _forwarder ( d ) ) return this . is _forwarder ( e ) && e . mount _id === d . mount _id ? this . follow _fs ( d ) . Link ( d . foreign _id , e . foreign _id , c ) : - 1 ; if ( this . is _forwarder ( e ) ) return - 1 ; this . link _under _dir ( a , b , c ) ; return 0 } ;
2024-11-28 07:25:05 +01:00
Z . prototype . Unlink = function ( a , b ) { if ( "." === b || ".." === b ) return - 1 ; const c = this . Search ( a , b ) , d = this . inodes [ c ] , e = this . inodes [ a ] ; if ( this . is _forwarder ( e ) ) return this . is _forwarder ( d ) , a = e . foreign _id , this . follow _fs ( e ) . Unlink ( a , b ) ; if ( this . IsDirectory ( c ) && ! this . IsEmpty ( c ) ) return - 39 ; this . unlink _from _dir ( a , b ) ; 0 === d . nlinks && ( d . status = ja , this . NotifyListeners ( c , "delete" ) ) ; return 0 } ;
2024-06-28 09:23:02 +02:00
Z . prototype . DeleteData = async function ( a ) { const b = this . inodes [ a ] ; this . is _forwarder ( b ) ? await this . follow _fs ( b ) . DeleteData ( b . foreign _id ) : ( b . size = 0 , delete this . inodedata [ a ] ) } ; Z . prototype . get _buffer = async function ( a ) { const b = this . inodes [ a ] ; return this . inodedata [ a ] ? this . inodedata [ a ] : 2 === b . status ? await this . storage . read ( b . sha256sum , 0 , b . size ) : null } ;
Z . prototype . get _data = async function ( a , b , c ) { const d = this . inodes [ a ] ; return this . inodedata [ a ] ? this . inodedata [ a ] . subarray ( b , b + c ) : 2 === d . status ? await this . storage . read ( d . sha256sum , b , c ) : null } ; Z . prototype . set _data = async function ( a , b ) { this . inodedata [ a ] = b ; 2 === this . inodes [ a ] . status && ( this . inodes [ a ] . status = 0 , this . storage . uncache ( this . inodes [ a ] . sha256sum ) ) } ; Z . prototype . GetInode = function ( a ) { isNaN ( a ) ; a = this . inodes [ a ] ; return this . is _forwarder ( a ) ? this . follow _fs ( a ) . GetInode ( a . foreign _id ) : a } ;
2024-10-02 21:03:04 +02:00
Z . prototype . ChangeSize = async function ( a , b ) { var c = this . GetInode ( a ) , d = await this . get _data ( a , 0 , c . size ) ; if ( b !== c . size ) { var e = new Uint8Array ( b ) ; c . size = b ; d && e . set ( d . subarray ( 0 , Math . min ( d . length , c . size ) ) , 0 ) ; await this . set _data ( a , e ) } } ;
2024-11-28 07:25:05 +01:00
Z . prototype . SearchPath = function ( a ) { a = a . replace ( "//" , "/" ) ; a = a . split ( "/" ) ; 0 < a . length && 0 === a [ a . length - 1 ] . length && a . pop ( ) ; 0 < a . length && 0 === a [ 0 ] . length && a . shift ( ) ; const b = a . length ; var c = - 1 , d = 0 ; let e = null ; for ( var g = 0 ; g < b ; g ++ ) if ( c = d , d = this . Search ( c , a [ g ] ) , ! e && this . is _forwarder ( this . inodes [ c ] ) && ( e = "/" + a . slice ( g ) . join ( "/" ) ) , - 1 === d ) return g < b - 1 ? { id : - 1 , parentid : - 1 , name : a [ g ] , forward _path : e } : { id : - 1 , parentid : c , name : a [ g ] , forward _path : e } ; return { id : d , parentid : c , name : a [ g ] , forward _path : e } } ;
2024-06-28 09:23:02 +02:00
Z . prototype . GetRecursiveList = function ( a , b ) { if ( this . is _forwarder ( this . inodes [ a ] ) ) { const c = this . follow _fs ( this . inodes [ a ] ) , d = this . inodes [ a ] . mount _id , e = b . length ; c . GetRecursiveList ( this . inodes [ a ] . foreign _id , b ) ; for ( a = e ; a < b . length ; a ++ ) b [ a ] . parentid = this . get _forwarder ( d , b [ a ] . parentid ) } else for ( const [ c , d ] of this . inodes [ a ] . direntries ) "." !== c && ".." !== c && ( b . push ( { parentid : a , name : c } ) , this . IsDirectory ( d ) && this . GetRecursiveList ( d , b ) ) } ;
2024-11-28 07:25:05 +01:00
Z . prototype . RecursiveDelete = function ( a ) { var b = [ ] ; a = this . SearchPath ( a ) ; if ( - 1 !== a . id ) for ( this . GetRecursiveList ( a . id , b ) , a = b . length - 1 ; 0 <= a ; a -- ) this . Unlink ( b [ a ] . parentid , b [ a ] . name ) } ; Z . prototype . DeleteNode = function ( a ) { var b = this . SearchPath ( a ) ; - 1 !== b . id && ( ( this . inodes [ b . id ] . mode & 61440 ) === ia ? this . Unlink ( b . parentid , b . name ) : ( this . inodes [ b . id ] . mode & 61440 ) === fa && ( this . RecursiveDelete ( a ) , this . Unlink ( b . parentid , b . name ) ) ) } ; Z . prototype . NotifyListeners = function ( ) { } ;
Z . prototype . Check = function ( ) { for ( var a = 1 ; a < this . inodes . length ; a ++ ) if ( - 1 !== this . inodes [ a ] . status ) { var b = this . GetInode ( a ) ; 0 > b . nlinks && w . Debug ( "Error in filesystem: negative nlinks=" + b . nlinks + " at id =" + a ) ; if ( this . IsDirectory ( a ) ) { b = this . GetInode ( a ) ; this . IsDirectory ( a ) && 0 > this . GetParent ( a ) && w . Debug ( "Error in filesystem: negative parent id " + a ) ; for ( const [ c , d ] of b . direntries ) { 0 === c . length && w . Debug ( "Error in filesystem: inode with no name and id " + d ) ; for ( const e of c ) 32 > e && w . Debug ( "Error in filesystem: Unallowed char in filename" ) } } } } ;
2025-01-03 12:44:26 +01:00
Z . prototype . FillDirectory = function ( a ) { var b = this . inodes [ a ] ; if ( this . is _forwarder ( b ) ) this . follow _fs ( b ) . FillDirectory ( b . foreign _id ) ; else { var c = 0 ; for ( const d of b . direntries . keys ( ) ) c += 24 + Dc . encode ( d ) . length ; a = this . inodedata [ a ] = new Uint8Array ( c ) ; b . size = c ; c = 0 ; for ( const [ d , e ] of b . direntries ) b = this . GetInode ( e ) , c += t . Marshall ( [ "Q" , "d" , "b" , "s" ] , [ b . qid , c + 13 + 8 + 1 + 2 + Dc . encode ( d ) . length , b . mode >> 12 , d ] , a , c ) } } ;
Z . prototype . RoundToDirentry = function ( a , b ) { a = this . inodedata [ a ] ; if ( b >= a . length ) return a . length ; let c = 0 ; for ( ; ; ) { const d = t . Unmarshall ( [ "Q" , "d" ] , a , { offset : c } ) [ 1 ] ; if ( d > b ) break ; c = d } return c } ; Z . prototype . IsDirectory = function ( a ) { a = this . inodes [ a ] ; return this . is _forwarder ( a ) ? this . follow _fs ( a ) . IsDirectory ( a . foreign _id ) : ( a . mode & 61440 ) === fa } ;
2024-06-28 09:23:02 +02:00
Z . prototype . IsEmpty = function ( a ) { a = this . inodes [ a ] ; if ( this . is _forwarder ( a ) ) return this . follow _fs ( a ) . IsDirectory ( a . foreign _id ) ; for ( const b of a . direntries . keys ( ) ) if ( "." !== b && ".." !== b ) return ! 1 ; return ! 0 } ; Z . prototype . GetChildren = function ( a ) { this . IsDirectory ( a ) ; a = this . inodes [ a ] ; if ( this . is _forwarder ( a ) ) return this . follow _fs ( a ) . GetChildren ( a . foreign _id ) ; const b = [ ] ; for ( const c of a . direntries . keys ( ) ) "." !== c && ".." !== c && b . push ( c ) ; return b } ;
Z . prototype . GetParent = function ( a ) { this . IsDirectory ( a ) ; a = this . inodes [ a ] ; if ( this . should _be _linked ( a ) ) return a . direntries . get ( ".." ) ; const b = this . follow _fs ( a ) . GetParent ( a . foreign _id ) ; return this . get _forwarder ( a . mount _id , b ) } ;
2025-01-03 12:44:26 +01:00
Z . prototype . PrepareCAPs = function ( a ) { a = this . GetInode ( a ) ; if ( a . caps ) return a . caps . length ; a . caps = new Uint8Array ( 20 ) ; a . caps [ 0 ] = 0 ; a . caps [ 1 ] = 0 ; a . caps [ 2 ] = 0 ; a . caps [ 3 ] = 2 ; a . caps [ 4 ] = 255 ; a . caps [ 5 ] = 255 ; a . caps [ 6 ] = 255 ; a . caps [ 7 ] = 255 ; a . caps [ 8 ] = 255 ; a . caps [ 9 ] = 255 ; a . caps [ 10 ] = 255 ; a . caps [ 11 ] = 255 ; a . caps [ 12 ] = 63 ; a . caps [ 13 ] = 0 ; a . caps [ 14 ] = 0 ; a . caps [ 15 ] = 0 ; a . caps [ 16 ] = 63 ; a . caps [ 17 ] = 0 ; a . caps [ 18 ] = 0 ; a . caps [ 19 ] = 0 ; return a . caps . length } ; function Ec ( a ) { this . fs = a ; this . backtrack = new Map }
Ec . prototype . get _state = function ( ) { const a = [ ] ; a [ 0 ] = this . fs ; a [ 1 ] = [ ... this . backtrack ] ; return a } ; Ec . prototype . set _state = function ( a ) { this . fs = a [ 0 ] ; this . backtrack = new Map ( a [ 1 ] ) } ; Z . prototype . set _forwarder = function ( a , b , c ) { const d = this . inodes [ a ] ; this . is _forwarder ( d ) && this . mounts [ d . mount _id ] . backtrack . delete ( d . foreign _id ) ; d . status = 5 ; d . mount _id = b ; d . foreign _id = c ; this . mounts [ b ] . backtrack . set ( c , a ) } ;
2024-06-28 09:23:02 +02:00
Z . prototype . create _forwarder = function ( a , b ) { const c = this . CreateInode ( ) , d = this . inodes . length ; this . inodes . push ( c ) ; c . fid = d ; this . set _forwarder ( d , a , b ) ; return d } ; Z . prototype . is _forwarder = function ( a ) { return 5 === a . status } ; Z . prototype . is _a _root = function ( a ) { return 0 === this . GetInode ( a ) . fid } ; Z . prototype . get _forwarder = function ( a , b ) { const c = this . mounts [ a ] . backtrack . get ( b ) ; return void 0 === c ? this . create _forwarder ( a , b ) : c } ; Z . prototype . delete _forwarder = function ( a ) { this . is _forwarder ( a ) ; a . status = - 1 ; this . mounts [ a . mount _id ] . backtrack . delete ( a . foreign _id ) } ;
2025-01-03 12:44:26 +01:00
Z . prototype . follow _fs = function ( a ) { const b = this . mounts [ a . mount _id ] ; this . is _forwarder ( a ) ; return b . fs } ; Z . prototype . Mount = function ( a , b ) { a = this . SearchPath ( a ) ; if ( - 1 === a . parentid ) return - 2 ; if ( - 1 !== a . id ) return - 17 ; if ( a . forward _path ) { var c = this . inodes [ a . parentid ] ; b = this . follow _fs ( c ) . Mount ( a . forward _path , b ) ; return 0 > b ? b : this . get _forwarder ( c . mount _id , b ) } c = this . mounts . length ; this . mounts . push ( new Ec ( b ) ) ; b = this . create _forwarder ( c , 0 ) ; this . link _under _dir ( a . parentid , b , a . name ) ; return b } ;
function Cc ( ) { this . type = 2 ; this . start = 0 ; this . length = Infinity ; this . proc _id = - 1 ; this . client _id = "" } Cc . prototype . get _state = function ( ) { const a = [ ] ; a [ 0 ] = this . type ; a [ 1 ] = this . start ; a [ 2 ] = Infinity === this . length ? 0 : this . length ; a [ 3 ] = this . proc _id ; a [ 4 ] = this . client _id ; return a } ; Cc . prototype . set _state = function ( a ) { this . type = a [ 0 ] ; this . start = a [ 1 ] ; this . length = 0 === a [ 2 ] ? Infinity : a [ 2 ] ; this . proc _id = a [ 3 ] ; this . client _id = a [ 4 ] } ; Cc . prototype . clone = function ( ) { const a = new Cc ; a . set _state ( this . get _state ( ) ) ; return a } ;
Cc . prototype . conflicts _with = function ( a ) { return this . proc _id === a . proc _id && this . client _id === a . client _id || 2 === this . type || 2 === a . type || 1 !== this . type && 1 !== a . type || this . start + this . length <= a . start || a . start + a . length <= this . start ? ! 1 : ! 0 } ; Cc . prototype . is _alike = function ( a ) { return a . proc _id === this . proc _id && a . client _id === this . client _id && a . type === this . type } ; Cc . prototype . may _merge _after = function ( a ) { return this . is _alike ( a ) && a . start + a . length === this . start } ;
Z . prototype . DescribeLock = function ( a , b , c , d , e ) { const g = new Cc ; g . type = a ; g . start = b ; g . length = c ; g . proc _id = d ; g . client _id = e ; return g } ; Z . prototype . GetLock = function ( a , b ) { a = this . inodes [ a ] ; if ( this . is _forwarder ( a ) ) { var c = a . foreign _id ; return this . follow _fs ( a ) . GetLock ( c , b ) } for ( c of a . locks ) if ( b . conflicts _with ( c ) ) return c . clone ( ) ; return null } ;
2024-11-28 07:25:05 +01:00
Z . prototype . Lock = function ( a , b , c ) { const d = this . inodes [ a ] ; if ( this . is _forwarder ( d ) ) return a = d . foreign _id , this . follow _fs ( d ) . Lock ( a , b , c ) ; b = b . clone ( ) ; if ( 2 !== b . type && this . GetLock ( a , b ) ) return 1 ; for ( c = 0 ; c < d . locks . length ; c ++ ) { a = d . locks [ c ] ; if ( a . start + a . length <= b . start ) continue ; if ( b . start + b . length <= a . start ) break ; if ( a . proc _id !== b . proc _id || a . client _id !== b . client _id ) { a . conflicts _with ( b ) ; continue } var e = b . start + b . length ; const g = b . start - a . start , f = a . start + a . length - e ; if ( 0 < g && 0 < f && a . type === b . type ) return 0 ; 0 < g && ( a . length =
g ) ; if ( 0 >= g && 0 < f ) a . start = e , a . length = f ; else if ( 0 < f ) { for ( ; c < d . locks . length && d . locks [ c ] . start < e ; ) c ++ ; d . locks . splice ( c , 0 , this . DescribeLock ( a . type , e , f , a . proc _id , a . client _id ) ) } else 0 >= g && ( d . locks . splice ( c , 1 ) , c -- ) } if ( 2 !== b . type ) { c = b ; a = ! 1 ; for ( e = 0 ; e < d . locks . length && ! ( c . may _merge _after ( d . locks [ e ] ) && ( d . locks [ e ] . length += b . length , c = d . locks [ e ] , a = ! 0 ) , b . start <= d . locks [ e ] . start ) ; e ++ ) ; a || ( d . locks . splice ( e , 0 , c ) , e ++ ) ; for ( ; e < d . locks . length ; e ++ ) if ( d . locks [ e ] . is _alike ( c ) ) { d . locks [ e ] . may _merge _after ( c ) && ( c . length += d . locks [ e ] . length ,
2025-01-03 12:44:26 +01:00
d . locks . splice ( e , 1 ) ) ; break } } return 0 } ; Z . prototype . read _dir = function ( a ) { a = this . SearchPath ( a ) ; if ( - 1 !== a . id ) return a = this . GetInode ( a . id ) , Array . from ( a . direntries . keys ( ) ) . filter ( b => "." !== b && ".." !== b ) } ; Z . prototype . read _file = function ( a ) { a = this . SearchPath ( a ) ; if ( - 1 === a . id ) return Promise . resolve ( null ) ; const b = this . GetInode ( a . id ) ; return this . Read ( a . id , 0 , b . size ) } ; var w = { Debug : function ( a ) { [ ] . slice . apply ( arguments ) . join ( " " ) } , Abort : function ( ) { } } ; var t = { } ; const Fc = new TextDecoder , Dc = new TextEncoder ;
t . Marshall = function ( a , b , c , d ) { for ( var e , g = 0 , f = 0 ; f < a . length ; f ++ ) switch ( e = b [ f ] , a [ f ] ) { case "w" : c [ d ++ ] = e & 255 ; c [ d ++ ] = e >> 8 & 255 ; c [ d ++ ] = e >> 16 & 255 ; c [ d ++ ] = e >> 24 & 255 ; g += 4 ; break ; case "d" : c [ d ++ ] = e & 255 ; c [ d ++ ] = e >> 8 & 255 ; c [ d ++ ] = e >> 16 & 255 ; c [ d ++ ] = e >> 24 & 255 ; c [ d ++ ] = 0 ; c [ d ++ ] = 0 ; c [ d ++ ] = 0 ; c [ d ++ ] = 0 ; g += 8 ; break ; case "h" : c [ d ++ ] = e & 255 ; c [ d ++ ] = e >> 8 ; g += 2 ; break ; case "b" : c [ d ++ ] = e ; g += 1 ; break ; case "s" : var k = d , l = 0 ; c [ d ++ ] = 0 ; c [ d ++ ] = 0 ; g += 2 ; e = Dc . encode ( e ) ; g += e . byteLength ; l += e . byteLength ; c . set ( e , d ) ; d += e . byteLength ; c [ k + 0 ] = l & 255 ; c [ k + 1 ] = l >> 8 &
255 ; break ; case "Q" : t . Marshall ( [ "b" , "w" , "d" ] , [ e . type , e . version , e . path ] , c , d ) ; d += 13 ; g += 13 ; break ; default : w . Debug ( "Marshall: Unknown type=" + a [ f ] ) } return g } ;
t . Unmarshall = function ( a , b , c ) { let d = c . offset ; for ( var e = [ ] , g = 0 ; g < a . length ; g ++ ) switch ( a [ g ] ) { case "w" : var f = b [ d ++ ] ; f += b [ d ++ ] << 8 ; f += b [ d ++ ] << 16 ; f += b [ d ++ ] << 24 >>> 0 ; e . push ( f ) ; break ; case "d" : f = b [ d ++ ] ; f += b [ d ++ ] << 8 ; f += b [ d ++ ] << 16 ; f += b [ d ++ ] << 24 >>> 0 ; d += 4 ; e . push ( f ) ; break ; case "h" : f = b [ d ++ ] ; e . push ( f + ( b [ d ++ ] << 8 ) ) ; break ; case "b" : e . push ( b [ d ++ ] ) ; break ; case "s" : f = b [ d ++ ] ; f += b [ d ++ ] << 8 ; var k = b . slice ( d , d + f ) ; d += f ; e . push ( Fc . decode ( k ) ) ; break ; case "Q" : c . offset = d ; f = t . Unmarshall ( [ "b" , "w" , "d" ] , b , c ) ; d = c . offset ; e . push ( { type : f [ 0 ] , version : f [ 1 ] ,
2024-11-28 07:25:05 +01:00
path : f [ 2 ] } ) ; break ; default : w . Debug ( "Error in Unmarshall: Unknown type=" + a [ g ] ) } c . offset = d ; return e } ; } ) . call ( this ) ;