[PATCH 3/4] dt/bindings: Introduce the FSL QorIQ DPAA QMan

Geoff Thorpe Geoff.Thorpe at freescale.com
Fri Oct 24 00:51:14 AEDT 2014


Thought I'd comment too on the interrupt question for the block-level (not portal-level) node;

> -----Original Message-----
> From: Mark Rutland [mailto:mark.rutland at arm.com]
> Sent: October-23-14 7:26 AM
> To: Medve Emilian-EMMEDVE1
> 
> [...]
> 
> > > You also seem to have an interrupt in the example. How many do you
> > > expect, and what are their their logical functions?
> >
> > That's the error interrupt and hopefully it never triggers. I didn't
> add
> > [many] words about it as it's a standard property
> 
> While the interrupts property is standard, it is only standard in the
> sense that the name and format are standard. Not every bidning has an
> interrupts property, and the set of interrupts described are specific
> to
> the binding. Please describe the set of interrupts you expect.
> 
> Does the device only have the error interrupt, or is that the only
> interrupt you care about?

So as with the portals, the blocks themselves each have a single interrupt line, but a number of the (CCSR) registers are related to that interrupt to capture the codes and attributes of the various error conditions being reported, because a wide variety of events and information can be conveyed through that interrupt line. In general, yes, this interrupt line is only for "errors", but some errors are more equal than others. Eg. there is the usual class of catastrophic DMA-failure, ECC, hardware-internal-inconsistency types of errors that devices tend to shout about. But there are also threshold-based "resource starvation" types of "errors" too, which are not really errors per se, unless the system configuration and use-case is explicitly engineered and constrained such that the thresholds shouldn't ever get tripped.

So the handling of the interrupt involves interrogating registers to classify the why, how, and what, and the reaction to it (whether a write-to-clear is needed, whether it should be masked, whether functionality should be halted, ...) is also a fairly elaborate question.

I don't know what the expectations are for these "bindings" docs, but the request to "describe the set of interrupts you expect" does risk opening a fairly elaborate can of worms (that may be better confined to the driver). Unless I misunderstood the request, which is always quite possible before my second coffee...

Cheers,
Geoff




More information about the Linuxppc-dev mailing list