Additional C28 device-specific APIs are also provided.
ISRs specified with Hwi_plug will not go through the dispatcher; the
  ISR function will be directly plugged into the vector table. Hwi_plug can 
  be used for any ISR which does not call any SYS/BIOS APIs.
ISRs can be plugged or created statically in the configuration script or 
  dynamically at runtime.
 
| const Hwi_NUM_INTERRUPTS |  | 
C28 supports 32 interrupts
#define Hwi_NUM_INTERRUPTS  (Int)32
 
 
 
| const Hwi_NUM_INTERRUPTS_ALL |  | 
 
 
| const Hwi_NUM_INTERRUPTS_PIE |  | 
C28 supports 96 PIE interrupts
#define Hwi_NUM_INTERRUPTS_PIE  (Int)96
 
 
 
| enum Hwi_MaskingOption |  | 
Shorthand interrupt masking options
typedef enum Hwi_MaskingOption {
    Hwi_MaskingOption_NONE, 
    Hwi_MaskingOption_ALL, 
    Hwi_MaskingOption_SELF, 
    Hwi_MaskingOption_BITMASK, 
    Hwi_MaskingOption_LOWER
} Hwi_MaskingOption;
 
 
VALUES
MaskingOption_NONE
 No interrupts are disabled
MaskingOption_ALL
 All interrupts are disabled
MaskingOption_SELF
 Only this interrupt is disabled
MaskingOption_BITMASK
 User supplies interrupt enable masks
MaskingOption_LOWER
 All current and lower priority
                                  interrupts are disabled.
Only a few targets/devices truly
                                  support this masking option. For those
                                  that don't, this setting is treated
                                  the same as MaskingOption_SELF.
 
| typedef Hwi_FuncPtr |  | 
Hwi create function type definition
typedef Void (*Hwi_FuncPtr)(UArg);
 
 
 
| typedef Hwi_Irp |  | 
Interrupt Return Pointer
 
DETAILS
This is the address of the interrupted instruction.
 
| typedef Hwi_PlugFuncPtr |  | 
Hwi plug function type definition, which doesn't take an arg
typedef Void (*Hwi_PlugFuncPtr)(Void);
 
 
 
| struct Hwi_HookSet |  | 
Hwi hook set type definition
typedef struct Hwi_HookSet {
    Void (*registerFxn)(Int);
} Hwi_HookSet;
 
 
DETAILS
The functions that make up a hookSet have certain restrictions. They
  cannot call any Hwi instance functions other than Hwi_getHookContext()
  and Hwi_setHookContext(). For all practical purposes, they should treat
  the Hwi_Handle passed to these functions as an opaque handle.
 
| config Hwi_A_badIntNum  // module-wide |  | 
Assert raised when an invalid interrupt number is passed to a Hwi call
 
 
| config Hwi_A_invalidArg  // module-wide |  | 
Assert raised when an invalid argument has been passed to a function
 
 
| config Hwi_A_zeroLatencyConflict  // module-wide |  | 
Assert raised when there is a conflict with the zero latency IER mask
extern const Assert_Id Hwi_A_zeroLatencyConflict;
 
 
 
DETAILS
This assert is raised when trying to create a Hwi with an intNum that
  conflicts with the supplied zero latency IER mask.
 
| config Hwi_E_alreadyDefined  // module-wide |  | 
Error raised when Hwi is already defined
extern const Error_Id Hwi_E_alreadyDefined;
 
 
 
 
| config Hwi_E_unpluggedInterrupt  // module-wide |  | 
Error raised when an unplugged interrupt is flagged
extern const Error_Id Hwi_E_unpluggedInterrupt;
 
 
 
 
| config Hwi_LD_end  // module-wide |  | 
Issued just after return from Hwi function (with interrupts disabled)
 
 
| config Hwi_LM_begin  // module-wide |  | 
Issued just prior to Hwi function invocation (with interrupts disabled)
 
 
| config Hwi_dispatcherAutoNestingSupport  // module-wide |  | 
Include interrupt nesting logic in interrupt dispatcher?
extern const Bool Hwi_dispatcherAutoNestingSupport;
 
 
DETAILS
Default is true.
This option provides the user with the ability to optimize
  interrupt dispatcher performance when support for interrupt
  nesting is not required.
Setting this parameter to false will disable the logic in
  the interrupt dispatcher that manipulates interrupt mask
  registers and enables and disables interrupts before and
  after invoking the user's Hwi function.
Set this parameter to false if you don't need interrupts 
  enabled during the execution of your Hwi functions.
 
| config Hwi_dispatcherIrpTrackingSupport  // module-wide |  | 
Controls whether the
  dispatcher retains the interrupted thread's return address
extern const Bool Hwi_dispatcherIrpTrackingSupport;
 
 
DETAILS
This option is enabled by default.
Setting this parameter to false will disable the logic in
  the interrupt dispatcher that keeps track of the interrupt's
  return address and provide a small savings in interrupt latency.
The application can get an interrupt's most recent return
  address using the 
getIrp API.
 
