2024-07-09 16:10:33 +08:00
/ *
* Copyright ( C ) 2024 Puter Technologies Inc .
*
* This file is part of Puter .
*
* Puter is free software : you can redistribute it and / or modify
* it under the terms of the GNU Affero General Public License as published
* by the Free Software Foundation , either version 3 of the License , or
* ( at your option ) any later version .
*
* This program is distributed in the hope that it will be useful ,
* but WITHOUT ANY WARRANTY ; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the
* GNU Affero General Public License for more details .
*
* You should have received a copy of the GNU Affero General Public License
* along with this program . If not , see < https : //www.gnu.org/licenses/>.
* /
2024-04-02 23:25:21 +08:00
; ( function ( ) { 'use strict' ; function ba ( a , b ) { function c ( x ) { x = x . toString ( 16 ) ; return "#" + "0" . repeat ( 6 - x . length ) + x } function d ( x , C , S , P ) { x . style . width = "" ; x . style . height = "" ; P && ( x . style . transform = "" ) ; var aa = x . getBoundingClientRect ( ) ; P ? x . style . transform = ( 1 === C ? "" : " scaleX(" + C + ")" ) + ( 1 === S ? "" : " scaleY(" + S + ")" ) : ( 0 === C % 1 && 0 === S % 1 ? ( e . style . imageRendering = "crisp-edges" , e . style . imageRendering = "pixelated" , e . style [ "-ms-interpolation-mode" ] = "nearest-neighbor" ) : ( e . style . imageRendering = "" , e . style [ "-ms-interpolation-mode" ] = "" ) , P = window . devicePixelRatio ||
1 , 0 !== P % 1 && ( C /= P , S /= P ) ) ; 1 !== C && ( x . style . width = aa . width * C + "px" ) ; 1 !== S && ( x . style . height = aa . height * S + "px" ) } console . assert ( a , "1st argument must be a DOM container" ) ; var e = a . getElementsByTagName ( "canvas" ) [ 0 ] , g = e . getContext ( "2d" , { alpha : ! 1 } ) , f = a . getElementsByTagName ( "div" ) [ 0 ] , k = document . createElement ( "div" ) , l , m , n = 1 , p = 1 , t = 1 , q , z = ! 1 , w , u , I , U = ! 1 , ea = this ; a = 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 Ab = 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 ] ) , Ra = [ ] , db , sa = 0 ; 256 > sa ; sa ++ ) db = 126 < sa ? a [ sa - 127 ] : 32 > sa ? Ab [ sa ] : sa , Ra [ sa ] = String . fromCharCode ( db ) ; g . imageSmoothingEnabled = ! 1 ; k . style . position = "absolute" ; k . style . backgroundColor = "#ccc" ; k . style . width = "7px" ; k . style . display = "inline-block" ; f . style . display = "block" ; e . style . display = "none" ; this . bus = b ; b . register ( "screen-set-mode" , function ( x ) { this . set _mode ( x ) } , this ) ; b . register ( "screen-fill-buffer-end" ,
function ( x ) { this . update _buffer ( x ) } , this ) ; b . register ( "screen-put-char" , function ( x ) { this . put _char ( x [ 0 ] , x [ 1 ] , x [ 2 ] , x [ 3 ] , x [ 4 ] ) } , this ) ; b . register ( "screen-update-cursor" , function ( x ) { this . update _cursor ( x [ 0 ] , x [ 1 ] ) } , this ) ; b . register ( "screen-update-cursor-scanline" , function ( x ) { this . update _cursor _scanline ( x [ 0 ] , x [ 1 ] ) } , this ) ; b . register ( "screen-clear" , function ( ) { this . clear _screen ( ) } , this ) ; b . register ( "screen-set-size-text" , function ( x ) { this . set _size _text ( x [ 0 ] , x [ 1 ] ) } , this ) ; b . register ( "screen-set-size-graphical" , function ( x ) { this . set _size _graphical ( x [ 0 ] ,
x [ 1 ] , x [ 2 ] , x [ 3 ] ) } , this ) ; this . init = function ( ) { this . set _size _text ( 80 , 25 ) ; this . timer ( ) } ; this . make _screenshot = function ( ) { const x = new Image ; if ( z ) x . src = e . toDataURL ( "image/png" ) ; else { const C = [ 9 , 16 ] , S = document . createElement ( "canvas" ) ; S . width = u * C [ 0 ] ; S . height = I * C [ 1 ] ; const P = S . getContext ( "2d" ) ; P . imageSmoothingEnabled = ! 1 ; P . font = window . getComputedStyle ( f ) . font ; P . textBaseline = "top" ; for ( let aa = 0 ; aa < u ; aa ++ ) for ( let fa = 0 ; fa < I ; fa ++ ) { const ta = 3 * ( fa * u + aa ) ; P . fillStyle = c ( w [ ta + 1 ] ) ; P . fillRect ( aa * C [ 0 ] , fa * C [ 1 ] , C [ 0 ] , C [ 1 ] ) ; P . fillStyle =
c ( w [ ta + 2 ] ) ; P . fillText ( Ra [ w [ ta ] ] , aa * C [ 0 ] , fa * C [ 1 ] ) } "none" !== k . style . display && ( P . fillStyle = k . style . backgroundColor , P . fillRect ( m * C [ 0 ] , l * C [ 1 ] + parseInt ( k . style . marginTop , 10 ) - 1 , parseInt ( k . style . width , 10 ) , parseInt ( k . style . height , 10 ) ) ) ; x . src = S . toDataURL ( "image/png" ) } return x } ; this . put _char = function ( x , C , S , P , aa ) { x < I && C < u && ( C = 3 * ( x * u + C ) , w [ C ] = S , w [ C + 1 ] = P , w [ C + 2 ] = aa , q [ x ] = 1 ) } ; this . timer = function ( ) { U || requestAnimationFrame ( z ? Bb : Cb ) } ; var Cb = function ( ) { for ( var x = 0 ; x < I ; x ++ ) q [ x ] && ( ea . text _update _row ( x ) , q [ x ] = 0 ) ; this . timer ( ) } . bind ( this ) ,
Bb = function ( ) { this . bus . send ( "screen-fill-buffer" ) ; this . timer ( ) } . bind ( this ) ; this . destroy = function ( ) { U = ! 0 } ; this . set _mode = function ( x ) { ( z = x ) ? ( f . style . display = "none" , e . style . display = "block" ) : ( f . style . display = "block" , e . style . display = "none" ) } ; this . clear _screen = function ( ) { g . fillStyle = "#000" ; g . fillRect ( 0 , 0 , e . width , e . height ) } ; this . set _size _text = function ( x , C ) { if ( x !== u || C !== I ) { q = new Int8Array ( C ) ; w = new Int32Array ( x * C * 3 ) ; u = x ; for ( I = C ; f . childNodes . length > C ; ) f . removeChild ( f . firstChild ) ; for ( ; f . childNodes . length < C ; ) f . appendChild ( document . createElement ( "div" ) ) ;
for ( x = 0 ; x < C ; x ++ ) this . text _update _row ( x ) ; d ( f , n , p , ! 0 ) } } ; this . set _size _graphical = function ( x , C ) { e . style . display = "block" ; e . width = x ; e . height = C ; t = 640 >= x && 2 * x < window . innerWidth * window . devicePixelRatio && 2 * C < window . innerHeight * window . devicePixelRatio ? 2 : 1 ; d ( e , n * t , p * t , ! 1 ) } ; this . set _scale = function ( x , C ) { n = x ; p = C ; d ( f , n , p , ! 0 ) ; d ( e , n * t , p * t , ! 1 ) } ; this . set _scale ( n , p ) ; this . update _cursor _scanline = function ( x , C ) { x & 32 ? k . style . display = "none" : ( k . style . display = "inline" , k . style . height = Math . min ( 15 , C - x ) + "px" , k . style . marginTop = Math . min ( 15 ,
x ) + "px" ) } ; this . update _cursor = function ( x , C ) { if ( x !== l || C !== m ) q [ x ] = 1 , q [ l ] = 1 , l = x , m = C } ; this . text _update _row = function ( x ) { var C = 3 * x * u , S ; var P = f . childNodes [ x ] ; var aa = document . createElement ( "div" ) ; for ( var fa = 0 ; fa < u ; ) { var ta = document . createElement ( "span" ) ; var eb = w [ C + 1 ] ; var fb = w [ C + 2 ] ; ta . style . backgroundColor = c ( eb ) ; ta . style . color = c ( fb ) ; for ( S = "" ; fa < u && w [ C + 1 ] === eb && w [ C + 2 ] === fb ; ) if ( S += Ra [ w [ C ] ] , fa ++ , C += 3 , x === l ) if ( fa === m ) break ; else if ( fa === m + 1 ) { aa . appendChild ( k ) ; break } ta . textContent = S ; aa . appendChild ( ta ) } P . parentNode . replaceChild ( aa ,
P ) } ; this . update _buffer = function ( x ) { x . forEach ( C => { g . putImageData ( C . image _data , C . screen _x - C . buffer _x , C . screen _y - C . buffer _y , C . buffer _x , C . buffer _y , C . buffer _width , C . buffer _height ) } ) } ; this . init ( ) } ; const ca = Object . freeze ( [ "shared" , "exclusive" , "unlock" ] ) ;
function da ( 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 h ( 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 ,
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 ( r . range ( 254 ) . map ( d => ( { bytes : 1 , name : "mount tag name " + d , read : ( ) => this . configspace _tagname [ d ] || 0 , write : ( ) => { } } ) ) ) } } ) ; this . virtqueue = this . virtio . queues [ 0 ] }
da . 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 } ;
da . 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 ] ) } ; da . prototype . Createfid = function ( a , b , c , d ) { return { inodeid : a , type : b , uid : c , dbg _name : d } } ;
da . prototype . update _dbg _name = function ( a , b ) { for ( const c of this . fids ) c . inodeid === a && ( c . dbg _name = b ) } ; da . prototype . Reset = function ( ) { this . fids = [ ] } ; da . prototype . BuildReply = function ( a , b , c ) { v . Marshall ( [ "w" , "b" , "h" ] , [ c + 7 , a + 1 , b ] , this . replybuffer , 0 ) ; c + 7 >= this . replybuffer . length && y . Debug ( "Error in 9p: payloadsize exceeds maximum length" ) ; this . replybuffersize = c + 7 } ; da . prototype . SendError = function ( a , b , c ) { b = v . Marshall ( [ "w" ] , [ c ] , this . replybuffer , 7 ) ; this . BuildReply ( 6 , a , b ) } ;
da . prototype . SendReply = function ( a ) { a . set _next _blob ( this . replybuffer . subarray ( 0 , this . replybuffersize ) ) ; this . virtqueue . push _reply ( a ) ; this . virtqueue . flush _replies ( ) } ;
da . prototype . ReceiveRequest = async function ( a ) { var b = new Uint8Array ( a . length _readable ) ; a . get _next _blob ( b ) ; var c = { offset : 0 } , d = v . 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 = v . Marshall ( "wwddddddw" . split ( "" ) , d , this . replybuffer , 7 ) ; this . BuildReply ( g ,
f , e ) ; this . SendReply ( a ) ; break ; case 112 : case 12 : d = v . Unmarshall ( [ "w" , "w" ] , b , c ) ; var k = d [ 0 ] ; c = d [ 1 ] ; y . Debug ( "[open] fid=" + k + ", mode=" + c ) ; b = this . fids [ k ] . inodeid ; var l = this . fs . GetInode ( b ) ; y . Debug ( "file open " + this . fids [ k ] . dbg _name ) ; e = this . fs . OpenInode ( b , c ) ; this . fs . AddEvent ( this . fids [ k ] . inodeid , function ( ) { y . Debug ( "file opened " + this . fids [ k ] . dbg _name + " tag:" + f ) ; var t = [ ] ; t [ 0 ] = l . qid ; t [ 1 ] = this . msize - 24 ; v . Marshall ( [ "Q" , "w" ] , t , this . replybuffer , 7 ) ; this . BuildReply ( g , f , 17 ) ; this . SendReply ( a ) } . bind ( this ) ) ; break ; case 70 : d =
v . Unmarshall ( [ "w" , "w" , "s" ] , b , c ) ; b = d [ 0 ] ; k = d [ 1 ] ; e = d [ 2 ] ; y . 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 = v . Unmarshall ( [ "w" , "s" , "s" , "w" ] , b , c ) ; k = d [ 0 ] ; e = d [ 1 ] ; b = d [ 2 ] ; d = d [ 3 ] ; y . 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 ; v . Marshall ( [ "Q" ] , [ l . qid ] , this . replybuffer , 7 ) ; this . BuildReply ( g , f , 13 ) ; this . SendReply ( a ) ; break ; case 18 : d = v . Unmarshall ( "wswwww" . split ( "" ) , b , c ) ; k = d [ 0 ] ; e = d [ 1 ] ; c = d [ 2 ] ; b = d [ 3 ] ; var m = d [ 4 ] ; d = d [ 5 ] ; y . 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 ; v . Marshall ( [ "Q" ] , [ l . qid ] , this . replybuffer , 7 ) ; this . BuildReply ( g , f , 13 ) ; this . SendReply ( a ) ; break ; case 22 : d = v . Unmarshall ( [ "w" ] ,
b , c ) ; k = d [ 0 ] ; l = this . fs . GetInode ( this . fids [ k ] . inodeid ) ; y . Debug ( "[readlink] fid=" + k + " name=" + this . fids [ k ] . dbg _name + " target=" + l . symlink ) ; e = v . Marshall ( [ "s" ] , [ l . symlink ] , this . replybuffer , 7 ) ; this . BuildReply ( g , f , e ) ; this . SendReply ( a ) ; break ; case 72 : d = v . Unmarshall ( [ "w" , "s" , "w" , "w" ] , b , c ) ; k = d [ 0 ] ; e = d [ 1 ] ; c = d [ 2 ] ; d = d [ 3 ] ; y . 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 | ha ; l . uid = this . fids [ k ] . uid ; l . gid = d ; v . Marshall ( [ "Q" ] , [ l . qid ] ,
this . replybuffer , 7 ) ; this . BuildReply ( g , f , 13 ) ; this . SendReply ( a ) ; break ; case 14 : d = v . 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 ] ) ; y . 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 ; v . Marshall ( [ "Q" , "w" ] , [ l . qid , this . msize - 24 ] , this . replybuffer ,
7 ) ; this . BuildReply ( g , f , 17 ) ; this . SendReply ( a ) ; break ; case 52 : d = v . 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 ] ) ; y . Debug ( "[lock] fid=" + k + ", type=" + ca [ d . type ] + ", start=" + d . start + ", length=" + d . length + ", proc_id=" + d . proc _id ) ; e = this . fs . Lock ( this . fids [ k ] . inodeid , d , b ) ; v . Marshall ( [ "b" ] , [ e ] , this . replybuffer , 7 ) ; this . BuildReply ( g , f , 1 ) ; this . SendReply ( a ) ; break ; case 54 : d = v . 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 ] ) ; y . Debug ( "[getlock] fid=" + k + ", type=" + ca [ 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 = v . 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 = v . Unmarshall ( [ "w" , "d" ] , b , c ) ; k = d [ 0 ] ; l = this . fs . GetInode ( this . fids [ k ] . inodeid ) ; y . Debug ( "[getattr]: fid=" +
k + " name=" + this . fids [ k ] . dbg _name + " request mask=" + d [ 1 ] ) ; if ( ! l || l . status === ia ) { y . Debug ( "getattr: unlinked" ) ; this . SendError ( f , "No such file or directory" , 2 ) ; this . SendReply ( a ) ; break } d [ 0 ] |= 4096 ; 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 ; v . Marshall ( "dQwwwddddddddddddddd" . split ( "" ) , d , this . replybuffer ,
7 ) ; this . BuildReply ( g , f , 153 ) ; this . SendReply ( a ) ; break ; case 26 : d = v . Unmarshall ( "wwwwwddddd" . split ( "" ) , b , c ) ; k = d [ 0 ] ; l = this . fs . GetInode ( this . fids [ k ] . inodeid ) ; y . 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 = v . Unmarshall ( [ "w" , "d" ] , b , c ) ; k = d [ 0 ] ; this . BuildReply ( g , f , 0 ) ; this . SendReply ( a ) ; break ; case 40 : case 116 : d = v . 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 && y . Debug ( "[treaddir]: fid=" + k + " offset=" + e + " count=" + m ) ; 116 == g && y . Debug ( "[read]: fid=" + k + " (" + this . fids [ k ] . dbg _name + ") offset=" + e + " count=" + m + " fidtype=" + this . fids [ k ] . type ) ; if ( ! l ||
l . status === ia ) { y . 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 ) ; v . Marshall ( [ "w" ] , [ m ] , this . replybuffer , 7 ) ; this . BuildReply ( g , f , 4 + m ) ; this . SendReply ( a ) ; break ; case 118 : d = v . Unmarshall ( [ "w" , "d" , "w" ] , b , c ) ; k = d [ 0 ] ; e = d [ 1 ] ; m = d [ 2 ] ; d = this . fids [ k ] . dbg _name ; y . 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 ] ) ; v . Marshall ( [ "w" ] , [ m ] , this . replybuffer , 7 ) ; this . BuildReply ( g , f , 4 ) ; this . SendReply ( a ) ; break ; case 74 : d = v . Unmarshall ( [ "w" , "s" , "w" , "s" ] , b , c ) ; e = d [ 0 ] ; b = d [ 1 ] ; c = d [ 2 ] ; d = d [ 3 ] ; y . 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 = v . Unmarshall ( [ "w" , "s" , "w" ] , b , c ) ; c = d [ 0 ] ; e = d [ 1 ] ; b = d [ 2 ] ; y . 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 = v . Unmarshall ( [ "w" , "s" ] , b , c ) ; y . Debug ( "[version]: msize=" + d [ 0 ] + " version=" + d [ 1 ] ) ; this . msize = d [ 0 ] ; e = v . Marshall ( [ "w" , "s" ] , [ this . msize , this . VERSION ] , this . replybuffer , 7 ) ; this . BuildReply ( g , f , e ) ; this . SendReply ( a ) ; break ; case 104 : d = v . Unmarshall ( [ "w" , "w" , "s" , "s" , "w" ] , b , c ) ; k = d [ 0 ] ; e = d [ 4 ] ; y . Debug ( "[attach]: fid=" + k + " afid=" + A ( d [ 1 ] ) + " uname=" + d [ 2 ] + " aname=" + d [ 3 ] ) ; this . fids [ k ] = this . Createfid ( 0 , 1 , e , "" ) ; l = this . fs . GetInode ( this . fids [ k ] . inodeid ) ; v . Marshall ( [ "Q" ] , [ l . qid ] , this . replybuffer , 7 ) ; this . BuildReply ( g ,
f , 13 ) ; this . SendReply ( a ) ; this . bus . send ( "9p-attach" ) ; break ; case 108 : d = v . Unmarshall ( [ "h" ] , b , c ) ; y . Debug ( "[flush] " + f ) ; this . BuildReply ( g , f , 0 ) ; this . SendReply ( a ) ; break ; case 110 : d = v . Unmarshall ( [ "w" , "w" , "h" ] , b , c ) ; k = d [ 0 ] ; m = d [ 1 ] ; var n = d [ 2 ] ; y . 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 ) ; v . 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 = v . Unmarshall ( e , b , c ) ; b = this . fids [ k ] . inodeid ; e = 9 ; var p = 0 ; y . 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 ) { y . Debug ( "Could not find: " + c [ d ] ) ; break } e += v . Marshall ( [ "Q" ] , [ this . fs . GetInode ( b ) . qid ] , this . replybuffer , e ) ; p ++ ; this . fids [ m ] = this . Createfid ( b , 1 , this . fids [ k ] . uid , c [ d ] ) } v . Marshall ( [ "h" ] , [ p ] , this . replybuffer , 7 ) ; this . BuildReply ( g , f , e - 7 ) ; this . SendReply ( a ) ; break ; case 120 : d = v . Unmarshall ( [ "w" ] , b , c ) ; y . 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 = v . Unmarshall ( [ "w" , "s" , "d" , "w" ] , b , c ) ; k = d [ 0 ] ; e = d [ 1 ] ; c = d [ 2 ] ; b = d [ 3 ] ; y . 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 = v . Unmarshall ( [ "w" , "w" , "s" ] , b , c ) ; k = d [ 0 ] ; e = d [ 2 ] ; y . Debug ( "[xattrwalk]: fid=" + d [ 0 ] + " newfid=" + d [ 1 ] + " name=" +
d [ 2 ] ) ; this . SendError ( f , "Setxattr not supported" , 95 ) ; this . SendReply ( a ) ; break ; default : y . Debug ( "Error in Virtio9p: Unknown id " + g + " received" ) , y . Abort ( ) } } ; function B ( 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 ) { A ( d >>> 0 , 8 ) ; return 255 } , function ( d , e ) { A ( d >>> 0 , 8 ) ; A ( e , 2 ) } , function ( d ) { A ( d >>> 0 , 8 ) ; return - 1 } , function ( d , e ) { A ( d >>> 0 , 8 ) ; A ( e >>> 0 , 8 ) } ) }
B . 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 } } ; B . prototype . empty _port _read8 = function ( ) { return 255 } ; B . prototype . empty _port _read16 = function ( ) { return 65535 } ; B . prototype . empty _port _read32 = function ( ) { return - 1 } ; B . prototype . empty _port _write = function ( ) { } ;
B . 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 } ; B . 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 } ;
B . 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 ) ) } ;
B . 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 ) ) } ;
B . 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 } ; B . 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 ) } ;
B . prototype . mmap _register = function ( a , b , c , d , e , g ) { A ( a >>> 0 , 8 ) ; A ( 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 } ; B . prototype . port _write8 = function ( a , b ) { var c = this . ports [ a ] ; c . write8 === this . empty _port _write && ( A ( a , 4 ) , A ( b , 2 ) , this . get _port _description ( a ) ) ; return c . write8 . call ( c . device , b ) } ;
B . prototype . port _write16 = function ( a , b ) { var c = this . ports [ a ] ; c . write16 === this . empty _port _write && ( A ( a , 4 ) , A ( b , 4 ) , this . get _port _description ( a ) ) ; return c . write16 . call ( c . device , b ) } ; B . prototype . port _write32 = function ( a , b ) { var c = this . ports [ a ] ; c . write32 === this . empty _port _write && ( A ( a , 4 ) , A ( b >>> 0 , 8 ) , this . get _port _description ( a ) ) ; return c . write32 . call ( c . device , b ) } ;
B . prototype . port _read8 = function ( a ) { var b = this . ports [ a ] ; b . read8 === this . empty _port _read8 && ( A ( a , 4 ) , this . get _port _description ( a ) ) ; b = b . read8 . call ( b . device ) ; A ( a ) ; return b } ; B . prototype . port _read16 = function ( a ) { var b = this . ports [ a ] ; b . read16 === this . empty _port _read16 && ( A ( a , 4 ) , this . get _port _description ( a ) ) ; b = b . read16 . call ( b . device ) ; A ( a ) ; return b } ; B . prototype . port _read32 = function ( a ) { var b = this . ports [ a ] ; b . read32 === this . empty _port _read32 && ( A ( a , 4 ) , this . get _port _description ( a ) ) ; return b . read32 . call ( b . device ) } ;
var ja = { 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" ,
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" ,
1297 : "PORT_QEMU_CFG_DATA" , 45056 : "PORT_ACPI_PM_BASE" , 45312 : "PORT_SMB_BASE" , 35072 : "PORT_BIOS_APM" } ; B . prototype . get _port _description = function ( a ) { return ja [ a ] ? " (" + ja [ a ] + ")" : "" } ; function D ( a , b ) { this . stopping = this . running = ! 1 ; this . tick _counter = 0 ; this . worker = null ; this . cpu = new E ( a , b , ( ) => { this . idle && this . next _tick ( 0 ) } ) ; this . bus = a ; a . register ( "cpu-init" , this . init , this ) ; a . register ( "cpu-run" , this . run , this ) ; a . register ( "cpu-stop" , this . stop , this ) ; a . register ( "cpu-restart" , this . restart , this ) ; 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 ( ) { globalThis . onmessage = function ( b ) { const c = b . data . t ; 1 > c ? postMessage ( b . data . tick ) : setTimeout ( ( ) => postMessage ( b . data . tick ) , c ) } } 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 F = F || { } ; F . exportSymbol = function ( ) { } ; F . exportProperty = function ( ) { } ; var r = r || { } ; r . pads = function ( a , b ) { return ( a || 0 === a ? a + "" : "" ) . padEnd ( b , " " ) } ; r . pad0 = function ( a , b ) { return ( a || 0 === a ? a + "" : "" ) . padStart ( b , "0" ) } ; r . zeros = function ( a ) { return Array ( a ) . fill ( 0 ) } ; r . range = function ( a ) { return Array . from ( Array ( a ) . keys ( ) ) } ;
r . 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 A ( a , b ) { a = a ? a . toString ( 16 ) : "" ; return "0x" + r . pad0 ( a . toUpperCase ( ) , b || 1 ) }
if ( "undefined" !== typeof crypto && crypto . getRandomValues ) { let a = new Int32Array ( 1 ) ; r . get _rand _int = function ( ) { crypto . getRandomValues ( a ) ; return a [ 0 ] } } else if ( "undefined" !== typeof require ) { const a = require ( "crypto" ) ; r . get _rand _int = function ( ) { return a . randomBytes ( 4 ) . readInt32LE ( 0 ) } }
( function ( ) { if ( "function" === typeof Math . clz32 ) r . int _log2 _byte = function ( d ) { return 31 - Math . clz32 ( d ) } , r . 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 ; r . int _log2 _byte = function ( d ) { return a [ d ] } ; r . 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 ] } } } ) ( ) ;
function ka ( 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 la ( a ) { this . size = a ; this . data = new Float32Array ( a ) ; this . length = this . end = this . start = 0 }
la . 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 } ; la . prototype . shift = function ( ) { if ( this . length ) { var a = this . data [ this . start ] ; this . start = this . start + 1 & this . size - 1 ; this . length -- ; return a } } ;
la . 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 } ; la . prototype . peek = function ( ) { if ( this . length ) return this . data [ this . start ] } ; la . prototype . clear = function ( ) { this . length = this . end = this . start = 0 } ;
r . Bitmap = function ( a ) { "number" === typeof a ? this . view = new Uint8Array ( a + 7 >> 3 ) : a instanceof ArrayBuffer && ( this . view = new Uint8Array ( a ) ) } ; r . 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 } ; r . Bitmap . prototype . get = function ( a ) { return this . view [ a >> 3 ] >> ( a & 7 ) & 1 } ; r . Bitmap . prototype . get _buffer = function ( ) { return this . view . buffer } ; r . load _file = "undefined" === typeof XMLHttpRequest ? ma : na ;
function na ( a , b , c ) { function d ( ) { const l = c || 0 ; setTimeout ( ( ) => { na ( 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 &&
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 ) { let 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 ) } function ma ( a , b ) { let 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 ) ) } ) }
r . 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 } r . SyncBuffer = a ; r . AsyncXHRBuffer = b ; r . AsyncXHRPartfileBuffer = c ; r . AsyncFileBuffer = e ; r . SyncFileBuffer = d ; r . buffer _from _object = function ( f , k ) { if ( f . buffer instanceof ArrayBuffer ) return new r . 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 r . AsyncFileBuffer ( f . buffer ) : new r . SyncFileBuffer ( f . buffer ) ; if ( f . url ) return f . use _parts ? new r . AsyncXHRPartfileBuffer ( f . url ,
f . size , f . fixed _chunk _size , ! 1 , k ) : new r . 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 ) ; r . load _file ( this . filename , { done : function ( t ) { t = new Uint8Array ( t ) ; this . handle _read ( n , p , t ) ; n === f && p === k ? l ( t ) : l ( t . 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 t = k . subarray ( 256 * n , 256 * ( n + 1 ) ) ; p . set ( t ) } 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 ( let [ 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 ( let [ 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 ) , t = f - p * this . fixed _chunk _size , q = Math . ceil ( ( t + k ) / this . fixed _chunk _size ) ,
z = new Uint8Array ( q * this . fixed _chunk _size ) ; let w = 0 ; for ( let u = 0 ; u < q ; 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 ) ) ? ( z . set ( n , u * this . fixed _chunk _size ) , w ++ , w === q && l ( z . subarray ( t , t + k ) ) ) : r . load _file ( m , { done : async function ( I ) { I = new Uint8Array ( I ) ; this . is _zstd && ( I = await this . zstd _decompress ( this . fixed _chunk _size , I ) , I = new Uint8Array ( I ) ) ;
z . set ( I , u * this . fixed _chunk _size ) ; this . handle _read ( ( p + u ) * this . fixed _chunk _size , this . fixed _chunk _size | 0 , I ) ; w ++ ; w === q && l ( z . subarray ( t , t + k ) ) } . bind ( this ) } ) } } else r . 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 ( q , z ) { return q - z } ) , m = 0 , n = 0 ; n < l . length ; n ++ ) { var p = l [ n ] , t = this . block _cache . get ( p ) ; p *= 256 ; p !== m && ( k . push ( this . file . slice ( m , p ) ) , m = p ) ; k . push ( t ) ; m += t . 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 ) { r . 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 G ( a , b , c , d , e , g ) { this . master = new H ( this , a , b , d , e , 0 , g ) ; this . slave = new H ( 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 ,
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 |
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 ( ) { A ( this . current _interface . error & 255 ) ; return this . current _interface . error & 255 } ) ; a . io . register _read ( this . ata _port | 2 , this , function ( ) { A ( this . current _interface . bytecount &
255 ) ; return this . current _interface . bytecount & 255 } ) ; a . io . register _read ( this . ata _port | 3 , this , function ( ) { A ( this . current _interface . sector & 255 ) ; return this . current _interface . sector & 255 } ) ; a . io . register _read ( this . ata _port | 4 , this , function ( ) { A ( this . current _interface . cylinder _low & 255 ) ; return this . current _interface . cylinder _low & 255 } ) ; a . io . register _read ( this . ata _port | 5 , this , function ( ) { A ( 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 ) { A ( 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 ) { A ( 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 ) { A ( 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 ) { A ( 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 ) { A ( 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 ; A ( 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 ) ;
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 ) ;
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 ) } G . prototype . read _status = function ( ) { if ( this . current _interface . buffer ) { var a = this . current _interface . status ; A ( a , 2 ) ; return a } return 0 } ; G . prototype . write _control = function ( a ) { A ( a , 2 ) ; a & 4 && ( this . cpu . device _lower _irq ( this . irq ) , this . master . device _reset ( ) , this . slave . device _reset ( ) ) ; this . device _control = a } ;
G . prototype . dma _read _addr = function ( ) { A ( this . prdt _addr , 8 ) ; return this . prdt _addr } ; G . prototype . dma _set _addr = function ( a ) { A ( a , 8 ) ; this . prdt _addr = a } ; G . prototype . dma _read _status = function ( ) { A ( this . dma _status ) ; return this . dma _status } ; G . prototype . dma _write _status = function ( a ) { A ( a ) ; this . dma _status &= ~ ( a & 6 ) } ; G . prototype . dma _read _command = function ( ) { return this . dma _read _command8 ( ) | this . dma _read _status ( ) << 16 } ; G . prototype . dma _read _command8 = function ( ) { A ( this . dma _command ) ; return this . dma _command } ;
G . prototype . dma _write _command = function ( a ) { A ( a ) ; this . dma _write _command8 ( a & 255 ) ; this . dma _write _status ( a >> 16 & 255 ) } ;
G . prototype . dma _write _command8 = function ( a ) { A ( a ) ; let 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 : A ( this . current _interface . current _command ) } } ;
G . prototype . push _irq = function ( ) { 0 === ( this . device _control & 2 ) && ( this . dma _status |= 4 , this . cpu . device _raise _irq ( this . irq ) ) } ; G . 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 } ;
G . 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 ] } ;
function H ( 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 /
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 >>
8 & 255 ) , a . cmos _write ( 35 , this . sectors _per _track & 255 ) ) ; this . stats = { sectors _read : 0 , sectors _written : 0 , bytes _read : 0 , bytes _written : 0 , loading : ! 1 } ; 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 = new Set ; this . cancelled _io _ids = new Set ; Object . seal ( this ) } H . 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 ( ) } ; H . prototype . push _irq = function ( ) { this . device . push _irq ( ) } ;
H . prototype . ata _command = function ( a ) { A ( 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 =
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 ( ) ,
this . status = 88 , this . cylinder _low = 20 , this . cylinder _high = 235 ) : this . status = 65 ; this . push _irq ( ) ; break ; case 198 : A ( 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 : A ( 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 : A ( a ) , this . status = 65 , this . error = 4 } else this . error = 4 , this . status =
65 , this . push _irq ( ) } ;
H . prototype . atapi _handle = function ( ) { A ( 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 ; A ( 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 ,
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 ) :
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 ; A ( b , 2 ) ; A ( 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 : A ( 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 ] ; A ( 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 ; A ( this . data [ 0 ] ) ; break ; case 190 : A ( 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 , A ( this . data [ 0 ] ) } this . bytecount = this . bytecount & - 8 | 2 ; 0 === ( this . status & 128 ) && this . push _irq ( ) ;
0 === ( this . status & 128 ) && 0 === this . data _length && ( this . bytecount |= 1 , this . status &= - 9 ) } ; H . 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 ) } ;
H . 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 ; J ( "CD read lba=" + A ( b ) + " lbacount=" + A ( c ) + " bytecount=" + A ( d ) + " flags=" + A ( a ) , 32768 ) ; this . data _length = 0 ; var g = this . cylinder _high << 8 & 65280 | this . cylinder _low & 255 ; J ( A ( this . cylinder _high , 2 ) + " " + A ( this . cylinder _low , 2 ) , 32768 ) ; this . cylinder _low = this . cylinder _high = 0 ; 65535 === g && g -- ; g > d && ( g = d ) ; e >= this . buffer . byteLength ? ( oa ( ! 1 , "CD read: Outside of disk end=" + A ( e + d ) + " size=" +
A ( 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 ) } ) ) } ;
H . 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 ; J ( "CD read DMA lba=" + A ( b ) + " lbacount=" + A ( c ) + " bytecount=" + A ( d ) + " flags=" + A ( a ) , 32768 ) ; e >= this . buffer . byteLength ? ( oa ( ! 1 , "CD read: Outside of disk end=" + A ( e + d ) + " size=" + A ( 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 &
- 8 | 2 ; this . data _set ( g ) ; this . do _atapi _dma ( ) } ) ) } ;
H . 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 ) ; A ( d ) ; A ( e ) ; A ( 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 ) { A ( b ) ; A ( this . data _length ) ; A ( this . current _command ) ; break } } while ( ! g ) ; this . status = 80 ; this . device . dma _status &= - 2 ; this . bytecount = this . bytecount &
- 8 | 3 ; this . push _irq ( ) } } ; H . prototype . read _data = function ( a ) { if ( this . data _pointer < this . data _end ) { A ( 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 ) ) && ( A ( this . data [ this . data _pointer ] , 2 ) , A ( this . data _pointer ) , A ( this . data _length ) ) ; this . data _pointer >= this . data _end && this . read _end ( ) ; return b } this . data _pointer += a ; return 0 } ;
H . prototype . read _end = function ( ) { A ( this . current _command ) ; A ( this . data _pointer ) ; A ( this . data _end ) ; A ( 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 ; A ( 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 ( ) ) } ;
H . prototype . write _data _port = function ( a , b ) { if ( this . data _pointer >= this . data _end ) A ( a ) , A ( this . data _end ) , A ( this . data _pointer ) ; else { if ( 0 === ( this . data _pointer + b & ( 0 === ( this . data _end & 4095 ) ? 4095 : 255 ) ) || 20 > this . data _end ) A ( a >>> 0 ) , A ( this . data _end ) , A ( 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 ( ) } } ;
H . prototype . write _data _port8 = function ( a ) { this . write _data _port ( a , 1 ) } ; H . prototype . write _data _port16 = function ( a ) { this . write _data _port ( a , 2 ) } ; H . prototype . write _data _port32 = function ( a ) { this . write _data _port ( a , 4 ) } ; H . prototype . write _end = function ( ) { 160 === this . current _command ? this . atapi _handle ( ) : ( A ( this . data _pointer ) , A ( this . data _length ) , this . data _pointer >= this . data _length ? this . do _write ( ) : ( A ( this . current _command ) , this . status = 88 , this . data _end += 512 , this . push _irq ( ) ) ) } ;
H . 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 |
0 ) % this . head _count & 15 , this . sector = a % this . sectors _per _track + 1 & 255 , this . get _chs ( ) ) } ;
H . 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 ; J ( "ATA read cmd=" + A ( a ) + " mode=" + ( this . is _lba ? "lba" : "chs" ) + " lba=" + A ( b ) + " lbacount=" + A ( c ) + " bytecount=" + A ( 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 ) } ) ) } ; H . 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 ; A ( b ) ; A ( a ) ; A ( c ) ; d + c > this . buffer . byteLength ? ( this . status = 255 , this . push _irq ( ) ) : ( this . status = 88 , this . device . dma _status |= 1 ) } ;
H . 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 ) ; A ( f ) ; A ( 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 ) } ) } ; H . 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 ; A ( b ) ; A ( c ) ; A ( 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 ) } ;
H . 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 ; A ( b ) ; A ( a ) ; A ( c ) ; d + c > this . buffer . byteLength ? ( this . status = 255 , this . push _irq ( ) ) : ( this . status = 88 , this . device . dma _status |= 1 ) } ;
H . 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 ; J ( "prdt addr: " + A ( 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 ) ; J ( "dma write transfer dest=" + A ( f ) + " prd_count=" + A ( 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 ,
b ) ; this . status = 80 ; this . push _irq ( ) ; this . device . dma _status &= - 2 ; this . current _command = - 1 } ) ; this . report _write ( a ) } ; H . 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 } ; H . prototype . get _lba28 = function ( ) { return this . sector & 255 | this . cylinder _low << 8 & 65280 | this . cylinder _high << 16 & 16711680 | ( this . head & 15 ) << 24 } ;
H . prototype . get _lba48 = function ( ) { return ( this . sector & 255 | this . cylinder _low << 8 & 65280 | this . cylinder _high << 16 & 16711680 | this . sector >> 8 << 24 & 4278190080 ) >>> 0 } ; H . prototype . get _lba = function ( a ) { return a ? this . get _lba48 ( ) : this . is _lba ? this . get _lba28 ( ) : this . get _chs ( ) } ; H . prototype . get _count = function ( a ) { a ? ( a = this . bytecount , 0 === a && ( a = 65536 ) ) : ( a = this . bytecount & 255 , 0 === a && ( a = 256 ) ) ; return a } ;
H . 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 ,
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 ,
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 } } ; H . prototype . data _allocate = function ( a ) { this . data _allocate _noclear ( a ) ; for ( var b = 0 ; b < a + 3 >> 2 ; b ++ ) this . data32 [ b ] = 0 } ;
H . 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 } ; H . prototype . data _set = function ( a ) { this . data _allocate _noclear ( a . length ) ; this . data . set ( a ) } ; H . prototype . report _read _start = function ( ) { this . stats . loading = ! 0 ; this . bus . send ( "ide-read-start" ) } ;
H . prototype . report _read _end = function ( a ) { this . stats . loading = ! 1 ; var b = a / this . sector _size | 0 ; this . stats . sectors _read += b ; this . stats . bytes _read += a ; this . bus . send ( "ide-read-end" , [ this . nr , a , b ] ) } ; H . prototype . report _write = function ( a ) { var b = a / this . sector _size | 0 ; this . stats . sectors _written += b ; this . stats . bytes _written += a ; this . bus . send ( "ide-write-end" , [ this . nr , a , b ] ) } ;
H . 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 ) ) } ) } ; H . 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 ( ) } ;
H . 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 ] =
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 } ;
H . 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 pa ( 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 =
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 ,
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 ) } pa . 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 } ;
pa . 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 && A ( 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 ] ) } ;
pa . 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=" + A ( a , 4 ) ) ; d += " dev=" + A ( c , 2 ) ; d += " addr=" + A ( 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 += " " + A ( this . pci _addr32 [ 0 ] >>> 0 , 8 ) + " -> " + A ( this . pci _response32 [ 0 ] >>> 0 , 8 ) ) : ( this . pci _response32 [ 0 ] = - 1 , this . pci _status32 [ 0 ] = 0 ) } ;
pa . prototype . pci _write8 = function ( a , b ) { var c = a >> 8 & 65535 ; a &= 255 ; var d = new Uint8Array ( this . device _spaces [ c ] . buffer ) ; A ( a ) ; A ( c >> 3 , 2 ) ; A ( a , 4 ) ; A ( b , 2 ) ; d [ a ] = b } ; pa . 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 ? A ( a ) : ( A ( a ) , A ( c >> 3 , 2 ) , A ( a , 4 ) , A ( b , 4 ) , d [ a >>> 1 ] = b ) } ;
pa . 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 ] ; A ( b >>> 0 ) ; A ( 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 ; A ( g >>> 0 , 8 ) ; A ( f >>> 0 , 8 ) ; this . set _io _bars ( e , g , f ) ; d [ c ] = b | 1 } } else d [ a >> 2 ] = 0 ; A ( d [ a >> 2 ] >>> 0 ) } else 48 === a ? ( A ( c >> 3 , 2 ) , A ( 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 ? ( A ( c >> 3 , 2 ) , A ( a , 4 ) , A ( b >>> 0 , 8 ) ) : ( A ( c >> 3 , 2 ) , A ( a , 4 ) , A ( b >>> 0 , 8 ) , d [ a >>> 2 ] = b ) } ; pa . prototype . register _device = function ( a ) { var b = a . pci _id ; A ( 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 } ;
pa . prototype . set _io _bars = function ( a , b , c ) { var d = a . size ; A ( b ) ; A ( 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 && A ( 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 || A ( c + g , 4 ) } } ; pa . 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 ) ] ) } ; pa . 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 K ( 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 ) ) ;
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 ) }
K . prototype . eject _fda = function ( ) { this . fda _image = null ; this . number _of _cylinders = this . number _of _heads = this . sectors _per _track = 0 ; this . dir = 128 } ;
K . 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 } ,
[ 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 r . 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 ) } ;
K . 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 } ;
K . 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 ] } ; K . prototype . port3F0 _read = function ( ) { return 0 } ;
K . prototype . port3F4 _read = function ( ) { var a = 128 ; this . response _index < this . response _length && ( a |= 80 ) ; 0 === ( this . dor & 8 ) && ( a |= 32 ) ; return a } ; K . prototype . port3F7 _read = function ( ) { return this . dir } ; K . prototype . port3F5 _read = function ( ) { return this . response _index < this . response _length ? ( this . cpu . device _lower _irq ( 6 ) , this . response _data [ this . response _index ++ ] ) : 255 } ; K . prototype . port3F4 _write = function ( a ) { A ( a ) ; a & 128 && ( this . status _reg0 = 192 , this . cpu . device _raise _irq ( 6 ) ) } ;
K . prototype . port3F5 _write = function ( a ) { J ( "3F5 write " + A ( 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 =
function ( b ) { this . do _sector ( ! 0 , b ) } ; this . bytes _expecting = 8 ; break ; case 6 : case 70 : 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 ; this . response _index =
0 ; this . response _length = 1 ; this . bytes _expecting = 0 ; break ; default : oa ( ! 1 , "Unimplemented floppy command call " + A ( a ) ) } this . receiving _index = 0 } } ; K . prototype . port3F2 _read = function ( ) { return this . dor } ; K . prototype . port3F2 _write = function ( a ) { 4 === ( a & 4 ) && 0 === ( this . dor & 4 ) && ( this . status _reg0 = 192 , this . cpu . device _raise _irq ( 6 ) ) ; A ( a >> 4 ) ; A ( a ) ; this . dor = a } ; K . 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 } ;
K . 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 ( ) } ; K . prototype . calibrate = function ( a ) { this . seek ( [ a [ 0 ] , 0 ] ) } ; K . 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 } ;
K . 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 ; A ( k ) ; A ( 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 } ;
K . 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 ( ) ) } ;
K . prototype . fix _drive _data = function ( a ) { a . slice ( 0 , this . bytes _expecting ) } ; K . prototype . configure = function ( a ) { a . slice ( 0 , this . bytes _expecting ) } ; K . 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 ( ) } ; K . prototype . raise _irq = function ( ) { this . dor & 8 && this . cpu . device _raise _irq ( 6 ) } ; E . prototype . mmap _read8 = function ( a ) { return this . memory _map _read8 [ a >>> 17 ] ( a ) } ; E . prototype . mmap _write8 = function ( a , b ) { this . memory _map _write8 [ a >>> 17 ] ( a , b ) } ; E . prototype . mmap _read16 = function ( a ) { var b = this . memory _map _read8 [ a >>> 17 ] ; return b ( a ) | b ( a + 1 | 0 ) << 8 } ; E . prototype . mmap _write16 = function ( a , b ) { var c = this . memory _map _write8 [ a >>> 17 ] ; c ( a , b & 255 ) ; c ( a + 1 | 0 , b >> 8 ) } ; E . prototype . mmap _read32 = function ( a ) { return this . memory _map _read32 [ a >>> 17 ] ( a ) } ;
E . prototype . mmap _write32 = function ( a , b ) { this . memory _map _write32 [ a >>> 17 ] ( a , b ) } ; E . prototype . mmap _write64 = function ( a , b , c ) { var d = this . memory _map _write32 [ a >>> 17 ] ; d ( a , b ) ; d ( a + 4 , c ) } ; E . 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 ) } ; E . 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 ) ) } ;
E . 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 L ( 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 ,
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 ,
this , this . port _mode _write . bind ( this , 4 ) ) ; a . register _write ( 12 , this , this . portC _write ) ; a . register _write ( 216 , this , this . portC _write ) } L . 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 ] } ;
L . 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 ] } ; L . prototype . port _count _write = function ( a , b ) { A ( 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 ) } ;
L . prototype . port _count _read = function ( a ) { A ( this . channel _count [ a ] ) ; return this . flipflop _read ( this . channel _count [ a ] ) } ; L . prototype . port _addr _write = function ( a , b ) { A ( 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 ) } ; L . prototype . port _addr _read = function ( a ) { A ( this . channel _addr [ a ] ) ; return this . flipflop _read ( this . channel _addr [ a ] ) } ; L . prototype . port _pagehi _write = function ( a , b ) { A ( b ) ; this . channel _pagehi [ a ] = b } ;
L . prototype . port _pagehi _read = function ( a ) { return this . channel _pagehi [ a ] } ; L . prototype . port _page _write = function ( a , b ) { A ( b ) ; this . channel _page [ a ] = b } ; L . prototype . port _page _read = function ( a ) { return this . channel _page [ a ] } ; L . prototype . port _singlemask _write = function ( a , b ) { this . update _mask ( ( b & 3 ) + a , b & 4 ? 1 : 0 ) } ; L . prototype . port _multimask _write = function ( a , b ) { A ( b ) ; for ( var c = 0 ; 4 > c ; c ++ ) this . update _mask ( a + c , b & 1 << c ) } ;
L . 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 ; A ( b ) ; return b } ; L . prototype . port _mode _write = function ( a , b ) { a = ( b & 3 ) + a ; A ( b ) ; this . channel _mode [ a ] = b } ; L . prototype . portC _write = function ( ) { this . lsb _msb _flipflop = 0 } ; L . prototype . on _unmask = function ( a , b ) { this . unmask _listeners . push ( { fn : a , this _value : b } ) } ;
L . 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 ) } ;
L . prototype . do _read = function ( a , b , c , d , e ) { var g = this . count _get _8bit ( d ) , f = this . address _get _8bit ( d ) ; J ( "to " + A ( f ) + " len " + A ( g ) , 16 ) ; c < g && J ( "DMA should read more than provided: " + A ( c ) + " " + A ( 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 ) } ) } } ;
L . 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 ; J ( "to " + A ( l ) + " len " + A ( 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 ) } ) ) } ;
L . 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 } ; L . prototype . count _get _8bit = function ( a ) { var b = this . channel _count [ a ] + 1 ; 5 <= a && ( b *= 2 ) ; return b } ; L . 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 } ; L . prototype . flipflop _read = function ( a ) { return ( this . lsb _msb _flipflop ^= 1 ) ? a & 255 : a >> 8 & 255 } ; function qa ( 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 ,
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 ,
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 ) } qa . 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 } ;
qa . 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 ] } ;
qa . 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 } ;
qa . 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 } ; qa . 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 ) } ;
qa . 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 } ;
qa . 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 ( ) , A ( this . counter _reload [ a ] ) ) ; 3 === this . counter _read _mode [ a ] && ( this . counter _next _low [ a ] ^= 1 ) } ;
qa . 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 && A ( 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 ] ] ) ) ) } ; qa . prototype . dump = function ( ) { } ; var ra = Uint32Array . from ( [ 655360 , 655360 , 720896 , 753664 ] ) , ua = Uint32Array . from ( [ 131072 , 65536 , 32768 , 32768 ] ) ;
function M ( a , b , c ) { this . cpu = a ; this . bus = b ; this . vga _memory _size = c ; 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 = this . horizontal _blank _start =
this . horizontal _display _enable _end = this . crtc _mode = 0 ; this . graphical _mode _is _linear = ! 0 ; this . graphical _mode = ! 1 ; setTimeout ( ( ) => { b . send ( "screen-set-mode" , this . graphical _mode ) } , 0 ) ; 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 = this . svga _bank _offset = 0 ; 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 : c } ] ; this . pci _rom _size = 65536 ; this . pci _rom _address = 4272947200 ; this . name = "vga" ; this . stats = { is _graphical : ! 1 , res _x : 0 , res _y : 0 , bpp : 0 } ; 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 = 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 ; c = a . io ; c . register _write ( 960 , this , this . port3C0 _write ) ; c . register _read ( 960 , this , this . port3C0 _read ,
this . port3C0 _read16 ) ; c . register _read ( 961 , this , this . port3C1 _read ) ; c . register _write ( 962 , this , this . port3C2 _write ) ; c . register _write _consecutive ( 964 , this , this . port3C4 _write , this . port3C5 _write ) ; c . register _read ( 964 , this , this . port3C4 _read ) ; c . register _read ( 965 , this , this . port3C5 _read ) ; c . register _write _consecutive ( 974 , this , this . port3CE _write , this . port3CF _write ) ; c . register _read ( 974 , this , this . port3CE _read ) ; c . register _read ( 975 , this , this . port3CF _read ) ; c . register _read ( 966 , this , this . port3C6 _read ) ; c . register _write ( 966 ,
this , this . port3C6 _write ) ; c . register _write ( 967 , this , this . port3C7 _write ) ; c . register _read ( 967 , this , this . port3C7 _read ) ; c . register _write ( 968 , this , this . port3C8 _write ) ; c . register _read ( 968 , this , this . port3C8 _read ) ; c . register _write ( 969 , this , this . port3C9 _write ) ; c . register _read ( 969 , this , this . port3C9 _read ) ; c . register _read ( 972 , this , this . port3CC _read ) ; c . register _write _consecutive ( 980 , this , this . port3D4 _write , this . port3D5 _write ) ; c . register _read ( 980 , this , this . port3D4 _read ) ; c . register _read ( 981 , this , this . port3D5 _read ,
( ) => this . port3D5 _read ( ) ) ; c . register _read ( 970 , this , function ( ) { return 0 } ) ; c . register _read ( 986 , this , this . port3DA _read ) ; c . register _read ( 954 , this , this . port3DA _read ) ; this . dispi _index = - 1 ; this . dispi _enable _value = 0 ; c . register _write ( 462 , this , void 0 , this . port1CE _write ) ; c . register _write ( 463 , this , void 0 , this . port1CF _write ) ; c . register _read ( 463 , this , void 0 , this . port1CF _read ) ; void 0 === this . vga _memory _size || 262144 > this . vga _memory _size ? this . vga _memory _size = 262144 : 268435456 < this . vga _memory _size ? this . vga _memory _size =
268435456 : this . vga _memory _size & 65535 && ( this . vga _memory _size |= 65535 , this . vga _memory _size ++ ) ; const d = a . svga _allocate _memory ( this . vga _memory _size ) >>> 0 ; this . svga _memory = r . view ( Uint8Array , a . wasm _memory , d , 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 = 0 ; this . image _data = null ; b . register ( "screen-fill-buffer" , function ( ) { this . screen _fill _buffer ( ) } , this ) ; 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 ) ; var e = this ; c . mmap _register ( 655360 , 131072 , function ( g ) { return e . vga _memory _read ( g ) } , function ( g , f ) { e . vga _memory _write ( g , f ) } ) ; a . devices . pci . register _device ( this ) }
M . 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 ;
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 ;
a [ 38 ] = this . dispi _enable _value ; a [ 39 ] = this . svga _memory ; a [ 40 ] = this . graphical _mode _is _linear ; 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 ; 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 ; return a } ;
M . 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 =
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 =
a [ 37 ] ; this . dispi _enable _value = a [ 38 ] ; this . svga _memory . set ( a [ 39 ] ) ; this . graphical _mode _is _linear = a [ 40 ] ; 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 = 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 . bus . send ( "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 _bpp , this . svga _width , this . svga _height ) ,
this . update _layers ( ) ) : ( this . update _vga _size ( ) , this . update _layers ( ) , this . complete _replot ( ) ) ) : ( this . set _size _text ( this . max _cols , this . max _rows ) , this . update _cursor _scanline ( ) , this . update _cursor ( ) ) ; this . complete _redraw ( ) } ;
M . prototype . vga _memory _read = function ( a ) { if ( this . svga _enabled && this . graphical _mode _is _linear ) return this . cpu . read8 ( ( a - 655360 | this . svga _bank _offset ) + 3758096384 | 0 ) ; var b = this . miscellaneous _graphics _register >> 2 & 3 ; a -= ra [ b ] ; if ( 0 > a || a >= ua [ b ] ) return A ( 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 ] ^ ~ ( 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 = 0 ; return this . vga _memory [ b << 16 | a ] } ;
M . prototype . vga _memory _write = function ( a , b ) { if ( this . svga _enabled && this . graphical _mode && this . graphical _mode _is _linear ) this . cpu . write8 ( ( a - 655360 | this . svga _bank _offset ) + 3758096384 | 0 , b ) ; else { var c = this . miscellaneous _graphics _register >> 2 & 3 ; a -= ra [ c ] ; 0 > a || a >= ua [ c ] ? ( A ( a ) , A ( b ) ) : this . graphical _mode ? this . vga _memory _write _graphical ( a , b ) : this . plane _write _bm & 3 && this . vga _memory _write _text _mode ( a , b ) } } ;
M . 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 ) } ; M . prototype . apply _feed = function ( a ) { return a | a << 8 | a << 16 | a << 24 } ;
M . 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 } ; M . prototype . apply _rotate = function ( a ) { return ( a | a << 8 ) >>> ( this . planar _rotate _reg & 7 ) & 255 } ; M . prototype . apply _setreset = function ( a , b ) { var c = this . apply _expand ( this . planar _setreset ) ; return ( a | b & c ) & ( ~ b | c ) } ; M . 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 } ; M . prototype . apply _bitmask = function ( a , b ) { return b & a | ~ b & this . latch _dword } ;
M . prototype . text _mode _redraw = function ( ) { var a = this . start _address << 1 ; const b = this . scan _line _to _screen _row ( this . line _compare ) , c = Math . max ( 0 , 2 * ( 2 * this . offset _register - this . max _cols ) ) ; for ( var d = 0 ; d < this . max _rows ; d ++ ) { d === b && ( a = 0 ) ; for ( var e = 0 ; e < this . max _cols ; e ++ ) { var g = this . vga _memory [ a ] ; var f = this . vga _memory [ a | 1 ] ; this . bus . send ( "screen-put-char" , [ d , e , g , this . vga256 _palette [ this . dac _mask & this . dac _map [ f >> 4 & 15 ] ] , this . vga256 _palette [ this . dac _mask & this . dac _map [ f & 15 ] ] ] ) ; a += 2 } a += c } } ;
M . prototype . vga _memory _write _text _mode = function ( 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 ) ) { if ( a & 1 ) { var g = b ; e = this . vga _memory [ a & - 2 ] } else e = b , g = this . vga _memory [ a | 1 ] ; this . bus . send ( "screen-put-char" , [ d , c , e , this . vga256 _palette [ this . dac _mask & this . dac _map [ g >> 4 & 15 ] ] , this . vga256 _palette [ this . dac _mask &
this . dac _map [ g & 15 ] ] ] ) ; this . vga _memory [ a ] = b } } ; M . 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 ) ; b = Math . min ( this . max _rows - 1 , b ) ; a = Math . min ( this . max _cols - 1 , a ) ; this . bus . send ( "screen-update-cursor" , [ b , a ] ) } ;
M . 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 ( ) } ; M . prototype . complete _replot = function ( ) { this . graphical _mode && ! this . svga _enabled && ( this . diff _plot _min = 0 , this . diff _plot _max = 524288 , this . complete _redraw ( ) ) } ; M . 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 ) } ;
M . 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 ) } ; M . 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 } ; M . prototype . destroy = function ( ) { } ; M . 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 } ;
M . 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 } ;
M . 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 } ;
M . 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 } ; M . prototype . set _size _text = function ( a , b ) { this . max _cols = a ; this . max _rows = b ; this . bus . send ( "screen-set-size-text" , [ a , b ] ) } ;
M . prototype . set _size _graphical = function ( a , b , c , d , e ) { if ( ! this . stats . is _graphical || this . stats . bpp !== c || this . screen _width !== a || this . screen _height !== b || this . virtual _width !== d || this . virtual _height !== e ) { this . screen _width = a ; this . screen _height = b ; this . virtual _width = d ; this . virtual _height = e ; this . stats . bpp = c ; this . stats . is _graphical = ! 0 ; this . stats . res _x = a ; this . stats . res _y = b ; if ( "undefined" !== typeof ImageData ) { const g = d * e , 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 ) , d , e ) ; this . cpu . svga _mark _dirty ( ) } this . bus . send ( "screen-set-size-graphical" , [ a , b , d , e , c ] ) } } ;
M . 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 = Math . ceil ( ua [ 0 ] / this . vga _bytes _per _line ( ) ) ; this . set _size _graphical ( a , b , 8 , c , d ) ; this . update _vertical _retrace ( ) ; this . update _layers ( ) } else this . max _scan _line &
128 && ( b >>>= 1 ) , c = b / ( 1 + ( this . max _scan _line & 31 ) ) | 0 , a && c && this . set _size _text ( a , c ) } } ;
M . 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 . bus . send ( "screen-clear" ) ; 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 ) ; 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 } ) } } ; M . 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 ( ) ) } ; M . prototype . update _cursor _scanline = function ( ) { this . bus . send ( "screen-update-cursor-scanline" , [ this . cursor _scanline _start , this . cursor _scanline _end ] ) } ;
M . prototype . port3C0 _write = function ( a ) { if ( - 1 === this . attribute _controller _index ) A ( a ) , this . attribute _controller _index = a & 31 , A ( this . attribute _controller _index ) , this . palette _source !== ( a & 32 ) && ( this . palette _source = a & 32 , this . update _layers ( ) ) ; else { if ( 16 > this . attribute _controller _index ) A ( this . attribute _controller _index ) , A ( a ) , this . dac _map [ this . attribute _controller _index ] = a , this . attribute _mode & 64 || this . complete _redraw ( ) ; else switch ( this . attribute _controller _index ) { case 16 : A ( a ) ; if ( this . attribute _mode !== a ) { var b =
this . attribute _mode ; this . attribute _mode = a ; var c = 0 < ( a & 1 ) ; this . svga _enabled || this . graphical _mode === c || ( this . graphical _mode = c , this . bus . send ( "screen-set-mode" , this . graphical _mode ) ) ; ( b ^ a ) & 64 && this . complete _replot ( ) ; this . update _vga _size ( ) ; this . complete _redraw ( ) } break ; case 18 : A ( a ) ; this . color _plane _enable !== a && ( this . color _plane _enable = a , this . complete _redraw ( ) ) ; break ; case 19 : A ( a ) ; this . horizontal _panning !== a && ( this . horizontal _panning = a & 15 , this . update _layers ( ) ) ; break ; case 20 : A ( a ) ; this . color _select !== a && ( this . color _select =
a , this . complete _redraw ( ) ) ; break ; default : A ( this . attribute _controller _index ) , A ( a ) } this . attribute _controller _index = - 1 } } ; M . prototype . port3C0 _read = function ( ) { return ( this . attribute _controller _index | this . palette _source ) & 255 } ; M . prototype . port3C0 _read16 = function ( ) { return this . port3C0 _read ( ) | this . port3C1 _read ( ) << 8 & 65280 } ;
M . prototype . port3C1 _read = function ( ) { if ( 16 > this . attribute _controller _index ) return A ( this . attribute _controller _index ) , A ( this . dac _map [ this . attribute _controller _index ] ) , this . dac _map [ this . attribute _controller _index ] & 255 ; switch ( this . attribute _controller _index ) { case 16 : return A ( this . attribute _mode ) , this . attribute _mode ; case 18 : return A ( this . color _plane _enable ) , this . color _plane _enable ; case 19 : return A ( this . horizontal _panning ) , this . horizontal _panning ; case 20 : return A ( this . color _select ) , this . color _select ; default : A ( this . attribute _controller _index ) } return 255 } ;
M . prototype . port3C2 _write = function ( a ) { A ( a ) ; this . miscellaneous _output _register = a } ; M . prototype . port3C4 _write = function ( a ) { this . sequencer _index = a } ; M . prototype . port3C4 _read = function ( ) { return this . sequencer _index } ; M . prototype . port3C5 _write = function ( a ) { switch ( this . sequencer _index ) { case 1 : A ( a ) ; var b = this . clocking _mode ; this . clocking _mode = a ; ( b ^ a ) & 32 && this . update _layers ( ) ; break ; case 2 : A ( a ) ; this . plane _write _bm = a ; break ; case 4 : A ( a ) ; this . sequencer _memory _mode = a ; break ; default : A ( this . sequencer _index ) , A ( a ) } } ;
M . prototype . port3C5 _read = function ( ) { A ( this . sequencer _index ) ; switch ( this . sequencer _index ) { case 1 : return this . clocking _mode ; case 2 : return this . plane _write _bm ; case 4 : return this . sequencer _memory _mode ; case 6 : return 18 } return 0 } ; M . prototype . port3C6 _write = function ( a ) { this . dac _mask = a } ; M . prototype . port3C6 _read = function ( ) { return this . dac _mask } ; M . prototype . port3C7 _write = function ( a ) { A ( a ) ; this . dac _color _index _read = 3 * a ; this . dac _state &= 0 } ; M . prototype . port3C7 _read = function ( ) { return this . dac _state } ;
M . prototype . port3C8 _write = function ( a ) { this . dac _color _index _write = 3 * a ; this . dac _state |= 3 } ; M . prototype . port3C8 _read = function ( ) { return this . dac _color _index _write / 3 & 255 } ;
M . 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 , A ( b ) , A ( d ) ) ; this . vga256 _palette [ b ] !== d && ( this . vga256 _palette [ b ] = d , this . complete _redraw ( ) ) ; this . dac _color _index _write ++ } ;
M . 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 } ; M . prototype . port3CC _read = function ( ) { return this . miscellaneous _output _register } ; M . prototype . port3CE _write = function ( a ) { this . graphics _index = a } ; M . prototype . port3CE _read = function ( ) { return this . graphics _index } ;
M . prototype . port3CF _write = function ( a ) { switch ( this . graphics _index ) { case 0 : this . planar _setreset = a ; A ( a ) ; break ; case 1 : this . planar _setreset _enable = a ; A ( a ) ; break ; case 2 : this . color _compare = a ; A ( a ) ; break ; case 3 : this . planar _rotate _reg = a ; A ( a ) ; break ; case 4 : this . plane _read = a ; A ( a ) ; break ; case 5 : var b = this . planar _mode ; this . planar _mode = a ; A ( a ) ; ( b ^ a ) & 96 && this . complete _replot ( ) ; break ; case 6 : A ( a ) ; this . miscellaneous _graphics _register !== a && ( this . miscellaneous _graphics _register = a , this . update _vga _size ( ) ) ; break ; case 7 : this . color _dont _care =
a ; A ( a ) ; break ; case 8 : this . planar _bitmap = a ; A ( a ) ; break ; default : A ( this . graphics _index ) , A ( a ) } } ; M . prototype . port3CF _read = function ( ) { A ( 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 } ;
M . prototype . port3D4 _write = function ( a ) { this . index _crtc = a } ; M . prototype . port3D4 _read = function ( ) { return this . index _crtc } ;
M . prototype . port3D5 _write = function ( a ) { switch ( this . index _crtc ) { case 1 : A ( 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 : A ( 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 : A ( a ) ; this . preset _row _scan = a ; this . update _layers ( ) ; break ; case 9 : A ( a ) ; 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 ; b !== this . vertical _blank _start && this . update _vga _size ( ) ;
this . update _layers ( ) ; break ; case 10 : A ( a ) ; this . cursor _scanline _start = a ; this . update _cursor _scanline ( ) ; break ; case 11 : A ( 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 ( ) ) ; A ( a ) ; A ( 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 ( ) ) ;
A ( a ) ; A ( this . start _address , 4 ) ; break ; case 14 : A ( a ) ; this . cursor _address = this . cursor _address & 255 | a << 8 ; this . update _cursor ( ) ; break ; case 15 : A ( a ) ; this . cursor _address = this . cursor _address & 65280 | a ; this . update _cursor ( ) ; break ; case 18 : A ( 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 : A ( a ) ; this . offset _register !== a && ( this . offset _register = a , this . update _vga _size ( ) , ~ this . crtc _mode & 3 && this . complete _replot ( ) ) ;
break ; case 20 : A ( 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 : A ( a ) ; ( this . vertical _blank _start & 255 ) !== a && ( this . vertical _blank _start = this . vertical _blank _start & 768 | a , this . update _vga _size ( ) ) ; break ; case 23 : A ( 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 : A ( 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 ) , A ( this . index _crtc ) , A ( a ) } } ;
M . prototype . port3D5 _read = function ( ) { A ( 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 ;
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 } ;
M . 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 } ; M . prototype . port1CE _write = function ( a ) { this . dispi _index = a } ;
M . prototype . port1CF _write = function ( a ) { A ( this . dispi _index ) ; A ( a ) ; switch ( this . dispi _index ) { case 0 : 45248 <= a && 45253 >= a ? this . svga _version = a : A ( 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 ) ; this . dispi _enable _value = a ; break ; case 5 : A ( a << 16 ) ; this . svga _bank _offset = a << 16 ; break ; case 9 : const b = a * this . svga _width ; A ( b ) ; A ( a ) ; this . svga _offset _y !==
a && ( this . svga _offset _y = a , this . svga _offset = b , this . complete _redraw ( ) ) ; break ; default : A ( this . dispi _index ) } ! this . svga _enabled || this . svga _width && this . svga _height || ( this . svga _enabled = ! 1 ) ; this . svga _enabled && 4 === this . dispi _index && ( this . set _size _graphical ( this . svga _width , this . svga _height , this . svga _bpp , this . svga _width , this . svga _height ) , this . bus . send ( "screen-set-mode" , ! 0 ) , this . graphical _mode _is _linear = this . graphical _mode = ! 0 ) ; this . svga _enabled || ( this . svga _bank _offset = 0 ) ; this . update _layers ( ) } ;
M . prototype . port1CF _read = function ( ) { A ( this . dispi _index ) ; return this . svga _register _read ( this . dispi _index ) } ;
M . 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 0 ; case 9 : return this . svga _offset _y ; case 10 : return this . vga _memory _size / 65536 | 0 ; default : A ( this . dispi _index ) } return 255 } ;
M . 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 ++ ,
a ++ ) this . pixel _buffer [ a ] = f [ p ] } } ;
M . 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 } ;
M . 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 ) ,
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 . bus . send ( "screen-fill-buffer-end" , [ { 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 . bus . send ( "screen-fill-buffer-end" , this . layers ) ; this . reset _diffs ( ) } this . update _vertical _retrace ( ) } ; function N ( 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 ka ( 1024 ) ; this . last _port60 _byte = 0 ; this . sample _rate = 100 ; this . mouse _id = this . mouse _detect _state = 0 ; this . mouse _reset _workaround = ! 1 ;
this . wheel _movement = 0 ; this . resolution = 4 ; this . scaling2 = ! 1 ; this . last _mouse _packet = - 1 ; this . mouse _buffer = new ka ( 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 -=
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 ) }
N . 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 ;
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 } ;
N . 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 ] ;
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 ) } ;
N . prototype . raise _irq = function ( ) { this . next _byte _is _ready || ( this . kbd _buffer . length ? this . kbd _irq ( ) : this . mouse _buffer . length && this . mouse _irq ( ) ) } ; N . 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 ) ) } ; N . 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 ) ) } ;
N . prototype . kbd _send _code = function ( a ) { this . enable _keyboard _stream && ( A ( a ) , this . kbd _buffer . push ( a ) , this . raise _irq ( ) ) } ; N . 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 ) ) } } ;
N . 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 ) ) } ;
N . 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 ( ) } ;
N . 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 } } ;
N . 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 ( ) ) ; A ( this . last _port60 _byte ) ; ( this . kbd _buffer . length || this . mouse _buffer . length ) && this . raise _irq ( ) ; return this . last _port60 _byte } ;
N . prototype . port64 _read = function ( ) { var a = 16 ; this . next _byte _is _ready && ( a |= 1 ) ; this . next _byte _is _aux && ( a |= 32 ) ; A ( a ) ; return a } ;
N . prototype . port60 _write = function ( a ) { A ( a ) ; if ( this . read _command _register ) this . command _register = a , this . read _command _register = ! 1 , A ( 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 } A ( a ) ; A ( 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 ( 2 ) ; 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 , A ( 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 : A ( 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 ) ;
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 =
0 ; break ; default : A ( a ) } this . mouse _irq ( ) } } else if ( this . read _controller _output _port ) this . read _controller _output _port = ! 1 , this . controller _output _port = a ; else { A ( 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 ( 83 ) ; 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 : A ( a ) } this . kbd _irq ( ) } } ;
N . prototype . port64 _write = function ( a ) { A ( 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 : A ( a ) } } ; function va ( 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 ) }
va . 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 } ;
va . 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 ] } ;
va . 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 } ; va . 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 } ; va . prototype . bcd _unpack = function ( a ) { return ( a & 15 ) + 10 * ( a >> 4 & 15 ) } ; va . prototype . encode _time = function ( a ) { return this . cmos _b & 4 ? a : this . bcd _pack ( a ) } ; va . prototype . decode _time = function ( a ) { return this . cmos _b & 4 ? a : this . bcd _unpack ( a ) } ;
va . prototype . cmos _port _read = function ( ) { var a = this . cmos _index ; switch ( a ) { case 0 : return this . encode _time ( ( new Date ( this . rtc _time ) ) . getUTCSeconds ( ) ) ; case 2 : return this . encode _time ( ( new Date ( this . rtc _time ) ) . getUTCMinutes ( ) ) ; case 4 : return this . encode _time ( ( new Date ( this . rtc _time ) ) . getUTCHours ( ) ) ; case 7 : return this . encode _time ( ( new Date ( this . rtc _time ) ) . getUTCDate ( ) ) ; case 8 : return this . encode _time ( ( new Date ( this . rtc _time ) ) . getUTCMonth ( ) + 1 ) ; case 9 : return 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 : return this . encode _time ( ( new Date ( this . rtc _time ) ) . getUTCFullYear ( ) / 100 | 0 ) ; default : return A ( a ) , this . cmos _data [ this . cmos _index ] } } ;
va . 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 ) ; A ( 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 ) ) } A ( this . cmos _b ,
2 ) ; break ; case 1 : case 3 : case 5 : this . cmos _write ( this . cmos _index , a ) ; break ; default : A ( this . cmos _index ) , A ( a ) } this . periodic _interrupt = 64 === ( this . cmos _b & 64 ) && 0 < ( this . cmos _a & 15 ) } ; va . prototype . cmos _read = function ( a ) { return this . cmos _data [ a ] } ; va . prototype . cmos _write = function ( a , b ) { A ( a ) ; A ( b ) ; this . cmos _data [ a ] = b } ; function wa ( 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 : J ( "Invalid serial port: " + A ( b ) , 16384 ) , this . com = 0 , this . irq = 4 } this . bus . register ( "serial" + this . com +
"-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" ,
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 , A ( this . baud _rate ) ) : ( 0 === ( this . ier & 2 ) && d & 2 && this . ThrowInterrupt ( 2 ) ,
this . ier = d & 15 , A ( 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 ( ) , A ( 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 ; A ( this . iir ) ; 2 == this . iir && this . ClearInterrupt ( 2 ) ; this . fifo _control &
1 && ( d |= 192 ) ; return d } ) ; a . register _write ( b | 2 , this , function ( d ) { A ( d ) ; this . fifo _control = d } ) ; a . register _read ( b | 3 , this , function ( ) { A ( this . line _control ) ; return this . line _control } ) ; a . register _write ( b | 3 , this , function ( d ) { A ( d ) ; this . line _control = d } ) ; a . register _read ( b | 4 , this , function ( ) { return this . modem _control } ) ; a . register _write ( b | 4 , this , function ( d ) { A ( d ) ; this . modem _control = d } ) ; a . register _read ( b | 5 , this , function ( ) { A ( this . lsr ) ; return this . lsr } ) ; a . register _write ( b | 5 , this , function ( ) { } ) ; a . register _read ( b | 6 , this , function ( ) { A ( this . modem _status ) ;
return this . modem _status &= 240 } ) ; a . register _write ( b | 6 , this , function ( d ) { A ( 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 } ) } wa . 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 } ;
wa . 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 ] } ;
wa . 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 ) ) } ; wa . prototype . ThrowInterrupt = function ( a ) { this . ints |= 1 << a ; this . CheckInterrupt ( ) } ;
wa . prototype . ClearInterrupt = function ( a ) { this . ints &= ~ ( 1 << a ) ; this . CheckInterrupt ( ) } ; wa . prototype . data _received = function ( a ) { A ( a ) ; this . input . push ( a ) ; this . lsr |= 1 ; this . fifo _control & 1 ? this . ThrowInterrupt ( 12 ) : this . ThrowInterrupt ( 4 ) } ; wa . prototype . write _data = function ( a ) { this . line _control & 128 ? this . baud _rate = this . baud _rate & - 256 | a : ( A ( a ) , this . ThrowInterrupt ( 2 ) , this . bus . send ( "serial" + this . com + "-output-byte" , a ) ) } ;
wa . prototype . set _modem _status = function ( a ) { A ( 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 xa ( 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 ) { A ( 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 ) { A ( 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 ) { A ( 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 ) { A ( c ) ; this . gpe [ 0 ] = c } ) ; b . register _write ( 45025 , this , function ( c ) { A ( c ) ; this . gpe [ 1 ] = c } ) ; b . register _write ( 45026 , this , function ( c ) { A ( c ) ; this . gpe [ 2 ] = c } ) ; b . register _write ( 45027 , this , function ( c ) { A ( c ) ; this . gpe [ 3 ] = c } ) }
xa . 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 } ;
xa . 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 } ; xa . 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 } ;
xa . prototype . set _state = function ( a ) { this . status = a [ 0 ] ; this . pm1 _status = a [ 1 ] ; this . pm1 _enable = a [ 2 ] ; this . gpe = a [ 3 ] } ; function O ( 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 => { A ( b >>> 0 ) ; var c = b & 3 ; return this . read32 ( b & - 4 ) >> 8 * c & 255 } , ( b , c ) => { A ( b ) ; A ( c ) } , b => this . read32 ( b ) , ( b , c ) => this . write32 ( b , c ) ) }
O . 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 , A ( 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 , A ( 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 , A ( this . irr [ a ] >>> 0 , 8 ) , this . irr [ a ] ; case 640 : return A ( 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 A ( this . timer _current _count >>> 0 , 8 ) , this . timer _current _count ; default : return A ( a ) , 0 } } ;
O . prototype . write32 = function ( a , b ) { a = a - 4276092928 | 0 ; switch ( a ) { case 48 : A ( 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 : A ( b >>> 0 , 8 ) ; this . local _destination = b & 4278190080 ; break ; case 224 : A ( b >>> 0 , 8 ) ; this . destination _format = b | 16777215 ; break ; case 240 : A ( b >>> 0 , 8 ) ; this . spurious _vector = b ; break ; case 640 : A ( 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 ; A ( b , 8 ) ; A ( 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 : A ( b >>> 0 , 8 ) ; this . icr1 = b ; break ; case 800 : A ( b >>> 0 , 8 ) ; this . lvt _timer = b ; break ; case 832 : A ( b >>> 0 , 8 ) ; this . lvt _perf _counter = b ; break ; case 848 : A ( b >>> 0 , 8 ) ; this . lvt _int0 = b ; break ; case 864 : A ( b >>> 0 , 8 ) ; this . lvt _int1 = b ; break ; case 880 : A ( b >>> 0 , 8 ) ; this . lvt _error = b ; break ; case 992 : A ( 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 : A ( 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 : A ( b >>> 0 , 8 ) ; break ; default : A ( a ) , A ( b >>> 0 , 8 ) } } ;
O . 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 &
65536 ) && this . deliver ( this . lvt _timer & 255 , 0 , ! 1 ) ) ) ; return Math . max ( 0 , this . timer _current _count / b ) } ; O . prototype . route = function ( a , b , c ) { this . deliver ( a , b , c ) } ; O . prototype . deliver = function ( a , b , c ) { 5 !== b && 4 !== b && ( this . register _get _bit ( this . irr , a ) ? A ( 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 ( ) ) ) } ; O . prototype . highest _irr = function ( ) { return this . register _get _highest _bit ( this . irr ) } ; O . prototype . highest _isr = function ( ) { return this . register _get _highest _bit ( this . isr ) } ;
O . prototype . check _vector = function ( ) { var a = this . highest _irr ( ) ; - 1 !== a && ( this . highest _isr ( ) >= a || ( a & 240 ) <= ( this . tpr & 240 ) || this . cpu . handle _irqs ( ) ) } ; O . 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 } ;
O . 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 ] =
this . read _error ; return a } ;
O . 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 =
a [ 21 ] } ; O . prototype . register _get _bit = function ( a , b ) { return a [ b >> 5 ] >> ( b & 31 ) & 1 } ; O . prototype . register _set _bit = function ( a , b ) { a [ b >> 5 ] |= 1 << ( b & 31 ) } ; O . prototype . register _clear _bit = function ( a , b ) { a [ b >> 5 ] &= ~ ( 1 << ( b & 31 ) ) } ; O . prototype . register _get _highest _bit = function ( a ) { for ( var b = 7 ; 0 <= b ; b -- ) { var c = a [ b ] ; if ( c ) return r . int _log2 ( c >>> 0 ) | b << 5 } return - 1 } ; function ya ( 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 , A ( this . ioregsel ) , this . read ( this . ioregsel ) >> 8 * c & 255 ; A ( c >>> 0 ) ; return 0 } , c => { A ( c >>> 0 ) } , c => { c = c - 4273995776 | 0 ; if ( 0 === c ) return this . ioregsel ; if ( 16 === c ) return this . read ( this . ioregsel ) ;
A ( c >>> 0 ) ; return 0 } , ( c , d ) => { c = c - 4273995776 | 0 ; 0 === c ? this . ioregsel = d : 16 === c ? this . write ( this . ioregsel , d ) : ( A ( c >>> 0 ) , A ( d >>> 0 , 8 ) ) } ) } ya . prototype . remote _eoi = function ( a ) { for ( var b = 0 ; 24 > b ; b ++ ) { var c = this . ioredtbl _config [ b ] ; ( c & 255 ) === a && c & 16384 && ( A ( b ) , this . ioredtbl _config [ b ] &= - 16385 , this . check _irq ( b ) ) } } ;
ya . 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 } } } ;
ya . 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 ) ) ) } } ; ya . 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 ) ) } } ;
ya . 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 ] ; A ( b ) ; A ( a , 8 ) ; return a } A ( a ) ; return 0 } ;
ya . 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 , A ( b >>> 0 , 8 ) , A ( c ) , A ( b >>> 24 , 2 ) ) : ( this . ioredtbl _config [ c ] = b & 110591 | this . ioredtbl _config [ c ] & - 110592 , a = b & 255 , A ( b >>> 0 , 8 ) , A ( c ) , A ( a , 2 ) , this . check _irq ( c ) ) } else A ( a ) , A ( b >>> 0 , 8 ) } ;
ya . 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 } ; ya . 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 za ( a ) { this . message = a } za . prototype = Error ( ) ; const Aa = { Uint8Array , Int8Array , Uint16Array , Int16Array , Uint32Array , Int32Array , Float32Array , Float64Array } ;
function Ba ( a , b ) { if ( "object" !== typeof a || null === a ) return a ; if ( a instanceof Array ) return a . map ( e => Ba ( 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 ] = Ba ( a [ d ] , b ) ; return c }
function Ca ( a , b ) { if ( "object" !== typeof a || null === a ) return a ; if ( a instanceof Array ) { for ( let c = 0 ; c < a . length ; c ++ ) a [ c ] = Ca ( a [ c ] , b ) ; return a } return new Aa [ a . _ _state _type _ _ ] ( b [ a . buffer _id ] ) }
E . prototype . save _state = function ( ) { for ( var a = [ ] , b = Ba ( 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 } ;
E . prototype . restore _state = function ( a ) { function b ( p , t ) { const q = p . length ; if ( 16 > q ) throw new za ( "Invalid length: " + q ) ; p = new Int32Array ( p . buffer , p . byteOffset , 4 ) ; if ( - 2039052682 !== p [ 0 ] ) throw new za ( "Invalid header: " + A ( p [ 0 ] >>> 0 ) ) ; if ( 6 !== p [ 1 ] ) throw new za ( "Version mismatch: dump=" + p [ 1 ] + " we=6" ) ; if ( t && p [ 2 ] !== q ) throw new za ( "Length doesn't match header: real=" + q + " 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 ) , t = this . zstd _read ( d , p ) ; m . set ( new Uint8Array ( this . wasm _memory . buffer , t , p ) , n ) ; this . zstd _read _free ( t , 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 = Ca ( 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 za ( "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 ( t => { const q = p + t . offset ; return a . buffer . slice ( q , q + t . length ) } ) ; l = Ca ( l , d ) ; this . set _state ( l ) } } ; function Da ( 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 ] ; A ( 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 ) A ( 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 =
a . subarray ( 14 ) , Ea ( a . subarray ( 8 , 14 ) ) , Ea ( 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 Ea ( 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 Fa ( a , b , c , d ) { this . cpu = a ; this . pci = a . devices . pci ; this . preserve _mac _from _state _image = c ; this . mac _address _translation = d ; this . bus = b ; this . bus . register ( "net0-receive" , function ( e ) { this . receive ( e ) } , this ) ; this . port = 768 ; 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 = 40 ; 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 . 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 ] = 87 ; J ( "Mac: " + Ea ( 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 ( e ) { this . cr = e ; A ( e , 2 ) ; A ( this . txcr , 2 ) ; this . cr & 1 || ( e & 24 && 0 === this . rcnt && this . do _interrupt ( 64 ) , e & 4 && ( e = this . tpsr << 8 , e = this . memory . subarray ( e , e + this . tcnt ) , this . mac _address _in _state && ( e = new Uint8Array ( e ) , Da ( e , this . mac _address _in _state , this . mac ) ) , this . bus . send ( "net0-send" , e ) , this . bus . send ( "eth-transmit-end" , [ e . length ] ) , this . cr &= - 5 , this . do _interrupt ( 2 ) , A ( e . 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 ( e ) { this . get _page ( ) ; A ( e , 2 ) } ) ; b . register _read ( this . port | 1 , this , function ( ) { var e = this . get _page ( ) ;
return 0 === e ? this . pstart : 1 === e ? this . mac [ 0 ] : 2 === e ? this . pstart : 0 } ) ; b . register _write ( this . port | 1 , this , function ( e ) { var g = this . get _page ( ) ; 0 === g ? ( A ( e , 2 ) , this . pstart = e ) : 1 === g ? ( A ( e ) , this . mac [ 0 ] = e ) : A ( e ) } ) ; b . register _read ( this . port | 2 , this , function ( ) { var e = this . get _page ( ) ; return 0 === e ? this . pstop : 1 === e ? this . mac [ 1 ] : 2 === e ? this . pstop : 0 } ) ; b . register _write ( this . port | 2 , this , function ( e ) { var g = this . get _page ( ) ; 0 === g ? ( A ( e , 2 ) , e > this . memory . length >> 8 && ( e = this . memory . length >> 8 , A ( e ) ) , this . pstop = e ) : 1 === g ? ( A ( e ) , this . mac [ 1 ] =
e ) : A ( e ) } ) ; b . register _read ( this . port | 7 , this , function ( ) { var e = this . get _page ( ) ; return 0 === e ? ( A ( this . isr , 2 ) , this . isr ) : 1 === e ? ( A ( this . curpg , 2 ) , this . curpg ) : 0 } ) ; b . register _write ( this . port | 7 , this , function ( e ) { var g = this . get _page ( ) ; 0 === g ? ( A ( e , 2 ) , this . isr &= ~ e , this . update _irq ( ) ) : 1 === g && ( A ( e , 2 ) , this . curpg = e ) } ) ; b . register _write ( this . port | 13 , this , function ( e ) { 0 === this . get _page ( ) && ( this . txcr = e ) ; A ( e , 2 ) } ) ; b . register _write ( this . port | 14 , this , function ( e ) { 0 === this . get _page ( ) ? ( A ( e , 2 ) , this . dcfg = e ) : A ( e , 2 ) } ) ; b . register _read ( this . port |
10 , this , function ( ) { var e = this . get _page ( ) ; return 0 === e ? 80 : 1 === e ? this . mar [ 2 ] : 0 } ) ; b . register _write ( this . port | 10 , this , function ( e ) { 0 === this . get _page ( ) ? ( A ( e , 2 ) , this . rcnt = this . rcnt & 65280 | e & 255 ) : A ( e , 2 ) } ) ; b . register _read ( this . port | 11 , this , function ( ) { var e = this . get _page ( ) ; return 0 === e ? 67 : 1 === e ? this . mar [ 3 ] : 0 } ) ; b . register _write ( this . port | 11 , this , function ( e ) { 0 === this . get _page ( ) ? ( A ( e , 2 ) , this . rcnt = this . rcnt & 255 | e << 8 & 65280 ) : A ( e , 2 ) } ) ; b . register _read ( this . port | 8 , this , function ( ) { var e = this . get _page ( ) ; return 0 === e ? this . rsar &
255 : 1 === e ? this . mar [ 0 ] : 0 } ) ; b . register _write ( this . port | 8 , this , function ( e ) { 0 === this . get _page ( ) ? ( A ( e , 2 ) , this . rsar = this . rsar & 65280 | e & 255 ) : A ( e , 2 ) } ) ; b . register _read ( this . port | 9 , this , function ( ) { var e = this . get _page ( ) ; return 0 === e ? this . rsar >> 8 & 255 : 1 === e ? this . mar [ 1 ] : 0 } ) ; b . register _write ( this . port | 9 , this , function ( e ) { 0 === this . get _page ( ) ? ( A ( e , 2 ) , this . rsar = this . rsar & 255 | e << 8 & 65280 ) : A ( e , 2 ) } ) ; b . register _write ( this . port | 15 , this , function ( e ) { 0 === this . get _page ( ) ? ( A ( e , 2 ) , A ( this . isr , 2 ) , this . imr = e , this . update _irq ( ) ) : A ( e ,
2 ) } ) ; b . register _read ( this . port | 3 , this , function ( ) { var e = this . get _page ( ) ; return 0 === e ? ( A ( this . boundary , 2 ) , this . boundary ) : 1 === e ? this . mac [ 2 ] : 0 } ) ; b . register _write ( this . port | 3 , this , function ( e ) { var g = this . get _page ( ) ; 0 === g ? ( A ( e , 2 ) , this . boundary = e ) : 1 === g ? ( A ( e ) , this . mac [ 2 ] = e ) : A ( e ) } ) ; b . register _read ( this . port | 4 , this , function ( ) { var e = this . get _page ( ) ; return 0 === e ? this . tsr : 1 === e ? this . mac [ 3 ] : 0 } ) ; b . register _write ( this . port | 4 , this , function ( e ) { var g = this . get _page ( ) ; 0 === g ? ( A ( e , 2 ) , this . tpsr = e ) : 1 === g ? ( A ( e ) , this . mac [ 3 ] =
e ) : A ( e ) } ) ; b . register _read ( this . port | 5 , this , function ( ) { var e = this . get _page ( ) ; return 0 === e ? 0 : 1 === e ? this . mac [ 4 ] : 0 } ) ; b . register _write ( this . port | 5 , this , function ( e ) { var g = this . get _page ( ) ; 0 === g ? ( A ( e , 2 ) , this . tcnt = this . tcnt & - 256 | e ) : 1 === g ? ( A ( e ) , this . mac [ 4 ] = e ) : A ( e ) } ) ; b . register _read ( this . port | 6 , this , function ( ) { var e = this . get _page ( ) ; return 0 === e ? 0 : 1 === e ? this . mac [ 5 ] : 0 } ) ; b . register _write ( this . port | 6 , this , function ( e ) { var g = this . get _page ( ) ; 0 === g ? ( A ( e , 2 ) , this . tcnt = this . tcnt & 255 | e << 8 ) : 1 === g ? ( A ( e ) , this . mac [ 5 ] = e ) : A ( e ) } ) ;
b . register _read ( this . port | 12 , this , function ( ) { var e = this . get _page ( ) ; return 0 === e ? 9 : 1 === e ? this . mar [ 4 ] : 0 } ) ; b . register _write ( this . port | 12 , this , function ( e ) { 0 === this . get _page ( ) ? ( A ( e , 2 ) , this . rxcr = e ) : A ( e ) } ) ; 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 ) }
Fa . 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 } ;
Fa . 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 ] , Ea ( this . mac _address _in _state ) , Ea ( this . mac ) ) } ;
Fa . prototype . do _interrupt = function ( a ) { A ( a , 2 ) ; this . isr |= a ; this . update _irq ( ) } ; Fa . prototype . update _irq = function ( ) { this . imr & this . isr ? this . pci . raise _irq ( this . pci _id ) : this . pci . lower _irq ( this . pci _id ) } ; Fa . 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 ) } ;
Fa . prototype . data _port _write16 = function ( a ) { this . data _port _write ( a ) ; this . dcfg & 1 && this . data _port _write ( a >> 8 ) } ; Fa . 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 ) } ; Fa . 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 } ;
Fa . prototype . data _port _read8 = function ( ) { return this . data _port _read16 ( ) & 255 } ; Fa . prototype . data _port _read16 = function ( ) { return this . dcfg & 1 ? this . data _port _read ( ) | this . data _port _read ( ) << 8 : this . data _port _read ( ) } ; Fa . 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 } ;
Fa . 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 ) , Da ( 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 +
( 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 ? ( A ( this . pstart ) , A ( this . pstop ) , A ( this . curpg ) , A ( f ) , A ( this . boundary ) , A ( 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 ) , A ( 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 , A ( b ) , A ( c ) , A ( e ) , this . do _interrupt ( 1 ) ) } } ; Fa . prototype . get _page = function ( ) { return this . cr >> 6 & 3 } ; var Ga = new Uint8Array ( 256 ) , Ha = [ ] , Ia = [ ] , Ja = [ ] , Ka = new Uint8Array ( 256 ) , La = [ ] ;
function Q ( a , b ) { this . cpu = a ; this . bus = b ; this . write _buffer = new ka ( 64 ) ; this . read _buffer = new ka ( 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 la ( 65536 ) , new la ( 65536 ) ] ; this . dma = a . devices . dma ; 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 _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 r . SyncBuffer ( this . dma _buffer ) ; this . dma _paused = this . dma _waiting _transfer = ! 1 ; this . sampling _rate = 22050 ; b . send ( "dac-tell-sampling-rate" ,
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 ka ( 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 ) ;
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 ( ) }
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 =
! 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 } ;
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 ] =
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 } ;
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 =
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 =
new Uint16Array ( this . dma _buffer ) ; this . dma _syncbuffer = new r . 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 ( ) ) ; A ( 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 ) { A ( a ) ; this . fm _current _address0 = 0 } ; Q . prototype . port2x1 _write = function ( a ) { A ( a ) ; var b = La [ 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 ) { A ( a ) ; this . fm _current _address1 = 0 } ; Q . prototype . port2x3 _write = function ( a ) { A ( a ) ; var b = La [ 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 ) { A ( a ) ; this . mixer _current _address = a } ; Q . prototype . port2x5 _write = function ( a ) { A ( a ) ; this . mixer _write ( this . mixer _current _address , a ) } ;
Q . prototype . port2x6 _write = function ( a ) { A ( 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 ? ( A ( a ) , this . command = a , this . write _buffer . clear ( ) , this . command _size = Ga [ a ] ) : ( A ( 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 ( ) ) ; A ( this . mpu _read _buffer _lastvalue ) ; return this . mpu _read _buffer _lastvalue } ; Q . prototype . port3x0 _write = function ( a ) { A ( a ) } ; Q . prototype . port3x1 _read = function ( ) { return 0 | 128 * ! this . mpu _read _buffer . length } ; Q . prototype . port3x1 _write = function ( a ) { A ( a ) ; 255 == a && ( this . mpu _read _buffer . clear ( ) , this . mpu _read _buffer . push ( 254 ) ) } ;
Q . prototype . command _do = function ( ) { var a = Ha [ 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 ( ) { A ( this . command ) } ; function R ( a , b , c ) { c || ( c = Q . prototype . dsp _default _handler ) ; for ( var d = 0 ; d < a . length ; d ++ ) Ga [ a [ d ] ] = b , Ha [ a [ d ] ] = c } function Ma ( a ) { for ( var b = [ ] , c = 0 ; 16 > c ; c ++ ) b . push ( a + c ) ; return b } R ( [ 14 ] , 2 , function ( ) { this . asp _registers [ this . write _buffer . shift ( ) ] = this . write _buffer . shift ( ) } ) ;
R ( [ 15 ] , 1 , function ( ) { this . read _buffer . clear ( ) ; this . read _buffer . push ( this . asp _registers [ this . write _buffer . shift ( ) ] ) } ) ; R ( [ 16 ] , 1 , function ( ) { var a = this . write _buffer . shift ( ) ; a = Na ( a / 127.5 + - 1 , - 1 , 1 ) ; this . dac _buffers [ 0 ] . push ( a ) ; this . dac _buffers [ 1 ] . push ( a ) ; this . bus . send ( "dac-enable" ) } ) ; R ( [ 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 ( ) } ) ; R ( [ 22 ] , 2 ) ; R ( [ 23 ] , 2 ) ;
R ( [ 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 ( ) } ) ; R ( [ 31 ] , 0 ) ; R ( [ 32 ] , 0 , function ( ) { this . read _buffer . clear ( ) ; this . read _buffer . push ( 127 ) } ) ; R ( [ 36 ] , 2 ) ; R ( [ 44 ] , 0 ) ; R ( [ 48 ] , 0 ) ; R ( [ 49 ] , 0 ) ; R ( [ 52 ] , 0 ) ; R ( [ 53 ] , 0 ) ; R ( [ 54 ] , 0 ) ; R ( [ 55 ] , 0 ) ; R ( [ 56 ] , 0 ) ; R ( [ 64 ] , 1 , function ( ) { this . sampling _rate _change ( 1E6 / ( 256 - this . write _buffer . shift ( ) ) / this . get _channel _count ( ) ) } ) ;
R ( [ 65 , 66 ] , 2 , function ( ) { this . sampling _rate _change ( this . write _buffer . shift ( ) << 8 | this . write _buffer . shift ( ) ) } ) ; R ( [ 72 ] , 2 , function ( ) { this . dma _transfer _size _set ( ) } ) ; R ( [ 116 ] , 2 ) ; R ( [ 117 ] , 2 ) ; R ( [ 118 ] , 2 ) ; R ( [ 119 ] , 2 ) ; R ( [ 125 ] , 0 ) ; R ( [ 127 ] , 0 ) ; R ( [ 128 ] , 2 ) ; R ( [ 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 ( ) } ) ; R ( [ 145 ] , 0 ) ; R ( [ 152 ] , 0 ) ; R ( [ 153 ] , 0 ) ; R ( [ 160 ] , 0 ) ; R ( [ 168 ] , 0 ) ;
R ( Ma ( 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 ( ) } } ) ;
R ( Ma ( 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 ( ) } } ) ; R ( [ 208 ] , 0 , function ( ) { this . dma _paused = ! 0 ; this . bus . send ( "dac-disable" ) } ) ; R ( [ 209 ] , 0 , function ( ) { this . dummy _speaker _enabled = ! 0 } ) ; R ( [ 211 ] , 0 , function ( ) { this . dummy _speaker _enabled = ! 1 } ) ;
R ( [ 212 ] , 0 , function ( ) { this . dma _paused = ! 1 ; this . bus . send ( "dac-enable" ) } ) ; R ( [ 213 ] , 0 , function ( ) { this . dma _paused = ! 0 ; this . bus . send ( "dac-disable" ) } ) ; R ( [ 214 ] , 0 , function ( ) { this . dma _paused = ! 1 ; this . bus . send ( "dac-enable" ) } ) ; R ( [ 216 ] , 0 , function ( ) { this . read _buffer . clear ( ) ; this . read _buffer . push ( 255 * this . dummy _speaker _enabled ) } ) ; R ( [ 217 , 218 ] , 0 , function ( ) { this . dma _autoinit = ! 1 } ) ; R ( [ 224 ] , 1 , function ( ) { this . read _buffer . clear ( ) ; this . read _buffer . push ( ~ this . write _buffer . shift ( ) ) } ) ;
R ( [ 225 ] , 0 , function ( ) { this . read _buffer . clear ( ) ; this . read _buffer . push ( 4 ) ; this . read _buffer . push ( 5 ) } ) ; R ( [ 226 ] , 1 ) ; R ( [ 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 ) } ) ; R ( [ 228 ] , 1 , function ( ) { this . test _register = this . write _buffer . shift ( ) } ) ; R ( [ 232 ] , 0 , function ( ) { this . read _buffer . clear ( ) ; this . read _buffer . push ( this . test _register ) } ) ; R ( [ 242 , 243 ] , 0 , function ( ) { this . raise _irq ( ) } ) ; var Oa = new Uint8Array ( 256 ) ;
Oa [ 14 ] = 255 ; Oa [ 15 ] = 7 ; Oa [ 55 ] = 56 ; R ( [ 249 ] , 1 , function ( ) { var a = this . write _buffer . shift ( ) ; this . read _buffer . clear ( ) ; this . read _buffer . push ( Oa [ a ] ) } ) ; Q . prototype . mixer _read = function ( a ) { var b = Ia [ a ] ; b ? b = b . call ( this ) : ( b = this . mixer _registers [ a ] , A ( a ) , A ( b ) ) ; return b } ; Q . prototype . mixer _write = function ( a , b ) { var c = Ja [ a ] ; c ? c . call ( this , b ) : ( A ( a ) , A ( b ) ) } ; Q . prototype . mixer _default _read = function ( ) { A ( this . mixer _current _address ) ; return this . mixer _registers [ this . mixer _current _address ] } ;
Q . prototype . mixer _default _write = function ( a ) { A ( this . mixer _current _address ) ; A ( a ) ; this . mixer _registers [ this . mixer _current _address ] = a } ;
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 ++ ) Ka [ a ] || this . mixer _write ( a , this . mixer _registers [ a ] ) } ;
function Pa ( a , b ) { b || ( b = Q . prototype . mixer _default _read ) ; Ia [ a ] = b } function Qa ( a , b ) { b || ( b = Q . prototype . mixer _default _write ) ; Ja [ a ] = b } function Sa ( a , b , c ) { Ka [ a ] = 1 ; Ia [ a ] = function ( ) { return this . mixer _registers [ b ] & 240 | this . mixer _registers [ c ] >>> 4 } ; Ja [ 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 ) } }
function Ta ( a , b , c ) { Ia [ a ] = Q . prototype . mixer _default _read ; Ja [ a ] = function ( d ) { this . mixer _registers [ a ] = d ; this . bus . send ( "mixer-volume" , [ b , c , ( d >>> 2 ) - 62 ] ) } } Pa ( 0 , function ( ) { this . mixer _reset ( ) ; return 0 } ) ; Qa ( 0 ) ; Sa ( 4 , 50 , 51 ) ; Sa ( 34 , 48 , 49 ) ; Sa ( 38 , 52 , 53 ) ; Sa ( 40 , 54 , 55 ) ; Sa ( 46 , 56 , 57 ) ; Ta ( 48 , 0 , 0 ) ; Ta ( 49 , 0 , 1 ) ; Ta ( 50 , 2 , 0 ) ; Ta ( 51 , 2 , 1 ) ; Pa ( 59 ) ; Qa ( 59 , function ( a ) { this . mixer _registers [ 59 ] = a ; this . bus . send ( "mixer-volume" , [ 1 , 2 , 6 * ( a >>> 6 ) - 18 ] ) } ) ; Pa ( 65 ) ;
Qa ( 65 , function ( a ) { this . mixer _registers [ 65 ] = a ; this . bus . send ( "mixer-gain-left" , 6 * ( a >>> 6 ) ) } ) ; Pa ( 66 ) ; Qa ( 66 , function ( a ) { this . mixer _registers [ 66 ] = a ; this . bus . send ( "mixer-gain-right" , 6 * ( a >>> 6 ) ) } ) ; Pa ( 68 ) ; Qa ( 68 , function ( a ) { this . mixer _registers [ 68 ] = a ; a >>>= 3 ; this . bus . send ( "mixer-treble-left" , a - ( 16 > a ? 14 : 16 ) ) } ) ; Pa ( 69 ) ; Qa ( 69 , function ( a ) { this . mixer _registers [ 69 ] = a ; a >>>= 3 ; this . bus . send ( "mixer-treble-right" , a - ( 16 > a ? 14 : 16 ) ) } ) ; Pa ( 70 ) ;
Qa ( 70 , function ( a ) { this . mixer _registers [ 70 ] = a ; a >>>= 3 ; this . bus . send ( "mixer-bass-right" , a - ( 16 > a ? 14 : 16 ) ) } ) ; Pa ( 71 ) ; Qa ( 71 , function ( a ) { this . mixer _registers [ 71 ] = a ; a >>>= 3 ; this . bus . send ( "mixer-bass-right" , a - ( 16 > a ? 14 : 16 ) ) } ) ; Pa ( 128 , function ( ) { switch ( this . irq ) { case 2 : return 1 ; case 5 : return 2 ; case 7 : return 4 ; case 10 : return 8 ; default : return 0 } } ) ; Qa ( 128 , function ( a ) { a & 1 && ( this . irq = 2 ) ; a & 2 && ( this . irq = 5 ) ; a & 4 && ( this . irq = 7 ) ; a & 8 && ( this . irq = 10 ) } ) ;
Pa ( 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 } ) ; Qa ( 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 ) } ) ; Pa ( 130 , function ( ) { for ( var a = 32 , b = 0 ; 16 > b ; b ++ ) a |= b * this . irq _triggered [ b ] ; return a } ) ;
Q . prototype . fm _default _write = function ( a , b , c ) { A ( c ) ; A ( a ) } ; function T ( a , b ) { b || ( b = Q . prototype . fm _default _write ) ; for ( var c = 0 ; c < a . length ; c ++ ) La [ a [ c ] ] = b } function Ua ( a , b ) { for ( var c = [ ] ; a <= b ; a ++ ) c . push ( a ) ; return c } var V = new Uint8Array ( 32 ) ; V [ 0 ] = 0 ; V [ 1 ] = 1 ; V [ 2 ] = 2 ; V [ 3 ] = 3 ; V [ 4 ] = 4 ; V [ 5 ] = 5 ; V [ 8 ] = 6 ; V [ 9 ] = 7 ; V [ 10 ] = 8 ; V [ 11 ] = 9 ; V [ 12 ] = 10 ; V [ 13 ] = 11 ; V [ 16 ] = 12 ; V [ 17 ] = 13 ; V [ 18 ] = 14 ; V [ 19 ] = 15 ; V [ 20 ] = 16 ; V [ 21 ] = 17 ; T ( [ 1 ] , function ( a , b ) { this . fm _waveform _select _enable [ b ] = a & 1 ; this . fm _update _waveforms ( ) } ) ; T ( [ 2 ] ) ; T ( [ 3 ] ) ; T ( [ 4 ] , function ( ) { } ) ;
T ( [ 5 ] , function ( a , b , c ) { 0 === b && this . fm _default _write ( a , b , c ) } ) ; T ( [ 8 ] , function ( ) { } ) ; T ( Ua ( 32 , 53 ) , function ( ) { } ) ; T ( Ua ( 64 , 85 ) , function ( ) { } ) ; T ( Ua ( 96 , 117 ) , function ( ) { } ) ; T ( Ua ( 128 , 149 ) , function ( ) { } ) ; T ( Ua ( 160 , 168 ) , function ( ) { } ) ; T ( Ua ( 176 , 184 ) , function ( ) { } ) ; T ( [ 189 ] , function ( ) { } ) ; T ( Ua ( 192 , 200 ) , function ( ) { } ) ; T ( Ua ( 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 ) ) ) } ) } ;
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 = Na ( 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 Na ( a , b , c ) { return ( a < b ) * b + ( a > c ) * c + ( b <= a && a <= c ) * a } ; function h ( 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 ( r . 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 =
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 W ( 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 ) ) ;
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 ( ) }
h . 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" ,
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 =>
{ this . queue _selected && ( b & b - 1 && ( b = 1 << r . 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 :
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 : ( ) => { } } ] } } ;
h . 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 } } ;
h . 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 : ( ) => { } } ] } } ; h . 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 } } ;
h . 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 << r . 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 +
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 &
- 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 +
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 } ;
h . 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 ) } ;
h . 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 ( let c of a . slice ( 10 ) ) this . queues [ b ] . set _state ( c ) , b ++ ; this . queue _selected = this . queues [ this . queue _select ] || null } ;
h . 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 ( ) } ; h . prototype . notify _config _changes = function ( ) { this . config _has _changed = ! 0 ; this . device _status & 4 && this . raise _irq ( 2 ) } ;
h . prototype . update _config _generation = function ( ) { this . config _has _changed && ( this . config _generation ++ , this . config _generation &= 255 , this . config _has _changed = ! 1 ) } ; h . prototype . is _feature _negotiated = function ( a ) { return 0 < ( this . driver _feature [ a >>> 5 ] & 1 << ( a & 31 ) ) } ; h . prototype . needs _reset = function ( ) { this . device _status |= 64 ; this . device _status & 4 && this . notify _config _changes ( ) } ; h . prototype . raise _irq = function ( a ) { A ( a ) ; this . isr _status |= a ; this . pci . raise _irq ( this . pci _id ) } ;
h . prototype . lower _irq = function ( ) { this . isr _status = 0 ; this . pci . lower _irq ( this . pci _id ) } ; function W ( 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 ( ) }
W . 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 } ;
W . 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 } ; W . 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 ) } ;
W . prototype . is _configured = function ( ) { return this . desc _addr && this . avail _addr && this . used _addr } ; W . prototype . enable = function ( ) { this . is _configured ( ) ; this . enabled = ! 0 } ; W . prototype . set _size = function ( a ) { this . size = a ; this . mask = a - 1 } ; W . prototype . count _requests = function ( ) { return this . avail _get _idx ( ) - this . avail _last _idx & this . mask } ; W . prototype . has _request = function ( ) { return ( this . avail _get _idx ( ) & this . mask ) !== this . avail _last _idx } ;
W . prototype . pop _request = function ( ) { this . has _request ( ) ; var a = this . avail _get _entry ( this . avail _last _idx ) ; a = new Va ( this , a ) ; this . avail _last _idx = this . avail _last _idx + 1 & this . mask ; return a } ; W . 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 ++ } ;
W . 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 ) } } ; W . prototype . notify _me _after = function ( a ) { a = this . avail _get _idx ( ) + a & 65535 ; this . used _set _avail _event ( a ) } ;
W . 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 ) } } ; W . prototype . avail _get _flags = function ( ) { return this . cpu . read16 ( this . avail _addr ) } ; W . prototype . avail _get _idx = function ( ) { return this . cpu . read16 ( this . avail _addr + 2 ) } ; W . prototype . avail _get _entry = function ( a ) { return this . cpu . read16 ( this . avail _addr + 4 + 2 * a ) } ;
W . prototype . avail _get _used _event = function ( ) { return this . cpu . read16 ( this . avail _addr + 4 + 2 * this . size ) } ; W . prototype . used _get _flags = function ( ) { return this . cpu . read16 ( this . used _addr ) } ; W . prototype . used _set _flags = function ( a ) { this . cpu . write16 ( this . used _addr , a ) } ; W . prototype . used _get _idx = function ( ) { return this . cpu . read16 ( this . used _addr + 2 ) } ; W . prototype . used _set _idx = function ( a ) { this . cpu . write16 ( this . used _addr + 2 , a ) } ;
W . 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 ) } ; W . prototype . used _set _avail _event = function ( a ) { this . cpu . write16 ( this . used _addr + 4 + 8 * this . size , a ) } ;
function Va ( 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 ) ; A ( k . addr _high , 8 ) ; A ( k . addr _low , 8 ) ; A ( k . len , 8 ) ; A ( k . flags , 4 ) ; A ( 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 ) }
Va . 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 } ;
Va . 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 Wa ( 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 h ( 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 => { let 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 ) ;
e . get _next _blob ( g ) ; var f = v . 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 : ( ) => 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 ) { let 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 ( ) &&
this . SendWindowSize ( c ) } , this ) } } Wa . prototype . SendWindowSize = function ( a ) { const b = this . virtio . queues [ 2 ] . pop _request ( ) ; let c = new Uint8Array ( 12 ) ; v . Marshall ( [ "w" , "h" , "h" , "h" , "h" ] , [ a , 5 , 0 , this . rows , this . cols ] , c , 0 ) ; this . Send ( 2 , b , c ) } ; Wa . prototype . SendName = function ( a , b ) { const c = this . virtio . queues [ 2 ] . pop _request ( ) ; b = ( new TextEncoder ) . encode ( b ) ; let d = new Uint8Array ( 8 + b . length + 1 ) ; v . 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 ) } ;
Wa . prototype . get _state = function ( ) { let a = [ ] ; a [ 0 ] = this . virtio ; a [ 1 ] = this . rows ; a [ 2 ] = this . cols ; a [ 3 ] = this . ports ; return a } ; Wa . prototype . set _state = function ( a ) { this . virtio . set _state ( a [ 0 ] ) ; this . rows = a [ 1 ] ; this . cols = a [ 2 ] ; this . ports = a [ 3 ] } ; Wa . prototype . Reset = function ( ) { } ; Wa . prototype . SendEvent = function ( a , b , c ) { const d = this . virtio . queues [ 2 ] . pop _request ( ) ; let e = new Uint8Array ( 8 ) ; v . Marshall ( [ "w" , "h" , "h" ] , [ a , b , c ] , e , 0 ) ; this . Send ( 2 , d , e ) } ;
Wa . prototype . Send = function ( a , b , c ) { b . set _next _blob ( c ) ; this . virtio . queues [ a ] . push _reply ( b ) ; this . virtio . queues [ a ] . flush _replies ( ) } ; Wa . 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 ( ) } ; var Xa = { } ; function Ya ( ) { this . listeners = { } ; this . pair = void 0 } Ya . 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 } ) } ; Ya . prototype . unregister = function ( a , b ) { var c = this . listeners [ a ] ; void 0 !== c && ( this . listeners [ a ] = c . filter ( function ( d ) { return d . fn !== b } ) ) } ; Ya . 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 ) } } ;
Ya . prototype . send _async = function ( a , b ) { setTimeout ( this . send . bind ( this , a , b ) , 0 ) } ; Xa . create = function ( ) { var a = new Ya , b = new Ya ; a . pair = b ; b . pair = a ; return [ a , b ] } ; function J ( ) { } function oa ( ) { } ; function E ( a , b , c ) { this . next _tick _immediately = c ; this . wm = b ; this . wasm _patch ( ) ; this . create _jit _imports ( ) ; this . wasm _memory = b = this . wm . exports . memory ; this . memory _size = r . view ( Uint32Array , b , 812 , 1 ) ; this . mem8 = new Uint8Array ( 0 ) ; this . mem32s = new Int32Array ( this . mem8 . buffer ) ; this . segment _is _null = r . view ( Uint8Array , b , 724 , 8 ) ; this . segment _offsets = r . view ( Int32Array , b , 736 , 8 ) ; this . segment _limits = r . view ( Uint32Array , b , 768 , 8 ) ; this . protected _mode = r . view ( Int32Array , b , 800 , 1 ) ; this . idtr _size = r . view ( Int32Array , b , 564 , 1 ) ; this . idtr _offset =
r . view ( Int32Array , b , 568 , 1 ) ; this . gdtr _size = r . view ( Int32Array , b , 572 , 1 ) ; this . gdtr _offset = r . view ( Int32Array , b , 576 , 1 ) ; this . tss _size _32 = r . view ( Int32Array , b , 1128 , 1 ) ; this . page _fault = r . view ( Uint32Array , b , 540 , 8 ) ; this . cr = r . view ( Int32Array , b , 580 , 8 ) ; this . cpl = r . view ( Uint8Array , b , 612 , 1 ) ; this . is _32 = r . view ( Int32Array , b , 804 , 1 ) ; this . stack _size _32 = r . view ( Int32Array , b , 808 , 1 ) ; this . in _hlt = r . view ( Uint8Array , b , 616 , 1 ) ; this . last _virt _eip = r . view ( Int32Array , b , 620 , 1 ) ; this . eip _phys = r . view ( Int32Array , b , 624 , 1 ) ; this . sysenter _cs = r . view ( Int32Array ,
b , 636 , 1 ) ; this . sysenter _esp = r . view ( Int32Array , b , 640 , 1 ) ; this . sysenter _eip = r . view ( Int32Array , b , 644 , 1 ) ; this . prefixes = r . view ( Int32Array , b , 648 , 1 ) ; this . flags = r . view ( Int32Array , b , 120 , 1 ) ; this . flags _changed = r . view ( Int32Array , b , 100 , 1 ) ; this . last _op _size = r . view ( Int32Array , b , 96 , 1 ) ; this . last _op1 = r . view ( Int32Array , b , 104 , 1 ) ; this . last _result = r . view ( Int32Array , b , 112 , 1 ) ; this . current _tsc = r . view ( Uint32Array , b , 960 , 2 ) ; this . devices = { } ; this . instruction _pointer = r . view ( Int32Array , b , 556 , 1 ) ; this . previous _ip = r . view ( Int32Array ,
b , 560 , 1 ) ; this . apic _enabled = r . view ( Uint8Array , b , 548 , 1 ) ; this . acpi _enabled = r . 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 = r . view ( Uint32Array , b , 664 , 1 ) ; this . reg32 = r . view ( Int32Array , b , 64 , 8 ) ; this . fpu _st = r . view ( Int32Array , b , 1152 , 32 ) ; this . fpu _stack _empty = r . view ( Uint8Array , b , 816 , 1 ) ; this . fpu _stack _empty [ 0 ] = 255 ; this . fpu _stack _ptr = r . view ( Uint8Array , b , 1032 , 1 ) ; this . fpu _stack _ptr [ 0 ] =
0 ; this . fpu _control _word = r . view ( Uint16Array , b , 1036 , 1 ) ; this . fpu _control _word [ 0 ] = 895 ; this . fpu _status _word = r . view ( Uint16Array , b , 1040 , 1 ) ; this . fpu _status _word [ 0 ] = 0 ; this . fpu _ip = r . view ( Int32Array , b , 1048 , 1 ) ; this . fpu _ip [ 0 ] = 0 ; this . fpu _ip _selector = r . view ( Int32Array , b , 1052 , 1 ) ; this . fpu _ip _selector [ 0 ] = 0 ; this . fpu _opcode = r . view ( Int32Array , b , 1044 , 1 ) ; this . fpu _opcode [ 0 ] = 0 ; this . fpu _dp = r . view ( Int32Array , b , 1056 , 1 ) ; this . fpu _dp [ 0 ] = 0 ; this . fpu _dp _selector = r . view ( Int32Array , b , 1060 , 1 ) ; this . fpu _dp _selector [ 0 ] = 0 ; this . reg _xmm32s =
r . view ( Int32Array , b , 832 , 32 ) ; this . mxcsr = r . view ( Int32Array , b , 824 , 1 ) ; this . sreg = r . view ( Uint16Array , b , 668 , 8 ) ; this . dreg = r . view ( Int32Array , b , 684 , 8 ) ; this . reg _pdpte = r . view ( Int32Array , b , 968 , 8 ) ; this . svga _dirty _bitmap _min _offset = r . view ( Uint32Array , b , 716 , 1 ) ; this . svga _dirty _bitmap _max _offset = r . 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 ( ) }
E . prototype . clear _opstats = function ( ) { ( new Uint8Array ( this . wasm _memory . buffer , 32768 , 131072 ) ) . fill ( 0 ) ; this . wm . exports . profiler _init ( ) } ; E . prototype . create _jit _imports = function ( ) { const a = Object . create ( null ) ; a . m = this . wm . exports . memory ; for ( let 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 } ;
E . 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" ) ;
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 =
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" ) } ; E . prototype . jit _force _generate = function ( a ) { this . jit _force _generate _unsafe && this . jit _force _generate _unsafe ( a ) } ; E . prototype . jit _clear _func = function ( a ) { this . wm . wasm _table . set ( a + 1024 , null ) } ; E . prototype . jit _clear _all _funcs = function ( ) { const a = this . wm . wasm _table ; for ( let b = 0 ; 900 > b ; b ++ ) a . set ( 1024 + b , null ) } ;
E . prototype . get _state = function ( ) { var a = [ ] ; a [ 0 ] = this . memory _size [ 0 ] ; a [ 1 ] = this . segment _is _null ; 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 ] ; 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 ] ; 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 ; return a } ;
E . 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 [ 12 ] = b [ 12 ] ; d [ 12 ] = b [ 12 ] ; return c } ;
E . 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 ] ) ; this . segment _is _null . set ( a [ 1 ] ) ; this . segment _offsets . set ( a [ 2 ] ) ; this . segment _limits . set ( a [ 3 ] ) ; this . protected _mode [ 0 ] = 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 && 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 . 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 ] = 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 r . Bitmap ( a [ 78 ] . buffer ) ; this . unpack _memory ( b , a [ 77 ] ) ; this . update _state _flags ( ) ; this . full _clear _tlb ( ) ; this . jit _clear _cache ( ) } ;
E . 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 [ 12 ] = d [ 12 ] ; c [ 12 ] = d [ 12 ] } ;
E . 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 r . Bitmap ( a ) ; c = new Uint8Array ( b . length << 12 ) ; for ( let [ 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 } } ;
E . 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 ++ } } ; E . 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 . load _bios ( ) } ; E . prototype . reset _memory = function ( ) { this . mem8 . fill ( 0 ) } ;
E . prototype . create _memory = function ( a ) { 1048576 > a ? a = 1048576 : 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 ; const b = this . allocate _memory ( a ) ; this . mem8 = r . view ( Uint8Array , this . wasm _memory , b , a ) ; this . mem32s = r . view ( Uint32Array , this . wasm _memory , b , a >> 2 ) } ; F . exportProperty ( E . prototype , "create_memory" , E . prototype . create _memory ) ;
E . prototype . init = function ( a , b ) { this . create _memory ( "number" === typeof a . memory _size ? a . memory _size : 67108864 ) ; 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 B ( this ) ; this . io = c ; this . bios . main = a . bios ; this . bios . vga = a . vga _bios ; this . load _bios ( ) ; if ( a . bzimage ) { const e = Za ( 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 } J ( "bios config port, index=" + A ( 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 ] , t = 4 + 64 * m ; e [ t + 0 >> 2 ] = k ( p . length ) ; e [ t + 4 >> 2 ] = f ( 49152 + m ) ; for ( let q = 0 ; q < n . length ; q ++ ) l [ t + 8 + q ] = n . charCodeAt ( q ) } 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 : ( J ( "Warning: Unimplemented fw index: " + A ( 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 pa ( this ) , this . acpi _enabled [ 0 ] && ( this . devices . ioapic = new ya ( this ) , this . devices . apic = new O ( this ) , this . devices . acpi = new xa ( this ) ) , this . devices . rtc = new va ( this ) , this . fill _cmos ( this . devices . rtc , a ) , this . devices . dma = new L ( this ) ,
this . devices . vga = new M ( this , b , a . vga _memory _size || 8388608 ) , this . devices . ps2 = new N ( this , b ) , this . devices . uart0 = new wa ( this , 1016 , b ) , a . uart1 && ( this . devices . uart1 = new wa ( this , 760 , b ) ) , a . uart2 && ( this . devices . uart2 = new wa ( this , 1E3 , b ) ) , a . uart3 && ( this . devices . uart3 = new wa ( this , 744 , b ) ) , this . devices . fdc = new K ( this , a . fda , a . fdb ) , c = 0 , a . hda && ( this . devices . hda = new G ( this , a . hda , a . hdb , ! 1 , c ++ , b ) ) , a . cdrom && ( this . devices . cdrom = new G ( this , a . cdrom , void 0 , ! 0 , c ++ , b ) ) , this . devices . pit = new qa ( this , b ) , a . enable _ne2k && ( this . devices . net =
new Fa ( this , b , a . preserve _mac _from _state _image , a . mac _address _translation ) ) , a . fs9p && ( this . devices . virtio _9p = new da ( a . fs9p , this , b ) ) , a . virtio _console && ( this . devices . virtio _console = new Wa ( 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 ) ) } ; E . prototype . load _multiboot = function ( a ) { this . load _multiboot _option _rom ( a , void 0 , "" ) && ( this . reg32 [ 0 ] = this . io . port _read32 ( 244 ) ) } ;
E . 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 ; J ( "Multiboot magic found, flags: " + A ( 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 t =
( new TextEncoder ) . encode ( c ) ; f . write _blob ( t , n ) ; n += t . length } if ( g & 2 ) { p |= 64 ; t = 0 ; f . write32 ( 31788 , 0 ) ; f . write32 ( 31792 , n ) ; var q = 0 ; var z = ! 1 ; for ( let u = 0 ; 4294967296 > u ; u += 131072 ) z && void 0 !== f . memory _map _read8 [ u >>> 17 ] ? ( f . write32 ( n , 20 ) , f . write32 ( n + 4 , q ) , f . write32 ( n + 8 , 0 ) , f . write32 ( n + 12 , u - q ) , f . write32 ( n + 16 , 0 ) , f . write32 ( n + 20 , 1 ) , n += 24 , t += 24 , z = ! 1 ) : z || void 0 !== f . memory _map _read8 [ u >>> 17 ] || ( q = u , z = ! 0 ) ; f . write32 ( 31788 , t ) } f . write32 ( 31744 , p ) ; t = p = 0 ; if ( g & 65536 ) { z = d [ e + 12 >> 2 ] ; p = d [ e + 16 >> 2 ] ; var w = d [ e + 20 >> 2 ] ; t = d [ e + 24 >> 2 ] ; q = d [ e + 28 >>
2 ] ; A ( z , 8 ) ; A ( p , 8 ) ; A ( w , 8 ) ; A ( t , 8 ) ; A ( q , 8 ) ; z = new Uint8Array ( a , e - ( z - p ) , 0 === w ? void 0 : w - p ) ; f . write _blob ( z , p ) ; p = q | 0 ; t = Math . max ( w , t ) } else if ( 1179403647 === d [ 0 ] ) { q = new DataView ( a ) ; let [ u , I ] = $a ( q , ab ) ; console . assert ( 52 === I ) ; 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 ] = bb ( new DataView ( q . buffer , q . byteOffset + u . phoff , u . phentsize * u . phnum ) , cb , u . phnum ) ; bb ( new DataView ( q . buffer , q . byteOffset + u . shoff , u . shentsize * u . shnum ) , gb , u . shnum ) ; q = u ; z = p ; p = q . entry ; for ( w of z ) 0 !== w . type && ( 1 === w . type ? w . paddr + w . memsz < f . memory _size [ 0 ] ? ( w . filesz && ( z = new Uint8Array ( a , w . offset , w . filesz ) , f . write _blob ( z , w . paddr ) ) , t = Math . max ( t ,
w . paddr + w . memsz ) , p === q . entry && w . vaddr <= p && w . vaddr + w . memsz > p && ( p = p - w . vaddr + w . paddr ) ) : A ( w . paddr ) : 2 === w . type || 3 === w . type || 4 === w . type || 6 === w . type || 7 === w . type || 1685382480 === w . type || 1685382481 === w . type || 1685382482 === w . type || 1685382483 === w . type || A ( w . type ) ) } b && ( f . write32 ( 31764 , 1 ) , f . write32 ( 31768 , n ) , w = t , 0 !== ( w & 4095 ) && ( w = ( w & - 4096 ) + 4096 ) , t = w + b . byteLength , f . write32 ( n , w ) , f . write32 ( n + 4 , t ) , f . write32 ( n + 8 , 0 ) , f . write32 ( n + 12 , 0 ) , f . write _blob ( new Uint8Array ( b ) , w ) ) ; 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 " + A ( n , 2 ) ) ; throw "HALT" ; } , function ( ) { } , function ( ) { } , function ( ) { } ) ; for ( let n = 0 ; 15 >= n ; n ++ ) { function p ( t ) { A ( n ) ; A ( t , 2 ) ; t ? 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 } } } ;
E . 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 ,
0 ) ; a . cmos _write ( 93 , 0 ) ; a . cmos _write ( 20 , 47 ) ; a . cmos _write ( 95 , 0 ) ; b . fastboot && a . cmos _write ( 63 , 1 ) } ;
E . 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 ) ) } } ;
E . 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 ) } ) } ; E . prototype . log _uncompiled _code = function ( ) { } ; E . prototype . dump _function _code = function ( ) { } ;
E . 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 ) } ; E . prototype . device _raise _irq = function ( a ) { this . pic _set _irq ( a ) ; this . devices . ioapic && this . devices . ioapic . set _irq ( a ) } ; E . prototype . device _lower _irq = function ( a ) { this . pic _clear _irq ( a ) ; this . devices . ioapic && this . devices . ioapic . clear _irq ( a ) } ;
"undefined" !== typeof window ? window . CPU = E : "undefined" !== typeof module && "undefined" !== typeof module . exports ? module . exports . CPU = E : "function" === typeof importScripts && ( self . CPU = E ) ; E . 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 ) { J ( A ( l . address >>> 0 ) + ": " + r . pads ( l . bytes . map ( m => A ( m , 2 ) . slice ( - 2 ) ) . join ( " " ) , 20 ) + " " + l . mnemonic + " " + l . op _str ) } ) } catch ( l ) { J ( "Could not disassemble: " + Array . from ( f ) . map ( m => A ( 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 ( ) } } } ; let hb = DataView . prototype , ib = { size : 1 , get : hb . getUint8 , set : hb . setUint8 } , jb = { size : 2 , get : hb . getUint16 , set : hb . setUint16 } , X = { size : 4 , get : hb . getUint32 , set : hb . setUint32 } , ab = kb ( [ { magic : X } , { class : ib } , { data : ib } , { version0 : ib } , { osabi : ib } , { abiversion : ib } , { pad0 : function ( a ) { return { size : a , get : ( ) => - 1 } } ( 7 ) } , { type : jb } , { machine : jb } , { version1 : X } , { entry : X } , { phoff : X } , { shoff : X } , { flags : X } , { ehsize : jb } , { phentsize : jb } , { phnum : jb } , { shentsize : jb } , { shnum : jb } , { shstrndx : jb } ] ) ; console . assert ( 52 === ab . reduce ( ( a , b ) => a + b . size , 0 ) ) ;
let cb = kb ( [ { type : X } , { offset : X } , { vaddr : X } , { paddr : X } , { filesz : X } , { memsz : X } , { flags : X } , { align : X } ] ) ; console . assert ( 32 === cb . reduce ( ( a , b ) => a + b . size , 0 ) ) ; let gb = kb ( [ { name : X } , { type : X } , { flags : X } , { addr : X } , { offset : X } , { size : X } , { link : X } , { info : X } , { addralign : X } , { entsize : X } ] ) ; console . assert ( 40 === gb . reduce ( ( a , b ) => a + b . size , 0 ) ) ; function kb ( 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 } } ) }
function $a ( a , b ) { let c = { } , d = 0 ; for ( let 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 bb ( a , b , c ) { let d = [ ] , e = 0 ; for ( var g = 0 ; g < c ; g ++ ) { let [ f , k ] = $a ( new DataView ( a . buffer , a . byteOffset + e , void 0 ) , b ) ; d . push ( f ) ; e += k } return [ d , e ] } ; function Za ( 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 ) A ( l ) ; else if ( l = g [ 257 ] | g [ 258 ] << 16 , 1400005704 !== l ) A ( l ) ; else { l = e [ 529 ] ; var m = g [ 283 ] , n = f [ 139 ] , p = f [ 140 ] , t = e [ 565 ] , q = f [ 142 ] , z = f [ 146 ] , w = f [ 147 ] , u = f [ 150 ] , I = f [ 151 ] , U = f [ 152 ] ; A ( g [ 259 ] ) ; A ( l ) ; A ( m ) ; A ( f [ 133 ] ) ; A ( n ) ; A ( p ) ; A ( t ) ; A ( q ) ; A ( z ) ; A ( w ) ; A ( I ) ; A ( u ) ; A ( U ) ; e [ 528 ] = 255 ; e [ 529 ] = l & - 97 | 128 ; g [ 274 ] = 56832 ; g [ 253 ] = 65535 ; A ( 56832 ) ; d += "\x00" ; A ( 581632 ) ; f [ 138 ] = 581632 ; for ( e = 0 ; e < d . length ; e ++ ) a [ 581632 + e ] = d . charCodeAt ( e ) ;
k = 512 * ( k + 1 ) ; A ( 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 } } } ; function lb ( a ) { function b ( q ) { ! q . altKey && k [ 56 ] && g ( 56 , ! 1 ) ; return e ( q , ! 1 ) } function c ( q ) { ! q . altKey && k [ 56 ] && g ( 56 , ! 1 ) ; return e ( q , ! 0 ) } function d ( ) { for ( var q = Object . keys ( k ) , z , w = 0 ; w < q . length ; w ++ ) z = + q [ w ] , k [ z ] && g ( z , ! 1 ) ; k = { } } function e ( q , z ) { var w ; if ( w = l . bus ) w = q . shiftKey && q . ctrlKey && ( 73 === q . keyCode || 74 === q . keyCode || 75 === q . keyCode ) || ! l . emu _enabled ? ! 1 : q . target ? q . target . classList . contains ( "phone_keyboard" ) || "INPUT" !== q . target . nodeName && "TEXTAREA" !== q . target . nodeName : ! 0 ; if ( w ) { a : { if ( void 0 !== q . code && ( w = t [ q . code ] , void 0 !==
w ) ) break a ; w = m [ q . keyCode ] } if ( w ) return g ( w , z , q . repeat ) , q . preventDefault && q . preventDefault ( ) , ! 1 ; console . log ( "Missing char in map: keyCode=" + ( q . keyCode || - 1 ) . toString ( 16 ) + " code=" + q . code ) } } function g ( q , z , w ) { if ( z ) k [ q ] && ! w && g ( q , ! 1 ) ; else if ( ! k [ q ] ) return ; ( k [ q ] = z ) || ( q |= 128 ) ; 255 < q ? ( f ( q >> 8 ) , f ( q & 255 ) ) : f ( q ) } function f ( q ) { l . bus . send ( "keyboard-code" , q ) } var k = { } , l = this ; this . emu _enabled = ! 0 ; var m = 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 , 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 ] ) ,
n = { 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 , 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 } , p = { 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 } , t = { Escape : 1 , Digit1 : 2 , Digit2 : 3 , Digit3 : 4 , Digit4 : 5 , Digit5 : 6 , Digit6 : 7 , Digit7 : 8 , Digit8 : 9 , Digit9 : 10 , 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 = a ; this . destroy = function ( ) { "undefined" !== typeof window && ( window . removeEventListener ( "keyup" , b , ! 1 ) , window . removeEventListener ( "keydown" , c , ! 1 ) , window . removeEventListener ( "blur" , d , ! 1 ) ) } ; this . init = function ( ) { "undefined" !== typeof window && ( this . destroy ( ) , window . addEventListener ( "keyup" ,
b , ! 1 ) , window . addEventListener ( "keydown" , c , ! 1 ) , window . addEventListener ( "blur" , d , ! 1 ) ) } ; this . init ( ) ; this . simulate _press = function ( q ) { q = { keyCode : q } ; e ( q , ! 0 ) ; e ( q , ! 1 ) } ; this . simulate _char = function ( q ) { var z = q . charCodeAt ( 0 ) ; z in n ? this . simulate _press ( n [ z ] ) : z in p ? ( f ( 42 ) , this . simulate _press ( p [ z ] ) , f ( 170 ) ) : console . log ( "ascii -> keyCode not found: " , z , q ) } } ; function mb ( a , b ) { function c ( u ) { if ( ! w . enabled || ! w . emu _enabled ) return ! 1 ; var I = b || document . body , U ; if ( ! ( U = document . pointerLockElement ) ) a : { for ( u = u . target ; u . parentNode ; ) { if ( u === I ) { U = ! 0 ; break a } u = u . parentNode } U = ! 1 } return U } function d ( u ) { c ( u ) && ( u = u . changedTouches ) && u . length && ( u = u [ u . length - 1 ] , q = u . clientX , z = u . clientY ) } function e ( ) { if ( n || t || p ) w . bus . send ( "mouse-click" , [ ! 1 , ! 1 , ! 1 ] ) , n = t = p = ! 1 } function g ( u ) { if ( w . bus && c ( u ) && w . is _running ) { var I = 0 , U = 0 , ea = u . changedTouches ; ea ? ea . length && ( ea = ea [ ea . length - 1 ] , I = ea . clientX -
q , U = ea . clientY - z , q = ea . clientX , z = ea . clientY , u . preventDefault ( ) ) : "number" === typeof u . movementX ? ( I = u . movementX , U = u . movementY ) : "number" === typeof u . webkitMovementX ? ( I = u . webkitMovementX , U = u . webkitMovementY ) : "number" === typeof u . mozMovementX ? ( I = u . mozMovementX , U = u . mozMovementY ) : ( I = u . clientX - q , U = u . clientY - z , q = u . clientX , z = u . clientY ) ; w . bus . send ( "mouse-delta" , [ . 15 * I , - ( . 15 * U ) ] ) ; b && w . 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 , I ) { w . bus && ( 1 === u . which ? n = I : 2 === u . which ? t = I : 3 === u . which && ( p = I ) , w . bus . send ( "mouse-click" , [ n , t , p ] ) , u . preventDefault ( ) ) } function m ( u ) { if ( c ( u ) ) { var I = u . wheelDelta || - u . detail ; 0 > I ? I = - 1 : 0 < I && ( I = 1 ) ; w . bus . send ( "mouse-wheel" , [ I , 0 ] ) ; u . preventDefault ( ) } } var n = ! 1 , p = ! 1 , t = ! 1 , q = 0 , z = 0 , w = 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 nb ( a ) { if ( "undefined" !== typeof window ) if ( window . AudioContext || window . webkitAudioContext ) { var b = window . AudioWorklet ? ob : pb ; this . bus = a ; this . audio _context = window . AudioContext ? new AudioContext : new webkitAudioContext ; this . mixer = new qb ( a , this . audio _context ) ; this . pcspeaker = new rb ( 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 ( ) } ,
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" ) } nb . 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 qb ( 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 ) ;
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 ) ;
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 ) } qb . prototype . add _source = function ( a , b ) { a = new sb ( this . audio _context , a , this . input _left , this . input _right ) ; this . sources . has ( b ) ; this . sources . set ( b , a ) ; return a } ; qb . prototype . connect _source = function ( a , b ) { a = this . sources . get ( a ) ; void 0 === a || a . connect ( b ) } ;
qb . prototype . disconnect _source = function ( a , b ) { a = this . sources . get ( a ) ; void 0 === a || a . disconnect ( b ) } ; qb . 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 ( ) } ;
qb . 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 sb ( 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 ) }
sb . 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 ) } ; sb . 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 ( ) } ;
sb . 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 ( ) } ; sb . 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 ( ) } ; sb . prototype . set _gain _hidden = function ( a ) { this . gain _hidden = a } ;
function rb ( 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 ) } rb . prototype . start = function ( ) { this . node _oscillator . start ( ) } ;
function ob ( 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 , t = 0 , q = this . source _offset + this . kernel _size , z = this . source _offset -
this . kernel _size + 1 ; z <= q ; z ++ ) { var w = this . source _block _start + z ; p += this . get _sample ( w , 0 ) * this . kernel ( this . source _time - z ) ; t += this . get _sample ( w , 1 ) * this . kernel ( this . source _time - z ) } if ( isNaN ( p ) || isNaN ( t ) ) p = t = 0 , this . dbg _log ( "ERROR: NaN values! Ignoring for now." ) ; n [ 0 ] [ 0 ] [ m ] = p ; n [ 0 ] [ 1 ] [ m ] = t ; 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 >
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 ] ) ;
n = this . source _buffer _current [ 0 ] . length ; for ( var t = 0 ; t < p ; t ++ ) { var q = this . queue _shift ( ) ; m [ 0 ] . set ( q [ 0 ] , n ) ; m [ 1 ] . set ( q [ 1 ] , n ) ; n += q [ 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 =
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 ) }
ob . prototype . queue = function ( a ) { this . node _processor && this . node _processor . port . postMessage ( { type : "queue" , value : a } , [ a [ 0 ] . buffer , a [ 1 ] . buffer ] ) } ; ob . prototype . pump = function ( ) { this . enabled && this . bus . send ( "dac-request-data" ) } ;
function pb ( 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" ,
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 ) }
pb . 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 ) } ; pb . prototype . pump = function ( ) { this . enabled && ( . 2 < this . buffered _time - this . audio _context . currentTime || this . bus . send ( "dac-request-data" ) ) } ; function tb ( 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 ub ( 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 ( ) } } } ub . prototype . show = function ( ) { this . term && this . term . open ( this . element ) } ; function vb ( a , b ) { this . bus = b ; this . socket = void 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 . bus . register ( "net0-send" , function ( c ) { this . send ( c ) } , this ) } vb . prototype . handle _message = function ( a ) { this . bus && this . bus . send ( "net0-receive" , new Uint8Array ( a . data ) ) } ; vb . prototype . handle _close = function ( ) { this . connect ( ) ; setTimeout ( this . connect . bind ( this ) , this . reconnect _interval ) } ;
vb . prototype . handle _open = function ( ) { for ( var a = 0 ; a < this . send _queue . length ; a ++ ) this . send ( this . send _queue [ a ] ) ; this . send _queue = [ ] } ; vb . prototype . handle _error = function ( ) { } ; vb . prototype . destroy = function ( ) { this . socket && this . socket . close ( ) } ;
vb . prototype . connect = function ( ) { if ( "undefined" !== typeof WebSocket ) { if ( this . socket ) { var a = this . socket . readyState ; if ( 0 === a || 1 === a ) return } a = Date . now ( ) ; this . last _connect _attempt + this . reconnect _interval > a || ( this . last _connect _attempt = Date . now ( ) , this . socket = new WebSocket ( this . url ) , 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 ) , this . socket . onerror = this . handle _error . bind ( this ) ) } } ;
vb . 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 ( ) ) } ; vb . 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 Y ( a ) { this . cpu _is _running = ! 1 ; this . cpu _exception _hook = function ( ) { } ; var b = Xa . 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 r . get _rand _int ( ) } , apic _acknowledge _irq : function ( ) { return c . devices . apic . acknowledge _irq ( ) } ,
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 ) { r . read _sized _string _from _mem ( d , f , k ) } , console _log _from _wasm : function ( f , k ) { f = r . 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 ) ; r . load _file ( l , { done : async n => { try { const { instance : p } = await WebAssembly . instantiate ( n , f ) ; this . wasm _source = n ; k ( p . exports ) } catch ( p ) { r . load _file ( m ,
{ done : async t => { const { instance : q } = await WebAssembly . instantiate ( t , f ) ; this . wasm _source = t ; k ( q . 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 = 0 }
Y . prototype . continue _init = async function ( a , b ) { function c ( t , q ) { switch ( t ) { case "hda" : e . hda = this . disk _images . hda = q ; break ; case "hdb" : e . hdb = this . disk _images . hdb = q ; break ; case "cdrom" : e . cdrom = this . disk _images . cdrom = q ; break ; case "fda" : e . fda = this . disk _images . fda = q ; break ; case "fdb" : e . fdb = this . disk _images . fdb = q ; break ; case "multiboot" : e . multiboot = this . disk _images . multiboot = q . buffer ; break ; case "bzimage" : e . bzimage = this . disk _images . bzimage = q . buffer ; break ; case "initrd" : e . initrd = this . disk _images . initrd = q . buffer ; break ;
case "bios" : e . bios = q . buffer ; break ; case "vga_bios" : e . vga _bios = q . buffer ; break ; case "initial_state" : e . initial _state = q . buffer ; break ; case "fs9p_json" : e . fs9p _json = q } } 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 : t , initrd _path : q } = this . get _bzimage _initrd _from _filesystem ( e . fs9p ) , [ z , w ] = await Promise . all ( [ e . fs9p . read _file ( q ) , e . fs9p . read _file ( t ) ] ) ; c . call ( this , "initrd" , new r . SyncBuffer ( z . buffer ) ) ; c . call ( this ,
"bzimage" , new r . SyncBuffer ( w . buffer ) ) } this . serial _adapter && this . serial _adapter . show && this . serial _adapter . show ( ) ; this . bus . send ( "cpu-init" , e ) ; e . initial _state && ( a . restore _state ( e . initial _state ) , e . initial _state = void 0 ) ; b . autostart && this . bus . send ( "cpu-run" ) ; this . emulator _bus . send ( "emulator-loaded" ) } this . bus . register ( "emulator-stopped" , function ( ) { this . cpu _is _running = ! 1 } , this ) ; this . bus . register ( "emulator-started" , function ( ) { this . cpu _is _running = ! 0 } , this ) ; var e = { } ; this . disk _images = { 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 . log _level = b . log _level ; 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 ; e . cpuid _level =
b . cpuid _level ; e . virtio _console = b . virtio _console ; b . network _adapter ? this . network _adapter = b . network _adapter ( this . bus ) : b . network _relay _url && ( this . network _adapter = new vb ( b . network _relay _url , this . bus ) ) ; e . enable _ne2k = ! 0 ; b . disable _keyboard || ( this . keyboard _adapter = new lb ( this . bus ) ) ; b . disable _mouse || ( this . mouse _adapter = new mb ( this . bus , b . screen _container ) ) ; b . screen _container ? this . screen _adapter = new ba ( b . screen _container , this . bus ) : b . screen _dummy && ( this . screen _adapter = new wb ( this . bus ) ) ; b . serial _container && ( this . serial _adapter =
new tb ( b . serial _container , this . bus ) ) ; b . serial _container _xtermjs && ( this . serial _adapter = new ub ( b . serial _container _xtermjs , this . bus ) ) ; b . disable _speaker || ( this . speaker _adapter = new nb ( this . bus ) ) ; var f = [ ] ; g = ( t , q ) => { if ( q ) if ( q . get && q . set && q . load ) f . push ( { name : t , loadable : q } ) ; else { if ( "bios" === t || "vga_bios" === t || "initial_state" === t || "multiboot" === t || "bzimage" === t || "initrd" === t ) q . async = ! 1 ; q . url && ! q . async ? f . push ( { name : t , url : q . url , size : q . size } ) : f . push ( { name : t , loadable : r . buffer _from _object ( q , 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 t = new xb ; k && ( t = new yb ( t , k ) ) ; e . fs9p = this . fs9p = new Z ( t ) ; 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 ( t ) { if ( t === n ) setTimeout ( d . bind ( this ) , 0 ) ; else { var q = f [ t ] ; q . loadable ? ( q . loadable . onload = function ( ) { c . call ( this , q . name , q . loadable ) ; p ( t + 1 ) } . bind ( this ) , q . loadable . load ( ) ) : r . load _file ( q . url , { done : function ( z ) { q . url . endsWith ( ".zst" ) && "initial_state" !== q . name && ( z = this . zstd _decompress ( q . size , new Uint8Array ( z ) ) ) ; c . call ( this , q . name , q . as _json ? z : new r . SyncBuffer ( z ) ) ; p ( t + 1 ) } . bind ( this ) , progress : function ( z ) { 200 === z . target . status ? m . emulator _bus . send ( "download-progress" ,
{ file _index : t , file _count : n , file _name : q . url , lengthComputable : z . lengthComputable , total : z . total || q . size , loaded : z . loaded } ) : m . emulator _bus . send ( "download-error" , { file _index : t , file _count : n , file _name : q . url , request : z . target } ) } , as _json : q . as _json } ) } } . bind ( this ) ; p ( 0 ) } ;
Y . 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 } ;
Y . 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 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 =>
[ 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 , t ) => { console . log ( String . fromCharCode ( ... ( new Uint8Array ( d . exports . memory . buffer , p , t ) ) ) ) } , 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 =
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 ] ) } ) } ;
Y . 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 ( let 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 } } ;
Y . prototype . run = async function ( ) { this . bus . send ( "cpu-run" ) } ; F . exportProperty ( Y . prototype , "run" , Y . prototype . run ) ; Y . 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 . bus . send ( "cpu-stop" ) } ) } ; F . exportProperty ( Y . prototype , "stop" , Y . prototype . stop ) ;
Y . 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 ( ) } ; F . exportProperty ( Y . prototype , "destroy" , Y . prototype . destroy ) ; Y . prototype . restart = function ( ) { this . bus . send ( "cpu-restart" ) } ;
F . exportProperty ( Y . prototype , "restart" , Y . prototype . restart ) ; Y . prototype . add _listener = function ( a , b ) { this . bus . register ( a , b , this ) } ; F . exportProperty ( Y . prototype , "add_listener" , Y . prototype . add _listener ) ; Y . prototype . remove _listener = function ( a , b ) { this . bus . unregister ( a , b ) } ; F . exportProperty ( Y . prototype , "remove_listener" , Y . prototype . remove _listener ) ; Y . prototype . restore _state = async function ( a ) { this . v86 . restore _state ( a ) } ; F . exportProperty ( Y . prototype , "restore_state" , Y . prototype . restore _state ) ;
Y . prototype . save _state = async function ( ) { return this . v86 . save _state ( ) } ; F . exportProperty ( Y . prototype , "save_state" , Y . prototype . save _state ) ; Y . prototype . get _instruction _counter = function ( ) { return this . v86 ? this . v86 . cpu . instruction _counter [ 0 ] >>> 0 : 0 } ; F . exportProperty ( Y . prototype , "get_instruction_counter" , Y . prototype . get _instruction _counter ) ; Y . prototype . is _running = function ( ) { return this . cpu _is _running } ; F . exportProperty ( Y . prototype , "is_running" , Y . prototype . is _running ) ;
Y . prototype . set _fda = async function ( a ) { if ( a . url && ! a . async ) r . load _file ( a . url , { done : b => { this . v86 . cpu . devices . fdc . set _fda ( new r . SyncBuffer ( b ) ) } } ) ; else { const b = r . buffer _from _object ( a , this . zstd _decompress _worker . bind ( this ) ) ; b . onload = ( ) => { this . v86 . cpu . devices . fdc . set _fda ( b ) } ; await b . load ( ) } } ; F . exportProperty ( Y . prototype , "set_fda" , Y . prototype . set _fda ) ; Y . prototype . eject _fda = function ( ) { this . v86 . cpu . devices . fdc . eject _fda ( ) } ; F . exportProperty ( Y . prototype , "eject_fda" , Y . prototype . eject _fda ) ;
Y . prototype . keyboard _send _scancodes = function ( a ) { for ( var b = 0 ; b < a . length ; b ++ ) this . bus . send ( "keyboard-code" , a [ b ] ) } ; F . exportProperty ( Y . prototype , "keyboard_send_scancodes" , Y . prototype . keyboard _send _scancodes ) ; Y . prototype . keyboard _send _keys = function ( a ) { for ( var b = 0 ; b < a . length ; b ++ ) this . keyboard _adapter . simulate _press ( a [ b ] ) } ; F . exportProperty ( Y . prototype , "keyboard_send_keys" , Y . prototype . keyboard _send _keys ) ; Y . prototype . keyboard _send _text = function ( a ) { for ( var b = 0 ; b < a . length ; b ++ ) this . keyboard _adapter . simulate _char ( a [ b ] ) } ;
F . exportProperty ( Y . prototype , "keyboard_send_text" , Y . prototype . keyboard _send _text ) ; Y . prototype . screen _make _screenshot = function ( ) { return this . screen _adapter ? this . screen _adapter . make _screenshot ( ) : null } ; F . exportProperty ( Y . prototype , "screen_make_screenshot" , Y . prototype . screen _make _screenshot ) ; Y . prototype . screen _set _scale = function ( a , b ) { this . screen _adapter && this . screen _adapter . set _scale ( a , b ) } ; F . exportProperty ( Y . prototype , "screen_set_scale" , Y . prototype . screen _set _scale ) ;
Y . 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 ( ) } } } ; F . exportProperty ( Y . prototype , "screen_go_fullscreen" , Y . prototype . screen _go _fullscreen ) ;
Y . prototype . lock _mouse = function ( ) { var a = document . body , b = a . requestPointerLock || a . mozRequestPointerLock || a . webkitRequestPointerLock ; b && b . call ( a ) } ; F . exportProperty ( Y . prototype , "lock_mouse" , Y . prototype . lock _mouse ) ; Y . prototype . mouse _set _status = function ( a ) { this . mouse _adapter && ( this . mouse _adapter . emu _enabled = a ) } ; Y . prototype . keyboard _set _status = function ( a ) { this . keyboard _adapter && ( this . keyboard _adapter . emu _enabled = a ) } ; F . exportProperty ( Y . prototype , "keyboard_set_status" , Y . prototype . keyboard _set _status ) ;
Y . prototype . serial0 _send = function ( a ) { for ( var b = 0 ; b < a . length ; b ++ ) this . bus . send ( "serial0-input" , a . charCodeAt ( b ) ) } ; F . exportProperty ( Y . prototype , "serial0_send" , Y . prototype . serial0 _send ) ; Y . prototype . serial _send _bytes = function ( a , b ) { for ( var c = 0 ; c < b . length ; c ++ ) this . bus . send ( "serial" + a + "-input" , b [ c ] ) } ; F . exportProperty ( Y . prototype , "serial_send_bytes" , Y . prototype . serial _send _bytes ) ; Y . prototype . serial _set _modem _status = function ( a , b ) { this . bus . send ( "serial" + a + "-modem-status-input" , b ) } ;
Y . prototype . serial _set _carrier _detect = function ( a , b ) { this . bus . send ( "serial" + a + "-carrier-detect-input" , b ) } ; Y . prototype . serial _set _ring _indicator = function ( a , b ) { this . bus . send ( "serial" + a + "-ring-indicator-input" , b ) } ; Y . prototype . serial _set _data _set _ready = function ( a , b ) { this . bus . send ( "serial" + a + "-data-set-ready-input" , b ) } ; Y . prototype . serial _set _clear _to _send = function ( a , b ) { this . bus . send ( "serial" + a + "-clear-to-send-input" , b ) } ;
Y . prototype . mount _fs = async function ( a , b , c , d ) { let e = new xb ; b && ( e = new yb ( e , b ) ) ; const g = new Z ( e , this . fs9p . qidcounter ) , f = ( ) => { const k = this . fs9p . Mount ( a , g ) ; d && ( - 2 === k ? d ( new zb ) : - 17 === k ? d ( new Db ) : 0 > k ? d ( Error ( "Failed to mount. Error number: " + - k ) ) : d ( null ) ) } ; b ? g . load _from _json ( c , ( ) => f ( ) ) : f ( ) } ; F . exportProperty ( Y . prototype , "mount_fs" , Y . prototype . mount _fs ) ;
Y . 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 zb ) } } ; F . exportProperty ( Y . prototype , "create_file" , Y . prototype . create _file ) ; Y . prototype . read _file = async function ( a ) { var b = this . fs9p ; if ( b ) return ( a = await b . read _file ( a ) ) ? a : Promise . reject ( new zb ) } ; F . exportProperty ( Y . prototype , "read_file" , Y . prototype . read _file ) ;
Y . prototype . automatically = function ( a ) { const b = c => { const d = c [ 0 ] ; if ( d ) { var e = c . slice ( 1 ) ; if ( d . sleep ) setTimeout ( ( ) => b ( e ) , 1E3 * d . sleep ) ; else if ( d . vga _text ) { const g = this . screen _adapter . get _text _screen ( ) ; for ( let f of g ) if ( f . includes ( d . vga _text ) ) { b ( e ) ; return } setTimeout ( ( ) => b ( c ) , 1E3 ) } else 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 ) } ;
Y . prototype . read _memory = function ( a , b ) { return this . v86 . cpu . read _blob ( a , b ) } ; Y . prototype . write _memory = function ( a , b ) { this . v86 . cpu . write _blob ( a , b ) } ; Y . prototype . set _serial _container _xtermjs = function ( a ) { this . serial _adapter && this . serial _adapter . destroy && this . serial _adapter . destroy ( ) ; this . serial _adapter = new ub ( a , this . bus ) ; this . serial _adapter . show ( ) } ; function Db ( a ) { this . message = a || "File already exists" } Db . prototype = Error . prototype ; function zb ( a ) { this . message = a || "File not found" } zb . prototype = Error . prototype ;
"undefined" !== typeof window ? ( window . V86Starter = Y , window . V86 = Y ) : "undefined" !== typeof module && "undefined" !== typeof module . exports ? ( module . exports . V86Starter = Y , module . exports . V86 = Y ) : "function" === typeof importScripts && ( self . V86Starter = Y , self . V86 = Y ) ; var Eb = { 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 ) } } ; Eb . 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 } ) } ; Eb . Connector . prototype . send = function ( a , b , c ) { this . pair && this . pair . postMessage ( [ a , b ] , c ) } ; Eb . init = function ( a ) { return new Eb . Connector ( a ) } ; function wb ( a ) { var b , c , d , e , g ; this . bus = a ; a . register ( "screen-set-mode" , function ( f ) { this . set _mode ( f ) } , this ) ; a . register ( "screen-fill-buffer-end" , function ( f ) { this . update _buffer ( f [ 0 ] , f [ 1 ] ) } , this ) ; a . register ( "screen-put-char" , function ( f ) { this . put _char ( f [ 0 ] , f [ 1 ] , f [ 2 ] , f [ 3 ] , f [ 4 ] ) } , this ) ; a . register ( "screen-text-scroll" , function ( f ) { console . log ( "scroll" , f ) } , this ) ; a . register ( "screen-update-cursor" , function ( f ) { this . update _cursor ( f [ 0 ] , f [ 1 ] ) } , this ) ; a . register ( "screen-update-cursor-scanline" , function ( f ) { this . update _cursor _scanline ( f [ 0 ] ,
f [ 1 ] ) } , this ) ; a . register ( "screen-set-size-text" , function ( f ) { this . set _size _text ( f [ 0 ] , f [ 1 ] ) } , this ) ; a . register ( "screen-set-size-graphical" , function ( f ) { this . set _size _graphical ( f [ 0 ] , f [ 1 ] ) } , this ) ; this . put _char = function ( f , k , l , m , n ) { f < g && k < e && ( f = 3 * ( f * e + k ) , d [ f ] = l , d [ f + 1 ] = m , d [ f + 2 ] = n ) } ; this . destroy = function ( ) { } ; this . set _mode = function ( ) { } ; this . clear _screen = function ( ) { } ; this . set _size _text = function ( f , k ) { if ( f !== e || k !== g ) d = new Int32Array ( f * k * 3 ) , e = f , g = k } ; this . set _size _graphical = function ( ) { } ; this . set _scale = function ( ) { } ;
this . update _cursor _scanline = function ( ) { } ; this . update _cursor = function ( f , k ) { if ( f !== b || k !== c ) b = f , c = k } ; this . update _buffer = function ( ) { } ; this . get _text _screen = function ( ) { for ( var f = [ ] , k = 0 ; k < g ; k ++ ) f . push ( this . get _text _row ( k ) ) ; return f } ; this . get _text _row = function ( f ) { var k = "" ; f = 3 * f * e ; for ( var l = 0 ; l < e ; l ++ ) k += String . fromCharCode ( d [ f + 3 * l ] ) ; return k } } ; const Fb = { stats _to _string : function ( a ) { return Fb . print _misc _stats ( a ) + Fb . 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 [ Fb . print _instruction _counts _offset ( a ,
! 1 , ! 1 , ! 1 , ! 1 ) , Fb . print _instruction _counts _offset ( a , ! 0 , ! 1 , ! 1 , ! 1 ) , Fb . print _instruction _counts _offset ( a , ! 1 , ! 0 , ! 1 , ! 1 ) , Fb . print _instruction _counts _offset ( a , ! 1 , ! 1 , ! 0 , ! 1 ) , Fb . 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 ( let t of [ ! 1 , ! 0 ] ) { var l = a . wm . exports . get _opstats _buffer ( b , c , d , e , n , ! 1 , t , p ) ; f . push ( { opcode : n ,
count : l , is _mem : t , fixed _g : p } ) ; l = a . wm . exports . get _opstats _buffer ( b , c , d , e , n , ! 0 , t , p ) ; f . push ( { opcode : 3840 | n , count : l , is _mem : t , fixed _g : p } ) } a = 0 ; b = new Set ( [ 38 , 46 , 54 , 62 , 100 , 101 , 102 , 103 , 240 , 242 , 243 ] ) ; for ( let { count : n , opcode : p } of f ) b . has ( p ) || ( a += n ) ; if ( 0 === a ) return "" ; c = new Uint32Array ( 256 ) ; b = new Uint32Array ( 256 ) ; for ( let { 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 = String ( d ) . length ;
g += ` Instruction counts ${ k } (in ${ m } ): \n ` ; for ( e = 0 ; 256 > e ; e ++ ) g += e . toString ( 16 ) . padStart ( 2 , "0" ) + ":" + r . 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" ) + ":" + r . 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 ( let { opcode : n , is _mem : p , fixed _g : t , count : q } of f . slice ( 0 , 200 ) ) f = n . toString ( 16 ) + "_" + t + ( p ? "_m" : "_r" ) , g += f + ":" + ( q / a * 100 ) . toFixed ( 2 ) +
" " ; return g + "\n" } } ; "undefined" !== typeof module && "undefined" !== typeof module . exports && ( module . exports . print _stats = Fb ) ; function xb ( ) { this . filedata = new Map } xb . prototype . read = async function ( a , b , c ) { return ( a = this . filedata . get ( a ) ) ? a . subarray ( b , b + c ) : null } ; xb . prototype . cache = async function ( a , b ) { this . filedata . set ( a , b ) } ; xb . prototype . uncache = function ( a ) { this . filedata . delete ( a ) } ; function yb ( a , b ) { this . storage = a ; this . baseurl = b } yb . prototype . load _from _server = function ( a ) { return new Promise ( b => { r . load _file ( this . baseurl + a , { done : async c => { c = new Uint8Array ( c ) ; await this . cache ( a , c ) ; b ( c ) } } ) } ) } ;
yb . 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 ) } ; yb . prototype . cache = async function ( a , b ) { return await this . storage . cache ( a , b ) } ; yb . prototype . uncache = function ( a ) { this . storage . uncache ( a ) } ;
"undefined" !== typeof window ? ( window . MemoryFileStorage = xb , window . ServerFileStorageWrapper = yb ) : "undefined" !== typeof module && "undefined" !== typeof module . exports ? ( module . exports . MemoryFileStorage = xb , module . exports . ServerFileStorageWrapper = yb ) : "function" === typeof importScripts && ( self . MemoryFileStorage = xb , self . ServerFileStorageWrapper = yb ) ; var ha = 16384 , ia = 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 & ha ) && a [ 2 ] . push ( [ b , c ] ) ; a [ 3 ] = this . total _size ; a [ 4 ] = this . used _size ; return a = a . concat ( this . mounts ) } ;
Z . prototype . set _state = function ( a ) { this . inodes = a [ 0 ] . map ( b => { const c = new Gb ( 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 } ) } ;
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 , b ) { 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 c = a . fsroot ; this . used _size = a . size ; for ( a = 0 ; a < c . length ; a ++ ) this . LoadRecursive ( c [ a ] , 0 ) ; b && b ( ) } ;
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 === ha ? ( this . PushInode ( c , b , d ) , this . LoadDir ( this . inodes . length - 1 , a [ 6 ] ) ) : 32768 === e ? ( 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 && A ( e ) } ; Z . prototype . LoadDir = function ( a , b ) { for ( var c = 0 ; c < b . length ; c ++ ) this . LoadRecursive ( b [ c ] , a ) } ;
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 -- ) ) } ;
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 ) : ( y . Debug ( "Error in Filesystem: Pushed inode with name = " + c + " has no parent" ) , y . Abort ( ) ) } ;
function Gb ( 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 }
Gb . prototype . get _state = function ( ) { const a = [ ] ; a [ 0 ] = this . mode ; a [ 1 ] = ( this . mode & 61440 ) === ha ? [ ... this . direntries ] : 32768 === ( this . mode & 61440 ) ? 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 } ;
Gb . prototype . set _state = function ( a ) { this . mode = a [ 0 ] ; if ( ( this . mode & 61440 ) === ha ) { this . direntries = new Map ; for ( const [ b , c ] of a [ 1 ] ) this . direntries . set ( b , c ) } else 32768 === ( this . mode & 61440 ) ? 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 Hb ; 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 ] ; this . qid . type = ( this . mode & 61440 ) >> 8 ; this . qid . version = a [ 11 ] ; this . qid . path = a [ 12 ] ; this . nlinks = a [ 13 ] } ;
Z . prototype . divert = function ( a , b ) { const c = this . Search ( a , b ) , d = this . inodes [ c ] , e = new Gb ( - 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 Gb ( ++ this . qidcounter . last _qidnumber ) ; b . atime = b . ctime = b . mtime = a ; return b } ;
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 | ha ; 0 <= b && ( c . uid = this . inodes [ b ] . uid , c . gid = this . inodes [ b ] . gid , c . mode = this . inodes [ b ] . mode & 511 | ha ) ; c . qid . type = ha >> 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 = 128 ; c . mode = this . inodes [ b ] . mode & 438 | 32768 ; this . PushInode ( c , b , a ) ; this . NotifyListeners ( this . inodes . length - 1 , "newfile" ) ; return this . inodes . length - 1 } ;
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 } ;
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 ) == ha && 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 == ia && ( b . status = - 1 , await this . DeleteData ( a ) ) } ;
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 } ;
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 ) } } ;
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 } ;
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 ) } ;
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 } ;
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 = ia , this . NotifyListeners ( c , "delete" ) ) ; return 0 } ;
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 } ;
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 ) } } ;
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 } } ;
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 ) ) } ;
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 && ( 32768 == ( this . inodes [ b . id ] . mode & 61440 ) ? this . Unlink ( b . parentid , b . name ) : ( this . inodes [ b . id ] . mode & 61440 ) == ha && ( 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 && y . 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 ) && y . Debug ( "Error in filesystem: negative parent id " + a ) ; for ( const [ c , d ] of b . direntries ) { 0 === c . length && y . Debug ( "Error in filesystem: inode with no name and id " + d ) ; for ( const e of c ) 32 > e && y . Debug ( "Error in filesystem: Unallowed char in filename" ) } } } } ;
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 + Ib . UTF8Length ( d ) ; a = this . inodedata [ a ] = new Uint8Array ( c ) ; b . size = c ; c = 0 ; for ( const [ d , e ] of b . direntries ) b = this . GetInode ( e ) , c += v . Marshall ( [ "Q" , "d" , "b" , "s" ] , [ b . qid , c + 13 + 8 + 1 + 2 + Ib . UTF8Length ( d ) , 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 = v . 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 ) === ha } ;
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 ) } ;
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 Jb ( a ) { this . fs = a ; this . backtrack = new Map }
Jb . prototype . get _state = function ( ) { const a = [ ] ; a [ 0 ] = this . fs ; a [ 1 ] = [ ... this . backtrack ] ; return a } ; Jb . 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 ) } ;
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 ) } ;
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 Jb ( b ) ) ; b = this . create _forwarder ( c , 0 ) ; this . link _under _dir ( a . parentid , b , a . name ) ; return b } ;
function Hb ( ) { this . type = 2 ; this . start = 0 ; this . length = Infinity ; this . proc _id = - 1 ; this . client _id = "" } Hb . 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 } ; Hb . 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 ] } ; Hb . prototype . clone = function ( ) { const a = new Hb ; a . set _state ( this . get _state ( ) ) ; return a } ;
Hb . 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 } ; Hb . prototype . is _alike = function ( a ) { return a . proc _id === this . proc _id && a . client _id === this . client _id && a . type === this . type } ; Hb . 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 Hb ; 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 } ;
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 ,
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 y = { Debug : function ( a ) { [ ] . slice . apply ( arguments ) . join ( " " ) } , Abort : function ( ) { } } ; var v = { 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 ; for ( var m of e ) Kb ( m . charCodeAt ( 0 ) ) . forEach ( function ( n ) { c [ d ++ ] = n ; g += 1 ; l ++ } ) ; c [ k + 0 ] = l & 255 ; c [ k + 1 ] =
l >> 8 & 255 ; break ; case "Q" : v . Marshall ( [ "b" , "w" , "d" ] , [ e . type , e . version , e . path ] , c , d ) ; d += 13 ; g += 13 ; break ; default : y . Debug ( "Marshall: Unknown type=" + a [ f ] ) } return g } , 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 ; for ( var k = "" , l = new Lb , m = 0 ; m < f ; m ++ ) { var n = l . Put ( b [ d ++ ] ) ; - 1 != n && ( k += String . fromCharCode ( n ) ) } e . push ( k ) ; break ; case "Q" : c . offset = d ; f = v . Unmarshall ( [ "b" , "w" , "d" ] , b , c ) ; d = c . offset ; e . push ( { type : f [ 0 ] , version : f [ 1 ] , path : f [ 2 ] } ) ; break ; default : y . Debug ( "Error in Unmarshall: Unknown type=" + a [ g ] ) } c . offset = d ; return e } } ; var Ib = { } ; function Lb ( ) { this . stream = new Uint8Array ( 5 ) ; this . ofs = 0 ; this . Put = function ( a ) { this . stream [ this . ofs ] = a ; this . ofs ++ ; switch ( this . ofs ) { case 1 : if ( 128 > this . stream [ 0 ] ) return this . ofs = 0 , this . stream [ 0 ] ; break ; case 2 : if ( 192 == ( this . stream [ 0 ] & 224 ) && 128 == ( this . stream [ 1 ] & 192 ) ) return this . ofs = 0 , ( this . stream [ 0 ] & 31 ) << 6 | this . stream [ 1 ] & 63 } return - 1 } } function Kb ( a ) { if ( 128 > a ) return [ a ] ; if ( 2048 > a ) return [ 192 | a >> 6 & 31 , 128 | a & 63 ] }
Ib . UTF8Length = function ( a ) { for ( var b = 0 , c = 0 ; c < a . length ; c ++ ) { var d = a . charCodeAt ( c ) ; b += 128 > d ? 1 : 2 } return b } ; } ) . call ( this ) ;