Add a comprehensive framework for formally documenting kernel APIs with
inline specifications. This framework provides:

- Structured API documentation with parameter specifications, return
  values, error conditions, and execution context requirements
- Runtime validation capabilities for debugging (CONFIG_KAPI_RUNTIME_CHECKS)
- Export of specifications via debugfs for tooling integration
- Support for both internal kernel APIs and system calls

The framework stores specifications in a dedicated ELF section and
provides infrastructure for:
- Compile-time validation of specifications
- Runtime querying of API documentation
- Machine-readable export formats
- Integration with existing SYSCALL_DEFINE macros

This commit introduces the core infrastructure without modifying any
existing APIs. Subsequent patches will add specifications to individual
subsystems.

Signed-off-by: Sasha Levin <sas...@kernel.org>
---
 Documentation/admin-guide/kernel-api-spec.rst |  507 +++++++
 MAINTAINERS                                   |    9 +
 arch/um/kernel/dyn.lds.S                      |    3 +
 arch/um/kernel/uml.lds.S                      |    3 +
 arch/x86/kernel/vmlinux.lds.S                 |    3 +
 include/asm-generic/vmlinux.lds.h             |   20 +
 include/linux/kernel_api_spec.h               |  942 +++++++++++++
 include/linux/syscall_api_spec.h              |  341 +++++
 include/linux/syscalls.h                      |    1 +
 init/Kconfig                                  |    2 +
 kernel/Makefile                               |    1 +
 kernel/api/Kconfig                            |   35 +
 kernel/api/Makefile                           |    7 +
 kernel/api/kernel_api_spec.c                  | 1169 +++++++++++++++++
 14 files changed, 3043 insertions(+)
 create mode 100644 Documentation/admin-guide/kernel-api-spec.rst
 create mode 100644 include/linux/kernel_api_spec.h
 create mode 100644 include/linux/syscall_api_spec.h
 create mode 100644 kernel/api/Kconfig
 create mode 100644 kernel/api/Makefile
 create mode 100644 kernel/api/kernel_api_spec.c

diff --git a/Documentation/admin-guide/kernel-api-spec.rst 
b/Documentation/admin-guide/kernel-api-spec.rst
new file mode 100644
index 0000000000000..3a63f6711e27b
--- /dev/null
+++ b/Documentation/admin-guide/kernel-api-spec.rst
@@ -0,0 +1,507 @@
+.. SPDX-License-Identifier: GPL-2.0
+
+======================================
+Kernel API Specification Framework
+======================================
+
+:Author: Sasha Levin <sas...@kernel.org>
+:Date: June 2025
+
+.. contents:: Table of Contents
+   :depth: 3
+   :local:
+
+Introduction
+============
+
+The Kernel API Specification Framework (KAPI) provides a comprehensive system 
for
+formally documenting, validating, and introspecting kernel APIs. This framework
+addresses the long-standing challenge of maintaining accurate, machine-readable
+documentation for the thousands of internal kernel APIs and system calls.
+
+Purpose and Goals
+-----------------
+
+The framework aims to:
+
+1. **Improve API Documentation**: Provide structured, inline documentation that
+   lives alongside the code and is maintained as part of the development 
process.
+
+2. **Enable Runtime Validation**: Optionally validate API usage at runtime to 
catch
+   common programming errors during development and testing.
+
+3. **Support Tooling**: Export API specifications in machine-readable formats 
for
+   use by static analyzers, documentation generators, and development tools.
+
+4. **Enhance Debugging**: Provide detailed API information at runtime through 
debugfs
+   for debugging and introspection.
+
+5. **Formalize Contracts**: Explicitly document API contracts including 
parameter
+   constraints, execution contexts, locking requirements, and side effects.
+
+Architecture Overview
+=====================
+
+Components
+----------
+
+The framework consists of several key components:
+
+1. **Core Framework** (``kernel/api/kernel_api_spec.c``)
+
+   - API specification registration and storage
+   - Runtime validation engine
+   - Specification lookup and querying
+
+2. **DebugFS Interface** (``kernel/api/kapi_debugfs.c``)
+
+   - Runtime introspection via ``/sys/kernel/debug/kapi/``
+   - JSON and XML export formats
+   - Per-API detailed information
+
+3. **IOCTL Support** (``kernel/api/ioctl_validation.c``)
+
+   - Extended framework for IOCTL specifications
+   - Automatic validation wrappers
+   - Structure field validation
+
+4. **Specification Macros** (``include/linux/kernel_api_spec.h``)
+
+   - Declarative macros for API documentation
+   - Type-safe parameter specifications
+   - Context and constraint definitions
+
+Data Model
+----------
+
+The framework uses a hierarchical data model::
+
+    kernel_api_spec
+    ├── Basic Information
+    │   ├── name (API function name)
+    │   ├── version (specification version)
+    │   ├── description (human-readable description)
+    │   └── kernel_version (when API was introduced)
+    │
+    ├── Parameters (up to 16)
+    │   └── kapi_param_spec
+    │       ├── name
+    │       ├── type (int, pointer, string, etc.)
+    │       ├── direction (in, out, inout)
+    │       ├── constraints (range, mask, enum values)
+    │       └── validation rules
+    │
+    ├── Return Value
+    │   └── kapi_return_spec
+    │       ├── type
+    │       ├── success conditions
+    │       └── validation rules
+    │
+    ├── Error Conditions (up to 32)
+    │   └── kapi_error_spec
+    │       ├── error code
+    │       ├── condition description
+    │       └── recovery advice
+    │
+    ├── Execution Context
+    │   ├── allowed contexts (process, interrupt, etc.)
+    │   ├── locking requirements
+    │   └── preemption/interrupt state
+    │
+    └── Side Effects
+        ├── memory allocation
+        ├── state changes
+        └── signal handling
+
+Usage Guide
+===========
+
+Basic API Specification
+-----------------------
+
+To document a kernel API, use the specification macros in the implementation 
file:
+
+.. code-block:: c
+
+    #include <linux/kernel_api_spec.h>
+
+    KAPI_DEFINE_SPEC(kmalloc_spec, kmalloc, "3.0")
+    KAPI_DESCRIPTION("Allocate kernel memory")
+    KAPI_PARAM(0, size, KAPI_TYPE_SIZE_T, KAPI_DIR_IN,
+               "Number of bytes to allocate")
+    KAPI_PARAM_RANGE(0, 0, KMALLOC_MAX_SIZE)
+    KAPI_PARAM(1, flags, KAPI_TYPE_FLAGS, KAPI_DIR_IN,
+               "Allocation flags (GFP_*)")
+    KAPI_PARAM_MASK(1, __GFP_BITS_MASK)
+    KAPI_RETURN(KAPI_TYPE_POINTER, "Pointer to allocated memory or NULL")
+    KAPI_ERROR(ENOMEM, "Out of memory")
+    KAPI_CONTEXT(KAPI_CTX_PROCESS | KAPI_CTX_SOFTIRQ | KAPI_CTX_HARDIRQ)
+    KAPI_SIDE_EFFECT("Allocates memory from kernel heap")
+    KAPI_LOCK_NOT_REQUIRED("Any lock")
+    KAPI_END_SPEC
+
+    void *kmalloc(size_t size, gfp_t flags)
+    {
+        /* Implementation */
+    }
+
+System Call Specification
+-------------------------
+
+System calls use specialized macros:
+
+.. code-block:: c
+
+    KAPI_DEFINE_SYSCALL_SPEC(open_spec, open, "1.0")
+    KAPI_DESCRIPTION("Open a file")
+    KAPI_PARAM(0, pathname, KAPI_TYPE_USER_STRING, KAPI_DIR_IN,
+               "Path to file")
+    KAPI_PARAM_PATH(0, PATH_MAX)
+    KAPI_PARAM(1, flags, KAPI_TYPE_FLAGS, KAPI_DIR_IN,
+               "Open flags (O_*)")
+    KAPI_PARAM(2, mode, KAPI_TYPE_MODE_T, KAPI_DIR_IN,
+               "File permissions (if creating)")
+    KAPI_RETURN(KAPI_TYPE_INT, "File descriptor or -1")
+    KAPI_ERROR(EACCES, "Permission denied")
+    KAPI_ERROR(ENOENT, "File does not exist")
+    KAPI_ERROR(EMFILE, "Too many open files")
+    KAPI_CONTEXT(KAPI_CTX_PROCESS | KAPI_CTX_SLEEPABLE)
+    KAPI_SIGNAL(EINTR, "Open can be interrupted by signal")
+    KAPI_END_SYSCALL_SPEC
+
+IOCTL Specification
+-------------------
+
+IOCTLs have extended support for structure validation:
+
+.. code-block:: c
+
+    KAPI_DEFINE_IOCTL_SPEC(vidioc_querycap_spec, VIDIOC_QUERYCAP,
+                           "VIDIOC_QUERYCAP",
+                           sizeof(struct v4l2_capability),
+                           sizeof(struct v4l2_capability),
+                           "video_fops")
+    KAPI_DESCRIPTION("Query device capabilities")
+    KAPI_IOCTL_FIELD(driver, KAPI_TYPE_CHAR_ARRAY, KAPI_DIR_OUT,
+                     "Driver name", 16)
+    KAPI_IOCTL_FIELD(card, KAPI_TYPE_CHAR_ARRAY, KAPI_DIR_OUT,
+                     "Device name", 32)
+    KAPI_IOCTL_FIELD(version, KAPI_TYPE_U32, KAPI_DIR_OUT,
+                     "Driver version")
+    KAPI_IOCTL_FIELD(capabilities, KAPI_TYPE_FLAGS, KAPI_DIR_OUT,
+                     "Device capabilities")
+    KAPI_END_IOCTL_SPEC
+
+Runtime Validation
+==================
+
+Enabling Validation
+-------------------
+
+Runtime validation is controlled by kernel configuration:
+
+1. Enable ``CONFIG_KAPI_SPEC`` to build the framework
+2. Enable ``CONFIG_KAPI_RUNTIME_CHECKS`` for runtime validation
+3. Optionally enable ``CONFIG_KAPI_SPEC_DEBUGFS`` for debugfs interface
+
+Validation Modes
+----------------
+
+The framework supports several validation modes:
+
+.. code-block:: c
+
+    /* Enable validation for specific API */
+    kapi_enable_validation("kmalloc");
+
+    /* Enable validation for all APIs */
+    kapi_enable_all_validation();
+
+    /* Set validation level */
+    kapi_set_validation_level(KAPI_VALIDATE_FULL);
+
+Validation Levels:
+
+- ``KAPI_VALIDATE_NONE``: No validation
+- ``KAPI_VALIDATE_BASIC``: Type and NULL checks only
+- ``KAPI_VALIDATE_NORMAL``: Basic + range and constraint checks
+- ``KAPI_VALIDATE_FULL``: All checks including custom validators
+
+Custom Validators
+-----------------
+
+APIs can register custom validation functions:
+
+.. code-block:: c
+
+    static bool validate_buffer_size(const struct kapi_param_spec *spec,
+                                     const void *value, void *context)
+    {
+        size_t size = *(size_t *)value;
+        struct my_context *ctx = context;
+
+        return size > 0 && size <= ctx->max_buffer_size;
+    }
+
+    KAPI_PARAM_CUSTOM_VALIDATOR(0, validate_buffer_size)
+
+DebugFS Interface
+=================
+
+The debugfs interface provides runtime access to API specifications:
+
+Directory Structure
+-------------------
+
+::
+
+    /sys/kernel/debug/kapi/
+    ├── apis/                    # All registered APIs
+    │   ├── kmalloc/
+    │   │   ├── specification   # Human-readable spec
+    │   │   ├── json           # JSON format
+    │   │   └── xml            # XML format
+    │   └── open/
+    │       └── ...
+    ├── summary                  # Overview of all APIs
+    ├── validation/              # Validation controls
+    │   ├── enabled             # Global enable/disable
+    │   ├── level               # Validation level
+    │   └── stats               # Validation statistics
+    └── export/                  # Bulk export options
+        ├── all.json            # All specs in JSON
+        └── all.xml             # All specs in XML
+
+Usage Examples
+--------------
+
+Query specific API::
+
+    $ cat /sys/kernel/debug/kapi/apis/kmalloc/specification
+    API: kmalloc
+    Version: 3.0
+    Description: Allocate kernel memory
+
+    Parameters:
+      [0] size (size_t, in): Number of bytes to allocate
+          Range: 0 - 4194304
+      [1] flags (flags, in): Allocation flags (GFP_*)
+          Mask: 0x1ffffff
+
+    Returns: pointer - Pointer to allocated memory or NULL
+
+    Errors:
+      ENOMEM: Out of memory
+
+    Context: process, softirq, hardirq
+
+    Side Effects:
+      - Allocates memory from kernel heap
+
+Export all specifications::
+
+    $ cat /sys/kernel/debug/kapi/export/all.json > kernel-apis.json
+
+Enable validation for specific API::
+
+    $ echo 1 > /sys/kernel/debug/kapi/apis/kmalloc/validate
+
+Performance Considerations
+==========================
+
+Memory Overhead
+---------------
+
+Each API specification consumes approximately 2-4KB of memory. With thousands
+of kernel APIs, this can add up to several megabytes. Consider:
+
+1. Building with ``CONFIG_KAPI_SPEC=n`` for production kernels
+2. Using ``__init`` annotations for APIs only used during boot
+3. Implementing lazy loading for rarely used specifications
+
+Runtime Overhead
+----------------
+
+When ``CONFIG_KAPI_RUNTIME_CHECKS`` is enabled:
+
+- Each validated API call adds 50-200ns overhead
+- Complex validations (custom validators) may add more
+- Use validation only in development/testing kernels
+
+Optimization Strategies
+-----------------------
+
+1. **Compile-time optimization**: When validation is disabled, all
+   validation code is optimized away by the compiler.
+
+2. **Selective validation**: Enable validation only for specific APIs
+   or subsystems under test.
+
+3. **Caching**: The framework caches validation results for repeated
+   calls with identical parameters.
+
+Documentation Generation
+------------------------
+
+The framework exports specifications via debugfs that can be used
+to generate documentation. Tools for automatic documentation generation
+from specifications are planned for future development.
+
+IDE Integration
+---------------
+
+Modern IDEs can use the JSON export for:
+
+- Parameter hints
+- Type checking
+- Context validation
+- Error code documentation
+
+Testing Framework
+-----------------
+
+The framework includes test helpers::
+
+    #ifdef CONFIG_KAPI_TESTING
+    /* Verify API behaves according to specification */
+    kapi_test_api("kmalloc", test_cases);
+    #endif
+
+Best Practices
+==============
+
+Writing Specifications
+----------------------
+
+1. **Be Comprehensive**: Document all parameters, errors, and side effects
+2. **Keep Updated**: Update specs when API behavior changes
+3. **Use Examples**: Include usage examples in descriptions
+4. **Validate Constraints**: Define realistic constraints for parameters
+5. **Document Context**: Clearly specify allowed execution contexts
+
+Maintenance
+-----------
+
+1. **Version Specifications**: Increment version when API changes
+2. **Deprecation**: Mark deprecated APIs and suggest replacements
+3. **Cross-reference**: Link related APIs in descriptions
+4. **Test Specifications**: Verify specs match implementation
+
+Common Patterns
+---------------
+
+**Optional Parameters**::
+
+    KAPI_PARAM(2, optional_arg, KAPI_TYPE_POINTER, KAPI_DIR_IN,
+               "Optional argument (may be NULL)")
+    KAPI_PARAM_OPTIONAL(2)
+
+**Variable Arguments**::
+
+    KAPI_PARAM(1, fmt, KAPI_TYPE_FORMAT_STRING, KAPI_DIR_IN,
+               "Printf-style format string")
+    KAPI_PARAM_VARIADIC(2, "Format arguments")
+
+**Callback Functions**::
+
+    KAPI_PARAM(1, callback, KAPI_TYPE_FUNCTION_PTR, KAPI_DIR_IN,
+               "Callback function")
+    KAPI_PARAM_CALLBACK(1, "int (*)(void *data)", "data")
+
+Troubleshooting
+===============
+
+Common Issues
+-------------
+
+**Specification Not Found**::
+
+    kernel: KAPI: Specification for 'my_api' not found
+
+    Solution: Ensure KAPI_DEFINE_SPEC is in the same translation unit
+    as the function implementation.
+
+**Validation Failures**::
+
+    kernel: KAPI: Validation failed for kmalloc parameter 'size':
+            value 5242880 exceeds maximum 4194304
+
+    Solution: Check parameter constraints or adjust specification if
+    the constraint is incorrect.
+
+**Build Errors**::
+
+    error: 'KAPI_TYPE_UNKNOWN' undeclared
+
+    Solution: Include <linux/kernel_api_spec.h> and ensure
+    CONFIG_KAPI_SPEC is enabled.
+
+Debug Options
+-------------
+
+Enable verbose debugging::
+
+    echo 8 > /proc/sys/kernel/printk
+    echo 1 > /sys/kernel/debug/kapi/debug/verbose
+
+Future Directions
+=================
+
+Planned Features
+----------------
+
+1. **Automatic Extraction**: Tool to extract specifications from existing
+   kernel-doc comments
+
+2. **Contract Verification**: Static analysis to verify implementation
+   matches specification
+
+3. **Performance Profiling**: Measure actual API performance against
+   documented expectations
+
+4. **Fuzzing Integration**: Use specifications to guide intelligent
+   fuzzing of kernel APIs
+
+5. **Version Compatibility**: Track API changes across kernel versions
+
+Research Areas
+--------------
+
+1. **Formal Verification**: Use specifications for mathematical proofs
+   of correctness
+
+2. **Runtime Monitoring**: Detect specification violations in production
+   with minimal overhead
+
+3. **API Evolution**: Analyze how kernel APIs change over time
+
+4. **Security Applications**: Use specifications for security policy
+   enforcement
+
+Contributing
+============
+
+Submitting Specifications
+-------------------------
+
+1. Add specifications to the same file as the API implementation
+2. Follow existing patterns and naming conventions
+3. Test with CONFIG_KAPI_RUNTIME_CHECKS enabled
+4. Verify debugfs output is correct
+5. Run scripts/checkpatch.pl on your changes
+
+Review Criteria
+---------------
+
+Specifications will be reviewed for:
+
+1. **Completeness**: All parameters and errors documented
+2. **Accuracy**: Specification matches implementation
+3. **Clarity**: Descriptions are clear and helpful
+4. **Consistency**: Follows framework conventions
+5. **Performance**: No unnecessary runtime overhead
+
+Contact
+-------
+
+- Maintainer: Sasha Levin <sas...@kernel.org>
diff --git a/MAINTAINERS b/MAINTAINERS
index a92290fffa163..7a2cb663131bd 100644
--- a/MAINTAINERS
+++ b/MAINTAINERS
@@ -13047,6 +13047,15 @@ W:     https://linuxtv.org
 T:     git git://linuxtv.org/media.git
 F:     drivers/media/radio/radio-keene*
 
