Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/katyo/kquery

Deep diving tool for Linux kernel sources.
https://github.com/katyo/kquery

Last synced: 16 days ago
JSON representation

Deep diving tool for Linux kernel sources.

Awesome Lists containing this project

README

        

# Linux source querying tool

[![github](https://img.shields.io/badge/github-katyo/kquery-8da0cb.svg?style=for-the-badge&logo=github)](https://github.com/katyo/kquery)
[![crates](https://img.shields.io/crates/v/kquery.svg?style=for-the-badge&color=fc8d62&logo=rust)](https://crates.io/crates/kquery)
[![docs](https://img.shields.io/badge/docs.rs-kquery-66c2a5?style=for-the-badge&logo=)](https://docs.rs/kquery)
[![status](https://img.shields.io/github/workflow/status/katyo/kquery/Rust?style=for-the-badge&logo=github-actions&logoColor=white)](https://github.com/katyo/kquery/actions?query=workflow%3ARust)

This is blazing fast querying tool for deep dive into Linux source code.
Development in early stage so things may work wrong or does not work at all.

Currently it consists of querying library and simple command-line tool.

## Command-line usage

Create or update index first:

```sh
$ cd path/to/linux/sources
$ kquery index
Found 21964 sources, 10521 compatible strings, 12519 configuration options
```

List all found sources:

```sh
$ kquery sources
```

List sources which match some pattern:

```sh
$ kquery sources drivers/**/arm/**
```

List all found compatible strings:

```sh
$ kquery compats
```

List compatible strings which match some pattern:

```sh
$ kquery compats arm,*
```

List all found configuration options:

```sh
$ kquery configs
```

List configuration options which match some pattern:

```sh
$ kquery compats ARM_*
```

Query source info which has compatible string:

```sh
$ kquery compat arm,smmu-v2
```

Query sources info related to configuration option:

```sh
$ kquery config ARM_SMMU
```

Query source info by path:

```sh
$ kquery source drivers/iommu/arm/arm-smmu/arm-smmu.c
```

## Library usage

```no_run
use kquery::{FileMgr, MetaData, Result};

#[tokio::main]
async fn main() -> Result<()> {
// Create file manager instance using path to sources
let filemgr = FileMgr::new("path/to/sources").await?;

// Create index from Linux source tree
let metadata = MetaData::from_kbuild(&filemgr).await?;

// Store metadata into file in source tree
metadata.to_file("path/to/metadata.json", None).await?;

// Load metadata from cache file in source tree
let metadata = MetaData::from_file("path/to/metadata.json", None).await?;

Ok(())
}
```