Interrupts on PPC 405Gr

MERRITT Nigel Nigel.Merritt at tenix.com
Fri Feb 6 14:37:18 EST 2004


The kernel is 2.4.18 from Timesys.
We have a logic analyser hooked up so we know for certain that the
signal is being generated on the correct line and is entering the UIC.

CPC0_CR0 is being set using the (probably very wrong) code:

      register_val = mfdcr(CPC0_CR0); // Read value from the register.

      // Set to 0.
      register_val = register_val & MASK_BIT_NOT_6;
      register_val = register_val & MASK_BIT_NOT_7;
      register_val = register_val & MASK_BIT_NOT_16;
      register_val = register_val & MASK_BIT_NOT_17;
      register_val = register_val & MASK_BIT_NOT_18;

      // Set to 1.
      register_val = register_val | MASK_BIT_9;
      register_val = register_val | MASK_BIT_10;
      register_val = register_val | MASK_BIT_12;
      register_val = register_val | MASK_BIT_13;

      // Write the value back to the register.
      mtdcr(CPC0_CR0, register_val);

Please tell me the correct way to set these registers, as I can't find
the functions to call in our documentation.
Polarity and trigger settings are being set in a similar manner, i.e:

      // Write the value back to the register.
      mtdcr(CPC0_CR0, register_val);

      //////////////////////////////////////
      // Set the interrupts to falling edge.
      //////////////////////////////////////
      register_val = mfdcr(UIC0_TR);
      register_val = register_val | MASK_BIT_24;
      register_val = register_val | MASK_BIT_30;
      register_val = register_val | MASK_BIT_31;
      mtdcr(UIC0_TR, register_val);

Again, how do these get set if not by adjusting the registers?

The GPIO lines are set up as follows:

      reg = (unsigned int*)GPIO0_TCR;
      register_val = *reg;
      register_val = register_val | MASK_BIT_14;
      register_val = register_val | MASK_BIT_17;
      *reg = register_val;

The request_irq call is:

   res = request_irq(5, DataReadyInterrupt,
                     SA_INTERRUPT, "fpga_o", reg_handle_o);

..with the handler being:

   void DataReadyInterrupt(int par1, void *par2, struct pt_regs *par3)

Many thanks,
   Nigel

-----Original Message-----
From: Eugene Surovegin [mailto:ebs at ebshome.net]
Sent: Friday, 6 February 2004 1:38 PM
To: MERRITT Nigel
Cc: linuxppc-embedded at lists.linuxppc.org
Subject: Re: Interrupts on PPC 405Gr


On Fri, Feb 06, 2004 at 01:47:28PM +1100, MERRITT Nigel wrote:
>
> I am using an IBM PowerPC 405Gr and have been trying to set up IRQ5 as
an interrupt.
> My problem is that the UIC0_ER (interrupt enable) register is not
being set by the request_irq call.
> Does anyone know of other calls that need to be made in order to allow
the interrupt enable register to stay set?
> I have used enable_irq after request_irq but this also has no affect.
As this is from a driver,
> I have even tried setting the correct bit (bit 30 for IRQ 5) directly,
by reading UIC0_ER, ORing
> bit 30 and writing the value back - reading and writing were performed
using mfdcr and mtdcr.
> I also use mtmsr to set the general interrupt enable bit (EE - bit
16)) in the MSR register.
>

Please, don't touch MSR and UIC registers. request_irq should work
just fine (I never had problems with UIC on 405 boards).

Probably you are doing something completely wrong.

Some questions:

1) What kernel tree are you using?

2) Are you sure IRQ5 is actually _generated_ by your external device?
Did you use scope to verify this?

3) Are you sure IRQ5 is enabled in CPC0_CR0 register and not used as
GPIO? Are the polarity and trigger settings are correct for your
external device?

Please, provide more detailed info (with all registers values and/or
code samples) if you wanted somebody to help you.

Eugene.

** Sent via the linuxppc-embedded mail list. See http://lists.linuxppc.org/





More information about the Linuxppc-embedded mailing list