| config Hwi_dispatcherSwiSupport  // module-wide |  | 
Include Swi scheduling logic in interrupt dispatcher?
extern const Bool Hwi_dispatcherSwiSupport;
 
 
DETAILS
Default is inherited from 
BIOS.swiEnabled, which is true by default.
This option provides the user with the ability to optimize
  interrupt dispatcher performance when it is known that Swis
  will not be posted from any of their Hwi threads.
Setting this parameter to false will disable the logic in
  the interrupt dispatcher that invokes the Swi scheduler
  prior to returning from an interrupt.
 
| config Hwi_dispatcherTaskSupport  // module-wide |  | 
Include Task scheduling logic in interrupt dispatcher?
extern const Bool Hwi_dispatcherTaskSupport;
 
 
DETAILS
Default is inherited from 
BIOS.taskEnabled, which is true by default.
This option provides the user with the ability to optimize
  interrupt dispatcher performance when it is known that no
  Task scheduling APIs (ie 
Semaphore_post()) will be executed from any of their Hwi threads.
Setting this parameter to false will disable the logic in
  the interrupt dispatcher that invokes the Task scheduler
  prior to returning from an interrupt.
 
| config Hwi_zeroLatencyIERMask  // module-wide |  | 
Zero Latency IER Mask
extern const Bits16 Hwi_zeroLatencyIERMask;
 
 
DETAILS
CPU interrupts specified in this mask (which corresponds to the 16-bit 
  IER register) will never be disabled.  This means that the  
  
disable, 
enable, and 
restore calls leave the
  zero latency CPU interrupts enabled after being called.  Zero latency
  operation may be used to ensure minimal interrupt-to-ISR time for 
  non-BIOS interrupt handlers in applications that demand low latency.
It is important to note that zero latency and non-zero latency PIE
  interrupts may not share a common PIE group. The entire PIE group whose
  bit is set in the zeroLatencyIERMask will be treated as zero latency.
Enabling zero latency mode (specifying a non-zero zeroLatencyIERMask)
  generates alternate (and slower) code used to disable, enable and
  restore interrupts.  This alternate code will maintain a shadow copy
  of interrupt state (IER register and global interrupt state). 
disableIER, 
enableIER and 
restoreIER will update
  both the IER register and its shadow.  The 
disable call
  will copy the zero latency IER mask (supplied here) into the IER 
  register.  The 
enable call will copy the contents of the
  shadow IER register into the actual register. The 
restore
  call may either disable or enable the non-zero-latency interrupts.
It is important to be aware of the performance penalty associated with
  using zero latency interrupts before using this feature.
Example:
  var Hwi = xdc.useModule('ti.sysbios.family.c28.Hwi');
  Hwi.zeroLatencyIERMask = 0x0010; 
  // PIE group 5 classified as zero latency
 
| Hwi_clearInterrupt()  // module-wide |  | 
Clear a specific interrupt
Void Hwi_clearInterrupt(UInt intNum);
 
 
ARGUMENTS
intNum
 interrupt number to clear
DETAILS
Clears a specific interrupt's pending status.
  The implementation is family-specific.
HWI
The behavior of clearInterrupt depends on whether the intNum
  is a PIE interrupt number.  If so, the corresponding PIEIFR bit is 
  cleared.  If not (1 <= intNum <= 14), the corresponding IFR bit is 
  cleared.
 
| Hwi_disable()  // module-wide |  | 
Globally disable interrupts
macro UInt Hwi_disable();
 
 
RETURNS
opaque key for use by Hwi_restore()
DETAILS
Hwi_disable globally disables hardware interrupts and returns an
  opaque key indicating whether interrupts were globally enabled or
  disabled on entry to Hwi_disable(). 
  The actual value of the key is target/device specific and is meant 
  to be passed to Hwi_restore().
Call Hwi_disable before a portion of a function that needs
  to run without interruption. When critical processing is complete, call
  Hwi_restore or Hwi_enable to reenable hardware interrupts.
Servicing of interrupts that occur while interrupts are disabled is
  postponed until interrupts are reenabled. However, if the same type 
  of interrupt occurs several times while interrupts are disabled, 
  the interrupt's function is executed only once when interrupts are 
  reenabled.
A context switch can occur when calling Hwi_enable or Hwi_restore if
  an enabled interrupt occurred while interrupts are disabled.
Hwi_disable may be called from main(). However, since Hwi interrupts
  are already disabled in main(), such a call has no effect.
CONSTRAINTS
If a Task switching API such as 
  
Semaphore_pend(), 
  
Semaphore_post(),
  
Task_sleep(), or
  
Task_yield() 
  is invoked which results in a context switch while
  interrupts are disabled, an embedded call to 
  
Hwi_enable occurs
  on the way to the new thread context which unconditionally re-enables
  interrupts. Interrupts will remain enabled until a subsequent 
  
Hwi_disable
  invocation.
Swis always run with interrupts enabled.
  See 
Swi_post() for a discussion Swis and
  interrupts.
 
| Hwi_disableIER()  // module-wide |  | 
Disable certain maskable interrupts
Bits16 Hwi_disableIER(Bits16 mask);
 
 
ARGUMENTS
mask
 bitmask of interrupts to disable
