git-svn-id: https://spexeah.com:8443/svn/Asuro@1319 6dbc8c32-bb84-406f-8558-d1cf31a0ab0c
This commit is contained in:
		| @@ -42,7 +42,7 @@ end; | ||||
| procedure register(); | ||||
| begin | ||||
|     memset(uint32(@Hooks[0]), 0, sizeof(pp_hook_method)*MAX_HOOKS); | ||||
|     isrmanager.registerISR(76, @Main); | ||||
|     //isrmanager.registerISR(76, @Main); | ||||
|     //IDT.set_gate(76, uint32(@Main), $08, ISR_RING_0); | ||||
| end; | ||||
|  | ||||
|   | ||||
| @@ -147,8 +147,8 @@ procedure readPIO28(drive : uint8; LBA : uint32; buffer : puint8); | ||||
| procedure writePIO28(drive : uint8; LBA : uint32; buffer : puint8); | ||||
| //read/write must be capable of reading/writting any amknt of data upto disk size | ||||
|  | ||||
| procedure read(device : PStorage_device; LBA : uint32; sectorCount : uint32; buffer : puint32); | ||||
| procedure write(device : PStorage_device; LBA : uint32; sectorCount : uint32; buffer : puint32); | ||||
| procedure dread(device : PStorage_device; LBA : uint32; sectorCount : uint32; buffer : puint32); | ||||
| procedure dwrite(device : PStorage_device; LBA : uint32; sectorCount : uint32; buffer : puint32); | ||||
|  | ||||
| implementation  | ||||
|  | ||||
| @@ -214,6 +214,7 @@ var | ||||
|     identResponse : TIdentResponse; | ||||
|     i : uint8; | ||||
| begin  | ||||
|     push_trace('IDE.Identify_Device'); | ||||
|     device_select(device); | ||||
|     no_interrupt(device); | ||||
|     port_write(ATA_REG_CONTROL, 0); | ||||
| @@ -256,10 +257,7 @@ begin | ||||
|     devID.id4:= idANY; | ||||
|     devID.ex:= nil; | ||||
|     drivermanagement.register_driver('IDE ATA Driver', @devID, @load); | ||||
|     //terminal.registerCommand('IDE', @test_command, 'TEST IDE DRIVER'); | ||||
|     buffer := Puint32(kalloc(1024*2)); | ||||
|     console.writestringln('[IDE] (INIT) END'); | ||||
|     pop_trace(); | ||||
| end; | ||||
|  | ||||
| function load(ptr : void) : boolean; | ||||
| @@ -272,7 +270,6 @@ var | ||||
| begin | ||||
|     push_trace('ide.load'); | ||||
|     console.writestringln('[IDE] (LOAD) BEGIN'); | ||||
|     //controller := PPCI_Device(ptr); | ||||
|     controller := PPCI_Device(ptr); | ||||
|  | ||||
|     console.writestringln('[IDE] (INIT) CHECK FLOATING BUS'); | ||||
| @@ -296,8 +293,8 @@ begin | ||||
|         masterDevice.sectorSize:= 512; | ||||
|         if masterDevice.maxSectorCount <> 0 then begin | ||||
|             IDEDevices[0].exists:= true; | ||||
|             masterDevice.readCallback:= @IDE.read; | ||||
|             masterDevice.writeCallback:= @IDE.write; | ||||
|             masterDevice.readCallback:= @dread; | ||||
|             masterDevice.writeCallback:= @dwrite; | ||||
|             storagemanagement.register_device(@masterDevice); | ||||
|         end; | ||||
|  | ||||
| @@ -311,18 +308,21 @@ begin | ||||
|     // buffer[4] := 5; | ||||
|     // buffer[5] := 6; | ||||
|     // writePIO28(0, 3, buffer); | ||||
|     // writePIO28(0, 3, buffer); | ||||
|     // writePIO28(0, 3, buffer); | ||||
|     // writePIO28(0, 4, buffer); | ||||
|     // writePIO28(0, 5, buffer); | ||||
|     // writePIO28(0, 5, buffer); | ||||
|     // writePIO28(0, 5, buffer); | ||||
|     // psleep(1000); | ||||
|     // writePIO28(0, 5, buffer); | ||||
|     // writePIO28(0, 5, buffer); | ||||
|     // writePIO28(0, 5, buffer); | ||||
|     // kfree(puint32(buffer)); | ||||
|  | ||||
|     console.writestringln('[IDE] (LOAD) END'); | ||||
|     pop_trace(); | ||||
| end; | ||||
|  | ||||
| // procedure flush(); | ||||
| // begin | ||||
| //     port_write(ATA_CMD_CACHE_FLUSH); | ||||
| //     if not is_ready() then exit; | ||||
| // end; | ||||
|  | ||||
| procedure readPIO28(drive : uint8; LBA : uint32; buffer : puint8); | ||||
| var | ||||
|     status : uint8; | ||||
| @@ -376,10 +376,14 @@ var | ||||
|     i: uint16; | ||||
|     device: uint8; | ||||
| begin  | ||||
|     push_trace('IDE.WritePIO28'); | ||||
|     if not validate_28bit_address(LBA) then begin | ||||
|         console.writestringln('IDE (writePIO28) ERROR: Invalid LBA!'); | ||||
|     end; | ||||
|  | ||||
|     console.writeintln(uint32(drive)); | ||||
|     console.writeintln(LBA); | ||||
|  | ||||
|     //Add last 4 bits of LBA to device port | ||||
|     if IDEDevices[drive].isMaster then begin | ||||
|         device:= ATA_DEVICE_MASTER; | ||||
| @@ -390,11 +394,12 @@ begin | ||||
|         device_select($F0 or ((LBA and $0F000000) shr 24)); //LBA primary slave | ||||
|     end; | ||||
|  | ||||
|     no_interrupt(device); | ||||
|     // no_interrupt(device); | ||||
|  | ||||
|     port_write(ATA_REG_ERROR, 0); | ||||
|     port_write(ATA_REG_CONTROL, 0); | ||||
|  | ||||
|     //check if bus is floating | ||||
|     // check if bus is floating | ||||
|     status := port_read(ATA_REG_COMMAND); | ||||
|     if status = $FF then exit; | ||||
|  | ||||
| @@ -407,9 +412,6 @@ begin | ||||
|     //send write command | ||||
|     port_write(ATA_REG_COMMAND, ATA_CMD_WRITE_PIO);  | ||||
|  | ||||
|         console.writestringlnWND('ide write start', getTerminalHWND()); | ||||
|     console.redrawWindows(); | ||||
|  | ||||
|     //write data | ||||
|     i:=0; | ||||
|     while i < 512 do begin | ||||
| @@ -417,40 +419,30 @@ begin | ||||
|         i:= i + 2; | ||||
|     end; | ||||
|  | ||||
|         console.writestringlnWND('ide write end', getTerminalHWND()); | ||||
|     console.redrawWindows(); | ||||
|  | ||||
|     //flush drive cache | ||||
|     psleep(1); | ||||
|     port_write(ATA_REG_COMMAND, ATA_CMD_CACHE_FLUSH); | ||||
|     psleep(1); | ||||
|     if not is_ready() then exit; | ||||
|  | ||||
|     console.writestringln('ide write end'); | ||||
|     console.redrawWindows(); | ||||
|  | ||||
| end; | ||||
|  | ||||
| procedure read(device : PStorage_device; LBA : uint32; sectorCount : uint32; buffer : Puint32); | ||||
| procedure dread(device : PStorage_device; LBA : uint32; sectorCount : uint32; buffer : Puint32); | ||||
| var | ||||
|     i : uint16; | ||||
| begin | ||||
|     // for i:=0 to sectorCount-1 do begin | ||||
|     //     readPIO28(device^.controllerId0, LBA, puint8(@buffer[512*i]));  | ||||
|     // end; | ||||
|  | ||||
|     readPIO28(device^.controllerId0, LBA, puint8(buffer));  | ||||
|  | ||||
|     for i:=0 to sectorCount-1 do begin | ||||
|         readPIO28(device^.controllerId0, LBA, puint8(@buffer[512*i]));  | ||||
|     end; | ||||
| end; | ||||
|  | ||||
| procedure write(device : PStorage_device; LBA : uint32; sectorCount : uint32; buffer : Puint32); | ||||
| procedure dwrite(device : PStorage_device; LBA : uint32; sectorCount : uint32; buffer : Puint32); | ||||
| var | ||||
|     i : uint16; | ||||
| begin | ||||
|     // for i:=0 to sectorCount-1 do begin | ||||
|     //     writePIO28(device^.controllerId0, LBA, puint8(@buffer[512*i])); | ||||
|     // end; | ||||
|      writePIO28(device^.controllerId0, LBA, puint8(buffer)); | ||||
|     for i:=0 to sectorCount-1 do begin | ||||
|         writePIO28(device^.controllerId0, LBA, puint8(@buffer[512*i])); | ||||
|     end; | ||||
|     // writePIO28(device^.controllerId0, LBA, puint8(buffer)); | ||||
| end; | ||||
|  | ||||
| end. | ||||
| @@ -833,73 +833,35 @@ begin //maybe increase buffer size by one? | ||||
|     console.writestringWND('sectorsize', getTerminalHWND()); | ||||
|     console.writeintlnWND(disk^.sectorsize, getTerminalHWND()); | ||||
|  | ||||
|     console.redrawWindows(); | ||||
|  | ||||
|     bt:= puint32(kalloc(512)); | ||||
|  | ||||
|     bt[1] := 1; | ||||
|     bt[2] := 1; | ||||
|     bt[3] := 1; | ||||
|     bt[4] := 1; | ||||
|     bt[5] := 1; | ||||
|     bt[6] := 1; | ||||
|     bt[7] := 11; | ||||
|     bt[8] := 33; | ||||
|     bt[9] := 22; | ||||
|     disk^.writecallback(disk, 3, 1, puint32(bt)); | ||||
|  | ||||
|  | ||||
|     // puint32(buffer)[127]:= $55AA; | ||||
|  | ||||
|         console.writestringlnWND('writting to bootrecord', getTerminalHWND()); | ||||
|         console.writeintlnWND(start + 1, getTerminalHWND()); | ||||
|     console.redrawWindows; | ||||
|  | ||||
|     disk^.writecallback(disk, start + 1, 1, puint32(buffer)); | ||||
|  | ||||
|         console.writestringlnWND('finished writting to bootrecord', getTerminalHWND()); | ||||
|  | ||||
|     console.redrawWindows; | ||||
|  | ||||
|     fatStart:= start + 1 + bootRecord^.rsvSectors; | ||||
|     dataStart:= fatStart + bootRecord^.FATSize; | ||||
|  | ||||
|     zeroBuffer:= puint32(kalloc( disk^.sectorSize )); | ||||
|     memset(uint32(zeroBuffer), 0, disk^.sectorSize ); | ||||
|  | ||||
|     // while true do begin | ||||
|     //     if i > FATSize then break;  | ||||
|     //     disk^.writecallback(disk, fatStart + i, 1, zeroBuffer); | ||||
|     //     i+=1; | ||||
|     // end; | ||||
|     while true do begin | ||||
|         if i > FATSize then break;  | ||||
|         disk^.writecallback(disk, fatStart + i, 1, zeroBuffer); | ||||
|         i+=1; | ||||
|     end; | ||||
|  | ||||
|     kfree(buffer); | ||||
|     kfree(zeroBuffer); | ||||
|     writestring('Frees'); | ||||
|     console.redrawWindows; | ||||
|         console.writestringlnWND('writting 1', getTerminalHWND()); | ||||
|     console.redrawWindows; | ||||
|  | ||||
|     buffer:= puint32(kalloc(disk^.sectorSize)); | ||||
|     memset(uint32(buffer), 0, disk^.sectorSize); | ||||
|         console.writestringlnWND('writting 1', getTerminalHWND()); | ||||
|     console.redrawWindows; | ||||
|  | ||||
|     puint32(buffer)[0]:= $FFFFFFF8; //fsinfo | ||||
|     puint32(buffer)[1]:= $FFFFFFF8; //root cluster | ||||
|     writestring('Buffer Alloc'); | ||||
|     console.redrawWindows; | ||||
|  | ||||
|     disk^.writecallback(disk, fatStart, 1, buffer); | ||||
|     writestring('WriteCB1'); | ||||
|     console.redrawWindows; | ||||
|  | ||||
|     kfree(buffer); | ||||
|  | ||||
|     buffer:= puint32(kalloc(disk^.sectorsize)); | ||||
|     memset(uint32(buffer), 0, disk^.sectorsize); | ||||
|     writestring('Buffer Alloc 2'); | ||||
|     console.redrawWindows; | ||||
|  | ||||
|     PDirectory(buffer)[0].fileName   := thisArray; | ||||
|     PDirectory(buffer)[0].attributes := $08; | ||||
| @@ -910,12 +872,8 @@ begin //maybe increase buffer size by one? | ||||
|     PDirectory(buffer)[1].clusterLow := 1; | ||||
|      | ||||
|     disk^.writecallback(disk, dataStart + (config^ * rootCluster), 1, buffer); | ||||
|     writestring('WriteCB2'); | ||||
|     console.redrawWindows; | ||||
|  | ||||
|     kfree(buffer); | ||||
|     writestring('Free'); | ||||
|     console.redrawWindows; | ||||
|  | ||||
| end; | ||||
|  | ||||
|   | ||||
| @@ -118,7 +118,7 @@ end; | ||||
|  | ||||
| { Disk subcommand for listing drives } | ||||
| procedure ls_command(params : PParamList); | ||||
| var | ||||
| var  | ||||
|     i : uint16; | ||||
| begin | ||||
|     push_trace('storagemanagment.ls_command'); | ||||
| @@ -152,15 +152,26 @@ end; | ||||
| procedure format_command(params : PParamList); | ||||
| var | ||||
|     driveIndex : uint16; | ||||
|     drive : PStorage_Device; | ||||
|  | ||||
|     filesystemString : pchar; | ||||
|     filesystem : PFileSystem; | ||||
|     spc : puint32; | ||||
| begin | ||||
|     // driveIndex:= stringToInt( getParam(params, 1) ); | ||||
|  | ||||
|     // PFilesystem(LL_Get(filesystems, 0))^.createCallback( | ||||
|     //     (PStorage_Device(LL_Get(storageDevices, drive))), 10000, 1, spc); //todo fs | ||||
|     spc:= puint32(kalloc(4)); | ||||
|     spc^:= 4; | ||||
|  | ||||
|     driveIndex:= stringToInt( getParam(1, params) ); | ||||
|     drive:= PStorage_Device(LL_Get(storageDevices, driveIndex)); | ||||
|  | ||||
|     //todo change b4 adding in aniother filesytem | ||||
|     PFilesystem(LL_Get(filesystems, 0))^.createCallback(drive, drive^.maxSectorCount-1, 1, spc);  | ||||
|  | ||||
|     writestringWnd('Drive ', getTerminalHWND); | ||||
|     writeintWnd(driveIndex, getTerminalHWND); | ||||
|     writestringlnWnd(' formatted.', getTerminalHWND); | ||||
|      | ||||
| end; | ||||
|  | ||||
|  | ||||
| @@ -172,6 +183,12 @@ var | ||||
|     subcmd : pchar; | ||||
| begin | ||||
|     push_trace('StorageManagment.disk_command'); | ||||
|  | ||||
|     //check if params wehre supplied | ||||
|     if paramCount(params) = 0 then begin | ||||
|         writestringlnWnd('Incorrect number of params.', getTerminalHWND); | ||||
|         exit; | ||||
|     end; | ||||
|      | ||||
|     subcmd:= getParam(0, params); | ||||
|  | ||||
| @@ -183,6 +200,7 @@ begin | ||||
|  | ||||
|     //format command for clearing a disk and make a new volume | ||||
|     if stringEquals(subcmd, 'format') then begin | ||||
|         format_command(params); | ||||
|     end; | ||||
|  | ||||
|     //lsfs command for listing filesystems | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 aaron
					aaron