+KERNEL API SPECIFICATION FRAMEWORK (KAPI)
+M:     Sasha Levin <sas...@kernel.org>
+L:     linux-...@vger.kernel.org
+S:     Maintained
+F:     Documentation/admin-guide/kernel-api-spec.rst
+F:     include/linux/kernel_api_spec.h
+F:     kernel/api/
+F:     scripts/extract-kapi-spec.sh
+
 KERNEL AUTOMOUNTER
 M:     Ian Kent <ra...@themaw.net>
 L:     aut...@vger.kernel.org
diff --git a/arch/um/kernel/dyn.lds.S b/arch/um/kernel/dyn.lds.S
index a36b7918a011a..283ab11788d8c 100644
--- a/arch/um/kernel/dyn.lds.S
+++ b/arch/um/kernel/dyn.lds.S
@@ -102,6 +102,9 @@ SECTIONS
   init.data : { INIT_DATA }
   __init_end = .;
 
+  /* Kernel API specifications in dedicated section */
+  KAPI_SPECS_SECTION()
+
   /* Ensure the __preinit_array_start label is properly aligned.  We
      could instead move the label definition inside the section, but
      the linker would then create the section even if it turns out to
diff --git a/arch/um/kernel/uml.lds.S b/arch/um/kernel/uml.lds.S
index a409d4b66114f..e3850d8293436 100644
--- a/arch/um/kernel/uml.lds.S
+++ b/arch/um/kernel/uml.lds.S
@@ -74,6 +74,9 @@ SECTIONS
   init.data : { INIT_DATA }
   __init_end = .;
 
+  /* Kernel API specifications in dedicated section */
+  KAPI_SPECS_SECTION()
+
   .data    :
   {
     INIT_TASK_DATA(KERNEL_STACK_SIZE)
diff --git a/arch/x86/kernel/vmlinux.lds.S b/arch/x86/kernel/vmlinux.lds.S
index 4fa0be732af10..8cc508adc9d51 100644
--- a/arch/x86/kernel/vmlinux.lds.S
+++ b/arch/x86/kernel/vmlinux.lds.S
@@ -173,6 +173,9 @@ SECTIONS
        RO_DATA(PAGE_SIZE)
        X86_ALIGN_RODATA_END
 
+       /* Kernel API specifications in dedicated section */
+       KAPI_SPECS_SECTION()
+
        /* Data */
        .data : AT(ADDR(.data) - LOAD_OFFSET) {
                /* Start of data section */
diff --git a/include/asm-generic/vmlinux.lds.h 
b/include/asm-generic/vmlinux.lds.h
index fa5f19b8d53a0..7b47736057e01 100644
--- a/include/asm-generic/vmlinux.lds.h
+++ b/include/asm-generic/vmlinux.lds.h
@@ -279,6 +279,26 @@ defined(CONFIG_AUTOFDO_CLANG) || 
defined(CONFIG_PROPELLER_CLANG)
 #define TRACE_SYSCALLS()
 #endif
 
+#ifdef CONFIG_KAPI_SPEC
+#define KAPI_SPECS()                           \
+       . = ALIGN(8);                           \
+       __start_kapi_specs = .;                 \
+       KEEP(*(.kapi_specs))                    \
+       __stop_kapi_specs = .;
+
+/* For placing KAPI specs in a dedicated section */
+#define KAPI_SPECS_SECTION()                   \
+       .kapi_specs : AT(ADDR(.kapi_specs) - LOAD_OFFSET) {     \
+               . = ALIGN(8);                   \
+               __start_kapi_specs = .;         \
+               KEEP(*(.kapi_specs))            \
+               __stop_kapi_specs = .;          \
+       }
+#else
+#define KAPI_SPECS()
+#define KAPI_SPECS_SECTION()
+#endif
+
 #ifdef CONFIG_BPF_EVENTS
 #define BPF_RAW_TP() STRUCT_ALIGN();                           \
        BOUNDED_SECTION_BY(__bpf_raw_tp_map, __bpf_raw_tp)
diff --git a/include/linux/kernel_api_spec.h b/include/linux/kernel_api_spec.h
new file mode 100644
index 0000000000000..04df5892bc6d6
--- /dev/null
+++ b/include/linux/kernel_api_spec.h
@@ -0,0 +1,942 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/*
+ * kernel_api_spec.h - Kernel API Formal Specification Framework
+ *
+ * This framework provides structures and macros to formally specify kernel 
APIs
+ * in both human and machine-readable formats. It supports comprehensive 
documentation
+ * of function signatures, parameters, return values, error conditions, and 
constraints.
+ */
+
+#ifndef _LINUX_KERNEL_API_SPEC_H
+#define _LINUX_KERNEL_API_SPEC_H
+
+#include <linux/types.h>
+#include <linux/stringify.h>
+#include <linux/compiler.h>
+
+#define KAPI_MAX_PARAMS                16
+#define KAPI_MAX_ERRORS                32
+#define KAPI_MAX_CONSTRAINTS   16
+#define KAPI_MAX_SIGNALS       32
+#define KAPI_MAX_NAME_LEN      128
+#define KAPI_MAX_DESC_LEN      512
+
+/**
+ * enum kapi_param_type - Parameter type classification
+ * @KAPI_TYPE_VOID: void type
+ * @KAPI_TYPE_INT: Integer types (int, long, etc.)
+ * @KAPI_TYPE_UINT: Unsigned integer types
+ * @KAPI_TYPE_PTR: Pointer types
+ * @KAPI_TYPE_STRUCT: Structure types
+ * @KAPI_TYPE_UNION: Union types
+ * @KAPI_TYPE_ENUM: Enumeration types
+ * @KAPI_TYPE_FUNC_PTR: Function pointer types
+ * @KAPI_TYPE_ARRAY: Array types
+ * @KAPI_TYPE_FD: File descriptor - validated in process context
+ * @KAPI_TYPE_USER_PTR: User space pointer - validated for access and size
+ * @KAPI_TYPE_PATH: Pathname - validated for access and path limits
+ * @KAPI_TYPE_CUSTOM: Custom/complex types
+ */
+enum kapi_param_type {
+       KAPI_TYPE_VOID = 0,
+       KAPI_TYPE_INT,
+       KAPI_TYPE_UINT,
+       KAPI_TYPE_PTR,
+       KAPI_TYPE_STRUCT,
+       KAPI_TYPE_UNION,
+       KAPI_TYPE_ENUM,
+       KAPI_TYPE_FUNC_PTR,
+       KAPI_TYPE_ARRAY,
+       KAPI_TYPE_FD,           /* File descriptor - validated in process 
context */
+       KAPI_TYPE_USER_PTR,     /* User space pointer - validated for access 
and size */
+       KAPI_TYPE_PATH,         /* Pathname - validated for access and path 
limits */
+       KAPI_TYPE_CUSTOM,
+};
+
+/**
+ * enum kapi_param_flags - Parameter attribute flags
+ * @KAPI_PARAM_IN: Input parameter
+ * @KAPI_PARAM_OUT: Output parameter
+ * @KAPI_PARAM_INOUT: Input/output parameter
+ * @KAPI_PARAM_OPTIONAL: Optional parameter (can be NULL)
+ * @KAPI_PARAM_CONST: Const qualified parameter
+ * @KAPI_PARAM_VOLATILE: Volatile qualified parameter
+ * @KAPI_PARAM_USER: User space pointer
+ * @KAPI_PARAM_DMA: DMA-capable memory required
+ * @KAPI_PARAM_ALIGNED: Alignment requirements
+ */
+enum kapi_param_flags {
+       KAPI_PARAM_IN           = (1 << 0),
+       KAPI_PARAM_OUT          = (1 << 1),
+       KAPI_PARAM_INOUT        = (1 << 2),
+       KAPI_PARAM_OPTIONAL     = (1 << 3),
+       KAPI_PARAM_CONST        = (1 << 4),
+       KAPI_PARAM_VOLATILE     = (1 << 5),
+       KAPI_PARAM_USER         = (1 << 6),
+       KAPI_PARAM_DMA          = (1 << 7),
+       KAPI_PARAM_ALIGNED      = (1 << 8),
+};
+
+/**
+ * enum kapi_context_flags - Function execution context flags
+ * @KAPI_CTX_PROCESS: Can be called from process context
+ * @KAPI_CTX_SOFTIRQ: Can be called from softirq context
+ * @KAPI_CTX_HARDIRQ: Can be called from hardirq context
+ * @KAPI_CTX_NMI: Can be called from NMI context
+ * @KAPI_CTX_ATOMIC: Must be called in atomic context
+ * @KAPI_CTX_SLEEPABLE: May sleep
+ * @KAPI_CTX_PREEMPT_DISABLED: Requires preemption disabled
+ * @KAPI_CTX_IRQ_DISABLED: Requires interrupts disabled
+ */
+enum kapi_context_flags {
+       KAPI_CTX_PROCESS        = (1 << 0),
+       KAPI_CTX_SOFTIRQ        = (1 << 1),
+       KAPI_CTX_HARDIRQ        = (1 << 2),
+       KAPI_CTX_NMI            = (1 << 3),
+       KAPI_CTX_ATOMIC         = (1 << 4),
+       KAPI_CTX_SLEEPABLE      = (1 << 5),
+       KAPI_CTX_PREEMPT_DISABLED = (1 << 6),
+       KAPI_CTX_IRQ_DISABLED   = (1 << 7),
+};
+
+/**
+ * enum kapi_lock_type - Lock types used/required by the function
+ * @KAPI_LOCK_NONE: No locking requirements
+ * @KAPI_LOCK_MUTEX: Mutex lock
+ * @KAPI_LOCK_SPINLOCK: Spinlock
+ * @KAPI_LOCK_RWLOCK: Read-write lock
+ * @KAPI_LOCK_SEQLOCK: Sequence lock
+ * @KAPI_LOCK_RCU: RCU lock
+ * @KAPI_LOCK_SEMAPHORE: Semaphore
+ * @KAPI_LOCK_CUSTOM: Custom locking mechanism
+ */
+enum kapi_lock_type {
+       KAPI_LOCK_NONE = 0,
+       KAPI_LOCK_MUTEX,
+       KAPI_LOCK_SPINLOCK,
+       KAPI_LOCK_RWLOCK,
+       KAPI_LOCK_SEQLOCK,
+       KAPI_LOCK_RCU,
+       KAPI_LOCK_SEMAPHORE,
+       KAPI_LOCK_CUSTOM,
+};
+
+/**
+ * enum kapi_constraint_type - Types of parameter constraints
+ * @KAPI_CONSTRAINT_NONE: No constraint
+ * @KAPI_CONSTRAINT_RANGE: Numeric range constraint
+ * @KAPI_CONSTRAINT_MASK: Bitmask constraint
+ * @KAPI_CONSTRAINT_ENUM: Enumerated values constraint
+ * @KAPI_CONSTRAINT_CUSTOM: Custom validation function
+ */
+enum kapi_constraint_type {
+       KAPI_CONSTRAINT_NONE = 0,
+       KAPI_CONSTRAINT_RANGE,
+       KAPI_CONSTRAINT_MASK,
+       KAPI_CONSTRAINT_ENUM,
+       KAPI_CONSTRAINT_CUSTOM,
+};
+
+/**
+ * struct kapi_param_spec - Parameter specification
+ * @name: Parameter name
+ * @type_name: Type name as string
+ * @type: Parameter type classification
+ * @flags: Parameter attribute flags
+ * @size: Size in bytes (for arrays/buffers)
+ * @alignment: Required alignment
+ * @min_value: Minimum valid value (for numeric types)
+ * @max_value: Maximum valid value (for numeric types)
+ * @valid_mask: Valid bits mask (for flag parameters)
+ * @enum_values: Array of valid enumerated values
+ * @enum_count: Number of valid enumerated values
+ * @constraint_type: Type of constraint applied
+ * @validate: Custom validation function
+ * @description: Human-readable description
+ * @constraints: Additional constraints description
+ * @size_param_idx: Index of parameter that determines size (-1 if fixed size)
+ * @size_multiplier: Multiplier for size calculation (e.g., sizeof(struct))
+ */
+struct kapi_param_spec {
+       char name[KAPI_MAX_NAME_LEN];
+       char type_name[KAPI_MAX_NAME_LEN];
+       enum kapi_param_type type;
+       u32 flags;
+       size_t size;
+       size_t alignment;
+       s64 min_value;
+       s64 max_value;
+       u64 valid_mask;
+       const s64 *enum_values;
+       u32 enum_count;
+       enum kapi_constraint_type constraint_type;
+       bool (*validate)(s64 value);
+       char description[KAPI_MAX_DESC_LEN];
+       char constraints[KAPI_MAX_DESC_LEN];
+       int size_param_idx;     /* Index of param that determines size, -1 if 
N/A */
+       size_t size_multiplier; /* Size per unit (e.g., sizeof(struct 
epoll_event)) */
+} __attribute__((packed));
+
+/**
+ * struct kapi_error_spec - Error condition specification
+ * @error_code: Error code value
+ * @name: Error code name (e.g., "EINVAL")
+ * @condition: Condition that triggers this error
+ * @description: Detailed error description
+ */
+struct kapi_error_spec {
+       int error_code;
+       char name[KAPI_MAX_NAME_LEN];
+       char condition[KAPI_MAX_DESC_LEN];
+       char description[KAPI_MAX_DESC_LEN];
+} __attribute__((packed));
+
+/**
+ * enum kapi_return_check_type - Return value check types
+ * @KAPI_RETURN_EXACT: Success is an exact value
+ * @KAPI_RETURN_RANGE: Success is within a range
+ * @KAPI_RETURN_ERROR_CHECK: Success is when NOT in error list
+ * @KAPI_RETURN_FD: Return value is a file descriptor (>= 0 is success)
+ * @KAPI_RETURN_CUSTOM: Custom validation function
+ */
+enum kapi_return_check_type {
+       KAPI_RETURN_EXACT,
+       KAPI_RETURN_RANGE,
+       KAPI_RETURN_ERROR_CHECK,
+       KAPI_RETURN_FD,
+       KAPI_RETURN_CUSTOM,
+};
+
+/**
+ * struct kapi_return_spec - Return value specification
+ * @type_name: Return type name
+ * @type: Return type classification
+ * @check_type: Type of success check to perform
+ * @success_value: Exact value indicating success (for EXACT)
+ * @success_min: Minimum success value (for RANGE)
+ * @success_max: Maximum success value (for RANGE)
+ * @error_values: Array of error values (for ERROR_CHECK)
+ * @error_count: Number of error values
+ * @is_success: Custom function to check success
+ * @description: Return value description
+ */
+struct kapi_return_spec {
+       char type_name[KAPI_MAX_NAME_LEN];
+       enum kapi_param_type type;
+       enum kapi_return_check_type check_type;
+       s64 success_value;
+       s64 success_min;
+       s64 success_max;
+       const s64 *error_values;
+       u32 error_count;
+       bool (*is_success)(s64 retval);
+       char description[KAPI_MAX_DESC_LEN];
+} __attribute__((packed));
+
+/**
+ * struct kapi_lock_spec - Lock requirement specification
+ * @lock_name: Name of the lock
+ * @lock_type: Type of lock
+ * @acquired: Whether function acquires this lock
+ * @released: Whether function releases this lock
+ * @held_on_entry: Whether lock must be held on entry
+ * @held_on_exit: Whether lock is held on exit
+ * @description: Additional lock requirements
+ */
+struct kapi_lock_spec {
+       char lock_name[KAPI_MAX_NAME_LEN];
+       enum kapi_lock_type lock_type;
+       bool acquired;
+       bool released;
+       bool held_on_entry;
+       bool held_on_exit;
+       char description[KAPI_MAX_DESC_LEN];
+} __attribute__((packed));
+
+/**
+ * struct kapi_constraint_spec - Additional constraint specification
+ * @name: Constraint name
+ * @description: Constraint description
+ * @expression: Formal expression (if applicable)
+ */
+struct kapi_constraint_spec {
+       char name[KAPI_MAX_NAME_LEN];
+       char description[KAPI_MAX_DESC_LEN];
+       char expression[KAPI_MAX_DESC_LEN];
+} __attribute__((packed));
+
+/**
+ * enum kapi_signal_direction - Signal flow direction
+ * @KAPI_SIGNAL_RECEIVE: Function may receive this signal
+ * @KAPI_SIGNAL_SEND: Function may send this signal
+ * @KAPI_SIGNAL_HANDLE: Function handles this signal specially
+ * @KAPI_SIGNAL_BLOCK: Function blocks this signal
+ * @KAPI_SIGNAL_IGNORE: Function ignores this signal
+ */
+enum kapi_signal_direction {
+       KAPI_SIGNAL_RECEIVE     = (1 << 0),
+       KAPI_SIGNAL_SEND        = (1 << 1),
+       KAPI_SIGNAL_HANDLE      = (1 << 2),
+       KAPI_SIGNAL_BLOCK       = (1 << 3),
+       KAPI_SIGNAL_IGNORE      = (1 << 4),
+};
+
+/**
+ * enum kapi_signal_action - What the function does with the signal
+ * @KAPI_SIGNAL_ACTION_DEFAULT: Default signal action applies
+ * @KAPI_SIGNAL_ACTION_TERMINATE: Causes termination
+ * @KAPI_SIGNAL_ACTION_COREDUMP: Causes termination with core dump
+ * @KAPI_SIGNAL_ACTION_STOP: Stops the process
+ * @KAPI_SIGNAL_ACTION_CONTINUE: Continues a stopped process
+ * @KAPI_SIGNAL_ACTION_CUSTOM: Custom handling described in notes
+ * @KAPI_SIGNAL_ACTION_RETURN: Returns from syscall with EINTR
+ * @KAPI_SIGNAL_ACTION_RESTART: Restarts the syscall
+ */
+enum kapi_signal_action {
+       KAPI_SIGNAL_ACTION_DEFAULT = 0,
+       KAPI_SIGNAL_ACTION_TERMINATE,
+       KAPI_SIGNAL_ACTION_COREDUMP,
+       KAPI_SIGNAL_ACTION_STOP,
+       KAPI_SIGNAL_ACTION_CONTINUE,
+       KAPI_SIGNAL_ACTION_CUSTOM,
+       KAPI_SIGNAL_ACTION_RETURN,
+       KAPI_SIGNAL_ACTION_RESTART,
+};
+
+/**
+ * struct kapi_signal_spec - Signal specification
+ * @signal_num: Signal number (e.g., SIGKILL, SIGTERM)
+ * @signal_name: Signal name as string
+ * @direction: Direction flags (OR of kapi_signal_direction)
+ * @action: What happens when signal is received
+ * @target: Description of target process/thread for sent signals
+ * @condition: Condition under which signal is sent/received/handled
+ * @description: Detailed description of signal handling
+ * @restartable: Whether syscall is restartable after this signal
+ */
+struct kapi_signal_spec {
+       int signal_num;
+       char signal_name[32];
+       u32 direction;
+       enum kapi_signal_action action;
+       char target[KAPI_MAX_DESC_LEN];
+       char condition[KAPI_MAX_DESC_LEN];
+       char description[KAPI_MAX_DESC_LEN];
+       bool restartable;
+} __attribute__((packed));
+
+/**
+ * struct kapi_signal_mask_spec - Signal mask specification
+ * @mask_name: Name of the signal mask
+ * @signals: Array of signal numbers in the mask
+ * @signal_count: Number of signals in the mask
+ * @description: Description of what this mask represents
+ */
+struct kapi_signal_mask_spec {
+       char mask_name[KAPI_MAX_NAME_LEN];
+       int signals[KAPI_MAX_SIGNALS];
+       u32 signal_count;
+       char description[KAPI_MAX_DESC_LEN];
+} __attribute__((packed));
+
+/**
+ * struct kapi_struct_field - Structure field specification
+ * @name: Field name
+ * @type: Field type classification
+ * @type_name: Type name as string
+ * @offset: Offset within structure
+ * @size: Size of field in bytes
+ * @flags: Field attribute flags
+ * @constraint_type: Type of constraint applied
+ * @min_value: Minimum valid value (for numeric types)
+ * @max_value: Maximum valid value (for numeric types)
+ * @valid_mask: Valid bits mask (for flag fields)
+ * @description: Field description
+ */
+struct kapi_struct_field {
+       char name[KAPI_MAX_NAME_LEN];
+       enum kapi_param_type type;
+       char type_name[KAPI_MAX_NAME_LEN];
+       size_t offset;
+       size_t size;
+       u32 flags;
+       enum kapi_constraint_type constraint_type;
+       s64 min_value;
+       s64 max_value;
+       u64 valid_mask;
+       char description[KAPI_MAX_DESC_LEN];
+} __attribute__((packed));
+
+/**
+ * struct kapi_struct_spec - Structure type specification
+ * @name: Structure name
+ * @size: Total size of structure
+ * @alignment: Required alignment
+ * @field_count: Number of fields
+ * @fields: Field specifications
+ * @description: Structure description
+ */
+struct kapi_struct_spec {
+       char name[KAPI_MAX_NAME_LEN];
+       size_t size;
+       size_t alignment;
+       u32 field_count;
+       struct kapi_struct_field fields[KAPI_MAX_PARAMS];
+       char description[KAPI_MAX_DESC_LEN];
+} __attribute__((packed));
+
+/**
+ * enum kapi_side_effect_type - Types of side effects
+ * @KAPI_EFFECT_NONE: No side effects
+ * @KAPI_EFFECT_ALLOC_MEMORY: Allocates memory
+ * @KAPI_EFFECT_FREE_MEMORY: Frees memory
+ * @KAPI_EFFECT_MODIFY_STATE: Modifies global/shared state
+ * @KAPI_EFFECT_SIGNAL_SEND: Sends signals
+ * @KAPI_EFFECT_FILE_POSITION: Modifies file position
+ * @KAPI_EFFECT_LOCK_ACQUIRE: Acquires locks
+ * @KAPI_EFFECT_LOCK_RELEASE: Releases locks
+ * @KAPI_EFFECT_RESOURCE_CREATE: Creates system resources (FDs, PIDs, etc)
+ * @KAPI_EFFECT_RESOURCE_DESTROY: Destroys system resources
+ * @KAPI_EFFECT_SCHEDULE: May cause scheduling/context switch
+ * @KAPI_EFFECT_HARDWARE: Interacts with hardware
+ * @KAPI_EFFECT_NETWORK: Network I/O operation
+ * @KAPI_EFFECT_FILESYSTEM: Filesystem modification
+ * @KAPI_EFFECT_PROCESS_STATE: Modifies process state
+ */
+enum kapi_side_effect_type {
+       KAPI_EFFECT_NONE = 0,
+       KAPI_EFFECT_ALLOC_MEMORY = (1 << 0),
+       KAPI_EFFECT_FREE_MEMORY = (1 << 1),
+       KAPI_EFFECT_MODIFY_STATE = (1 << 2),
+       KAPI_EFFECT_SIGNAL_SEND = (1 << 3),
+       KAPI_EFFECT_FILE_POSITION = (1 << 4),
+       KAPI_EFFECT_LOCK_ACQUIRE = (1 << 5),
+       KAPI_EFFECT_LOCK_RELEASE = (1 << 6),
+       KAPI_EFFECT_RESOURCE_CREATE = (1 << 7),
+       KAPI_EFFECT_RESOURCE_DESTROY = (1 << 8),
+       KAPI_EFFECT_SCHEDULE = (1 << 9),
+       KAPI_EFFECT_HARDWARE = (1 << 10),
+       KAPI_EFFECT_NETWORK = (1 << 11),
+       KAPI_EFFECT_FILESYSTEM = (1 << 12),
+       KAPI_EFFECT_PROCESS_STATE = (1 << 13),
+};
+
+/**
+ * struct kapi_side_effect - Side effect specification
+ * @type: Bitmask of effect types
+ * @target: What is affected (e.g., "process memory", "file descriptor table")
+ * @condition: Condition under which effect occurs
+ * @description: Detailed description of the effect
+ * @reversible: Whether the effect can be undone
+ */
+struct kapi_side_effect {
+       u32 type;
+       char target[KAPI_MAX_NAME_LEN];
+       char condition[KAPI_MAX_DESC_LEN];
+       char description[KAPI_MAX_DESC_LEN];
+       bool reversible;
+} __attribute__((packed));
+
+/**
+ * struct kapi_state_transition - State transition specification
+ * @from_state: Starting state description
+ * @to_state: Ending state description
+ * @condition: Condition for transition
+ * @object: Object whose state changes
+ * @description: Detailed description
+ */
+struct kapi_state_transition {
+       char from_state[KAPI_MAX_NAME_LEN];
+       char to_state[KAPI_MAX_NAME_LEN];
+       char condition[KAPI_MAX_DESC_LEN];
+       char object[KAPI_MAX_NAME_LEN];
+       char description[KAPI_MAX_DESC_LEN];
+} __attribute__((packed));
+
+#define KAPI_MAX_STRUCT_SPECS  8
+#define KAPI_MAX_SIDE_EFFECTS  16
+#define KAPI_MAX_STATE_TRANS   8
+
+/**
+ * struct kernel_api_spec - Complete kernel API specification
+ * @name: Function name
+ * @version: API version
+ * @description: Brief description
+ * @long_description: Detailed description
+ * @context_flags: Execution context flags
+ * @param_count: Number of parameters
+ * @params: Parameter specifications
+ * @return_spec: Return value specification
+ * @error_count: Number of possible errors
+ * @errors: Error specifications
+ * @lock_count: Number of lock specifications
+ * @locks: Lock requirement specifications
+ * @constraint_count: Number of additional constraints
+ * @constraints: Additional constraint specifications
+ * @examples: Usage examples
+ * @notes: Additional notes
+ * @since_version: Kernel version when introduced
+ * @deprecated: Whether API is deprecated
+ * @replacement: Replacement API if deprecated
+ * @signal_count: Number of signal specifications
+ * @signals: Signal handling specifications
+ * @signal_mask_count: Number of signal mask specifications
+ * @signal_masks: Signal mask specifications
+ * @struct_spec_count: Number of structure specifications
+ * @struct_specs: Structure type specifications
+ * @side_effect_count: Number of side effect specifications
+ * @side_effects: Side effect specifications
+ * @state_trans_count: Number of state transition specifications
+ * @state_transitions: State transition specifications
+ */
+struct kernel_api_spec {
+       char name[KAPI_MAX_NAME_LEN];
+       u32 version;
+       char description[KAPI_MAX_DESC_LEN];
+       char long_description[KAPI_MAX_DESC_LEN * 4];
+       u32 context_flags;
+
+       /* Parameters */
+       u32 param_count;
+       struct kapi_param_spec params[KAPI_MAX_PARAMS];
+
+       /* Return value */
+       struct kapi_return_spec return_spec;
+
+       /* Errors */
+       u32 error_count;
+       struct kapi_error_spec errors[KAPI_MAX_ERRORS];
+
+       /* Locking */
+       u32 lock_count;
+       struct kapi_lock_spec locks[KAPI_MAX_CONSTRAINTS];
+
+       /* Constraints */
+       u32 constraint_count;
+       struct kapi_constraint_spec constraints[KAPI_MAX_CONSTRAINTS];
+
+       /* Additional information */
+       char examples[KAPI_MAX_DESC_LEN * 2];
+       char notes[KAPI_MAX_DESC_LEN];
+       char since_version[32];
+       bool deprecated;
+       char replacement[KAPI_MAX_NAME_LEN];
+
+       /* Signal specifications */
+       u32 signal_count;
+       struct kapi_signal_spec signals[KAPI_MAX_SIGNALS];
+
+       /* Signal mask specifications */
+       u32 signal_mask_count;
+       struct kapi_signal_mask_spec signal_masks[KAPI_MAX_SIGNALS];
+
+       /* Structure specifications */
+       u32 struct_spec_count;
+       struct kapi_struct_spec struct_specs[KAPI_MAX_STRUCT_SPECS];
+
+       /* Side effects */
+       u32 side_effect_count;
+       struct kapi_side_effect side_effects[KAPI_MAX_SIDE_EFFECTS];
+
+       /* State transitions */
+       u32 state_trans_count;
+       struct kapi_state_transition state_transitions[KAPI_MAX_STATE_TRANS];
+} __attribute__((packed));
+
+/* Macros for defining API specifications */
+
+/**
+ * DEFINE_KERNEL_API_SPEC - Define a kernel API specification
+ * @func_name: Function name to specify
+ */
+#define DEFINE_KERNEL_API_SPEC(func_name) \
+       static struct kernel_api_spec __kapi_spec_##func_name \
+       __used __section(".kapi_specs") = {     \
+               .name = __stringify(func_name), \
+               .version = 1,
+
+#define KAPI_END_SPEC };
+
+/**
+ * KAPI_DESCRIPTION - Set API description
+ * @desc: Description string
+ */
+#define KAPI_DESCRIPTION(desc) \
+       .description = desc,
+
+/**
+ * KAPI_LONG_DESC - Set detailed API description
+ * @desc: Detailed description string
+ */
+#define KAPI_LONG_DESC(desc) \
+       .long_description = desc,
+
+/**
+ * KAPI_CONTEXT - Set execution context flags
+ * @flags: Context flags (OR'ed KAPI_CTX_* values)
+ */
+#define KAPI_CONTEXT(flags) \
+       .context_flags = flags,
+
+/**
+ * KAPI_PARAM - Define a parameter specification
+ * @idx: Parameter index (0-based)
+ * @pname: Parameter name
+ * @ptype: Type name string
+ * @pdesc: Parameter description
+ */
+#define KAPI_PARAM(idx, pname, ptype, pdesc) \
+       .params[idx] = {                        \
+               .name = pname,                  \
+               .type_name = ptype,             \
+               .description = pdesc,           \
+               .size_param_idx = -1,           /* Default: no dynamic sizing */
+
+#define KAPI_PARAM_FLAGS(pflags) \
+               .flags = pflags,
+
+#define KAPI_PARAM_SIZE(psize) \
+               .size = psize,
+
+#define KAPI_PARAM_RANGE(pmin, pmax) \
+               .min_value = pmin,      \
+               .max_value = pmax,
+
+#define KAPI_PARAM_END },
+
+/**
+ * KAPI_RETURN - Define return value specification
+ * @rtype: Return type name
+ * @rdesc: Return value description
+ */
+#define KAPI_RETURN(rtype, rdesc) \
+       .return_spec = {                \
+               .type_name = rtype,     \
+               .description = rdesc,
+
+#define KAPI_RETURN_SUCCESS(val) \
+               .success_value = val,
+
+#define KAPI_RETURN_END },
+
+/**
+ * KAPI_ERROR - Define an error condition
+ * @idx: Error index
+ * @ecode: Error code value
+ * @ename: Error name
+ * @econd: Error condition
+ * @edesc: Error description
+ */
+#define KAPI_ERROR(idx, ecode, ename, econd, edesc) \
+       .errors[idx] = {                        \
+               .error_code = ecode,            \
+               .name = ename,                  \
+               .condition = econd,             \
+               .description = edesc,           \
+       },
+
+/**
+ * KAPI_LOCK - Define a lock requirement
+ * @idx: Lock index
+ * @lname: Lock name
+ * @ltype: Lock type
+ */
+#define KAPI_LOCK(idx, lname, ltype) \
+       .locks[idx] = {                 \
+               .lock_name = lname,     \
+               .lock_type = ltype,
+
+#define KAPI_LOCK_ACQUIRED \
+               .acquired = true,
+
+#define KAPI_LOCK_RELEASED \
+               .released = true,
+
+#define KAPI_LOCK_HELD_ENTRY \
+               .held_on_entry = true,
+
+#define KAPI_LOCK_HELD_EXIT \
+               .held_on_exit = true,
+
+#define KAPI_LOCK_DESC(ldesc) \
+               .description = ldesc,
+
+#define KAPI_LOCK_END },
+
+/**
+ * KAPI_CONSTRAINT - Define an additional constraint
+ * @idx: Constraint index
+ * @cname: Constraint name
+ * @cdesc: Constraint description
+ */
+#define KAPI_CONSTRAINT(idx, cname, cdesc) \
+       .constraints[idx] = {           \
+               .name = cname,          \
+               .description = cdesc,
+
+#define KAPI_CONSTRAINT_EXPR(expr) \
+               .expression = expr,
+
+#define KAPI_CONSTRAINT_END },
+
+/**
+ * KAPI_SIGNAL - Define a signal specification
+ * @idx: Signal index
+ * @signum: Signal number (e.g., SIGKILL)
+ * @signame: Signal name string
+ * @dir: Direction flags
+ * @act: Action taken
+ */
+#define KAPI_SIGNAL(idx, signum, signame, dir, act) \
+       .signals[idx] = {                       \
+               .signal_num = signum,           \
+               .signal_name = signame,         \
+               .direction = dir,               \
+               .action = act,
+
+#define KAPI_SIGNAL_TARGET(tgt) \
+               .target = tgt,
+
+#define KAPI_SIGNAL_CONDITION(cond) \
+               .condition = cond,
+
+#define KAPI_SIGNAL_DESC(desc) \
+               .description = desc,
+
+#define KAPI_SIGNAL_RESTARTABLE \
+               .restartable = true,
+
+#define KAPI_SIGNAL_END },
+
+/**
+ * KAPI_SIGNAL_MASK - Define a signal mask specification
+ * @idx: Mask index
+ * @name: Mask name
+ * @desc: Mask description
+ */
+#define KAPI_SIGNAL_MASK(idx, name, desc) \
+       .signal_masks[idx] = {          \
+               .mask_name = name,      \
+               .description = desc,
+
+#define KAPI_SIGNAL_MASK_ADD(signum) \
+               .signals[.signal_count++] = signum,
+
+#define KAPI_SIGNAL_MASK_END },
+
+/**
+ * KAPI_STRUCT_SPEC - Define a structure specification
+ * @idx: Structure spec index
+ * @sname: Structure name
+ * @sdesc: Structure description
+ */
+#define KAPI_STRUCT_SPEC(idx, sname, sdesc) \
+       .struct_specs[idx] = {          \
+               .name = #sname,         \
+               .description = sdesc,
+
+#define KAPI_STRUCT_SIZE(ssize, salign) \
+               .size = ssize,          \
+               .alignment = salign,
+
+#define KAPI_STRUCT_FIELD_COUNT(n) \
+               .field_count = n,
+
+/**
+ * KAPI_STRUCT_FIELD - Define a structure field
+ * @fidx: Field index
+ * @fname: Field name
+ * @ftype: Field type (KAPI_TYPE_*)
+ * @ftype_name: Type name as string
+ * @fdesc: Field description
+ */
+#define KAPI_STRUCT_FIELD(fidx, fname, ftype, ftype_name, fdesc) \
+               .fields[fidx] = {       \
+                       .name = fname,  \
+                       .type = ftype,  \
+                       .type_name = ftype_name, \
+                       .description = fdesc,
+
+#define KAPI_FIELD_OFFSET(foffset) \
+                       .offset = foffset,
+
+#define KAPI_FIELD_SIZE(fsize) \
+                       .size = fsize,
+
+#define KAPI_FIELD_FLAGS(fflags) \
+                       .flags = fflags,
+
+#define KAPI_FIELD_CONSTRAINT_RANGE(min, max) \
+                       .constraint_type = KAPI_CONSTRAINT_RANGE, \
+                       .min_value = min, \
+                       .max_value = max,
+
+#define KAPI_FIELD_CONSTRAINT_MASK(mask) \
+                       .constraint_type = KAPI_CONSTRAINT_MASK, \
+                       .valid_mask = mask,
+
+#define KAPI_FIELD_CONSTRAINT_ENUM(values, count) \
+                       .constraint_type = KAPI_CONSTRAINT_ENUM, \
+                       .enum_values = values, \
+                       .enum_count = count,
+
+#define KAPI_STRUCT_FIELD_END },
+
+#define KAPI_STRUCT_SPEC_END },
+
+/* Counter for structure specifications */
+#define KAPI_STRUCT_SPEC_COUNT(n) \
+       .struct_spec_count = n,
+
+/**
+ * KAPI_SIDE_EFFECT - Define a side effect
+ * @idx: Side effect index
+ * @etype: Effect type bitmask (OR'ed KAPI_EFFECT_* values)
+ * @etarget: What is affected
+ * @edesc: Effect description
+ */
+#define KAPI_SIDE_EFFECT(idx, etype, etarget, edesc) \
+       .side_effects[idx] = {          \
+               .type = etype,          \
+               .target = etarget,      \
+               .description = edesc,   \
+               .reversible = false,    /* Default to non-reversible */
+
+#define KAPI_EFFECT_CONDITION(cond) \
+               .condition = cond,
+
+#define KAPI_EFFECT_REVERSIBLE \
+               .reversible = true,
+
+#define KAPI_SIDE_EFFECT_END },
+
+/**
+ * KAPI_STATE_TRANS - Define a state transition
+ * @idx: State transition index
+ * @obj: Object whose state changes
+ * @from: From state
+ * @to: To state
+ * @desc: Transition description
+ */
+#define KAPI_STATE_TRANS(idx, obj, from, to, desc) \
+       .state_transitions[idx] = {     \
+               .object = obj,          \
+               .from_state = from,     \
+               .to_state = to,         \
+               .description = desc,
+
+#define KAPI_STATE_TRANS_COND(cond) \
+               .condition = cond,
+
+#define KAPI_STATE_TRANS_END },
+
+/* Counters for side effects and state transitions */
+#define KAPI_SIDE_EFFECT_COUNT(n) \
+       .side_effect_count = n,
+
+#define KAPI_STATE_TRANS_COUNT(n) \
+       .state_trans_count = n,
+
+/* Helper macros for common side effect patterns */
+#define KAPI_EFFECTS_MEMORY    (KAPI_EFFECT_ALLOC_MEMORY | 
KAPI_EFFECT_FREE_MEMORY)
+#define KAPI_EFFECTS_LOCKING   (KAPI_EFFECT_LOCK_ACQUIRE | 
KAPI_EFFECT_LOCK_RELEASE)
+#define KAPI_EFFECTS_RESOURCES (KAPI_EFFECT_RESOURCE_CREATE | 
KAPI_EFFECT_RESOURCE_DESTROY)
+#define KAPI_EFFECTS_IO                (KAPI_EFFECT_NETWORK | 
KAPI_EFFECT_FILESYSTEM)
+
+/* Helper macros for common patterns */
+
+#define KAPI_PARAM_IN          (KAPI_PARAM_IN)
+#define KAPI_PARAM_OUT         (KAPI_PARAM_OUT)
+#define KAPI_PARAM_INOUT       (KAPI_PARAM_IN | KAPI_PARAM_OUT)
+#define KAPI_PARAM_OPTIONAL    (KAPI_PARAM_OPTIONAL)
+#define KAPI_PARAM_USER_PTR    (KAPI_PARAM_USER | KAPI_PARAM_PTR)
+
+/* Validation and runtime checking */
+
+#ifdef CONFIG_KAPI_RUNTIME_CHECKS
+bool kapi_validate_params(const struct kernel_api_spec *spec, ...);
+bool kapi_validate_param(const struct kapi_param_spec *param_spec, s64 value);
+bool kapi_validate_param_with_context(const struct kapi_param_spec *param_spec,
+                                      s64 value, const s64 *all_params, int 
param_count);
+int kapi_validate_syscall_param(const struct kernel_api_spec *spec,
+                               int param_idx, s64 value);
+int kapi_validate_syscall_params(const struct kernel_api_spec *spec,
+                                const s64 *params, int param_count);
+bool kapi_check_return_success(const struct kapi_return_spec *return_spec, s64 
retval);
+bool kapi_validate_return_value(const struct kernel_api_spec *spec, s64 
retval);
+int kapi_validate_syscall_return(const struct kernel_api_spec *spec, s64 
retval);
+void kapi_check_context(const struct kernel_api_spec *spec);
+void kapi_check_locks(const struct kernel_api_spec *spec);
+#else
+static inline bool kapi_validate_params(const struct kernel_api_spec *spec, 
...)
+{
+       return true;
+}
+static inline bool kapi_validate_param(const struct kapi_param_spec 
*param_spec, s64 value)
+{
+       return true;
+}
+static inline bool kapi_validate_param_with_context(const struct 
kapi_param_spec *param_spec,
+                                                    s64 value, const s64 
*all_params, int param_count)
+{
+       return true;
+}
+static inline int kapi_validate_syscall_param(const struct kernel_api_spec 
*spec,
+                                              int param_idx, s64 value)
+{
+       return 0;
+}
+static inline int kapi_validate_syscall_params(const struct kernel_api_spec 
*spec,
+                                              const s64 *params, int 
param_count)
+{
+       return 0;
+}
+static inline bool kapi_check_return_success(const struct kapi_return_spec 
*return_spec, s64 retval)
+{
+       return true;
+}
+static inline bool kapi_validate_return_value(const struct kernel_api_spec 
*spec, s64 retval)
+{
+       return true;
+}
+static inline int kapi_validate_syscall_return(const struct kernel_api_spec 
*spec, s64 retval)
+{
+       return 0;
+}
+static inline void kapi_check_context(const struct kernel_api_spec *spec) {}
+static inline void kapi_check_locks(const struct kernel_api_spec *spec) {}
+#endif
+
+/* Export/query functions */
+const struct kernel_api_spec *kapi_get_spec(const char *name);
+int kapi_export_json(const struct kernel_api_spec *spec, char *buf, size_t 
size);
+int kapi_export_xml(const struct kernel_api_spec *spec, char *buf, size_t 
size);
+void kapi_print_spec(const struct kernel_api_spec *spec);
+
+/* Registration for dynamic APIs */
+int kapi_register_spec(struct kernel_api_spec *spec);
+void kapi_unregister_spec(const char *name);
+
+/* Helper to get parameter constraint info */
+static inline bool kapi_get_param_constraint(const char *api_name, int 
param_idx,
+                                             enum kapi_constraint_type *type,
+                                             u64 *valid_mask, s64 *min_val, 
s64 *max_val)
+{
+       const struct kernel_api_spec *spec = kapi_get_spec(api_name);
+
+       if (!spec || param_idx >= spec->param_count)
+               return false;
+
+       if (type)
+               *type = spec->params[param_idx].constraint_type;
+       if (valid_mask)
+               *valid_mask = spec->params[param_idx].valid_mask;
+       if (min_val)
+               *min_val = spec->params[param_idx].min_value;
+       if (max_val)
+               *max_val = spec->params[param_idx].max_value;
+
+       return true;
+}
+
+#endif /* _LINUX_KERNEL_API_SPEC_H */
\ No newline at end of file
diff --git a/include/linux/syscall_api_spec.h b/include/linux/syscall_api_spec.h
new file mode 100644
index 0000000000000..48ad95647dd39
--- /dev/null
+++ b/include/linux/syscall_api_spec.h
@@ -0,0 +1,341 @@
+/* SPDX-License-Identifier: GPL-2.0 */
+/*
+ * syscall_api_spec.h - System Call API Specification Integration
+ *
+ * This header extends the SYSCALL_DEFINEX macros to support inline API 
specifications,
+ * allowing syscall documentation to be written alongside the implementation 
in a
+ * human-readable and machine-parseable format.
+ */
+
+#ifndef _LINUX_SYSCALL_API_SPEC_H
+#define _LINUX_SYSCALL_API_SPEC_H
+
+#include <linux/kernel_api_spec.h>
+
+/*
+ * Extended SYSCALL_DEFINE macros with API specification support
+ *
+ * Usage example:
+ *
+ * SYSCALL_DEFINE_SPEC2(example,
+ *     KAPI_DESCRIPTION("Example system call"),
+ *     KAPI_LONG_DESC("This is a detailed description of the example syscall"),
+ *     KAPI_CONTEXT(KAPI_CTX_PROCESS | KAPI_CTX_SLEEPABLE),
+ *
+ *     KAPI_PARAM(0, "fd", "int", "File descriptor to operate on")
+ *         KAPI_PARAM_FLAGS(KAPI_PARAM_IN)
+ *         KAPI_PARAM_RANGE(0, INT_MAX)
+ *     KAPI_PARAM_END,
+ *
+ *     KAPI_PARAM(1, "flags", "unsigned int", "Operation flags")
+ *         KAPI_PARAM_FLAGS(KAPI_PARAM_IN)
+ *     KAPI_PARAM_END,
+ *
+ *     KAPI_RETURN("long", "0 on success, negative error code on failure")
+ *         KAPI_RETURN_SUCCESS(0, "== 0")
+ *     KAPI_RETURN_END,
+ *
+ *     KAPI_ERROR(0, -EBADF, "EBADF", "fd is not a valid file descriptor",
+ *                "The file descriptor is invalid or closed"),
+ *     KAPI_ERROR(1, -EINVAL, "EINVAL", "flags contains invalid values",
+ *                "Invalid flag combination specified"),
+ *
+ *     .error_count = 2,
+ *     .param_count = 2,
+ *
+ *     int, fd, unsigned int, flags)
+ * {
+ *     // Implementation here
+ * }
+ */
+
+/* Helper to count parameters */
+#define __SYSCALL_PARAM_COUNT(...) __SYSCALL_PARAM_COUNT_I(__VA_ARGS__, 6, 5, 
4, 3, 2, 1, 0)
+#define __SYSCALL_PARAM_COUNT_I(_1, _2, _3, _4, _5, _6, N, ...) N
+
+/* Extract syscall name from parameters */
+#define __SYSCALL_NAME(name, ...) name
+
+/* Generate API spec structure name */
+#define __SYSCALL_API_SPEC_NAME(name) __kapi_spec_sys_##name
+
+/* Helper to count syscall parameters (pairs of type, name) */
+#define __SYSCALL_ARG_COUNT(...) __SYSCALL_ARG_COUNT_I(__VA_ARGS__, 6, 6, 5, 
5, 4, 4, 3, 3, 2, 2, 1, 1, 0)
+#define __SYSCALL_ARG_COUNT_I(_1, _2, _3, _4, _5, _6, _7, _8, _9, _10, _11, 
_12, N, ...) N
+
+/* Automatic syscall validation infrastructure */
+#ifdef CONFIG_KAPI_RUNTIME_CHECKS
+
+/* Helper to inject validation at the beginning of syscall */
+#define __KAPI_SYSCALL_VALIDATE_0(name)
+#define __KAPI_SYSCALL_VALIDATE_1(name, t1, a1) \
+       const struct kernel_api_spec *__spec = kapi_get_spec("sys_" #name); \
+       if (__spec) { \
+               s64 __params[1] = { (s64)(a1) }; \
+               int __ret = kapi_validate_syscall_params(__spec, __params, 1); \
+               if (__ret) return __ret; \
+       }
+#define __KAPI_SYSCALL_VALIDATE_2(name, t1, a1, t2, a2) \
+       const struct kernel_api_spec *__spec = kapi_get_spec("sys_" #name); \
+       if (__spec) { \
+               s64 __params[2] = { (s64)(a1), (s64)(a2) }; \
+               int __ret = kapi_validate_syscall_params(__spec, __params, 2); \
+               if (__ret) return __ret; \
+       }
+#define __KAPI_SYSCALL_VALIDATE_3(name, t1, a1, t2, a2, t3, a3) \
+       const struct kernel_api_spec *__spec = kapi_get_spec("sys_" #name); \
+       if (__spec) { \
+               s64 __params[3] = { (s64)(a1), (s64)(a2), (s64)(a3) }; \
+               int __ret = kapi_validate_syscall_params(__spec, __params, 3); \
+               if (__ret) return __ret; \
+       }
+#define __KAPI_SYSCALL_VALIDATE_4(name, t1, a1, t2, a2, t3, a3, t4, a4) \
+       const struct kernel_api_spec *__spec = kapi_get_spec("sys_" #name); \
+       if (__spec) { \
+               s64 __params[4] = { (s64)(a1), (s64)(a2), (s64)(a3), (s64)(a4) 
}; \
+               int __ret = kapi_validate_syscall_params(__spec, __params, 4); \
+               if (__ret) return __ret; \
+       }
+#define __KAPI_SYSCALL_VALIDATE_5(name, t1, a1, t2, a2, t3, a3, t4, a4, t5, 
a5) \
+       const struct kernel_api_spec *__spec = kapi_get_spec("sys_" #name); \
+       if (__spec) { \
+               s64 __params[5] = { (s64)(a1), (s64)(a2), (s64)(a3), (s64)(a4), 
(s64)(a5) }; \
+               int __ret = kapi_validate_syscall_params(__spec, __params, 5); \
+               if (__ret) return __ret; \
+       }
+#define __KAPI_SYSCALL_VALIDATE_6(name, t1, a1, t2, a2, t3, a3, t4, a4, t5, 
a5, t6, a6) \
+       const struct kernel_api_spec *__spec = kapi_get_spec("sys_" #name); \
+       if (__spec) { \
+               s64 __params[6] = { (s64)(a1), (s64)(a2), (s64)(a3), (s64)(a4), 
(s64)(a5), (s64)(a6) }; \
+               int __ret = kapi_validate_syscall_params(__spec, __params, 6); \
+               if (__ret) return __ret; \
+       }
+
+#else /* !CONFIG_KAPI_RUNTIME_CHECKS */
+
+#define __KAPI_SYSCALL_VALIDATE_0(name)
+#define __KAPI_SYSCALL_VALIDATE_1(name, t1, a1)
+#define __KAPI_SYSCALL_VALIDATE_2(name, t1, a1, t2, a2)
+#define __KAPI_SYSCALL_VALIDATE_3(name, t1, a1, t2, a2, t3, a3)
+#define __KAPI_SYSCALL_VALIDATE_4(name, t1, a1, t2, a2, t3, a3, t4, a4)
+#define __KAPI_SYSCALL_VALIDATE_5(name, t1, a1, t2, a2, t3, a3, t4, a4, t5, a5)
+#define __KAPI_SYSCALL_VALIDATE_6(name, t1, a1, t2, a2, t3, a3, t4, a4, t5, 
a5, t6, a6)
+
+#endif /* CONFIG_KAPI_RUNTIME_CHECKS */
+
+/* Helper to inject validation for return values */
+#ifdef CONFIG_KAPI_RUNTIME_CHECKS
+
+#define __KAPI_SYSCALL_VALIDATE_RETURN(name, retval) \
+       do { \
+               const struct kernel_api_spec *__spec = kapi_get_spec("sys_" 
#name); \
+               if (__spec) { \
+                       kapi_validate_syscall_return(__spec, (s64)(retval)); \
+               } \
+       } while (0)
+
+/* Wrapper to validate both params and return value */
+#define __SYSCALL_DEFINE_SPEC(name, spec_args, ...) \
+       DEFINE_KERNEL_API_SPEC(sys_##name) \
+               .name = "sys_" #name, \
+               spec_args \
+       KAPI_END_SPEC; \
+       static long __kapi_sys_##name(__MAP((__SYSCALL_ARG_COUNT(__VA_ARGS__)), 
__SC_DECL, __VA_ARGS__)); \
+       SYSCALL_DEFINE##__SYSCALL_ARG_COUNT(__VA_ARGS__)(name, __VA_ARGS__) \
+       { \
+               long __ret; \
+               
__KAPI_SYSCALL_VALIDATE_##__SYSCALL_ARG_COUNT(__VA_ARGS__)(name, __VA_ARGS__); \
+               __ret = 
__kapi_sys_##name(__MAP((__SYSCALL_ARG_COUNT(__VA_ARGS__)), __SC_CAST, 
__VA_ARGS__)); \
+               __KAPI_SYSCALL_VALIDATE_RETURN(name, __ret); \
+               return __ret; \
+       } \
+       static long __kapi_sys_##name(__MAP((__SYSCALL_ARG_COUNT(__VA_ARGS__)), 
__SC_DECL, __VA_ARGS__))
+
+#else /* !CONFIG_KAPI_RUNTIME_CHECKS */
+
+#define __SYSCALL_DEFINE_SPEC(name, spec_args, ...) \
+       DEFINE_KERNEL_API_SPEC(sys_##name) \
+               .name = "sys_" #name, \
+               spec_args \
+       KAPI_END_SPEC; \
+       SYSCALL_DEFINE##__SYSCALL_ARG_COUNT(__VA_ARGS__)(name, __VA_ARGS__)
+
+#endif /* CONFIG_KAPI_RUNTIME_CHECKS */
+
+
+/* Convenience macros for different parameter counts */
+#define SYSCALL_DEFINE_SPEC0(name, spec_args)                          \
+       DEFINE_KERNEL_API_SPEC(sys_##name)                              \
+               .name = "sys_" #name,                                   \
+               .param_count = 0,                                       \
+               spec_args                                               \
+       KAPI_END_SPEC;                                                  \
+       SYSCALL_DEFINE0(name)
+
+#define SYSCALL_DEFINE_SPEC1(name, spec_args, t1, a1)                  \
+       __SYSCALL_DEFINE_SPEC(name, spec_args, t1, a1)
+
+#define SYSCALL_DEFINE_SPEC2(name, spec_args, t1, a1, t2, a2)          \
+       __SYSCALL_DEFINE_SPEC(name, spec_args, t1, a1, t2, a2)
+
+#define SYSCALL_DEFINE_SPEC3(name, spec_args, t1, a1, t2, a2, t3, a3)  \
+       __SYSCALL_DEFINE_SPEC(name, spec_args, t1, a1, t2, a2, t3, a3)
+
+#define SYSCALL_DEFINE_SPEC4(name, spec_args, t1, a1, t2, a2, t3, a3,  \
+                            t4, a4)                                    \
+       __SYSCALL_DEFINE_SPEC(name, spec_args, t1, a1, t2, a2, t3, a3, t4, a4)
+
+#define SYSCALL_DEFINE_SPEC5(name, spec_args, t1, a1, t2, a2, t3, a3,  \
+                            t4, a4, t5, a5)                            \
+       __SYSCALL_DEFINE_SPEC(name, spec_args, t1, a1, t2, a2, t3, a3,  \
+                             t4, a4, t5, a5)
+
+#define SYSCALL_DEFINE_SPEC6(name, spec_args, t1, a1, t2, a2, t3, a3,  \
+                            t4, a4, t5, a5, t6, a6)                    \
+       __SYSCALL_DEFINE_SPEC(name, spec_args, t1, a1, t2, a2, t3, a3,  \
+                             t4, a4, t5, a5, t6, a6)
+
+/*
+ * Helper macros for common syscall patterns
+ */
+
+/* For syscalls that can sleep */
+#define KAPI_SYSCALL_SLEEPABLE \
+       KAPI_CONTEXT(KAPI_CTX_PROCESS | KAPI_CTX_SLEEPABLE)
+
+/* For syscalls that must be atomic */
+#define KAPI_SYSCALL_ATOMIC \
+       KAPI_CONTEXT(KAPI_CTX_PROCESS | KAPI_CTX_ATOMIC)
+
+/* Common parameter specifications */
+#define KAPI_PARAM_FD(idx, desc) \
+       KAPI_PARAM(idx, "fd", "int", desc) \
+               KAPI_PARAM_FLAGS(KAPI_PARAM_IN) \
+               .type = KAPI_TYPE_FD, \
+               .constraint_type = KAPI_CONSTRAINT_NONE, \
+       KAPI_PARAM_END
+
+#define KAPI_PARAM_USER_BUF(idx, name, desc) \
+       KAPI_PARAM(idx, name, "void __user *", desc) \
+               KAPI_PARAM_FLAGS(KAPI_PARAM_USER_PTR | KAPI_PARAM_IN) \
+       KAPI_PARAM_END
+
+#define KAPI_PARAM_USER_STRUCT(idx, name, struct_type, desc) \
+       KAPI_PARAM(idx, name, #struct_type " __user *", desc) \
+               KAPI_PARAM_FLAGS(KAPI_PARAM_USER | KAPI_PARAM_IN) \
+               .type = KAPI_TYPE_USER_PTR, \
+               .size = sizeof(struct_type), \
+               .constraint_type = KAPI_CONSTRAINT_NONE, \
+       KAPI_PARAM_END
+
+#define KAPI_PARAM_SIZE_T(idx, name, desc) \
+       KAPI_PARAM(idx, name, "size_t", desc) \
+               KAPI_PARAM_FLAGS(KAPI_PARAM_IN) \
+               KAPI_PARAM_RANGE(0, SIZE_MAX) \
+       KAPI_PARAM_END
+
+/* Common error specifications */
+#define KAPI_ERROR_EBADF(idx) \
+       KAPI_ERROR(idx, -EBADF, "EBADF", "Invalid file descriptor", \
+                  "The file descriptor is not valid or has been closed")
+
+#define KAPI_ERROR_EINVAL(idx, condition) \
+       KAPI_ERROR(idx, -EINVAL, "EINVAL", condition, \
+                  "Invalid argument provided")
+
+#define KAPI_ERROR_ENOMEM(idx) \
+       KAPI_ERROR(idx, -ENOMEM, "ENOMEM", "Insufficient memory", \
+                  "Cannot allocate memory for the operation")
+
+#define KAPI_ERROR_EPERM(idx) \
+       KAPI_ERROR(idx, -EPERM, "EPERM", "Operation not permitted", \
+                  "The calling process does not have the required permissions")
+
+#define KAPI_ERROR_EFAULT(idx) \
+       KAPI_ERROR(idx, -EFAULT, "EFAULT", "Bad address", \
+                  "Invalid user space address provided")
+
+/* Standard return value specifications */
+#define KAPI_RETURN_SUCCESS_ZERO \
+       KAPI_RETURN("long", "0 on success, negative error code on failure") \
+               KAPI_RETURN_SUCCESS(0, "== 0") \
+       KAPI_RETURN_END
+
+#define KAPI_RETURN_FD_SPEC \
+       KAPI_RETURN("long", "File descriptor on success, negative error code on 
failure") \
+               .check_type = KAPI_RETURN_FD, \
+       KAPI_RETURN_END
+
+#define KAPI_RETURN_COUNT \
+       KAPI_RETURN("long", "Number of bytes processed on success, negative 
error code on failure") \
+               KAPI_RETURN_SUCCESS(0, ">= 0") \
+       KAPI_RETURN_END
+
+
+/*
+ * Compat syscall support
+ */
+#ifdef CONFIG_COMPAT
+
+#define COMPAT_SYSCALL_DEFINE_SPEC0(name, spec_args) \
+       DEFINE_KERNEL_API_SPEC(compat_sys_##name) \
+               .name = "compat_sys_" #name, \
+               .param_count = 0, \
+               spec_args \
+       KAPI_END_SPEC; \
+       COMPAT_SYSCALL_DEFINE0(name)
+
+#define COMPAT_SYSCALL_DEFINE_SPEC1(name, spec_args, t1, a1) \
+       DEFINE_KERNEL_API_SPEC(compat_sys_##name) \
+               .name = "compat_sys_" #name, \
+               .param_count = 1, \
+               spec_args \
+       KAPI_END_SPEC; \
+       COMPAT_SYSCALL_DEFINE1(name, t1, a1)
+
+#define COMPAT_SYSCALL_DEFINE_SPEC2(name, spec_args, t1, a1, t2, a2) \
+       DEFINE_KERNEL_API_SPEC(compat_sys_##name) \
+               .name = "compat_sys_" #name, \
+               .param_count = 2, \
+               spec_args \
+       KAPI_END_SPEC; \
+       COMPAT_SYSCALL_DEFINE2(name, t1, a1, t2, a2)
+
+#define COMPAT_SYSCALL_DEFINE_SPEC3(name, spec_args, t1, a1, t2, a2, t3, a3) \
+       DEFINE_KERNEL_API_SPEC(compat_sys_##name) \
+               .name = "compat_sys_" #name, \
+               .param_count = 3, \
+               spec_args \
+       KAPI_END_SPEC; \
+       COMPAT_SYSCALL_DEFINE3(name, t1, a1, t2, a2, t3, a3)
+
+#define COMPAT_SYSCALL_DEFINE_SPEC4(name, spec_args, t1, a1, t2, a2, t3, a3, \
+                                    t4, a4) \
+       DEFINE_KERNEL_API_SPEC(compat_sys_##name) \
+               .name = "compat_sys_" #name, \
+               .param_count = 4, \
+               spec_args \
+       KAPI_END_SPEC; \
+       COMPAT_SYSCALL_DEFINE4(name, t1, a1, t2, a2, t3, a3, t4, a4)
+
+#define COMPAT_SYSCALL_DEFINE_SPEC5(name, spec_args, t1, a1, t2, a2, t3, a3, \
+                                    t4, a4, t5, a5) \
+       DEFINE_KERNEL_API_SPEC(compat_sys_##name) \
+               .name = "compat_sys_" #name, \
+               .param_count = 5, \
+               spec_args \
+       KAPI_END_SPEC; \
+       COMPAT_SYSCALL_DEFINE5(name, t1, a1, t2, a2, t3, a3, t4, a4, t5, a5)
+
+#define COMPAT_SYSCALL_DEFINE_SPEC6(name, spec_args, t1, a1, t2, a2, t3, a3, \
+                                    t4, a4, t5, a5, t6, a6) \
+       DEFINE_KERNEL_API_SPEC(compat_sys_##name) \
+               .name = "compat_sys_" #name, \
+               .param_count = 6, \
+               spec_args \
+       KAPI_END_SPEC; \
+       COMPAT_SYSCALL_DEFINE6(name, t1, a1, t2, a2, t3, a3, t4, a4, t5, a5, 
t6, a6)
+
+#endif /* CONFIG_COMPAT */
+
+#endif /* _LINUX_SYSCALL_API_SPEC_H */
\ No newline at end of file
diff --git a/include/linux/syscalls.h b/include/linux/syscalls.h
index e5603cc91963d..f2951ece2068b 100644
--- a/include/linux/syscalls.h
+++ b/include/linux/syscalls.h
@@ -87,6 +87,7 @@ struct xattr_args;
 #include <linux/bug.h>
 #include <linux/sem.h>
 #include <asm/siginfo.h>
+#include <linux/syscall_api_spec.h>
 #include <linux/unistd.h>
 #include <linux/quota.h>
 #include <linux/key.h>
diff --git a/init/Kconfig b/init/Kconfig
index af4c2f0854554..7a15248933895 100644
--- a/init/Kconfig
+++ b/init/Kconfig
@@ -2079,6 +2079,8 @@ config TRACEPOINTS
 
 source "kernel/Kconfig.kexec"
 
+source "kernel/api/Kconfig"
+
 endmenu                # General setup
 
 source "arch/Kconfig"
diff --git a/kernel/Makefile b/kernel/Makefile
index 32e80dd626af0..ba94ee4bb2292 100644
--- a/kernel/Makefile
+++ b/kernel/Makefile
@@ -56,6 +56,7 @@ obj-y += livepatch/
 obj-y += dma/
 obj-y += entry/
 obj-$(CONFIG_MODULES) += module/
+obj-$(CONFIG_KAPI_SPEC) += api/
 
 obj-$(CONFIG_KCMP) += kcmp.o
 obj-$(CONFIG_FREEZER) += freezer.o
diff --git a/kernel/api/Kconfig b/kernel/api/Kconfig
new file mode 100644
index 0000000000000..fde25ec70e134
--- /dev/null
+++ b/kernel/api/Kconfig
@@ -0,0 +1,35 @@
+# SPDX-License-Identifier: GPL-2.0-only
+#
+# Kernel API Specification Framework Configuration
+#
+
+config KAPI_SPEC
+       bool "Kernel API Specification Framework"
+       help
+         This option enables the kernel API specification framework,
+         which provides formal documentation of kernel APIs in both
+         human and machine-readable formats.
+
+         The framework allows developers to document APIs inline with
+         their implementation, including parameter specifications,
+         return values, error conditions, locking requirements, and
+         execution context constraints.
+
+         When enabled, API specifications can be queried at runtime
+         and exported in various formats (JSON, XML) through debugfs.
+
+         If unsure, say N.
+
+config KAPI_RUNTIME_CHECKS
+       bool "Runtime API specification checks"
+       depends on KAPI_SPEC
+       depends on DEBUG_KERNEL
+       help
+         Enable runtime validation of API usage against specifications.
+         This includes checking execution context requirements, parameter
+         validation, and lock state verification.
+
+         This adds overhead and should only be used for debugging and
+         development. The checks use WARN_ONCE to report violations.
+
+         If unsure, say N.
diff --git a/kernel/api/Makefile b/kernel/api/Makefile
new file mode 100644
index 0000000000000..4120ded7e5cf1
--- /dev/null
+++ b/kernel/api/Makefile
@@ -0,0 +1,7 @@
+# SPDX-License-Identifier: GPL-2.0
+#
+# Makefile for the Kernel API Specification Framework
+#
+
+# Core API specification framework
+obj-$(CONFIG_KAPI_SPEC)                += kernel_api_spec.o
\ No newline at end of file
diff --git a/kernel/api/kernel_api_spec.c b/kernel/api/kernel_api_spec.c
new file mode 100644
index 0000000000000..29c0c84d87f7c
--- /dev/null
+++ b/kernel/api/kernel_api_spec.c
@@ -0,0 +1,1169 @@
+// SPDX-License-Identifier: GPL-2.0
+/*
+ * kernel_api_spec.c - Kernel API Specification Framework Implementation
+ *
+ * Provides runtime support for kernel API specifications including validation,
+ * export to various formats, and querying capabilities.
+ */
+
+#include <linux/kernel.h>
+#include <linux/kernel_api_spec.h>
+#include <linux/string.h>
+#include <linux/slab.h>
+#include <linux/list.h>
+#include <linux/mutex.h>
+#include <linux/seq_file.h>
+#include <linux/debugfs.h>
+#include <linux/export.h>
+#include <linux/preempt.h>
+#include <linux/hardirq.h>
+#include <linux/file.h>
+#include <linux/fdtable.h>
+#include <linux/uaccess.h>
+#include <linux/limits.h>
+#include <linux/fcntl.h>
+
+/* Section where API specifications are stored */
+extern struct kernel_api_spec __start_kapi_specs[];
+extern struct kernel_api_spec __stop_kapi_specs[];
+
+/* Dynamic API registration */
+static LIST_HEAD(dynamic_api_specs);
+static DEFINE_MUTEX(api_spec_mutex);
+
+struct dynamic_api_spec {
+       struct list_head list;
+       struct kernel_api_spec *spec;
+};
+
+/**
+ * kapi_get_spec - Get API specification by name
+ * @name: Function name to look up
+ *
+ * Return: Pointer to API specification or NULL if not found
+ */
+const struct kernel_api_spec *kapi_get_spec(const char *name)
+{
+       struct kernel_api_spec *spec;
+       struct dynamic_api_spec *dyn_spec;
+
+       /* Search static specifications */
+       for (spec = __start_kapi_specs; spec < __stop_kapi_specs; spec++) {
+               if (strcmp(spec->name, name) == 0)
+                       return spec;
+       }
+
+       /* Search dynamic specifications */
+       mutex_lock(&api_spec_mutex);
+       list_for_each_entry(dyn_spec, &dynamic_api_specs, list) {
+               if (strcmp(dyn_spec->spec->name, name) == 0) {
+                       mutex_unlock(&api_spec_mutex);
+                       return dyn_spec->spec;
+               }
+       }
+       mutex_unlock(&api_spec_mutex);
+
+       return NULL;
+}
+EXPORT_SYMBOL_GPL(kapi_get_spec);
+
+/**
+ * kapi_register_spec - Register a dynamic API specification
+ * @spec: API specification to register
+ *
+ * Return: 0 on success, negative error code on failure
+ */
+int kapi_register_spec(struct kernel_api_spec *spec)
+{
+       struct dynamic_api_spec *dyn_spec;
+
+       if (!spec || !spec->name[0])
+               return -EINVAL;
+
+       /* Check if already exists */
+       if (kapi_get_spec(spec->name))
+               return -EEXIST;
+
+       dyn_spec = kzalloc(sizeof(*dyn_spec), GFP_KERNEL);
+       if (!dyn_spec)
+               return -ENOMEM;
+
+       dyn_spec->spec = spec;
+
+       mutex_lock(&api_spec_mutex);
+       list_add_tail(&dyn_spec->list, &dynamic_api_specs);
+       mutex_unlock(&api_spec_mutex);
+
+       return 0;
+}
+EXPORT_SYMBOL_GPL(kapi_register_spec);
+
+/**
+ * kapi_unregister_spec - Unregister a dynamic API specification
+ * @name: Name of API to unregister
+ */
+void kapi_unregister_spec(const char *name)
+{
+       struct dynamic_api_spec *dyn_spec, *tmp;
+
+       mutex_lock(&api_spec_mutex);
+       list_for_each_entry_safe(dyn_spec, tmp, &dynamic_api_specs, list) {
+               if (strcmp(dyn_spec->spec->name, name) == 0) {
+                       list_del(&dyn_spec->list);
+                       kfree(dyn_spec);
+                       break;
+               }
+       }
+       mutex_unlock(&api_spec_mutex);
+}
+EXPORT_SYMBOL_GPL(kapi_unregister_spec);
+
+/**
+ * param_type_to_string - Convert parameter type to string
+ * @type: Parameter type
+ *
+ * Return: String representation of type
+ */
+static const char *param_type_to_string(enum kapi_param_type type)
+{
+       static const char * const type_names[] = {
+               [KAPI_TYPE_VOID] = "void",
+               [KAPI_TYPE_INT] = "int",
+               [KAPI_TYPE_UINT] = "uint",
+               [KAPI_TYPE_PTR] = "pointer",
+               [KAPI_TYPE_STRUCT] = "struct",
+               [KAPI_TYPE_UNION] = "union",
+               [KAPI_TYPE_ENUM] = "enum",
+               [KAPI_TYPE_FUNC_PTR] = "function_pointer",
+               [KAPI_TYPE_ARRAY] = "array",
+               [KAPI_TYPE_FD] = "file_descriptor",
+               [KAPI_TYPE_USER_PTR] = "user_pointer",
+               [KAPI_TYPE_PATH] = "pathname",
+               [KAPI_TYPE_CUSTOM] = "custom",
+       };
+
+       if (type >= ARRAY_SIZE(type_names))
+               return "unknown";
+
+       return type_names[type];
+}
+
+/**
+ * lock_type_to_string - Convert lock type to string
+ * @type: Lock type
+ *
+ * Return: String representation of lock type
+ */
+static const char *lock_type_to_string(enum kapi_lock_type type)
+{
+       static const char * const lock_names[] = {
+               [KAPI_LOCK_NONE] = "none",
+               [KAPI_LOCK_MUTEX] = "mutex",
+               [KAPI_LOCK_SPINLOCK] = "spinlock",
+               [KAPI_LOCK_RWLOCK] = "rwlock",
+               [KAPI_LOCK_SEQLOCK] = "seqlock",
+               [KAPI_LOCK_RCU] = "rcu",
+               [KAPI_LOCK_SEMAPHORE] = "semaphore",
+               [KAPI_LOCK_CUSTOM] = "custom",
+       };
+
+       if (type >= ARRAY_SIZE(lock_names))
+               return "unknown";
+
+       return lock_names[type];
+}
+
+/**
+ * return_check_type_to_string - Convert return check type to string
+ * @type: Return check type
+ *
+ * Return: String representation of return check type
+ */
+static const char *return_check_type_to_string(enum kapi_return_check_type 
type)
+{
+       static const char * const check_names[] = {
+               [KAPI_RETURN_EXACT] = "exact",
+               [KAPI_RETURN_RANGE] = "range",
+               [KAPI_RETURN_ERROR_CHECK] = "error_check",
+               [KAPI_RETURN_FD] = "file_descriptor",
+               [KAPI_RETURN_CUSTOM] = "custom",
+       };
+
+       if (type >= ARRAY_SIZE(check_names))
+               return "unknown";
+
+       return check_names[type];
+}
+
+/**
+ * kapi_export_json - Export API specification to JSON format
+ * @spec: API specification to export
+ * @buf: Buffer to write JSON to
+ * @size: Size of buffer
+ *
+ * Return: Number of bytes written or negative error
+ */
+int kapi_export_json(const struct kernel_api_spec *spec, char *buf, size_t 
size)
+{
+       int ret = 0;
+       int i;
+
+       if (!spec || !buf || size == 0)
+               return -EINVAL;
+
+       ret = scnprintf(buf, size,
+               "{\n"
+               "  \"name\": \"%s\",\n"
+               "  \"version\": %u,\n"
+               "  \"description\": \"%s\",\n"
+               "  \"long_description\": \"%s\",\n"
+               "  \"context_flags\": \"0x%x\",\n",
+               spec->name,
+               spec->version,
+               spec->description,
+               spec->long_description,
+               spec->context_flags);
+
+       /* Parameters */
+       ret += scnprintf(buf + ret, size - ret,
+               "  \"parameters\": [\n");
+
+       for (i = 0; i < spec->param_count && i < KAPI_MAX_PARAMS; i++) {
+               const struct kapi_param_spec *param = &spec->params[i];
+
+               ret += scnprintf(buf + ret, size - ret,
+                       "    {\n"
+                       "      \"name\": \"%s\",\n"
+                       "      \"type\": \"%s\",\n"
+                       "      \"type_class\": \"%s\",\n"
+                       "      \"flags\": \"0x%x\",\n"
+                       "      \"description\": \"%s\"\n"
+                       "    }%s\n",
+                       param->name,
+                       param->type_name,
+                       param_type_to_string(param->type),
+                       param->flags,
+                       param->description,
+                       (i < spec->param_count - 1) ? "," : "");
+       }
+
+       ret += scnprintf(buf + ret, size - ret, "  ],\n");
+
+       /* Return value */
+       ret += scnprintf(buf + ret, size - ret,
+               "  \"return\": {\n"
+               "    \"type\": \"%s\",\n"
+               "    \"type_class\": \"%s\",\n"
+               "    \"check_type\": \"%s\",\n",
+               spec->return_spec.type_name,
+               param_type_to_string(spec->return_spec.type),
+               return_check_type_to_string(spec->return_spec.check_type));
+
+       switch (spec->return_spec.check_type) {
+       case KAPI_RETURN_EXACT:
+               ret += scnprintf(buf + ret, size - ret,
+                       "    \"success_value\": %lld,\n",
+                       spec->return_spec.success_value);
+               break;
+       case KAPI_RETURN_RANGE:
+               ret += scnprintf(buf + ret, size - ret,
+                       "    \"success_min\": %lld,\n"
+                       "    \"success_max\": %lld,\n",
+                       spec->return_spec.success_min,
+                       spec->return_spec.success_max);
+               break;
+       case KAPI_RETURN_ERROR_CHECK:
+               ret += scnprintf(buf + ret, size - ret,
+                       "    \"error_count\": %u,\n",
+                       spec->return_spec.error_count);
+               break;
+       default:
+               break;
+       }
+
+       ret += scnprintf(buf + ret, size - ret,
+               "    \"description\": \"%s\"\n"
+               "  },\n",
+               spec->return_spec.description);
+
+       /* Errors */
+       ret += scnprintf(buf + ret, size - ret,
+               "  \"errors\": [\n");
+
+       for (i = 0; i < spec->error_count && i < KAPI_MAX_ERRORS; i++) {
+               const struct kapi_error_spec *error = &spec->errors[i];
+
+               ret += scnprintf(buf + ret, size - ret,
+                       "    {\n"
+                       "      \"code\": %d,\n"
+                       "      \"name\": \"%s\",\n"
+                       "      \"condition\": \"%s\",\n"
+                       "      \"description\": \"%s\"\n"
+                       "    }%s\n",
+                       error->error_code,
+                       error->name,
+                       error->condition,
+                       error->description,
+                       (i < spec->error_count - 1) ? "," : "");
+       }
+
+       ret += scnprintf(buf + ret, size - ret, "  ],\n");
+
+       /* Locks */
+       ret += scnprintf(buf + ret, size - ret,
+               "  \"locks\": [\n");
+
+       for (i = 0; i < spec->lock_count && i < KAPI_MAX_CONSTRAINTS; i++) {
+               const struct kapi_lock_spec *lock = &spec->locks[i];
+
+               ret += scnprintf(buf + ret, size - ret,
+                       "    {\n"
+                       "      \"name\": \"%s\",\n"
+                       "      \"type\": \"%s\",\n"
+                       "      \"acquired\": %s,\n"
+                       "      \"released\": %s,\n"
+                       "      \"held_on_entry\": %s,\n"
+                       "      \"held_on_exit\": %s,\n"
+                       "      \"description\": \"%s\"\n"
+                       "    }%s\n",
+                       lock->lock_name,
+                       lock_type_to_string(lock->lock_type),
+                       lock->acquired ? "true" : "false",
+                       lock->released ? "true" : "false",
+                       lock->held_on_entry ? "true" : "false",
+                       lock->held_on_exit ? "true" : "false",
+                       lock->description,
+                       (i < spec->lock_count - 1) ? "," : "");
+       }
+
+       ret += scnprintf(buf + ret, size - ret, "  ],\n");
+
+       /* Additional info */
+       ret += scnprintf(buf + ret, size - ret,
+               "  \"since_version\": \"%s\",\n"
+               "  \"deprecated\": %s,\n"
+               "  \"replacement\": \"%s\",\n"
+               "  \"examples\": \"%s\",\n"
+               "  \"notes\": \"%s\"\n"
+               "}\n",
+               spec->since_version,
+               spec->deprecated ? "true" : "false",
+               spec->replacement,
+               spec->examples,
+               spec->notes);
+
+       return ret;
+}
+EXPORT_SYMBOL_GPL(kapi_export_json);
+
+/**
+ * kapi_export_xml - Export API specification to XML format
+ * @spec: API specification to export
+ * @buf: Buffer to write XML to
+ * @size: Size of buffer
+ *
+ * Return: Number of bytes written or negative error
+ */
+int kapi_export_xml(const struct kernel_api_spec *spec, char *buf, size_t size)
+{
+       int ret = 0;
+       int i;
+
+       if (!spec || !buf || size == 0)
+               return -EINVAL;
+
+       ret = scnprintf(buf, size,
+               "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n"
+               "<kernel_api>\n"
+               "  <name>%s</name>\n"
+               "  <version>%u</version>\n"
+               "  <description>%s</description>\n"
+               "  <long_description><![CDATA[%s]]></long_description>\n"
+               "  <context_flags>0x%x</context_flags>\n",
+               spec->name,
+               spec->version,
+               spec->description,
+               spec->long_description,
+               spec->context_flags);
+
+       /* Parameters */
+       ret += scnprintf(buf + ret, size - ret, "  <parameters>\n");
+
+       for (i = 0; i < spec->param_count && i < KAPI_MAX_PARAMS; i++) {
+               const struct kapi_param_spec *param = &spec->params[i];
+
+               ret += scnprintf(buf + ret, size - ret,
+                       "    <parameter>\n"
+                       "      <name>%s</name>\n"
+                       "      <type>%s</type>\n"
+                       "      <type_class>%s</type_class>\n"
+                       "      <flags>0x%x</flags>\n"
+                       "      <description><![CDATA[%s]]></description>\n"
+                       "    </parameter>\n",
+                       param->name,
+                       param->type_name,
+                       param_type_to_string(param->type),
+                       param->flags,
+                       param->description);
+       }
+
+       ret += scnprintf(buf + ret, size - ret, "  </parameters>\n");
+
+       /* Return value */
+       ret += scnprintf(buf + ret, size - ret,
+               "  <return>\n"
+               "    <type>%s</type>\n"
+               "    <type_class>%s</type_class>\n"
+               "    <check_type>%s</check_type>\n",
+               spec->return_spec.type_name,
+               param_type_to_string(spec->return_spec.type),
+               return_check_type_to_string(spec->return_spec.check_type));
+
+       switch (spec->return_spec.check_type) {
+       case KAPI_RETURN_EXACT:
+               ret += scnprintf(buf + ret, size - ret,
+                       "    <success_value>%lld</success_value>\n",
+                       spec->return_spec.success_value);
+               break;
+       case KAPI_RETURN_RANGE:
+               ret += scnprintf(buf + ret, size - ret,
+                       "    <success_min>%lld</success_min>\n"
+                       "    <success_max>%lld</success_max>\n",
+                       spec->return_spec.success_min,
+                       spec->return_spec.success_max);
+               break;
+       case KAPI_RETURN_ERROR_CHECK:
+               ret += scnprintf(buf + ret, size - ret,
+                       "    <error_count>%u</error_count>\n",
+                       spec->return_spec.error_count);
+               break;
+       default:
+               break;
+       }
+
+       ret += scnprintf(buf + ret, size - ret,
+               "    <description><![CDATA[%s]]></description>\n"
+               "  </return>\n",
+               spec->return_spec.description);
+
+       /* Errors */
+       ret += scnprintf(buf + ret, size - ret, "  <errors>\n");
+
+       for (i = 0; i < spec->error_count && i < KAPI_MAX_ERRORS; i++) {
+               const struct kapi_error_spec *error = &spec->errors[i];
+
+               ret += scnprintf(buf + ret, size - ret,
+                       "    <error>\n"
+                       "      <code>%d</code>\n"
+                       "      <name>%s</name>\n"
+                       "      <condition><![CDATA[%s]]></condition>\n"
+                       "      <description><![CDATA[%s]]></description>\n"
+                       "    </error>\n",
+                       error->error_code,
+                       error->name,
+                       error->condition,
+                       error->description);
+       }
+
+       ret += scnprintf(buf + ret, size - ret, "  </errors>\n");
+
+       /* Additional info */
+       ret += scnprintf(buf + ret, size - ret,
+               "  <since_version>%s</since_version>\n"
+               "  <deprecated>%s</deprecated>\n"
+               "  <replacement>%s</replacement>\n"
+               "  <examples><![CDATA[%s]]></examples>\n"
+               "  <notes><![CDATA[%s]]></notes>\n"
+               "</kernel_api>\n",
+               spec->since_version,
+               spec->deprecated ? "true" : "false",
+               spec->replacement,
+               spec->examples,
+               spec->notes);
+
+       return ret;
+}
+EXPORT_SYMBOL_GPL(kapi_export_xml);
+
+/**
+ * kapi_print_spec - Print API specification to kernel log
+ * @spec: API specification to print
+ */
+void kapi_print_spec(const struct kernel_api_spec *spec)
+{
+       int i;
+
+       if (!spec)
+               return;
+
+       pr_info("=== Kernel API Specification ===\n");
+       pr_info("Name: %s\n", spec->name);
+       pr_info("Version: %u\n", spec->version);
+       pr_info("Description: %s\n", spec->description);
+
+       if (spec->long_description[0])
+               pr_info("Long Description: %s\n", spec->long_description);
+
+       pr_info("Context Flags: 0x%x\n", spec->context_flags);
+
+       /* Parameters */
+       if (spec->param_count > 0) {
+               pr_info("Parameters:\n");
+               for (i = 0; i < spec->param_count && i < KAPI_MAX_PARAMS; i++) {
+                       const struct kapi_param_spec *param = &spec->params[i];
+                       pr_info("  [%d] %s: %s (flags: 0x%x)\n",
+                               i, param->name, param->type_name, param->flags);
+                       if (param->description[0])
+                               pr_info("      Description: %s\n", 
param->description);
+               }
+       }
+
+       /* Return value */
+       pr_info("Return: %s\n", spec->return_spec.type_name);
+       if (spec->return_spec.description[0])
+               pr_info("  Description: %s\n", spec->return_spec.description);
+
+       /* Errors */
+       if (spec->error_count > 0) {
+               pr_info("Possible Errors:\n");
+               for (i = 0; i < spec->error_count && i < KAPI_MAX_ERRORS; i++) {
+                       const struct kapi_error_spec *error = &spec->errors[i];
+                       pr_info("  %s (%d): %s\n",
+                               error->name, error->error_code, 
error->condition);
+               }
+       }
+
+       pr_info("================================\n");
+}
+EXPORT_SYMBOL_GPL(kapi_print_spec);
+
+#ifdef CONFIG_KAPI_RUNTIME_CHECKS
+
+/**
+ * kapi_validate_fd - Validate that a file descriptor is valid in current 
context
+ * @fd: File descriptor to validate
+ *
+ * Return: true if fd is valid in current process context, false otherwise
+ */
+static bool kapi_validate_fd(int fd)
+{
+       struct fd f;
+
+       /* Special case: AT_FDCWD is always valid */
+       if (fd == AT_FDCWD)
+               return true;
+
+       /* Check basic range */
+       if (fd < 0)
+               return false;
+
+       /* Check if fd is valid in current process context */
+       f = fdget(fd);
+       if (fd_empty(f)) {
+               return false;
+       }
+
+       /* fd is valid, release reference */
+       fdput(f);
+       return true;
+}
+
+/**
+ * kapi_validate_user_ptr - Validate that a user pointer is accessible
+ * @ptr: User pointer to validate
+ * @size: Size in bytes to validate
+ * @write: Whether write access is required
+ *
+ * Return: true if user memory is accessible, false otherwise
+ */
+static bool kapi_validate_user_ptr(const void __user *ptr, size_t size, bool 
write)
+{
+       /* NULL is valid if parameter is marked optional */
+       if (!ptr)
+               return false;
+
+       /* Check if the user memory region is accessible */
+       if (write) {
+               return access_ok(ptr, size);
+       } else {
+               return access_ok(ptr, size);
+       }
+}
+
+/**
+ * kapi_validate_user_ptr_with_params - Validate user pointer with dynamic size
+ * @param_spec: Parameter specification
+ * @ptr: User pointer to validate
+ * @all_params: Array of all parameter values
+ * @param_count: Number of parameters
+ *
+ * Return: true if user memory is accessible, false otherwise
+ */
+static bool kapi_validate_user_ptr_with_params(const struct kapi_param_spec 
*param_spec,
+                                               const void __user *ptr,
+                                               const s64 *all_params,
+                                               int param_count)
+{
+       size_t actual_size;
+       bool write;
+
+       /* NULL is allowed for optional parameters */
+       if (!ptr && (param_spec->flags & KAPI_PARAM_OPTIONAL))
+               return true;
+
+       /* Calculate actual size based on related parameter */
+       if (param_spec->size_param_idx >= 0 &&
+           param_spec->size_param_idx < param_count) {
+               s64 count = all_params[param_spec->size_param_idx];
+
+               /* Validate count is positive */
+               if (count <= 0) {
+                       pr_warn("Parameter %s: size determinant is non-positive 
(%lld)\n",
+                               param_spec->name, count);
+                       return false;
+               }
+
+               /* Check for multiplication overflow */
+               if (param_spec->size_multiplier > 0 &&
+                   count > SIZE_MAX / param_spec->size_multiplier) {
+                       pr_warn("Parameter %s: size calculation overflow\n",
+                               param_spec->name);
+                       return false;
+               }
+
+               actual_size = count * param_spec->size_multiplier;
+       } else {
+               /* Use fixed size */
+               actual_size = param_spec->size;
+       }
+
+       write = (param_spec->flags & KAPI_PARAM_OUT) ||
+               (param_spec->flags & KAPI_PARAM_INOUT);
+
+       return kapi_validate_user_ptr(ptr, actual_size, write);
+}
+
+/**
+ * kapi_validate_path - Validate that a pathname is accessible and within 
limits
+ * @path: User pointer to pathname
+ * @param_spec: Parameter specification
+ *
+ * Return: true if path is valid, false otherwise
+ */
+static bool kapi_validate_path(const char __user *path,
+                               const struct kapi_param_spec *param_spec)
+{
+       size_t len;
+
+       /* NULL is allowed for optional parameters */
+       if (!path && (param_spec->flags & KAPI_PARAM_OPTIONAL))
+               return true;
+
+       if (!path) {
+               pr_warn("Parameter %s: NULL path not allowed\n", 
param_spec->name);
+               return false;
+       }
+
+       /* Check if the path is accessible */
+       if (!access_ok(path, 1)) {
+               pr_warn("Parameter %s: path pointer %p not accessible\n",
+                       param_spec->name, path);
+               return false;
+       }
+
+       /* Use strnlen_user to get the length and validate accessibility */
+       len = strnlen_user(path, PATH_MAX + 1);
+       if (len == 0) {
+               pr_warn("Parameter %s: invalid path pointer %p\n",
+                       param_spec->name, path);
+               return false;
+       }
+
+       /* Check path length limit */
+       if (len > PATH_MAX) {
+               pr_warn("Parameter %s: path too long (exceeds PATH_MAX)\n",
+                       param_spec->name);
+               return false;
+       }
+
+       return true;
+}
+
+/**
+ * kapi_validate_param - Validate a parameter against its specification
+ * @param_spec: Parameter specification
+ * @value: Parameter value to validate
+ *
+ * Return: true if valid, false otherwise
+ */
+bool kapi_validate_param(const struct kapi_param_spec *param_spec, s64 value)
+{
+       int i;
+
+       /* Special handling for file descriptor type */
+       if (param_spec->type == KAPI_TYPE_FD) {
+               if (!kapi_validate_fd((int)value)) {
+                       pr_warn("Parameter %s: invalid file descriptor %lld\n",
+                               param_spec->name, value);
+                       return false;
+               }
+               /* Continue with additional constraint checks if needed */
+       }
+
+       /* Special handling for user pointer type */
+       if (param_spec->type == KAPI_TYPE_USER_PTR) {
+               const void __user *ptr = (const void __user *)value;
+               bool write = (param_spec->flags & KAPI_PARAM_OUT) ||
+                            (param_spec->flags & KAPI_PARAM_INOUT);
+
+               /* NULL is allowed for optional parameters */
+               if (!ptr && (param_spec->flags & KAPI_PARAM_OPTIONAL))
+                       return true;
+
+               if (!kapi_validate_user_ptr(ptr, param_spec->size, write)) {
+                       pr_warn("Parameter %s: invalid user pointer %p (size: 
%zu, %s)\n",
+                               param_spec->name, ptr, param_spec->size,
+                               write ? "write" : "read");
+                       return false;
+               }
+               /* Continue with additional constraint checks if needed */
+       }
+
+       /* Special handling for path type */
+       if (param_spec->type == KAPI_TYPE_PATH) {
+               const char __user *path = (const char __user *)value;
+
+               if (!kapi_validate_path(path, param_spec)) {
+                       return false;
+               }
+               /* Continue with additional constraint checks if needed */
+       }
+
+       switch (param_spec->constraint_type) {
+       case KAPI_CONSTRAINT_NONE:
+               return true;
+
+       case KAPI_CONSTRAINT_RANGE:
+               if (value < param_spec->min_value || value > 
param_spec->max_value) {
+                       pr_warn("Parameter %s value %lld out of range [%lld, 
%lld]\n",
+                               param_spec->name, value,
+                               param_spec->min_value, param_spec->max_value);
+                       return false;
+               }
+               return true;
+
+       case KAPI_CONSTRAINT_MASK:
+               if (value & ~param_spec->valid_mask) {
+                       pr_warn("Parameter %s value 0x%llx contains invalid 
bits (valid mask: 0x%llx)\n",
+                               param_spec->name, value, 
param_spec->valid_mask);
+                       return false;
+               }
+               return true;
+
+       case KAPI_CONSTRAINT_ENUM:
+               if (!param_spec->enum_values || param_spec->enum_count == 0)
+                       return true;
+
+               for (i = 0; i < param_spec->enum_count; i++) {
+                       if (value == param_spec->enum_values[i])
+                               return true;
+               }
+               pr_warn("Parameter %s value %lld not in valid enumeration\n",
+                       param_spec->name, value);
+               return false;
+
+       case KAPI_CONSTRAINT_CUSTOM:
+               if (param_spec->validate)
+                       return param_spec->validate(value);
+               return true;
+
+       default:
+               return true;
+       }
+}
+EXPORT_SYMBOL_GPL(kapi_validate_param);
+
+/**
+ * kapi_validate_param_with_context - Validate parameter with access to all 
params
+ * @param_spec: Parameter specification
+ * @value: Parameter value to validate
+ * @all_params: Array of all parameter values
+ * @param_count: Number of parameters
+ *
+ * Return: true if valid, false otherwise
+ */
+bool kapi_validate_param_with_context(const struct kapi_param_spec *param_spec,
+                                      s64 value, const s64 *all_params, int 
param_count)
+{
+       /* Special handling for user pointer type with dynamic sizing */
+       if (param_spec->type == KAPI_TYPE_USER_PTR) {
+               const void __user *ptr = (const void __user *)value;
+
+               /* NULL is allowed for optional parameters */
+               if (!ptr && (param_spec->flags & KAPI_PARAM_OPTIONAL))
+                       return true;
+
+               if (!kapi_validate_user_ptr_with_params(param_spec, ptr, 
all_params, param_count)) {
+                       pr_warn("Parameter %s: invalid user pointer %p\n",
+                               param_spec->name, ptr);
+                       return false;
+               }
+               /* Continue with additional constraint checks if needed */
+       }
+
+       /* For other types, fall back to regular validation */
+       return kapi_validate_param(param_spec, value);
+}
+EXPORT_SYMBOL_GPL(kapi_validate_param_with_context);
+
+/**
+ * kapi_validate_syscall_param - Validate syscall parameter with enforcement
+ * @spec: API specification
+ * @param_idx: Parameter index
+ * @value: Parameter value
+ *
+ * Return: -EINVAL if invalid, 0 if valid
+ */
+int kapi_validate_syscall_param(const struct kernel_api_spec *spec,
+                                int param_idx, s64 value)
+{
+       const struct kapi_param_spec *param_spec;
+
+       if (!spec || param_idx >= spec->param_count)
+               return 0;
+
+       param_spec = &spec->params[param_idx];
+
+       if (!kapi_validate_param(param_spec, value)) {
+               if (strncmp(spec->name, "sys_", 4) == 0) {
+                       /* For syscalls, we can return EINVAL to userspace */
+                       return -EINVAL;
+               }
+       }
+
+       return 0;
+}
+EXPORT_SYMBOL_GPL(kapi_validate_syscall_param);
+
+/**
+ * kapi_validate_syscall_params - Validate all syscall parameters together
+ * @spec: API specification
+ * @params: Array of parameter values
+ * @param_count: Number of parameters
+ *
+ * Return: -EINVAL if any parameter is invalid, 0 if all valid
+ */
+int kapi_validate_syscall_params(const struct kernel_api_spec *spec,
+                                const s64 *params, int param_count)
+{
+       int i;
+
+       if (!spec || !params)
+               return 0;
+
+       /* Validate that we have the expected number of parameters */
+       if (param_count != spec->param_count) {
+               pr_warn("API %s: parameter count mismatch (expected %u, got 
%d)\n",
+                       spec->name, spec->param_count, param_count);
+               return -EINVAL;
+       }
+
+       /* Validate each parameter with context */
+       for (i = 0; i < spec->param_count && i < KAPI_MAX_PARAMS; i++) {
+               const struct kapi_param_spec *param_spec = &spec->params[i];
+
+               if (!kapi_validate_param_with_context(param_spec, params[i], 
params, param_count)) {
+                       if (strncmp(spec->name, "sys_", 4) == 0) {
+                               /* For syscalls, we can return EINVAL to 
userspace */
+                               return -EINVAL;
+                       }
+               }
+       }
+
+       return 0;
+}
+EXPORT_SYMBOL_GPL(kapi_validate_syscall_params);
+
+/**
+ * kapi_check_return_success - Check if return value indicates success
+ * @return_spec: Return specification
+ * @retval: Return value to check
+ *
+ * Returns true if the return value indicates success according to the spec.
+ */
+bool kapi_check_return_success(const struct kapi_return_spec *return_spec, s64 
retval)
+{
+       u32 i;
+
+       if (!return_spec)
+               return true; /* No spec means we can't validate */
+
+       switch (return_spec->check_type) {
+       case KAPI_RETURN_EXACT:
+               return retval == return_spec->success_value;
+
+       case KAPI_RETURN_RANGE:
+               return retval >= return_spec->success_min &&
+                      retval <= return_spec->success_max;
+
+       case KAPI_RETURN_ERROR_CHECK:
+               /* Success if NOT in error list */
+               if (return_spec->error_values) {
+                       for (i = 0; i < return_spec->error_count; i++) {
+                               if (retval == return_spec->error_values[i])
+                                       return false; /* Found in error list */
+                       }
+               }
+               return true; /* Not in error list = success */
+
+       case KAPI_RETURN_FD:
+               /* File descriptors: >= 0 is success, < 0 is error */
+               return retval >= 0;
+
+       case KAPI_RETURN_CUSTOM:
+               if (return_spec->is_success)
+                       return return_spec->is_success(retval);
+               fallthrough;
+
+       default:
+               return true; /* Unknown check type, assume success */
+       }
+}
+EXPORT_SYMBOL_GPL(kapi_check_return_success);
+
+/**
+ * kapi_validate_return_value - Validate that return value matches spec
+ * @spec: API specification
+ * @retval: Return value to validate
+ *
+ * Return: true if return value is valid according to spec, false otherwise.
+ *
+ * This function checks:
+ * 1. If the value indicates success, it must match the success criteria
+ * 2. If the value indicates error, it must be one of the specified error codes
+ */
+bool kapi_validate_return_value(const struct kernel_api_spec *spec, s64 retval)
+{
+       int i;
+       bool is_success;
+
+       if (!spec)
+               return true; /* No spec means we can't validate */
+
+       /* First check if this is a success return */
+       is_success = kapi_check_return_success(&spec->return_spec, retval);
+
+       if (is_success) {
+               /* Success case - already validated by 
kapi_check_return_success */
+               return true;
+       }
+
+       /* Special validation for file descriptor returns */
+       if (spec->return_spec.check_type == KAPI_RETURN_FD && is_success) {
+               /* For successful FD returns, validate it's a valid FD */
+               if (!kapi_validate_fd((int)retval)) {
+                       pr_warn("API %s returned invalid file descriptor 
%lld\n",
+                               spec->name, retval);
+                       return false;
+               }
+               return true;
+       }
+
+       /* Error case - check if it's one of the specified errors */
+       if (spec->error_count == 0) {
+               /* No errors specified, so any error is potentially valid */
+               pr_debug("API %s returned unspecified error %lld\n",
+                        spec->name, retval);
+               return true;
+       }
+
+       /* Check if the error is in our list of specified errors */
+       for (i = 0; i < spec->error_count && i < KAPI_MAX_ERRORS; i++) {
+               if (retval == spec->errors[i].error_code)
+                       return true;
+       }
+
+       /* Error not in spec */
+       pr_warn("API %s returned unspecified error code %lld. Valid errors 
are:\n",
+               spec->name, retval);
+       for (i = 0; i < spec->error_count && i < KAPI_MAX_ERRORS; i++) {
+               pr_warn("  %s (%d): %s\n",
+                       spec->errors[i].name,
+                       spec->errors[i].error_code,
+                       spec->errors[i].condition);
+       }
+
+       return false;
+}
+EXPORT_SYMBOL_GPL(kapi_validate_return_value);
+
+/**
+ * kapi_validate_syscall_return - Validate syscall return value with 
enforcement
+ * @spec: API specification
+ * @retval: Return value
+ *
+ * Return: 0 if valid, -EINVAL if the return value doesn't match spec
+ *
+ * For syscalls, this can help detect kernel bugs where unspecified error
+ * codes are returned to userspace.
+ */
+int kapi_validate_syscall_return(const struct kernel_api_spec *spec, s64 
retval)
+{
+       if (!spec)
+               return 0;
+
+       if (!kapi_validate_return_value(spec, retval)) {
+               /* Log the violation but don't change the return value */
+               WARN_ONCE(1, "Syscall %s returned unspecified value %lld\n",
+                         spec->name, retval);
+               /* Could return -EINVAL here to enforce, but that might break 
userspace */
+       }
+
+       return 0;
+}
+EXPORT_SYMBOL_GPL(kapi_validate_syscall_return);
+
+/**
+ * kapi_check_context - Check if current context matches API requirements
+ * @spec: API specification to check against
+ */
+void kapi_check_context(const struct kernel_api_spec *spec)
+{
+       u32 ctx = spec->context_flags;
+       bool valid = false;
+
+       if (!ctx)
+               return;
+
+       /* Check if we're in an allowed context */
+       if ((ctx & KAPI_CTX_PROCESS) && !in_interrupt())
+               valid = true;
+
+       if ((ctx & KAPI_CTX_SOFTIRQ) && in_softirq())
+               valid = true;
+
+       if ((ctx & KAPI_CTX_HARDIRQ) && in_hardirq())
+               valid = true;
+
+       if ((ctx & KAPI_CTX_NMI) && in_nmi())
+               valid = true;
+
+       if (!valid) {
+               WARN_ONCE(1, "API %s called from invalid context\n", 
spec->name);
+       }
+
+       /* Check specific requirements */
+       if ((ctx & KAPI_CTX_ATOMIC) && preemptible()) {
+               WARN_ONCE(1, "API %s requires atomic context\n", spec->name);
+       }
+
+       if ((ctx & KAPI_CTX_SLEEPABLE) && !preemptible()) {
+               WARN_ONCE(1, "API %s requires sleepable context\n", spec->name);
+       }
+}
+EXPORT_SYMBOL_GPL(kapi_check_context);
+
+#endif /* CONFIG_KAPI_RUNTIME_CHECKS */
+
+/* DebugFS interface */
+#ifdef CONFIG_DEBUG_FS
+
+static struct dentry *kapi_debugfs_root;
+
+static int kapi_spec_show(struct seq_file *s, void *v)
+{
+       struct kernel_api_spec *spec = s->private;
+       char *buf;
+       int ret;
+
+       buf = kmalloc(PAGE_SIZE * 4, GFP_KERNEL);
+       if (!buf)
+               return -ENOMEM;
+
+       ret = kapi_export_json(spec, buf, PAGE_SIZE * 4);
+       if (ret > 0)
+               seq_printf(s, "%s", buf);
+
+       kfree(buf);
+       return 0;
+}
+
+static int kapi_spec_open(struct inode *inode, struct file *file)
+{
+       return single_open(file, kapi_spec_show, inode->i_private);
+}
+
+static const struct file_operations kapi_spec_fops = {
+       .open = kapi_spec_open,
+       .read = seq_read,
+       .llseek = seq_lseek,
+       .release = single_release,
+};
+
+static int kapi_list_show(struct seq_file *s, void *v)
+{
+       struct kernel_api_spec *spec;
+       struct dynamic_api_spec *dyn_spec;
+
+       seq_printf(s, "Kernel API Specifications:\n\n");
+
+       /* List static specifications */
+       seq_printf(s, "Static APIs:\n");
+       for (spec = __start_kapi_specs; spec < __stop_kapi_specs; spec++) {
+               seq_printf(s, "  %s (v%u): %s\n",
+                       spec->name, spec->version, spec->description);
+       }
+
+       /* List dynamic specifications */
+       seq_printf(s, "\nDynamic APIs:\n");
+       mutex_lock(&api_spec_mutex);
+       list_for_each_entry(dyn_spec, &dynamic_api_specs, list) {
+               spec = dyn_spec->spec;
+               seq_printf(s, "  %s (v%u): %s\n",
+                       spec->name, spec->version, spec->description);
+       }
+       mutex_unlock(&api_spec_mutex);
+
+       return 0;
+}
+
+static int kapi_list_open(struct inode *inode, struct file *file)
+{
+       return single_open(file, kapi_list_show, NULL);
+}
+
+static const struct file_operations kapi_list_fops = {
+       .open = kapi_list_open,
+       .read = seq_read,
+       .llseek = seq_lseek,
+       .release = single_release,
+};
+
+static int __init kapi_debugfs_init(void)
+{
+       struct kernel_api_spec *spec;
+       struct dentry *spec_dir;
+
+       kapi_debugfs_root = debugfs_create_dir("kapi", NULL);
+       if (!kapi_debugfs_root)
+               return -ENOMEM;
+
+       /* Create list file */
+       debugfs_create_file("list", 0444, kapi_debugfs_root, NULL,
+                           &kapi_list_fops);
+
+       /* Create directory for specifications */
+       spec_dir = debugfs_create_dir("specs", kapi_debugfs_root);
+
+       /* Create files for each static specification */
+       for (spec = __start_kapi_specs; spec < __stop_kapi_specs; spec++) {
+               debugfs_create_file(spec->name, 0444, spec_dir, spec,
+                                   &kapi_spec_fops);
+       }
+
+       return 0;
+}
+
+late_initcall(kapi_debugfs_init);
+
+#endif /* CONFIG_DEBUG_FS */
\ No newline at end of file
-- 
2.39.5



Reply via email to