RETURNS
previous IER settings bitmask
DETAILS
Atomically disables specific interrupts by clearing the bits
  specified by mask in the Interrupt Enable Register (IER).
The IER bits to be cleared should be set to 1 in the mask.
 
| Hwi_disableInterrupt()  // module-wide |  | 
Disable a specific interrupt
UInt Hwi_disableInterrupt(UInt intNum);
 
 
ARGUMENTS
intNum
 interrupt number to disable
RETURNS
key to restore previous enable/disable state
DETAILS
Disable a specific interrupt identified by an interrupt number.
HWI
The behavior of Hwi_disableInterrupt depends on whether the intNum
  is a PIE interrupt number.  If so, the appropriate bit in its group's 
  PIEIER register is cleared.  Note that, unlike 
  
enableInterrupt, disableInterrupt does not touch IER bits
  when operating upon a PIE interrupt number. If intNum is a non-PIE  
  interrupt (1 <= intNum <= 14), then the corresponding bit in the IER 
  register is cleared.
The return value is a key whose value reflects the previous state of
  the PIEIER bit.
 
| Hwi_disablePIEIER()  // module-wide |  | 
Disable interrupts in a PIE group
Bits16 Hwi_disablePIEIER(UInt groupNum, Bits16 pieMask);
 
 
ARGUMENTS
groupNum
 PIE group number
pieMask
 PIEIER disable mask for group
RETURNS
Previous PIEIER settings bitmask
DETAILS
Atomically disable PIE interrupts in a single PIE group
  according to supplied PIEIER bitmask
 
| Hwi_enable()  // module-wide |  | 
Globally enable interrupts
 
RETURNS
opaque key for use by Hwi_restore()
DETAILS
Hwi_enable globally enables hardware interrupts and returns an
  opaque key indicating whether interrupts were globally enabled or
  disabled on entry to Hwi_enable(). 
  The actual value of the key is target/device specific and is meant 
  to be passed to Hwi_restore().
This function is 
  called as part of SYS/BIOS Startup_POST_APP_MAIN phase.
Hardware interrupts are enabled unless a call to Hwi_disable disables
  them.
Servicing of interrupts that occur while interrupts are disabled is
  postponed until interrupts are reenabled. However, if the same type 
  of interrupt occurs several times while interrupts are disabled, 
  the interrupt's function is executed only once when interrupts are 
  reenabled.
A context switch can occur when calling Hwi_enable or Hwi_restore if
  an enabled interrupt occurred while interrupts are disabled.
Any call to Hwi_enable enables interrupts, even if Hwi_disable has 
  been called several times.
Hwi_enable must not be called from main().
 
| Hwi_enableIER()  // module-wide |  | 
Enable certain maskable interrupts
Bits16 Hwi_enableIER(Bits16 mask);
 
 
ARGUMENTS
mask
 Bitmask of interrupts to enable
RETURNS
Previous IER settings bitmask
DETAILS
Atomically enables specific interrupts by setting the bits 
  specified by mask in the Interrupt Enable Register (IER).
The IER bits to be set should be set to 1 in the mask.
 
| Hwi_enableInterrupt()  // module-wide |  | 
Enable a specific interrupt
UInt Hwi_enableInterrupt(UInt intNum);
 
 
ARGUMENTS
intNum
 interrupt number to enable
RETURNS
key to restore previous enable/disable state
DETAILS
Enables a specific interrupt identified by an interrupt number.
HWI
The behavior of enableInterrupt depends on whether the intNum
  is a PIE interrupt number.  If so, two operations are
  performed. The IER bit for intNum's PIE group is set and the
  appropriate bit in its group's PIEIER register is also set.  However,
  if intNum is a non-PIE interrupt (1 <= intNum <= 14), then the
  corresponding bit in the IER register is set.
The return value is a key whose value reflects the previous state of
  the PIEIER bit. Note that the key does not reflect
  the IER register's previous state even if its state is modified by this
  call.
 
| Hwi_enablePIEIER()  // module-wide |  | 
Enable interrupts in a PIE group
Bits16 Hwi_enablePIEIER(UInt groupNum, Bits16 pieMask);
 
 
ARGUMENTS
groupNum
 PIE group number
pieMask
 PIEIER enable mask for group
RETURNS
Previous PIEIER settings bitmask
DETAILS
Atomically enable PIE interrupts in a single PIE group
  according to supplied PIEIER bitmask
 
| Hwi_getHandle()  // module-wide |  | 
Returns Hwi handle associated with intNum
 
ARGUMENTS
intNum
 Interrupt number
RETURNS
Hwi handle associated with intNum
 
| Hwi_plug()  // module-wide |  | 
Plug an interrupt vector with an ISR address
 
ARGUMENTS
intNum
 interrupt number
fxn
 pointer to ISR function
DETAILS
plug hooks up the specified function as the branch target for a
  hardware interrupt (fielded by the CPU) at the vector address
  corresponding to intNum. plug does not enable the interrupt. Use
  Hwi_enableIER to enable specific interrupts.
This API can plug the full set of vectors supported by the PIE (0-127).
 
