RE: MSI on Intel APIC

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Hello Peter,

Yes, I'm using a virtual address to write to that physical address (I'm
building page tables myself, something like what ioremap() does) 

:-(

Rajat 

> -----Original Message-----
> From: Peter Teoh [mailto:htmldeveloper@xxxxxxxxx] 
> Sent: Sunday, June 21, 2009 5:26 PM
> To: Rajat Jain
> Cc: Pei Lin; kernelnewbies@xxxxxxxxxxxx; 
> linux-newbie@xxxxxxxxxxxxxxx; Nguyen, Tom L
> Subject: Re: MSI on Intel APIC
> 
> On Fri, Jun 19, 2009 at 1:40 PM, Rajat 
> Jain<Rajat.Jain@xxxxxxxxxxxx> wrote:
> >
> > Hello Pei / Tom,
> >
> > Thanks for the response. Actually I understand why the 
> error is coming,
> > but my question is a little different.
> >
> > I'm saying that I understand that MSI works like following:
> >
> > 1) The device is given "an address" and a "value" (using MAR & MDR
> > registers) that it can use later on to generate an interrupt.
> > 2) The device later on when wants to send an interrupt, simply write
> > this "value" into that address using a PCI write transaction.
> > 3) This "address" and "value" is decided by the Intel APIC 
> architecture
> > (described in section 9.12 (MSI) of ""Intel 64 and IA-32 
> Architectures
> > Software Developer's Manual"
> > http://www.intel.com/Assets/PDF/manual/253668.pdf).
> > 4) It is the responsibility of the Intel APIC to generate 
> an interrupt
> > to the processor when that "value" is written to that "address".
> >
> > Now my question is simply this:
> >
> > Question
> > ========
> > APIC generates an interrupt when the device writes that "value" into
> > that "address". But will it also generate an interrupt if a SOFTWARE
> 
> normally, when a device write to an address, it is a physical address
> from the device's perspective.
> 
> > writes that same "value" into the same "address"????
> 
> but when a CPU write to an address, due to MMU/pagetable in operation,
> it is always a virtual address, that have yet to be translated to a
> physical address.   the API ioremap() and friends are used for getting
> virtual address that will map to the physical address of the hardware
> device.
> 
> >
> > Currently, my software tries the same and gets the APIC 
> error interrupt.
> > Which is partly justified by the section 9.6.3 (Illegal 
> register access)
> > since the "address" specified by the same specification (sec 9.12.1)
> > actually falls into the reserved category. But since the 
> device can use
> > that address, theoritically my SW should also be able to? No?
> 
> whether it is the hardware device accessing the DMA memory or software
> accessing the DMA memory, is the same.   yes, should be able to.   but
> u have to make sure that they are touching the same physical address.
>  not sure if ioremap() have been used?
> 
> sorry if my answer is incorrect......just trying my luck...:-).
> 
> >
> > Thanks & Best Regards,
> >
> 
> 
> 
> 
> 
> -- 
> Regards,
> Peter Teoh
> 

--
To unsubscribe from this list: send an email with
"unsubscribe kernelnewbies" to ecartis@xxxxxxxxxxxx
Please read the FAQ at http://kernelnewbies.org/FAQ



[Index of Archives]     [Newbies FAQ]     [Linux Kernel Mentors]     [Linux Kernel Development]     [IETF Annouce]     [Git]     [Networking]     [Security]     [Bugtraq]     [Yosemite]     [MIPS Linux]     [ARM Linux]     [Linux RAID]     [Linux SCSI]     [Linux ACPI]
  Powered by Linux