memoriosa (Fase 7c) demostró que un app podía persistir su huella. Esta fase la lleva al gesto natural: un editor de texto. Tecleas, reinicias renaser, el texto sigue ahí. La huella vive en el grafo de objetos como todo lo demás. - Nuevo crate `apps/bitacora/`: lienzo 480×280, tipografía 8×8 embebida (`font8x8 = "0.3"`) escalada x2 a 16×16, render pixel a pixel desde la memoria del propio app. Buffer 512 bytes con wrap automático a 28 columnas; `Enter` salta línea, Backspace borra; al desbordar el buffer se descartan los 64 primeros para amortizar la mudanza. Cada cambio invoca `sys_estado_guardar`; al arrancar, `init` llama a `sys_estado_cargar` y reconstruye. - Mapeo de scancodes US a ASCII (letras, dígitos, puntuación básica, espacio). Sin shift ni mayúsculas — minimalismo. - `GENESIS` crece de 7 a 8 apps; `bitacora` es la PRIMERA — gana la celda maestra al arrancar y te invita a teclear. - `CELDA_TASKBAR_ANCHO` baja de 150 a 130 px para que las ocho pestañas + lanzador + reloj quepan holgadas en 1280 px. Verificado en QEMU: tras escribir "hola renaser" y reiniciar el kernel con el mismo disk.img, bitácora muestra el texto donde lo dejó. El `almacen` reporta 24 objetos en el grafo (frente a 9 antes de escribir) y `raiz presente` — cada `guardar` anexó una versión al log direccionado por contenido. Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>
renaser
renaser es un kernel asíncrono de Espacio de Direccionamiento Único
(SASOS), escrito en Rust #![no_std] para x86_64 bare-metal.
Es un sistema operativo disruptivo que rompe por completo con el paradigma POSIX de los años 70: no emula Linux, no usa archivos planos, no usa TTYs ni capas GNU. El aislamiento entre aplicaciones no descansa en la MMU ni en los anillos de privilegio de la CPU, sino en límites matemáticos sobre el bytecode — aislamiento por software (SFI). La interfaz es visual desde el primer microsegundo: el texto es, simplemente, un caso particular del dibujo.
Qué hace, hoy
- Arranca por UEFI y adopta el framebuffer GOP con doble búfer sin parpadeo.
- Se autoempaqueta en una imagen de disco UEFI y se lanza en QEMU.
- Tiene reflejos de fallo: GDT/TSS, IDT y manejadores de excepción; si colapsa, lo dibuja (franja roja de pánico, naranja de memoria agotada).
- Late con el hardware: PIC remapeado, temporizador (PIT) y teclado.
- Gestiona memoria dinámica (heap de 64 MiB, asignador global).
- Ejecuta un reactor asíncrono cooperativo sobre los
Futurenativos de Rust: las interrupciones no conmutan contexto, despiertan tareas. - Rasteriza texto vectorial al vuelo con
fontdue. - Ejecuta un userspace WebAssembly aislado por capacidades (
wasmi): las aplicaciones solo tocan el mundo a través de funciones de host concedidas.
Construir y ejecutar
Requisitos: rustup con toolchain nightly, QEMU y firmware OVMF.
cargo run
Compila el kernel para x86_64-unknown-none, forja la imagen de disco UEFI y
abre QEMU. Ver CLAUDE.md para el resto de comandos y el flujo de la app WASM.
Documentación
| Documento | Contenido |
|---|---|
ARCHITECTURE.md |
la arquitectura del sistema, subsistema a subsistema |
ROADMAP.md |
fases completadas y plan de las siguientes |
CLAUDE.md |
guía operativa: comandos, estructura y convenciones |
Licencia
MPL-2.0