| Hwi_restore()  // module-wide |  | 
Globally restore interrupts
macro Void Hwi_restore(UInt key);
 
 
ARGUMENTS
key
 enable/disable state to restore
DETAILS
Hwi_restore globally restores interrupts to the state determined 
  by the key argument provided by a previous invocation of Hwi_disable.
A context switch may occur when calling Hwi_restore if Hwi_restore
  reenables interrupts and another Hwi occurred while interrupts were 
  disabled.
Hwi_restore may be called from main(). However, since Hwi_enable
  cannot be called from main(), interrupts are always disabled in 
  main(), and a call to Hwi_restore has no effect.
 
| Hwi_restoreIER()  // module-wide |  | 
Restore maskable interrupts
Bits16 Hwi_restoreIER(Bits16 mask);
 
 
ARGUMENTS
mask
 Bitmask of interrupts to restore
RETURNS
Previous IER settings bitmask
DETAILS
Restores maskable interrupts to the state they were in 
  when either disableIER() or enableIER() was called.
Atomically writes the given mask to the IER register. Typically used
  to restore the IER register to the state returned from a call to
  either 
disableIER() or 
enableIER().
 
| Hwi_restoreInterrupt()  // module-wide |  | 
Restore a specific interrupt's enabled/disabled state
Void Hwi_restoreInterrupt(UInt intNum, UInt key);
 
 
ARGUMENTS
intNum
 interrupt number to restore
key
 key returned from enableInt or disableInt
DETAILS
Restores a specific interrupt identified by an interrupt number.
  restoreInterrupt is generally used to restore an interrupt to its state
  before 
disableInterrupt or 
enableInterrupt was
  invoked
HWI
The behavior of restoreInterrupt depends on whether the intNum
  is a PIE interrupt number.  If so, the supplied key returned by an 
  earlier call to 
disableInterrupt and 
enableInterrupt
  is used to restore the corresponding PIEIER bit to its state before
  the earlier call.
  However, if intNum is a non-PIE interrupt (1 <= intNum <= 14), then the
  corresponding bit in the IER register is restored using the key.
 
| Hwi_restorePIEIER()  // module-wide |  | 
Restores interrupts in a PIE group
Bits16 Hwi_restorePIEIER(UInt groupNum, Bits16 pieMask);
 
 
ARGUMENTS
groupNum
 PIE group number
pieMask
 PIEIER restore mask for group
RETURNS
Previous PIEIER settings bitmask
DETAILS
Atomically restore PIE interrupts in a single PIE group
  according to supplied PIEIER bitmask
 
| Hwi_startup()  // module-wide |  | 
Initially enable interrupts
 
DETAILS
Called within BIOS_start
| Module-Wide Built-Ins |  | 
// Get this module's unique id
 
Bool Hwi_Module_startupDone();
// Test if this module has completed startup
 
// The heap from which this module allocates memory
 
Bool Hwi_Module_hasMask();
// Test whether this module has a diagnostics mask
 
Bits16 Hwi_Module_getMask();
// Returns the diagnostics mask for this module
 
Void Hwi_Module_setMask(Bits16 mask);
// Set the diagnostics mask for this module
 
| Instance Object Types |  | 
typedef struct Hwi_Object Hwi_Object;
// Opaque internal representation of an instance object
 
// Client reference to an instance object
 
typedef struct Hwi_Struct Hwi_Struct;
// Opaque client structure large enough to hold an instance object
 
// Convert this instance structure pointer into an instance handle
 
// Convert this instance handle into an instance structure pointer
 
| Instance Config Parameters |  | 
typedef struct Hwi_Params {
// Instance config-params structure
    // Common per-instance configs
    UArg arg;
    // ISR function argument. Default is 0
    Bits16 disableMask;
    // Dispatcher auto-nesting interrupt disable mask
    Bool enableAck;
    // Enable automatic acknowledgement of PIE interrupts by the Hwi interrupt
  dispatcher
    Bool enableInt;
    // Enable this interrupt when object is created? Default is true
    Int eventId;
    // Interrupt event ID (Interrupt Selection Number)
    Int priority;
    // Interrupt priority. Not supported on this target
    Bits16 restoreMask;
    // Dispatcher auto-nesting interrupt restore mask
} Hwi_Params;
 
// Initialize this config-params structure with supplier-specified defaults before instance creation
 
 
| config Hwi_arg  // instance |  | 
ISR function argument. Default is 0
 
 
| config Hwi_disableMask  // instance |  | 
Dispatcher auto-nesting interrupt disable mask
 
DETAILS
When the dispatcher's auto interrupt nesting support feature 
  is enabled (see 
dispatcherAutoNestingSupport), 
  this mask defines which IER bits are disabled prior to invoking
  the user's ISR function with GIE = 1.
disableMask bits set to 1 correspond to IER bits that will be cleared
  prior to invoking the ISR.
The value of this mask is normally auto-calculated based on the
  value of the maskSetting. However, manual setting of this
  mask is enabled by setting the maskSetting to 
  
MaskingOption_BITMASK.
The default value is derived from the 
  
MaskingOption_SELF
  maskSetting.
 
| config Hwi_enableAck  // instance |  | 
Enable automatic acknowledgement of PIE interrupts by the Hwi interrupt
  dispatcher
 
 
