Misplaced Pages

Storage violation

Article snapshot taken from Wikipedia with creative commons attribution-sharealike license. Give it a read and then ask your questions in the chat. We can research this topic together.

This is the current revision of this page, as edited by ClueBot NG (talk | contribs) at 06:21, 22 April 2024 (Reverting possible vandalism by 37.186.61.151 to version by Onel5969. Report False Positive? Thanks, ClueBot NG. (4316824) (Bot)). The present address (URL) is a permanent link to this version.

Revision as of 06:21, 22 April 2024 by ClueBot NG (talk | contribs) (Reverting possible vandalism by 37.186.61.151 to version by Onel5969. Report False Positive? Thanks, ClueBot NG. (4316824) (Bot))(diff) ← Previous revision | Latest revision (diff) | Newer revision → (diff) Hardware or software fault

In computing a storage violation is a hardware or software fault that occurs when a task attempts to access an area of computer storage which it is not permitted to access.

Types of storage violation

Storage violation can, for instance, consist of reading from, writing to, or freeing storage not owned by the task. A common type of storage violation is known as a stack buffer overflow where a program attempts to exceed the limits set for its call stack. It can also refer to attempted modification of memory "owned" by another thread where there is incomplete (or no) memory protection.

Avoidance of storage violations

Storage violations can occur in transaction systems such as CICS in circumstances where it is possible to write to storage not owned by the transaction; such violations can be reduced by enabling features such as storage protection and transaction isolation.

Detection of storage violations

Storage violations can be difficult to detect as a program can often run for a period of time after the violation before it crashes. For example, a pointer to a freed area of memory can be retained and later reused causing an error. As a result, efforts focus on detecting violations as they occur, rather than later when the problem is observed.

In systems such as CICS, storage violations are sometimes detected (by the CICS kernel) by the use of "signatures", which can be tested to see if they have been overlaid.

An alternative runtime library may be used to better detect storage violations, at the cost of additional overhead. Some programming languages use software bounds checking to prevent these occurrences.

Some program debugging software will also detect violations during testing.

Common causes

  • A runaway subscript leading to illegal use of reference modification during run time.
  • Linkage layout mismatch between called and the calling elements.
  • Use of previously freed (and sometimes already re-allocated) memory.

Examples of software detecting storage violations

See also

References

  1. "Debug Malloc Library". Dmalloc - Debug Malloc Library. Retrieved 2017-04-26.

External links


Stub icon

This computer science article is a stub. You can help Misplaced Pages by expanding it.

Categories: