flat assembler
Message board for the users of flat assembler.
  
|  Index
      > OS Construction > ATAPI Read Help Goto page 1, 2 Next | 
| Author | 
 | 
| smiddy 26 Nov 2015, 15:59 Greetings All,
 I'm stuck. I am providing a code fragment for you perusal to see if, where I'm going wrong. If I allow for the interrupt to happen, it fails even if I add 5 seconds to the delay time. I am leveraging the ATAPI C code fragment from http://wiki.osdev.org/ATAPI for the following code: Code: .IDEBootDrive: ; Leads into loading VENDORS.TXT from CD-ROM, like the floppy interface above cmp word [BootDrive.IOPort],0 ; Check for zero in the port address, from BootDrive.ASM [INT 13h AH=48h from EDD] je .AHCIBootDrive ; If so, go to AHCI drive interface ; Need to determine is ATA or ATAPI, assumes ATAPI for now ; Read IDE drive information, then get VENDORS.TXT mov esi,IDEPortMessage ; Load IDE Port Message into ESI call PrintString32 ; Print ESI to the screen movzx eax,word [BootDrive.IOPort] ; Place boot drive's IO Port into EAX, from BootDrive.ASM [INT 13h AH=48h from EDD] mov cl,16 ; Setup to display only 16 bits call ToHex32 ; Convert EAX to Hex Text mov esi,HexBuffer32 ; Load ESI with Hexed EAX Text call PrintString32 ; Print ESI to the screen mov esi,TheEndOfLine call PrintString32 ; Print ESI to the screen mov esi,IDEIRQMessage ; Load ESI with IDE IRQ Message call PrintString32 ; Print ESI to the screen movzx eax,byte [BootDrive.IRQ] ; Place boot drive's IRQ number into EAX, from BootDrive.ASM [INT 13h AH=48h from EDD] mov cl,8 ; Setup to display only 8 bits call ToHex32 mov esi,HexBuffer32 call PrintString32 ; Print ESI to the screen mov esi,TheEndOfLine call PrintString32 ; Print ESI to the screen cli ; Stop interrupts call DisableAllIRQs ; Disable all IRQs mov esi,IDEISR ; IDEISR address into ESI movzx eax,byte [BootDrive.IRQ] ; IRQ number to assign the IDE to, from BootDrive.ASM [INT 13h AH=48h from EDD] call AddISRToIDT ; Set this IRQ/ISR sti ; Restart interrupts movzx eax,byte [BootDrive.IRQ] ; IRQ for BootDrive into EAX, from BootDrive.ASM [INT 13h AH=48h from EDD] call EnableAnIRQ ; Set this IRQ to ON mov esi,BootDriveNumberMessage ; Load ESI with Boot Drive Number Message call PrintString32 ; Print ESI to the screen movzx eax,byte [BootDrive.DeviceNumber] ; Load EAX with boot drive's device number, from BootDrive.ASM [INT 13h AH=48h from EDD] ; shl al,4 ; Shift 4 bits left [not needed, done in mov [Drive32],al ; Update variable with unshifted drive number mov cl,8 ; Setup to display 8 bits call ToHex32 mov esi,HexBuffer32 call PrintString32 mov esi,TheEndOfLine call PrintString32 mov dword [SectorSize32],2048 ; Setup CD-ROM sector size (hard setting for now) mov [StartingSector32],16 ; Setup variable with Primary Volume Descriptor sector mov [NumberOfSectors32],1 ; Setup variable with to read in one sector mov edi,ATAPIBootSectorData ; Load EDI with read in destination (will make this dynamic later) call IDEATAPIRead ; Go read the CD-ROM ; Check address 3 and address 2 for size? mov eax,dword [ATAPIBootSectorData+158] ; Get the root director sector location (offset 156 should be 34 for the length in bytes of the root directory entry) ; DEBUG ------------------; mov esi,StartingCDROMDirectoryMessage ; Load ESI with starting sector of CD-ROM directory entry call PrintString32 ; Print ESI to the screen mov cl,32 ; Setup for 32 bits call ToDecimal32 ; Convert to decimal text mov esi,DecimalBuffer32 ; Load ESI with the decimal text buffer call PrintString32 ; Print ESI to the screen mov esi,TheEndOfLine ; Load 13,10,0 into ESI call PrintString32 ; Print ESI to the screen ; DEBUG ------------------; jmp .Done ; Finito .AHCIBootDrive: mov esi,AHCIDriveLookMessage call PrintString32 jmp .Done ; Print ESI to the screen .Done: ret ATAPIBootSectorData: TIMES 2048 db 0 ; Buffer for reading a sector from the CD-ROM StartingCDROMDirectoryMessage db 'Root directory starting sector: ',0 ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; ;; IDEATAPIPacket - This routine sends a packet to ATAPI device. Originally ;; written by Craig Bamford(ASHLEY4 ala Dex4U) over at ;; flatassembler. Adjusted for use here. ;; ;; Assumes: ESI = pointer 12 byte packet to be sent ;; [Port32] = base port of the device ;; [Drive32] = drive number to use ;; ;; ToDo - buffering for read and (potentially) write operations ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; IDEATAPIPacket: xor edx,edx mov ebx,0ffffh mov ecx,ebx mov dx,[Port32] ; Base Port add dx,7 ; Read Status = 7 + the base = ex. if base port is 170h then 177h .StatusReg1_1: in al,dx ; Mov data from port to al and al,80h ; Check bit 7(busy bit) ,loop if not 0 jz .WriteCommand1_1 ; Jump to WriteCommand1_1 if al bit7 =0 loop .StatusReg1_1 ; If al bit 7 = 1, loop StatusReg1_1 ret ; If CX = 0, return to caller .WriteCommand1_1: dec edx ; (ala 176h) ; xor eax,eax ; Bit 4 ,0 to select primary drive, 1 to select secondary drive mov al,[Drive32] ; Place drive number into AL shl al,4 ; Mov it to the left 4 bits (0 = 0; 1 = 10h after), from BootDrive.ASM [INT 13h AH=48h from EDD Device Number] out dx,al ; Write AL to port (register) mov ecx,ebx ; Mov cx, number of loops(bx=0xffff) inc edx ; Back to status port .StatusReg2_1: in al,dx ; Mov data from port to al and al,80h ; Check bit 7(busy bit) ,loop if not 0 jz .WriteCommand2_1 ; Jump to WriteCommand2_1 if al bit7 =0 loop .StatusReg2_1 ; If al bit 7 =1,loop StatusReg2_1 .DeviceBusy_1: ; time out I am also uploading two different views. One from Bochs and one from VirtualBox. On my PC I get the same results as Bochs. Any help will be appreciated, thanks! 
 
 | |||||||||||||||||||
