Dangerous Signal Handler not Disabled During Sensitive Operations

Draft Base
Structure: Simple
Description

The product uses a signal handler that shares state with other signal handlers, but it does not properly mask or prevent those signal handlers from being invoked while the original signal handler is still running.

Extended Description

During the execution of a signal handler, it can be interrupted by another handler when a different signal is sent. If the two handlers share state - such as global variables - then an attacker can corrupt the state by sending another signal before the first handler has completed execution.

Common Consequences 1
Scope: Integrity

Impact: Modify Application Data

Potential Mitigations 1
Phase: Implementation
Turn off dangerous handlers when performing sensitive operations.
Applicable Platforms
Languages:
Not Language-Specific : Undetermined
Modes of Introduction
Implementation
Related Weaknesses
Taxonomy Mapping
  • CERT C Secure Coding
  • PLOVER