View previous topic :: View next topic |
Author |
Message |
srikrishna
Joined: 06 Sep 2017 Posts: 82
|
difference between Global Interrupt Enable bit |
Posted: Sun Feb 02, 2020 4:30 am |
|
|
Hi guys! What is the difference between Global Interrupt Enable and Peripheral Interrupt Enable bit in pic 18f micro controller? What is their function? |
|
|
Ttelmah
Joined: 11 Mar 2010 Posts: 19620
|
|
Posted: Sun Feb 02, 2020 5:01 am |
|
|
Read the chip data sheet.
The GIE (global interrupt enable) allows all enabled interrupts to start
responding.
The individual interrupt enables control each separate interrupt.
An interrupt handler is called when:
1) The GIE is TRUE.
2) The individual PIE is TRUE.
and 3) The physical interrupt flag is set. |
|
|
srikrishna
Joined: 06 Sep 2017 Posts: 82
|
|
Posted: Sun Feb 02, 2020 7:55 am |
|
|
What is unmasked interrupt ?
|
|
|
temtronic
Joined: 01 Jul 2010 Posts: 9295 Location: Greensville,Ontario
|
|
Posted: Sun Feb 02, 2020 8:16 am |
|
|
All peripherals that can cause an interrupt have a 'control' bit in a register to enable or disable that feature. If set to a '0' that peripheral will not generate an interrupt, If set to a '1' it will generate an interrupt IF both 'peripheral' interrupt AND global interrupt bits are set.
The 'mask' is a way to enable/disable entire sets or groups of interrupts based upon what your program is supposed to do. |
|
|
srikrishna
Joined: 06 Sep 2017 Posts: 82
|
|
Posted: Sun Feb 02, 2020 8:47 am |
|
|
temtronic wrote: | All peripherals that can cause an interrupt have a 'control' bit in a register to enable or disable that feature. |
Is this INTCON register ?? |
|
|
Ttelmah
Joined: 11 Mar 2010 Posts: 19620
|
|
Posted: Sun Feb 02, 2020 9:22 am |
|
|
Enables all interrupts that are not masked off by their PIE bits.
The bits are all 'masks'. The GIE, is a mask for all the interrupts.
The PIE bits mask each individual interrupt. |
|
|
temtronic
Joined: 01 Jul 2010 Posts: 9295 Location: Greensville,Ontario
|
|
Posted: Sun Feb 02, 2020 9:22 am |
|
|
There are several registers that are used depending on which PIC you have.
Generally speaking 'CONtrol' registers decide what to do, 'PIE' registers control 'enable' bits for peripheral device.
You need to read the datasheet of whatever PIC you're using as not all PICs have all peripherals ! |
|
|
srikrishna
Joined: 06 Sep 2017 Posts: 82
|
|
Posted: Sun Feb 02, 2020 9:24 am |
|
|
temtronic wrote: | There are several registers that are used depending on which PIC you have.
Generally speaking 'CONtrol' registers decide what to do, 'PIE' registers control 'enable' bits for peripheral device.
You need to read the datasheet of whatever PIC you're using as not all PICs have all peripherals ! |
I am using pic18f2550. |
|
|
srikrishna
Joined: 06 Sep 2017 Posts: 82
|
|
Posted: Sun Feb 02, 2020 11:01 am |
|
|
I have read the datasheet of pic 18f2550. I guess INTCON, INTCON2 and INTCON3 controls the peripherals interrupt. PIR1,PIR2 registers contain the individual flag bits for the peripheral interrupts. PIE1, PIE2 registers contain the individual enable bits for the peripheral interrupts. |
|
|
Ttelmah
Joined: 11 Mar 2010 Posts: 19620
|
|
Posted: Sun Feb 02, 2020 2:33 pm |
|
|
No.
The INTCON registers contain GIE, then some of the physical interrupt flags
(though you don't need these when using an interrupt, they can be 'polled',
and they have to be cleared when the interrupt is exited (the compiler
does this for you unless you say otherwise). They also contain some 'P' bits
for some interrupts that sets the priority if interrupt priorities are enabled.
Have a look at this thread which discusses priorities:
<http://www.ccsinfo.com/forum/viewtopic.php?t=58480>
It is quite confusing, since they put a few of the priority bits here, and
the rest in the IPR registers.
The enables are then in the PIE registers, and the rest of the interrupt
flags in the PIR registers.
It suffers a little because as chips have grown areas that originally
contained things are no longer large enough, so new registers were
created, but to retain the reverse compatibility the old locations are
used for the older peripherals.
Key is that everything is described in the data sheet. If (for example), you
search for PIR1, you get basic layouts showing where it is and the bit
names, but then later in the sheet you get a whole page describing
every bit in the register. |
|
|
|