| config Hwi_enableInt  // instance |  | 
Enable this interrupt when object is created? Default is true
 
 
| config Hwi_eventId  // instance |  | 
Interrupt event ID (Interrupt Selection Number)
 
DETAILS
Default is -1. 
  Not all targets/devices support this instance parameter. 
  On those that don't, this parameter is ignored.
 
| config Hwi_maskSetting  // instance |  | 
maskSetting. Default is Hwi_MaskingOption_SELF
 
 
| config Hwi_priority  // instance |  | 
Interrupt priority. Not supported on this target
 
DETAILS
Default is -1.
  Not all targets/devices support this instance parameter. 
  On those that don't, this parameter is ignored.
 
| config Hwi_restoreMask  // instance |  | 
Dispatcher auto-nesting interrupt restore mask
 
DETAILS
When the dispatcher's auto interrupt nesting support feature 
  is enabled (see 
dispatcherAutoNestingSupport), 
  this mask defines which IER bits are restored to their previous
  setting upon return from the user's ISR function.
restoreMask bits set to 1 correspond to IER bits that will be restored.
The value of this mask is normally auto-calculated based on the
  value of the maskSetting. However, manual setting of this
  mask is enabled by setting the maskSetting to 
  
MaskingOption_BITMASK.
The default value is derived from the 
  
MaskingOption_SELF
  maskSetting.
| Instance Creation |  | 
// Allocate and initialize a new instance object and return its handle
 
// Initialize a new instance object inside the provided structure
 
ARGUMENTS
intNum
 interrupt number
hwiFxn
 pointer to ISR function
params
 per-instance config params, or NULL to select default values (target-domain only)
eb
 active error-handling block, or NULL to select default policy (target-domain only)
DETAILS
A Hwi dispatcher table entry is created and filled with the 
  function specified by the fxn parameter and the attributes 
  specified by the params parameter.
If params is NULL, the Hwi's dispatcher properties are assigned a 
  default set of values. Otherwise, the following properties
  are specified by a structure of type Hwi_Params.
-  The arg element is a generic argument that is passed to the plugged
  function as its only parameter. The default value is 0.
-  The enableInt element determines whether the interrupt should be
  enabled in the IER by create.
-  The maskSetting element defines the dispatcherAutoNestingSupport 
  behavior of the interrupt.
Hwi_create returns a pointer to the created Hwi object.
| Instance Deletion |  | 
// Finalize and free this previously allocated instance object, setting the referenced handle to NULL
 
// Finalize the instance object inside the provided structure
 
 
| Hwi_getFunc()  // instance |  | 
Get Hwi function and arg
 
ARGUMENTS
handle
 handle of a previously-created Hwi instance object
arg
 pointer for returning hwi's ISR function argument
RETURNS
hwi's ISR function
 
| Hwi_getHookContext()  // instance |  | 
Get hook instance's context for a Hwi
Ptr Hwi_getHookContext(
Hwi_Handle handle, 
Int id);
 
 
 
ARGUMENTS
handle
 handle of a previously-created Hwi instance object
RETURNS
hook instance's context for hwi
 
| Hwi_getIrp()  // instance |  | 
Get address of interrupted instruction
 
ARGUMENTS
handle
 handle of a previously-created Hwi instance object
RETURNS
most current IRP of a Hwi
 
| Hwi_reconfig()  // instance |  | 
Reconfigure a dispatched interrupt
 
ARGUMENTS
handle
 handle of a previously-created Hwi instance object
 
| Hwi_setFunc()  // instance |  | 
Overwrite Hwi function and arg
 
ARGUMENTS
handle
 handle of a previously-created Hwi instance object
fxn
 pointer to ISR function
arg
 argument to ISR function
DETAILS
Replaces a Hwi object's hwiFxn function originally
  provided in 
create.
 
| Hwi_setHookContext()  // instance |  | 
Set hook instance's context for a Hwi
Void Hwi_setHookContext(
Hwi_Handle handle, 
Int id, 
Ptr hookContext);
 
 
 
ARGUMENTS
handle
 handle of a previously-created Hwi instance object
id
 hook instance's ID
hookContext
 value to write to context
| Instance Convertors |  | 
// unconditionally move one level up the inheritance hierarchy
 
// conditionally move one level down the inheritance hierarchy; NULL upon failure
 
| Instance Built-Ins |  | 
Int Hwi_Object_count();
// The number of statically-created instance objects
 
// The handle of the i-th statically-created instance object (array == NULL)
 
// The handle of the first dynamically-created instance object, or NULL
 
// The handle of the next dynamically-created instance object, or NULL
 
// The heap used to allocate dynamically-created instance objects
 
// The label associated with this instance object
 
// The name of this instance object
 
 
 
| const Hwi.NUM_INTERRUPTS |  | 
C28 supports 32 interrupts
| XDCscript usage | meta-domain | 
const Hwi.NUM_INTERRUPTS = 32;
 
 
C SYNOPSIS
 
| const Hwi.NUM_INTERRUPTS_ALL |  | 
| XDCscript usage | meta-domain | 
 
C SYNOPSIS
 
