ax-memory-addr 0.6.2

Wrappers and helper functions for physical and virtual addresses
Documentation
<h1 align="center">ax-memory-addr</h1>

<p align="center">Wrappers and helper functions for physical and virtual addresses</p>

<div align="center">

[![Crates.io](https://img.shields.io/crates/v/ax-memory-addr.svg)](https://crates.io/crates/ax-memory-addr)
[![Docs.rs](https://docs.rs/ax-memory-addr/badge.svg)](https://docs.rs/ax-memory-addr)
[![Rust](https://img.shields.io/badge/edition-2021-orange.svg)](https://www.rust-lang.org/)
[![License](https://img.shields.io/badge/license-Apache--2.0-blue.svg)](./LICENSE)

</div>

English | [中文]README_CN.md

# Introduction

`ax-memory-addr` provides Wrappers and helper functions for physical and virtual addresses. It is maintained as part of the TGOSKits component set and is intended for Rust projects that integrate with ArceOS, AxVisor, or related low-level systems software.


> ax-memory-addr was derived from https://github.com/arceos-org/axmm_crates

## Quick Start

### Installation

Add this crate to your `Cargo.toml`:

```toml
[dependencies]
ax-memory-addr = "0.6.1"
```

### Run Check and Test

```bash
# Enter the crate directory
cd components/axmm_crates/memory_addr

# Format code
cargo fmt --all

# Run clippy
cargo clippy --all-targets --all-features

# Run tests
cargo test --all-features

# Build documentation
cargo doc --no-deps
```

## Integration

### Example

```rust
use ax_memory_addr as _;

fn main() {
    // Integrate `ax-memory-addr` into your project here.
}
```

### Documentation

Generate and view API documentation:

```bash
cargo doc --no-deps --open
```

Online documentation: [docs.rs/ax-memory-addr](https://docs.rs/ax-memory-addr)

# Contributing

1. Fork the repository and create a branch
2. Run local format and checks
3. Run local tests relevant to this crate
4. Submit a PR and ensure CI passes

# License

Licensed under the Apache License, Version 2.0. See [LICENSE](./LICENSE) for details.