This discussion has been locked.
You can no longer post new replies to this discussion. If you have a question you can start a new discussion

IRQ Not Firing

Hello,

I am writing an I2C master transmitter object. The problem I am having is that the IRQ Handler for I2C1 is not firing. According to the manual, it should fire after the start condition is sent and the status register is 0x08. When I step through the code with the debugger, the status code is 0x08. I am using an MCB1700 development board. Why is it not firing? Did I not configure something properly? For tests, All I am doing is toggling an LED on when the interrupt fires. Once I solve this problem, I will write the rest of the code.

#include <stdio.h>
#include <LPC17XX.h>
#include "GPIO1Output.h"

GPIO1Output out(P1_28);

__irq void I2C1_IRQHandler(void)
{
        if (LPC_I2C1->I2STAT == 0x08)
        {
             out.Set();
        }
}

int main(void)
{
        // Initialize I2C.
        LPC_PINCON->PINSEL0 = 0x0F;
        LPC_PINCON->PINMODE_OD0 = 0x03;

        NVIC_EnableIRQ(I2C1_IRQn);
        LPC_I2C1->I2CONSET = 0x40;

        LPC_I2C1->I2CONSET = 0x20;
        int status = LPC_I2C1->I2STAT;
}

Parents Reply Children
  • No, C++ does not cause weak references to interrupt handlers.

    But C++ uses name mangling, which means the external name the linker sees contains extra characters encoding the returned data type, and the parameter list.

    So a C++ file with a function void hello(void) will not let the linker see a function "hello". You don't need to use the braces to wrap. Standard C++ documentation tells you that you can specifiy directly for the function that it should use the C calling convention and have C bindings.

  • If I Recall/Remember Correctly,
    For Cortex-M3, or I should say NXP LPC17xx,
    There are two kind of Keil examples,
    1. Older, not CMSIS style; it has two important source files; startup_LPC17xx.s, system_LPC17xx.c
    2. Newer, CMSIS style; it has three important source files; startup_LPC17xx.s, system_LPC17xx.c, core_cm3.c
    Newer Keil MDK provides the CMSIS style source, startup_LPC17xx.s, system_LPC17xx.c, core_cm3.c.
    If you mix-up the [not CMSIS style source] with [CMSIS style source], you will have some problems to fix.

  • In your Difference Report->system_LPC17xx_c.htm

    Left:

    #define PLL0CFG_Val           0x0000000B
    


    Right:

    #define PLL0CFG_Val           0x00050063
    

  • As per your Difference Report, I believe that
    If you mix-up different versions of the [CMSIS style source], you will have some problems to fix.

  • There are also examples from NXP

    I don't know, but I would not expect arbitrary files taken from NXP examples to "just work" with Keil examples - or vice-versa.