| const Hwi.NUM_INTERRUPTS_PIE |  | 
C28 supports 96 PIE interrupts
| XDCscript usage | meta-domain | 
const Hwi.NUM_INTERRUPTS_PIE = 96;
 
 
C SYNOPSIS
 
| enum Hwi.MaskingOption |  | 
Shorthand interrupt masking options
| XDCscript usage | meta-domain | 
values of type Hwi.MaskingOption
    const Hwi.MaskingOption_NONE;
    const Hwi.MaskingOption_ALL;
    const Hwi.MaskingOption_SELF;
    const Hwi.MaskingOption_BITMASK;
    const Hwi.MaskingOption_LOWER;
 
 
VALUES
MaskingOption_NONE
 No interrupts are disabled
MaskingOption_ALL
 All interrupts are disabled
MaskingOption_SELF
 Only this interrupt is disabled
MaskingOption_BITMASK
 User supplies interrupt enable masks
MaskingOption_LOWER
 All current and lower priority
                                  interrupts are disabled.
Only a few targets/devices truly
                                  support this masking option. For those
                                  that don't, this setting is treated
                                  the same as MaskingOption_SELF.
C SYNOPSIS
 
| struct Hwi.HookSet |  | 
Hwi hook set type definition
| XDCscript usage | meta-domain | 
var obj = new Hwi.HookSet;
 
    obj.registerFxn = Void(*)(Int)  ...
 
 
DETAILS
The functions that make up a hookSet have certain restrictions. They
  cannot call any Hwi instance functions other than Hwi_getHookContext()
  and Hwi_setHookContext(). For all practical purposes, they should treat
  the Hwi_Handle passed to these functions as an opaque handle.
C SYNOPSIS
 
| metaonly struct Hwi.NonDispatchedInterrupt |  | 
Non-dispatched interrupt object
| XDCscript usage | meta-domain | 
var obj = new Hwi.NonDispatchedInterrupt;
 
    obj.intNum = Int  ...
    obj.fxn = Void(*)(Void)  ...
    obj.enableInt = Bool  ...
 
 
FIELDS
intNum
 Interrupt number
fxn
 Non-dispatched interrupt service routine (ISR)
enableInt
 Enable the interrupt after plugging the vector
DETAILS
Provided so that XGCONF users can easily plug non-dispatched interrupts
 
| config Hwi.A_badIntNum  // module-wide |  | 
Assert raised when an invalid interrupt number is passed to a Hwi call
| XDCscript usage | meta-domain | 
    msg: "A_badIntNum: Invalid interrupt number"
};
 
 
C SYNOPSIS
 
| config Hwi.A_invalidArg  // module-wide |  | 
Assert raised when an invalid argument has been passed to a function
| XDCscript usage | meta-domain | 
    msg: "A_invalidArg: Invalid argument"
};
 
 
C SYNOPSIS
 
| config Hwi.A_zeroLatencyConflict  // module-wide |  | 
Assert raised when there is a conflict with the zero latency IER mask
| XDCscript usage | meta-domain | 
    msg: "A_zeroLatencyConflict: Conflict with zero latency IER mask"
};
 
 
DETAILS
This assert is raised when trying to create a Hwi with an intNum that
  conflicts with the supplied zero latency IER mask.
C SYNOPSIS
 
| config Hwi.E_alreadyDefined  // module-wide |  | 
Error raised when Hwi is already defined
| XDCscript usage | meta-domain | 
    msg: "E_alreadyDefined: Hwi already defined: intr# %d"
};
 
 
C SYNOPSIS
 
| config Hwi.E_unpluggedInterrupt  // module-wide |  | 
Error raised when an unplugged interrupt is flagged
| XDCscript usage | meta-domain | 
    msg: "E_unpluggedInterrupt: Unplugged interrupt flagged: intr# %d"
};
 
 
C SYNOPSIS
 
| config Hwi.LD_end  // module-wide |  | 
Issued just after return from Hwi function (with interrupts disabled)
| XDCscript usage | meta-domain | 
    msg: "LD_end: hwi: 0x%x"
};
 
 
C SYNOPSIS
 
| config Hwi.LM_begin  // module-wide |  | 
Issued just prior to Hwi function invocation (with interrupts disabled)
| XDCscript usage | meta-domain | 
    msg: "LM_begin: hwi: 0x%x, func: 0x%x, preThread: %d, intNum: %d, irp: 0x%x"
};
 
 
C SYNOPSIS
 
| config Hwi.dispatcherAutoNestingSupport  // module-wide |  | 
Include interrupt nesting logic in interrupt dispatcher?
| XDCscript usage | meta-domain | 
Hwi.dispatcherAutoNestingSupport = Bool true;
 
 
DETAILS
Default is true.
This option provides the user with the ability to optimize
  interrupt dispatcher performance when support for interrupt
  nesting is not required.
Setting this parameter to false will disable the logic in
  the interrupt dispatcher that manipulates interrupt mask
  registers and enables and disables interrupts before and
  after invoking the user's Hwi function.
Set this parameter to false if you don't need interrupts 
  enabled during the execution of your Hwi functions.
