flat assembler
Message board for the users of flat assembler.

Index > Main > IOAPIC delay ?

Author
Thread Post new topic Reply to topic
ouadji



Joined: 24 Dec 2008
Posts: 1080
Location: Belgium
ouadji 25 Apr 2011, 09:46

do I put a delay between writing and reading of a IOAPIC register
Code:
;P5Q Pro Q6600 2.8Ghz

;proc SetIntIrq IRQ:dword, INT:dword, mask:dword

    ...
 mov     ebx,[IRQ]
   mov     eax,[mapped_IOAPIC_base]

        lea     ebx,[(ebx*2)+10h]
   mov     [eax],ebx               ;IO_APIC[0]=IOREGSEL

    ;delay <--------  Question

        mov     ebx,[eax+(4*4)]         ;IO_APIC[4]=IOWIN
   ...

    

_________________
I am not young enough to know everything (Oscar Wilde)- Image
Post 25 Apr 2011, 09:46
View user's profile Send private message Send e-mail Reply with quote
revolution
When all else fails, read the source


Joined: 24 Aug 2004
Posts: 20754
Location: In your JS exploiting you and your system
revolution 25 Apr 2011, 10:00
ouadji wrote:
do I put a delay between writing and reading of a IOAPIC register
No.

The CPU is already many times faster than the I/O bus, so any short delay you might try to insert would have no affect anyway.
Post 25 Apr 2011, 10:00
View user's profile Send private message Visit poster's website Reply with quote
ouadji



Joined: 24 Dec 2008
Posts: 1080
Location: Belgium
ouadji 25 Apr 2011, 11:24

thanks for your reply revolution

If the CPU is many times faster than the I/O bus,
will the data be available when the CPU will read it ?
and this in any cases ?
If the I/O bus and IOAPIC are slower than cpu,
the data will be maybe not yet available or not yet stable ?
(is there a waiting signal between the IOAPIC and the cpu?)

_________________
I am not young enough to know everything (Oscar Wilde)- Image
Post 25 Apr 2011, 11:24
View user's profile Send private message Send e-mail Reply with quote
revolution
When all else fails, read the source


Joined: 24 Aug 2004
Posts: 20754
Location: In your JS exploiting you and your system
revolution 25 Apr 2011, 11:41
The I/O bus takes care of all the timing. Don't worry about it. The hardware knows what it is doing. You don't need to do anything software-wise to make it work.
Post 25 Apr 2011, 11:41
View user's profile Send private message Visit poster's website Reply with quote
ouadji



Joined: 24 Dec 2008
Posts: 1080
Location: Belgium
ouadji 25 Apr 2011, 12:54

ok, understood, thank you revolution.

_________________
I am not young enough to know everything (Oscar Wilde)- Image
Post 25 Apr 2011, 12:54
View user's profile Send private message Send e-mail Reply with quote
b1528932



Joined: 21 May 2010
Posts: 287
b1528932 25 Apr 2011, 13:35
no delay is ever needed when writing using mmio/pio.
if hardware needs time to do something and return in other register, it must provide away for you to poll it or trigger irq on completion.
In case of polling, for example you write to one register, and constantly read second one untill highest bit is 1. When its 1, you reset it (write this register again with msb =0) and assume data is 'correct'. This is just an example. If you must write multiple times something on register, i have bad news, you cant do that. You must use polling method every time. If hardware doesnt support it, it sucks. As far as i remember, PIC initialization require writing 2+ icw one after another to 1 register. This is a bad design as controller might be too slow compared to cpu.
Post 25 Apr 2011, 13:35
View user's profile Send private message Reply with quote
ouadji



Joined: 24 Dec 2008
Posts: 1080
Location: Belgium
ouadji 25 Apr 2011, 16:06
Quote:

it must provide a way for you to poll it or trigger irq on completion.

(in advance, sorry for my English, I do my best) Confused

In the case of ioapic, there is nothing to do that.
(like you say.... polling or other ways).
It seems that the hardware (ioapic) did not need delay to react.
(since it gives no way to check this delay)
Having said that, currently, the ioapic is part of Southbridge,
that's maybe why it reacts so quickly to requests from the cpu.

_________________
I am not young enough to know everything (Oscar Wilde)- Image
Post 25 Apr 2011, 16:06
View user's profile Send private message Send e-mail Reply with quote
Display posts from previous:
Post new topic Reply to topic

Jump to:  


< Last Thread | Next Thread >
Forum Rules:
You cannot post new topics in this forum
You cannot reply to topics in this forum
You cannot edit your posts in this forum
You cannot delete your posts in this forum
You cannot vote in polls in this forum
You cannot attach files in this forum
You can download files in this forum


Copyright © 1999-2025, Tomasz Grysztar. Also on GitHub, YouTube.

Website powered by rwasa.