DragonOS/kernel/crates/bitmap/src/static_bitmap.rs
GnoCiYeH 52da9a5937
完成与Linux兼容的Ntty (#517)
* 已经完成的功能:
- 写:printf能够正常在tty输出
- 读:与键盘驱动接上
- 信号: 能够正常通过ctrl向前台进程发送信号

* 支持目前的shell,改动printk使其与新版tty兼容。

* 删除原有tty文件夹,并更改新tty文件名

* 添加clear清屏程序

* 实现tty部分ioctl,更改部分问题
2024-02-26 15:27:19 +08:00

121 lines
2.8 KiB
Rust

use core::mem::size_of;
use crate::{bitmap_core::BitMapCore, traits::BitMapOps};
/// 静态位图
///
/// 该位图的大小在编译时确定,不可变
#[derive(Debug, Clone)]
pub struct StaticBitmap<const N: usize>
where
[(); (N + usize::BITS as usize - 1) / (usize::BITS as usize)]:,
{
pub data: [usize; (N + usize::BITS as usize - 1) / (usize::BITS as usize)],
core: BitMapCore<usize>,
}
impl<const N: usize> StaticBitmap<N>
where
[(); (N + usize::BITS as usize - 1) / (usize::BITS as usize)]:,
{
/// 创建一个新的静态位图
pub const fn new() -> Self {
Self {
data: [0; (N + usize::BITS as usize - 1) / (usize::BITS as usize)],
core: BitMapCore::new(),
}
}
}
impl<const N: usize> BitMapOps<usize> for StaticBitmap<N>
where
[(); (N + usize::BITS as usize - 1) / (usize::BITS as usize)]:,
{
#[inline]
fn get(&self, index: usize) -> Option<bool> {
return self.core.get(N, &self.data, index);
}
#[inline]
fn set(&mut self, index: usize, value: bool) -> Option<bool> {
return self.core.set(N, &mut self.data, index, value);
}
#[inline]
fn len(&self) -> usize {
N
}
#[inline]
fn size(&self) -> usize {
self.data.len() * size_of::<usize>()
}
#[inline]
fn first_index(&self) -> Option<usize> {
self.core.first_index(&self.data)
}
#[inline]
fn first_false_index(&self) -> Option<usize> {
self.core.first_false_index(N, &self.data)
}
#[inline]
fn last_index(&self) -> Option<usize> {
self.core.last_index(N, &self.data)
}
#[inline]
fn last_false_index(&self) -> Option<usize> {
self.core.last_false_index(N, &self.data)
}
#[inline]
fn next_index(&self, index: usize) -> Option<usize> {
self.core.next_index(N, &self.data, index)
}
#[inline]
fn next_false_index(&self, index: usize) -> Option<usize> {
self.core.next_false_index(N, &self.data, index)
}
#[inline]
fn prev_index(&self, index: usize) -> Option<usize> {
self.core.prev_index(N, &self.data, index)
}
#[inline]
fn prev_false_index(&self, index: usize) -> Option<usize> {
self.core.prev_false_index(N, &self.data, index)
}
#[inline]
fn invert(&mut self) {
self.core.invert(N, &mut self.data);
}
#[inline]
fn is_full(&self) -> bool {
self.core.is_full(N, &self.data)
}
#[inline]
fn is_empty(&self) -> bool {
self.core.is_empty(&self.data)
}
#[inline]
unsafe fn as_bytes(&self) -> &[u8] {
core::slice::from_raw_parts(
self.data.as_ptr() as *const u8,
core::mem::size_of::<Self>(),
)
}
fn set_all(&mut self, value: bool) {
self.core.set_all(N, &mut self.data, value);
}
}