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

Re: [openrisc] PIC documentation



Scott,
 
before we make a rush decision let see what are some other options.
 
How about clearing pending interrupts in PICSR by reading PICSR register. This would constitute an atomic interrupt read/clear operation. You get pending interrupts and ack them by single PICSR read operation. Any current software would have to be modified if it doesn't store PICSR status already and therefore this could mean that current software wouldn't have to be modified and there would be no two version of the software in the future.
 
regards,
Damjan
 
----- Original Message -----
Sent: Tuesday, February 25, 2003 7:00 AM
Subject: RE: [openrisc] PIC documentation

[Sorry for the lag in reply – somehow missed your message until just now.]

 

You could, as I mentioned in a previous message add an acknowledgement register (PICAR) to the PIC architecture definition.  A one bit written to the PICAR would atomically clear the corresponding bit in the PICSR.  Additionally, it is traditional to provide a similar capability to force an interrupt in software, i.e. a new PIC register that would be OR’ed into the PICSR when it is written.

 

Code written for the existing PIC would continue to work on the “new and improved” PIC (although it might suffer from the aforementioned race conditions if any edge-triggered interrupts are used).  Unfortunately, code designed to work with the new PIC would not work on designs that used the old PIC.  For those that are maintaining OpenRISC SW that must work on an existing OpenRISC-based platform as well as some later OpenRISC implementation, that could be a bit of a pain. I think your willingness to make a change like this hinges on your perception of how close to “1.0 release” the architecture is.

 

An alternate approach would be to document in the architecture manual that the PIC, as defined, is only suitable for level-triggered interrupts and that for edge-triggered interrupts, an external (not defined by the architecture) interrupt controller needs to be connected to one of the PIC’s inputs.

 

 

-----Original Message-----
From: owner-openrisc@opencores.org [mailto:owner-openrisc@opencores.org] On Behalf Of Damjan Lampret
Sent:
Friday, February 21, 2003 8:27 AM
To: openrisc@opencores.org
Subject: Re: [openrisc] PIC documentation

 

Scott,

 

do you have a suggestion how to keep OR1200 as it is and make definition of PIC broader to fit also the edge triggered interrupt scheme?