C SYNOPSIS
 
| config Hwi.dispatcherIrpTrackingSupport  // module-wide |  | 
Controls whether the
  dispatcher retains the interrupted thread's return address
| XDCscript usage | meta-domain | 
Hwi.dispatcherIrpTrackingSupport = Bool true;
 
 
DETAILS
This option is enabled by default.
Setting this parameter to false will disable the logic in
  the interrupt dispatcher that keeps track of the interrupt's
  return address and provide a small savings in interrupt latency.
The application can get an interrupt's most recent return
  address using the 
getIrp API.
C SYNOPSIS
 
| config Hwi.dispatcherSwiSupport  // module-wide |  | 
Include Swi scheduling logic in interrupt dispatcher?
| XDCscript usage | meta-domain | 
Hwi.dispatcherSwiSupport = Bool undefined;
 
 
DETAILS
Default is inherited from 
BIOS.swiEnabled, which is true by default.
This option provides the user with the ability to optimize
  interrupt dispatcher performance when it is known that Swis
  will not be posted from any of their Hwi threads.
Setting this parameter to false will disable the logic in
  the interrupt dispatcher that invokes the Swi scheduler
  prior to returning from an interrupt.
C SYNOPSIS
 
| config Hwi.dispatcherTaskSupport  // module-wide |  | 
Include Task scheduling logic in interrupt dispatcher?
| XDCscript usage | meta-domain | 
Hwi.dispatcherTaskSupport = Bool undefined;
 
 
DETAILS
Default is inherited from 
BIOS.taskEnabled, which is true by default.
This option provides the user with the ability to optimize
  interrupt dispatcher performance when it is known that no
  Task scheduling APIs (ie 
Semaphore_post()) will be executed from any of their Hwi threads.
Setting this parameter to false will disable the logic in
  the interrupt dispatcher that invokes the Task scheduler
  prior to returning from an interrupt.
C SYNOPSIS
 
| config Hwi.zeroLatencyIERMask  // module-wide |  | 
Zero Latency IER Mask
| XDCscript usage | meta-domain | 
Hwi.zeroLatencyIERMask = Bits16 0x0;
 
 
DETAILS
CPU interrupts specified in this mask (which corresponds to the 16-bit 
  IER register) will never be disabled.  This means that the  
  
disable, 
enable, and 
restore calls leave the
  zero latency CPU interrupts enabled after being called.  Zero latency
  operation may be used to ensure minimal interrupt-to-ISR time for 
  non-BIOS interrupt handlers in applications that demand low latency.
It is important to note that zero latency and non-zero latency PIE
  interrupts may not share a common PIE group. The entire PIE group whose
  bit is set in the zeroLatencyIERMask will be treated as zero latency.
Enabling zero latency mode (specifying a non-zero zeroLatencyIERMask)
  generates alternate (and slower) code used to disable, enable and
  restore interrupts.  This alternate code will maintain a shadow copy
  of interrupt state (IER register and global interrupt state). 
disableIER, 
enableIER and 
restoreIER will update
  both the IER register and its shadow.  The 
disable call
  will copy the zero latency IER mask (supplied here) into the IER 
  register.  The 
enable call will copy the contents of the
  shadow IER register into the actual register. The 
restore
  call may either disable or enable the non-zero-latency interrupts.
It is important to be aware of the performance penalty associated with
  using zero latency interrupts before using this feature.
Example:
  var Hwi = xdc.useModule('ti.sysbios.family.c28.Hwi');
  Hwi.zeroLatencyIERMask = 0x0010; 
  // PIE group 5 classified as zero latency
C SYNOPSIS
 
| metaonly config Hwi.common$  // module-wide |  | 
Common module configuration parameters
| XDCscript usage | meta-domain | 
 
DETAILS
All modules have this configuration parameter.  Its name
  contains the '$' character to ensure it does not conflict with
  configuration parameters declared by the module.  This allows
  new configuration parameters to be added in the future without
  any chance of breaking existing modules.
 
| metaonly config Hwi.nonDispatchedInterrupts  // module-wide |  | 
Non-dispatched interrupt array
| XDCscript usage | meta-domain | 
 
DETAILS
Provided so that XGCONF users can easily plug non-dispatched interrupts
 
| metaonly Hwi.addHookSet()  // module-wide |  | 
addHookSet is used in a config file to add a hook set (defined
  by struct HookSet)
| XDCscript usage | meta-domain | 
 
ARGUMENTS
hook
 structure of type HookSet
DETAILS
HookSet structure elements may be omitted, in which case those
  elements will not exist.
 
| metaonly Hwi.plugMeta()  // module-wide |  | 
Statically plug an interrupt vector with an ISR address
| XDCscript usage | meta-domain | 
Hwi.plugMeta(UInt intNum, Void(*)(Void) fxn) returns Void
 
 
ARGUMENTS
intNum
 Interrupt number
fxn
 Pointer to ISR function
