VariantDraft

CWE-781Improper Address Validation in IOCTL with METHOD_NEITHER I/O Control Code

Category: other

Description

The product defines an IOCTL that uses METHOD_NEITHER for I/O, but it does not validate or incorrectly validates the addresses that are provided. When an IOCTL uses the METHOD_NEITHER option for I/O control, it is the responsibility of the IOCTL to validate the addresses that have been supplied to it. If validation is missing or incorrect, attackers can supply arbitrary memory addresses, leading to code execution or a denial of service.

Common consequences· 1

  • Integrity / Availability / Confidentiality — Modify Memory, Read Memory, Execute Unauthorized Code or Commands, DoS: Crash, Exit, or Restart
    An attacker may be able to access memory that belongs to another process or user. If the attacker can control the contents that the IOCTL writes, it may lead to code execution at high privilege levels. At the least, a crash can occur.

Potential mitigations· 3

  • [Implementation]If METHOD_NEITHER is required for the IOCTL, then ensure that all user-space addresses are properly validated before they are first accessed. The ProbeForRead and ProbeForWrite routines are available for this task. Also properly protect and manage the user-supplied buffers, since the I/O Manager does not do this when METHOD_NEITHER is being used. See References.
  • [Architecture and Design]If possible, avoid using METHOD_NEITHER in the IOCTL and select methods that effectively control the buffer size, such as METHOD_BUFFERED, METHOD_IN_DIRECT, or METHOD_OUT_DIRECT.
  • [Architecture and Design, Implementation]If the IOCTL is part of a driver that is only intended to be accessed by trusted users, then use proper access control for the associated device or device namespace. See References.

References

  1. https://cwe.mitre.org/data/definitions/781.html

Compliance frameworks addressing this (incoming)1

TypeTargetConfidenceTier
ComplianceControlcis_v8-8100%live

Related by meaning· 6

Nearest entities by semantic similarity across the cs-graph corpus.

CWE
Exposed IOCTL with Insufficient Access Control
CWE
Improper Access Control for Register Interface
CWE
Improper Prevention of Lock Bit Modification
CWE
Security-Sensitive Hardware Controls with Missing Lock Bit Protection
CWE
Improper Handling of Overlap Between Protected Memory Ranges
CVE
CVE-2026-25258
Sourced from MITRE CWE 4.20. Curated for EU compliance use cases by Adam Lundqvist, Founder at SQUR.