|  26 Nov 2015, 15:59 | 
 | ||||||||||||||||||
| smiddy 02 Dec 2015, 01:09 Thanks taking a look. I'll tackle your questions in sequential order:
 1) I have tried it on actual hardware. The configuration there is kind of different than these two emulators. But they should, in theory, work the very same. (the read function looks at two words from the I/O port, I'm assuming since something is wrong, it fills them with 0FFFFFFFFh, ala 4,294,967,295 bytes). I do assume that due to their respective settings for the drives and controllers, that may be a part of the anomaly. 2) VirtualBox: Primary IDE controller: Master = my OS iso image (no other HDDs or CD/DVDs). Bochs: ata0-master: type=disk, mode=flat, path="D:\1G-3Copy.img" ata0-slave: type=cdrom, path="D:\SmiddyOS\OS\booting\iso9660smiddy.iso", status=inserted ata1-master: type=disk, mode=flat, path="D:\1G-1.img" ata1-slave: type=disk, mode=flat, path="D:\1G-2Copy.img". I have swapped the drives around, and placed the ISO on a tertiary (non-PCI based controller) and received the same things. 3) I will be working on AHCI, SATA, USB, and SAS interfaces in the future. I do have it configured for the IDE interface (double check the port I/O being announced, also, ambiguous in this display for DEBUG only, the interface number indicates ISA/IDE. This comes from BIOS on boot up INT 13h AH=48h from the EDD). The fact that you haven't done so doesn't mean you can't be helpful. That is part of the learning process in my mind. Plus you'll get to experience my pitfalls and perhaps avoid them on your own attempts. I have done some changes to the code and did get some different results (see attachments). Note that now I have three different results from three different emulators. Hyper-V doesn't even allow the packet to be sent to the controller with the information to read. VirtualBox I can at least read the base sector (sector 16) of the CD now, but subsequent reads fail. With Bochs I'm able to read the boot sector (Primary Volume Descriptor) and discern the information there and read the root directory from the CD-ROM. My next step probably tomorrow, is to try to read in the file, one sector at a time for now, based on the root directory information (what is displayed there is the filename, the size in bytes, and the beginning sector in LBA where it is located on the CD-ROM. Secondary NOTE: none of these does the IRQ fire, I'm bypassing that for the moment. I am looking on and off at using the bus master DMA since it seems I can get 64k chunks of data at a time, but it requires the IRQ to fire. 
 
 
 | ||||||||||||||||||||||||||||
|  02 Dec 2015, 01:09 | 
 | |||||||||||||||||||||||||||
| nkeck72 02 Dec 2015, 01:19 Hmm, do you have any source code or images i can use for testing of my own? I can try to help to the extent of my knowledge and am willing to learn more if I have to (that's why we have Google!).
 ***Edit: Does the BIOS put E0 int DL for the boot drive for all cases? | |||
|  02 Dec 2015, 01:19 | 
 | 
| smiddy 02 Dec 2015, 03:13 Attached are the ISO (CD-ROM) image and a floppy image. It is certainly not ready for prime time...
 Well, scratch that, I tried to upload the iso and vfd, but both file extensions are not allowed. | |||
|  02 Dec 2015, 03:13 | 
 | 
| smiddy 02 Dec 2015, 03:16 nkeck72 wrote: Hmm, do you have any source code or images i can use for testing of my own? I can try to help to the extent of my knowledge and am willing to learn more if I have to (that's why we have Google!). No, on Hyper-V it is EF for the CD-ROM. My PC it is F0. | |||
|  02 Dec 2015, 03:16 | 
 | 
| nkeck72 02 Dec 2015, 03:20 Could you perhaps post a link to the source, I can compile and test from there. | |||
|  02 Dec 2015, 03:20 | 
 | 
| smiddy 02 Dec 2015, 12:04 No, it isn't ready. I will post it once I've completed version 1.0.0, which will not be for a long time, since it is taking me forever to work it.
 I will zip those two image files up though, when I get home from work. I seem to recall zip files where acceptable file extensions. | |||
|  02 Dec 2015, 12:04 | 
 | 
| smiddy 03 Dec 2015, 02:47 Let's see if a zip file works: 
 | |||||||||||
|  03 Dec 2015, 02:47 | 
 | 
| nkeck72 05 Dec 2015, 18:18 Very strange, I also must point out that I personally do not see in your code where this might screw up... And when I used the floppy image the bootloader mysteriously prints a repeating "1234567890" string before the Smiddy OS message. Other than that, the floppy image seems to boot up fine and proceeds to load VENDORS.TXT. Until that point I do not see the OS load an IDE driver, so I think you have every right to assume that there is something wrong with the ATAPI packet. I have not yet figured out what, but it does look awful suspicious...
 I must ask, in the routine when you are trying to create the ATAPI packet, do you mean to read LBA 0? Code: ReadPacket db 0A8h, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 ; Used below, see table above This may be causing problems, seeing as you are reading the bootloader. Note also that you are setting the drive to read 0 sectors, and that might be why the CD won't get read. | |||
|  05 Dec 2015, 18:18 | 
 | 
| smiddy 05 Dec 2015, 20:30   The floppy loader I have displaying repeating numbers, sequentially (80 across the screen or 80 sectors, so I know which sectors it load through) to show it is working. I am working towards getting the IDE interface (HDD and CD-ROMs; CD-ROMs first) to load VENDORS.TXT file. Incidentally, is a database downloaded, and can be updated from, PCIDatabase.com. It interfaces or is used with the PCI routine, which is scanned to display what hardware is installed on the system it is running on. ATAPI packet variable ReadPacket is updated on the fly with the sector number to read, and the number of sectors to read. Initially for a CD-ROM it reads sector 16. NOTE: CD-ROM sectors are 2,048 bytes in size. It then reads the contents of sector 16 (Primary Volume Descriptor, see ISO-9660) to determine where the boot directory is located, then updates teh packet variable again with the directory's (starting) sector, and reads in the first sector (for now, will be dynamic later). then I display the contents of the first five director entries (will again, be dynamic later). When I get back from running (5 miles of trail, love me some trail), I will update it to do a similar thing to loading of VENDORS.TXT from the CD-ROM since it appears Bochs seems to work, one sector at a time like the floppy. In the mean time, I have read up on the IDE controller some more. As it turns out, these controllers are all DMA boot mastering controller. That means I can setup a 64k memory area to have the controller download disc data to the memory area in 64k junks, so I will work that too. I still don't understand why it doesn't do an interrupt. NOTE: like the floppy, I set it up the very same way, so I'm at a loss as to why at the moment. I still don't understand why on my real machine and the Hyper-V emulator that it times out trying to send the read packet variable. The similarity between those two is that they are actually PCI interface controllers, versus the other are using ISA. There is likely something to that, and perhaps I'm force to use DMA transfers instead of PIO, which is what I'm trying to use, although it is interesting that it seems to call for an interrupt. So I need to understand that too. Thanks for trying it out. Did you try any of the the other commands? (Type HELP) Smiddy | |||
|  05 Dec 2015, 20:30 | 
 | 
| nkeck72 06 Dec 2015, 02:14 Yes I also tried a few commands, and all the ones I tried seem to be fully functional. Is it normal for me to boot from the floppy and it tell me "[No Drive]:\>"? All the commands work, but it does not appear to show me the current (logged) drive.
 It could be that the PCI systems and ISA systems differ in the use of PIO/DMA, I would experiment with that and see if you can implement a fix by detecting which type of controller there is present on the system. Also, you may want to double check this -- x86 processors are little endian devices, which means the words are byte-swapped when you load them into the registers. It's just a guess, but perhaps you meant to load up the packet as they are listed in order in RAM, but forget that you are loading the packet as 6 words and not 12 bytes. More than once I have done that in my own OS.  _________________ It may look hard, but it won't take long if you take it one byte at a time. NOS: www.github.com/nkeck720/nos | |||
|  06 Dec 2015, 02:14 | 
 | 
| smiddy 06 Dec 2015, 13:49 I don't have the drive information setup yet, which is why it says [No Drive]. I'm not sure about my convention yet, but was thinking of using numbers, 1 to n, where n is the last drive found in sequence, the boot drive of course being 1. I will implement that once I get it to boot from HDD, as then I will have all the boot types completed.
 Yeah, I suspect there is something to the PCI versus ISA thing. Yep, I have rechecked the Endian-ness, that's all good. Also the packet load is all good (works on Bochs). I should get the opportunity to work it today and load the file on Bochs. Once I do I'll post the resulting iso/floppy image. | |||
|  06 Dec 2015, 13:49 | 
 | 
| smiddy 07 Dec 2015, 12:24 Well, I got VENDORS.TXT to load within Bochs, however I uncovered a pointer problem with the PCI routine. So time to fix that before moving on... | |||
|  07 Dec 2015, 12:24 | 
 | 
| nkeck72 07 Dec 2015, 21:01 I thought it might be something PCI/ISA related. Send an ISO once you get that fixed!
 Also, do you happen to have a Git repo set up or a GitHub or (dare I say it) SourceForge page for this? _________________ It may look hard, but it won't take long if you take it one byte at a time. NOS: www.github.com/nkeck720/nos | |||
|  07 Dec 2015, 21:01 | 
 | 
| smiddy 08 Dec 2015, 12:32 Nope, I'm not using an online repository. I may once it is at the 1.0.0 stage.
 I solved the PCI routine issue with the pointer (this routine shows the installed devices; it uses VENDORS.TXT to display that information). I'll zip up the ISO and FLOPPY images after work today, then put them on here. So, my problem still is: - No interrupt firing - ATAPI read doesn't work on VirtualBox after first read -- I am assuming this is related to the interrupts not firing and general cleanup of that since the first read works (reading the boot directory or Primary Volume Descriptor) - Time out trying to send ATAPI packet on Hyper-V and real PC -- Both are PCI bus interfaces instead of so may have to use DMA transfer ToDo: - Study Bus Mastering ATAPI read, and implement that if available - Study up on IDE interrupt usage, implement usage I am going to work on saving the IDE drive information for retrieval now, rather than work the above first, then I will get back to trying to make it work with the other virtual machines and my PC. It working in Bochs is enough for now. After I get this working, then I'll start on AHCI. Oh, and IDE HDDs before AHCI... | |||
|  08 Dec 2015, 12:32 | 
 | 
| cod3b453 08 Dec 2015, 19:32 On VBox I noticed:     Quote: 00:00:10.259038 Guest Log: BIOS: int13_cdrom: unsupported AH=08 Quote: Offset Length The code I have for this doesn't wait for IRQ and just polls the status but everything else looks like same values and IO... | |||
|  08 Dec 2015, 19:32 | 
 | 
| smiddy 08 Dec 2015, 20:16 Thanks cod3b453!
 I forget to look at those screens. The first sector should be 16, and it is reading it. However, the second read fails to load the directory sector, which it does when I use Bochs. Everything I've read so far says that I should wait for an interrupt after a read, but none of the emulators nor my PC do an interrupt within 3 seconds (I've upped that to 10 too on the delay). I'll give it a quick look again tonight, but I have less time tonight. | |||
|  08 Dec 2015, 20:16 | 
 | 
| smiddy 08 Dec 2015, 22:14 Here's the latest build. Note the screen shots from Bochs. 
 
 
 | |||||||||||||||||||||||||||||
|  08 Dec 2015, 22:14 | 
 | ||||||||||||||||||||||||||||
| smiddy 08 Dec 2015, 22:16 Here's what is happening on the VirtualBox. Note how the Root Directory Starting Sector is 23, so it is loading correctly the very first sector to read, but the subsequent one it fails. 
 | ||||||||||
|  08 Dec 2015, 22:16 | 
 | |||||||||
| Goto page 1, 2  Next < Last Thread | Next Thread > | 
| Forum Rules: 
 | 
Copyright © 1999-2025, Tomasz Grysztar. Also on GitHub, YouTube.
Website powered by rwasa.