| Instance Config Parameters |  | 
| XDCscript usage | meta-domain | 
var params = new Hwi.Params;
// Instance config-params object
    params.arg = UArg 0;
    // ISR function argument. Default is 0
    params.disableMask = Bits16 0;
    // Dispatcher auto-nesting interrupt disable mask
    params.enableAck = Bool true;
    // Enable automatic acknowledgement of PIE interrupts by the Hwi interrupt
  dispatcher
    params.enableInt = Bool true;
    // Enable this interrupt when object is created? Default is true
    params.eventId = Int -1;
    // Interrupt event ID (Interrupt Selection Number)
    params.priority = Int 0;
    // Interrupt priority. Not supported on this target
    params.restoreMask = Bits16 0;
    // Dispatcher auto-nesting interrupt restore mask
 
 
| config Hwi.arg  // instance |  | 
ISR function argument. Default is 0
| XDCscript usage | meta-domain | 
var params = new Hwi.Params;
  ...
params.arg = UArg 0;
 
 
C SYNOPSIS
 
| config Hwi.disableMask  // instance |  | 
Dispatcher auto-nesting interrupt disable mask
| XDCscript usage | meta-domain | 
var params = new Hwi.Params;
  ...
params.disableMask = Bits16 0;
 
 
DETAILS
When the dispatcher's auto interrupt nesting support feature 
  is enabled (see 
dispatcherAutoNestingSupport), 
  this mask defines which IER bits are disabled prior to invoking
  the user's ISR function with GIE = 1.
disableMask bits set to 1 correspond to IER bits that will be cleared
  prior to invoking the ISR.
The value of this mask is normally auto-calculated based on the
  value of the maskSetting. However, manual setting of this
  mask is enabled by setting the maskSetting to 
  
MaskingOption_BITMASK.
The default value is derived from the 
  
MaskingOption_SELF
  maskSetting.
C SYNOPSIS
 
| config Hwi.enableAck  // instance |  | 
Enable automatic acknowledgement of PIE interrupts by the Hwi interrupt
  dispatcher
| XDCscript usage | meta-domain | 
var params = new Hwi.Params;
  ...
params.enableAck = Bool true;
 
 
C SYNOPSIS
 
| config Hwi.enableInt  // instance |  | 
Enable this interrupt when object is created? Default is true
| XDCscript usage | meta-domain | 
var params = new Hwi.Params;
  ...
params.enableInt = Bool true;
 
 
C SYNOPSIS
 
| config Hwi.eventId  // instance |  | 
Interrupt event ID (Interrupt Selection Number)
| XDCscript usage | meta-domain | 
var params = new Hwi.Params;
  ...
params.eventId = Int -1;
 
 
DETAILS
Default is -1. 
  Not all targets/devices support this instance parameter. 
  On those that don't, this parameter is ignored.
C SYNOPSIS
 
| config Hwi.maskSetting  // instance |  | 
maskSetting. Default is Hwi_MaskingOption_SELF
| XDCscript usage | meta-domain | 
var params = new Hwi.Params;
  ...
 
 
C SYNOPSIS
 
| config Hwi.priority  // instance |  | 
Interrupt priority. Not supported on this target
| XDCscript usage | meta-domain | 
var params = new Hwi.Params;
  ...
params.priority = Int 0;
 
 
DETAILS
Default is -1.
  Not all targets/devices support this instance parameter. 
  On those that don't, this parameter is ignored.
C SYNOPSIS
 
| config Hwi.restoreMask  // instance |  | 
Dispatcher auto-nesting interrupt restore mask
| XDCscript usage | meta-domain | 
var params = new Hwi.Params;
  ...
params.restoreMask = Bits16 0;
 
 
DETAILS
When the dispatcher's auto interrupt nesting support feature 
  is enabled (see 
dispatcherAutoNestingSupport), 
  this mask defines which IER bits are restored to their previous
  setting upon return from the user's ISR function.
restoreMask bits set to 1 correspond to IER bits that will be restored.
The value of this mask is normally auto-calculated based on the
  value of the maskSetting. However, manual setting of this
  mask is enabled by setting the maskSetting to 
  
MaskingOption_BITMASK.
The default value is derived from the 
  
MaskingOption_SELF
  maskSetting.
C SYNOPSIS
| Instance Creation |  | 
| XDCscript usage | meta-domain | 
// Allocate instance config-params
params.config =   ...
// Assign individual configs
 
var inst = Hwi.create(Int intNum, Void(*)(UArg) hwiFxn, params);
// Create an instance-object
 
ARGUMENTS
intNum
 interrupt number
hwiFxn
 pointer to ISR function
params
 per-instance config params, or NULL to select default values (target-domain only)
eb
 active error-handling block, or NULL to select default policy (target-domain only)
DETAILS
A Hwi dispatcher table entry is created and filled with the 
  function specified by the fxn parameter and the attributes 
  specified by the params parameter.
If params is NULL, the Hwi's dispatcher properties are assigned a 
  default set of values. Otherwise, the following properties
  are specified by a structure of type Hwi_Params.
-  The arg element is a generic argument that is passed to the plugged
  function as its only parameter. The default value is 0.
-  The enableInt element determines whether the interrupt should be
  enabled in the IER by create.
-  The maskSetting element defines the dispatcherAutoNestingSupport 
  behavior of the interrupt.
Hwi_create returns a pointer to the created Hwi object.