kmax


Namekmax JSON
Version 4.8 PyPI version JSON
download
home_pagehttps://github.com/paulgazz/kmax
SummaryTools for working with symbolic constraints from Kbuild Makefile.
upload_time2024-10-16 20:05:31
maintainerNone
docs_urlNone
authorPaul Gazzillo
requires_pythonNone
licenseGPLv2+
keywords makefile kconfig kbuild configurations kmax kclause klocalizer
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            <!-- START doctoc generated TOC please keep comment here to allow auto update -->
<!-- DON'T EDIT THIS SECTION, INSTEAD RE-RUN doctoc TO UPDATE -->

- [The kmax tool suite](#the-kmax-tool-suite)
  - [Installation](#installation)
    - [Dependencies](#dependencies)
    - [Installing the kmax tool suite](#installing-the-kmax-tool-suite)
    - [Quick test](#quick-test)
  - [Using `krepair` on patches](#using-krepair-on-patches)
    - [The paper example](#the-paper-example)
  - [Using `kismet`](#using-kismet)
    - [Checking a single select construct](#checking-a-single-select-construct)
    - [Checking all Kconfig files for an architecture](#checking-all-kconfig-files-for-an-architecture)
  - [Using `klocalizer --save-dimacs` and `klocalizer --save-smt`](#using-klocalizer---save-dimacs-and-klocalizer---save-smt)
  - [Additional documentation](#additional-documentation)
  - [Bugs found](#bugs-found)
  - [Credits](#credits)

<!-- END doctoc generated TOC please keep comment here to allow auto update -->


# The kmax tool suite

## Installation

### Dependencies

#### System dependencies

    # kmax dependencies
    sudo apt install -y pipx python3-dev gcc build-essential
    # linux dependencies
    sudo apt install -y flex bison bc libssl-dev libelf-dev git
    # superc dependencies
    sudo apt install -y wget libz3-java libjson-java sat4j unzip xz-utils lftp
	
#### User dependencies
	
    # install superc and make.cross
    wget -O - https://raw.githubusercontent.com/appleseedlab/superc/master/scripts/install.sh | bash

### Environment

Add these environment variables to your shell, e.g., `.bash_profile`:

    export COMPILER_INSTALL_PATH=$HOME/0day
    export CLASSPATH=/usr/share/java/org.sat4j.core.jar:/usr/share/java/json-lib.jar:${HOME}/.local/share/superc/z3-4.8.12-x64-glibc-2.31/bin/com.microsoft.z3.jar:${HOME}/.local/share/superc/JavaBDD/javabdd-1.0b2.jar:${HOME}/.local/share/superc/xtc.jar:${HOME}/.local/share/superc/superc.jar:${CLASSPATH}
    export PATH=${HOME}/.local/bin/:${PATH}

### Installing the kmax tool suite

    pipx install kmax

### Quick test
    
Get Linux kernel source:

    cd ~/
    wget https://cdn.kernel.org/pub/linux/kernel/v6.x/linux-6.10.tar.xz
    tar -xvf linux-6.10.tar.xz
    cd ~/linux-6.10/

Test `krepair` by automatically repairing `allnoconfig` to include `drivers/usb/storage/alauda.o`, which would normally be omitted by `allnoconfig`.

    # create allnoconfig
    make ARCH=x86_64 allnoconfig
    # run klocalizer --repair allnoconfig to build alauda.c
    klocalizer --repair .config -o allnoconfig_repaired --include drivers/usb/storage/alauda.o
    # clean and build the kernel with the repair config file
    KCONFIG_CONFIG=allnoconfig_repaired make ARCH=x86_64 olddefconfig clean drivers/usb/storage/alauda.o
    
You should see `CC      drivers/usb/storage/alauda.o` at the end of the build.

## Using `krepair` on patches

`klocalizer --repair` will take a config file that fails to build lines of a patch and repairs it to build the whole patch. 
This uses [SuperC](https://github.com/appleseedlab/superc) to find `#ifdef` constraints.

Let's first get the Linux source code:

    cd ~/
    git clone git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
	
Now let's get an example patch from the Linux kernel's mainline repository:	
	
    cd ~/linux/
    git checkout 6fc88c354f3af
    git show > 6fc88c354f3af.diff

Next, let's repair allnoconfig, which does not build all lines from the patch.

    # create allnoconfig
    make.cross ARCH=x86_64 allnoconfig
    # run klocalizer to repair allnoconfig to include the patch
    klocalizer --repair .config -a x86_64 --include-mutex 6fc88c354f3af.diff
    # clean and build the files modified by the patch (WERROR=0 for tools/lib/subcmd/subcmd-util.h which triggers a use-after-free on gcc 13)
    KCONFIG_CONFIG=0-x86_64.config make.cross WERROR=0 ARCH=x86_64 olddefconfig clean kernel/bpf/cgroup.o net/ipv4/af_inet.o net/ipv4/udp.o net/ipv6/af_inet6.o net/ipv6/udp.o

We can use `koverage` to check how much of patch is covered by a given config file:

    koverage -f --config 0-x86_64.config --arch x86_64 --check-patch 6fc88c354f3af.diff -o coverage_results.json
    cat coverage_results.json

In contrast, we can see that `allnoconfig` omits coverage of the patch:

    make.cross ARCH=x86_64 allnoconfig
    koverage -f --config .config --arch x86_64 --check-patch 6fc88c354f3af.diff -o allnoconfig_coverage_results.json
    cat allnoconfig_coverage_results.json

Notes:

- While repair usually covers all lines of a patch, some lines may still be omitted, for instance if they are dead code or in header files.
- If a patch modifies both arms of an `#ifdef`, multiple config files are needed to cover all lines.  These are exported as `NUM-ARCH.config`.

### The paper example

Here is another example from the [krepair paper](https://paulgazzillo.com/papers/fse24.pdf).  This [patch](https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/commit/?id=8594c3b85171b6f68e34e07b533ec2f1bf7fb065) modifies code in both arms of an `#ifdef`, so a single `.config` file cannot cover all patched lines.  `klocalizer` emits two `.config` files, which together cover all lines.

    git checkout 8594c3b85171b
    git show > 8594c3b85171b.diff
	make.cross ARCH=arm allnoconfig
    klocalizer --repair .config -a arm --include-mutex 8594c3b85171b.diff
    koverage -f --config 0-arm.config --arch arm --check-patch 8594c3b85171b.diff -o 0-coverage_results.json
    koverage -f --config 1-arm.config --arch arm --check-patch 8594c3b85171b.diff -o 1-coverage_results.json
    cat 0-coverage_results.json
    cat 1-coverage_results.json
	diff -y 0-coverage_results.json 1-coverage_results.json | less

## Using `kismet`

This tool will check for unmet dependency bugs in [Kconfig specifications](https://www.kernel.org/doc/html/latest/kbuild/kconfig-language.html#menu-attributes) due to reverse dependencies overriding direct dependencies.

### Checking a single select construct

Found by [Intel's kernel test robot running kismet](https://lore.kernel.org/lkml/cc9905dd-5b66-d01e-491c-64c18198d208@intel.com/)

    git checkout 5a7f27a624d9e33262767b328aa7a4baf7846c14
    kismet --linux-ksrc=./ --selectees CONFIG_SND_SOC_MAX98357A --selectors CONFIG_SND_SOC_INTEL_SOF_CS42L42_MACH -a=x86_64

The alarm can be found in `kismet_summary_x86_64.csv` and `.config` files that exercise the bug can be found in `kismet-test-cases/`.

### Checking all Kconfig files for an architecture

Run `kismet` on the root of the Linux source tree.

    cd ~/
    wget https://cdn.kernel.org/pub/linux/kernel/v5.x/linux-5.16.tar.xz
    tar -xvf linux-5.16.tar.xz
    cd ~/linux-5.16/
    kismet --linux-ksrc="${HOME}/linux-5.16/" -a=x86_64

Once finished (it can take about an hour on a commodity desktop), kismet will produce three outputs:

  1. A summary of the results in `kismet_summary_x86_64.txt`
  2. A list of results for each `select` construct in `kismet_summary_x86_64.csv` (`UNMET_ALARM` denotes the buggy ones)
  3. A list of `.config` files meant to exercise each bug in `kismet-test-cases/`

Technical details can be found in in the [kismet documentation](https://github.com/paulgazz/kmax/blob/master/docs/advanced.md#kismet) and the [publication](https://paulgazzillo.com/papers/esecfse21.pdf) on `kclause` and `kismet`.  The experiment [replication script](https://github.com/paulgazz/kmax/blob/master/scripts/kismet_evaluation/kismet_experiments_replication.sh) can be used to run kismet on all architectures' Kconfig specifications.

## Using `klocalizer --save-dimacs` and `klocalizer --save-smt`

This tool extracts a DIMACS or a SMT formula.
Therefore, execute the following commands in the root directory of your Linux kernel:

    klocalizer -a x86_64 --save-dimacs <Path>
    klocalizer -a x86_64 --save-smt <Path>

Note that `<Path>` should be replaced by the absolute path to the file, the formulae should be written to.
If you intend to use a Docker container, feel free to use the Dockerfile provided in [Advanced Usage](https://github.com/paulgazz/kmax/blob/master/docs/advanced.md).

## Additional documentation

[Advanced Usage](https://github.com/paulgazz/kmax/blob/master/docs/advanced.md)


## Bugs found

[Bugs Found](https://github.com/paulgazz/kmax/blob/master/docs/bugs_found.md) by our tools


## Credits

The main developers of this project have been [Paul Gazzillo](https://paulgazzillo.com) (`kextract`, `kclause`, `kmax`, `klocalizer`), [Necip Yildiran](http://www.necipyildiran.com/) (`kismet`, `krepair`, `koverage`), [Jeho Oh](https://www.linkedin.com/in/jeho-oh-110a2092/) (`kclause`), and [Julian Braha](https://julianbraha.com/) (`koverage`).  [Julia Lawall](https://pages.lip6.fr/Julia.Lawall/) has posed new applications and provided invaluable advice, feedback, and support.  Thanks to all the users who have contributed code and issues.  Special thanks to the [Intel 0-day](https://01.org/lkp) team for working to [include `kismet` into the kernel test robot](https://lore.kernel.org/all/d13eec5d-ee87-2207-05a4-1c7732bca4cd@intel.com/) and for their valuable feedback.  This work is funded in part by the National Science Foundation under awards [CCF-1840934](https://nsf.gov/awardsearch/showAward?AWD_ID=1840934) and [CCF-1941816](https://nsf.gov/awardsearch/showAward?AWD_ID=1941816).

            

Raw data

            {
    "_id": null,
    "home_page": "https://github.com/paulgazz/kmax",
    "name": "kmax",
    "maintainer": null,
    "docs_url": null,
    "requires_python": null,
    "maintainer_email": null,
    "keywords": "makefile kconfig kbuild configurations kmax kclause klocalizer",
    "author": "Paul Gazzillo",
    "author_email": "paul@pgazz.com",
    "download_url": "https://files.pythonhosted.org/packages/96/66/0b543d7519f3b1d4780448ddb87f44d9876e8a36b20f2141100d42b0fdbe/kmax-4.8.tar.gz",
    "platform": null,
    "description": "<!-- START doctoc generated TOC please keep comment here to allow auto update -->\n<!-- DON'T EDIT THIS SECTION, INSTEAD RE-RUN doctoc TO UPDATE -->\n\n- [The kmax tool suite](#the-kmax-tool-suite)\n  - [Installation](#installation)\n    - [Dependencies](#dependencies)\n    - [Installing the kmax tool suite](#installing-the-kmax-tool-suite)\n    - [Quick test](#quick-test)\n  - [Using `krepair` on patches](#using-krepair-on-patches)\n    - [The paper example](#the-paper-example)\n  - [Using `kismet`](#using-kismet)\n    - [Checking a single select construct](#checking-a-single-select-construct)\n    - [Checking all Kconfig files for an architecture](#checking-all-kconfig-files-for-an-architecture)\n  - [Using `klocalizer --save-dimacs` and `klocalizer --save-smt`](#using-klocalizer---save-dimacs-and-klocalizer---save-smt)\n  - [Additional documentation](#additional-documentation)\n  - [Bugs found](#bugs-found)\n  - [Credits](#credits)\n\n<!-- END doctoc generated TOC please keep comment here to allow auto update -->\n\n\n# The kmax tool suite\n\n## Installation\n\n### Dependencies\n\n#### System dependencies\n\n    # kmax dependencies\n    sudo apt install -y pipx python3-dev gcc build-essential\n    # linux dependencies\n    sudo apt install -y flex bison bc libssl-dev libelf-dev git\n    # superc dependencies\n    sudo apt install -y wget libz3-java libjson-java sat4j unzip xz-utils lftp\n\t\n#### User dependencies\n\t\n    # install superc and make.cross\n    wget -O - https://raw.githubusercontent.com/appleseedlab/superc/master/scripts/install.sh | bash\n\n### Environment\n\nAdd these environment variables to your shell, e.g., `.bash_profile`:\n\n    export COMPILER_INSTALL_PATH=$HOME/0day\n    export CLASSPATH=/usr/share/java/org.sat4j.core.jar:/usr/share/java/json-lib.jar:${HOME}/.local/share/superc/z3-4.8.12-x64-glibc-2.31/bin/com.microsoft.z3.jar:${HOME}/.local/share/superc/JavaBDD/javabdd-1.0b2.jar:${HOME}/.local/share/superc/xtc.jar:${HOME}/.local/share/superc/superc.jar:${CLASSPATH}\n    export PATH=${HOME}/.local/bin/:${PATH}\n\n### Installing the kmax tool suite\n\n    pipx install kmax\n\n### Quick test\n    \nGet Linux kernel source:\n\n    cd ~/\n    wget https://cdn.kernel.org/pub/linux/kernel/v6.x/linux-6.10.tar.xz\n    tar -xvf linux-6.10.tar.xz\n    cd ~/linux-6.10/\n\nTest `krepair` by automatically repairing `allnoconfig` to include `drivers/usb/storage/alauda.o`, which would normally be omitted by `allnoconfig`.\n\n    # create allnoconfig\n    make ARCH=x86_64 allnoconfig\n    # run klocalizer --repair allnoconfig to build alauda.c\n    klocalizer --repair .config -o allnoconfig_repaired --include drivers/usb/storage/alauda.o\n    # clean and build the kernel with the repair config file\n    KCONFIG_CONFIG=allnoconfig_repaired make ARCH=x86_64 olddefconfig clean drivers/usb/storage/alauda.o\n    \nYou should see `CC      drivers/usb/storage/alauda.o` at the end of the build.\n\n## Using `krepair` on patches\n\n`klocalizer --repair` will take a config file that fails to build lines of a patch and repairs it to build the whole patch. \nThis uses [SuperC](https://github.com/appleseedlab/superc) to find `#ifdef` constraints.\n\nLet's first get the Linux source code:\n\n    cd ~/\n    git clone git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git\n\t\nNow let's get an example patch from the Linux kernel's mainline repository:\t\n\t\n    cd ~/linux/\n    git checkout 6fc88c354f3af\n    git show > 6fc88c354f3af.diff\n\nNext, let's repair allnoconfig, which does not build all lines from the patch.\n\n    # create allnoconfig\n    make.cross ARCH=x86_64 allnoconfig\n    # run klocalizer to repair allnoconfig to include the patch\n    klocalizer --repair .config -a x86_64 --include-mutex 6fc88c354f3af.diff\n    # clean and build the files modified by the patch (WERROR=0 for tools/lib/subcmd/subcmd-util.h which triggers a use-after-free on gcc 13)\n    KCONFIG_CONFIG=0-x86_64.config make.cross WERROR=0 ARCH=x86_64 olddefconfig clean kernel/bpf/cgroup.o net/ipv4/af_inet.o net/ipv4/udp.o net/ipv6/af_inet6.o net/ipv6/udp.o\n\nWe can use `koverage` to check how much of patch is covered by a given config file:\n\n    koverage -f --config 0-x86_64.config --arch x86_64 --check-patch 6fc88c354f3af.diff -o coverage_results.json\n    cat coverage_results.json\n\nIn contrast, we can see that `allnoconfig` omits coverage of the patch:\n\n    make.cross ARCH=x86_64 allnoconfig\n    koverage -f --config .config --arch x86_64 --check-patch 6fc88c354f3af.diff -o allnoconfig_coverage_results.json\n    cat allnoconfig_coverage_results.json\n\nNotes:\n\n- While repair usually covers all lines of a patch, some lines may still be omitted, for instance if they are dead code or in header files.\n- If a patch modifies both arms of an `#ifdef`, multiple config files are needed to cover all lines.  These are exported as `NUM-ARCH.config`.\n\n### The paper example\n\nHere is another example from the [krepair paper](https://paulgazzillo.com/papers/fse24.pdf).  This [patch](https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/commit/?id=8594c3b85171b6f68e34e07b533ec2f1bf7fb065) modifies code in both arms of an `#ifdef`, so a single `.config` file cannot cover all patched lines.  `klocalizer` emits two `.config` files, which together cover all lines.\n\n    git checkout 8594c3b85171b\n    git show > 8594c3b85171b.diff\n\tmake.cross ARCH=arm allnoconfig\n    klocalizer --repair .config -a arm --include-mutex 8594c3b85171b.diff\n    koverage -f --config 0-arm.config --arch arm --check-patch 8594c3b85171b.diff -o 0-coverage_results.json\n    koverage -f --config 1-arm.config --arch arm --check-patch 8594c3b85171b.diff -o 1-coverage_results.json\n    cat 0-coverage_results.json\n    cat 1-coverage_results.json\n\tdiff -y 0-coverage_results.json 1-coverage_results.json | less\n\n## Using `kismet`\n\nThis tool will check for unmet dependency bugs in [Kconfig specifications](https://www.kernel.org/doc/html/latest/kbuild/kconfig-language.html#menu-attributes) due to reverse dependencies overriding direct dependencies.\n\n### Checking a single select construct\n\nFound by [Intel's kernel test robot running kismet](https://lore.kernel.org/lkml/cc9905dd-5b66-d01e-491c-64c18198d208@intel.com/)\n\n    git checkout 5a7f27a624d9e33262767b328aa7a4baf7846c14\n    kismet --linux-ksrc=./ --selectees CONFIG_SND_SOC_MAX98357A --selectors CONFIG_SND_SOC_INTEL_SOF_CS42L42_MACH -a=x86_64\n\nThe alarm can be found in `kismet_summary_x86_64.csv` and `.config` files that exercise the bug can be found in `kismet-test-cases/`.\n\n### Checking all Kconfig files for an architecture\n\nRun `kismet` on the root of the Linux source tree.\n\n    cd ~/\n    wget https://cdn.kernel.org/pub/linux/kernel/v5.x/linux-5.16.tar.xz\n    tar -xvf linux-5.16.tar.xz\n    cd ~/linux-5.16/\n    kismet --linux-ksrc=\"${HOME}/linux-5.16/\" -a=x86_64\n\nOnce finished (it can take about an hour on a commodity desktop), kismet will produce three outputs:\n\n  1. A summary of the results in `kismet_summary_x86_64.txt`\n  2. A list of results for each `select` construct in `kismet_summary_x86_64.csv` (`UNMET_ALARM` denotes the buggy ones)\n  3. A list of `.config` files meant to exercise each bug in `kismet-test-cases/`\n\nTechnical details can be found in in the [kismet documentation](https://github.com/paulgazz/kmax/blob/master/docs/advanced.md#kismet) and the [publication](https://paulgazzillo.com/papers/esecfse21.pdf) on `kclause` and `kismet`.  The experiment [replication script](https://github.com/paulgazz/kmax/blob/master/scripts/kismet_evaluation/kismet_experiments_replication.sh) can be used to run kismet on all architectures' Kconfig specifications.\n\n## Using `klocalizer --save-dimacs` and `klocalizer --save-smt`\n\nThis tool extracts a DIMACS or a SMT formula.\nTherefore, execute the following commands in the root directory of your Linux kernel:\n\n    klocalizer -a x86_64 --save-dimacs <Path>\n    klocalizer -a x86_64 --save-smt <Path>\n\nNote that `<Path>` should be replaced by the absolute path to the file, the formulae should be written to.\nIf you intend to use a Docker container, feel free to use the Dockerfile provided in [Advanced Usage](https://github.com/paulgazz/kmax/blob/master/docs/advanced.md).\n\n## Additional documentation\n\n[Advanced Usage](https://github.com/paulgazz/kmax/blob/master/docs/advanced.md)\n\n\n## Bugs found\n\n[Bugs Found](https://github.com/paulgazz/kmax/blob/master/docs/bugs_found.md) by our tools\n\n\n## Credits\n\nThe main developers of this project have been [Paul Gazzillo](https://paulgazzillo.com) (`kextract`, `kclause`, `kmax`, `klocalizer`), [Necip Yildiran](http://www.necipyildiran.com/) (`kismet`, `krepair`, `koverage`), [Jeho Oh](https://www.linkedin.com/in/jeho-oh-110a2092/) (`kclause`), and [Julian Braha](https://julianbraha.com/) (`koverage`).  [Julia Lawall](https://pages.lip6.fr/Julia.Lawall/) has posed new applications and provided invaluable advice, feedback, and support.  Thanks to all the users who have contributed code and issues.  Special thanks to the [Intel 0-day](https://01.org/lkp) team for working to [include `kismet` into the kernel test robot](https://lore.kernel.org/all/d13eec5d-ee87-2207-05a4-1c7732bca4cd@intel.com/) and for their valuable feedback.  This work is funded in part by the National Science Foundation under awards [CCF-1840934](https://nsf.gov/awardsearch/showAward?AWD_ID=1840934) and [CCF-1941816](https://nsf.gov/awardsearch/showAward?AWD_ID=1941816).\n",
    "bugtrack_url": null,
    "license": "GPLv2+",
    "summary": "Tools for working with symbolic  constraints from Kbuild Makefile.",
    "version": "4.8",
    "project_urls": {
        "Homepage": "https://github.com/paulgazz/kmax"
    },
    "split_keywords": [
        "makefile",
        "kconfig",
        "kbuild",
        "configurations",
        "kmax",
        "kclause",
        "klocalizer"
    ],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "96660b543d7519f3b1d4780448ddb87f44d9876e8a36b20f2141100d42b0fdbe",
                "md5": "7bdcd94c7c28f8ace285d2365e020f52",
                "sha256": "ec60c0aa0016e6a21274b6fa0089a69ae9f7111df4d2500aa5ce9476fdf57a9a"
            },
            "downloads": -1,
            "filename": "kmax-4.8.tar.gz",
            "has_sig": false,
            "md5_digest": "7bdcd94c7c28f8ace285d2365e020f52",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": null,
            "size": 780303,
            "upload_time": "2024-10-16T20:05:31",
            "upload_time_iso_8601": "2024-10-16T20:05:31.035848Z",
            "url": "https://files.pythonhosted.org/packages/96/66/0b543d7519f3b1d4780448ddb87f44d9876e8a36b20f2141100d42b0fdbe/kmax-4.8.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2024-10-16 20:05:31",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "paulgazz",
    "github_project": "kmax",
    "travis_ci": false,
    "coveralls": false,
    "github_actions": false,
    "lcname": "kmax"
}
        
Elapsed time: 3.36007s