Skip to content

Vv2zp/gramado

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

The Amazing Gramado Operating System

    Gramado OS

Here are some screenshots of Gramado Operating System.

Screenshot Screenshot

What is Gramado Operating System?

GramadoOS is a graphical operating system for x86_64 computers.

What is the category it belongs to?

Gramado is a hobby operating system, not a commercial operating system, because it is a small system and has only some few features, not all the features needed by a commercial operating system.

Kernel features. (see: ama/kernel/)

  • hw - cpu: Intel and AMD. 64bit only.
  • hw - mm: Paging. Chunck of 2MB, using 4KB pages.
  • hw - blk device: IDE PATA.
  • hw - char device: ps/2 keyboard.
  • hw - char device: ps/2 mouse works fine only on qemu.
  • hw - char device: Serial port. (COM). Used for debug.
  • hw - network device: e1000 Intel NIC. Works on Oracle virtual box.
  • sw - Processes: Process structure and Thread structure.
  • sw - Scheduler: Round robin. (Threads only).
  • sw - Syscalls using software interrups. (Traps).
  • sw - IPC: sockets.
  • sw - IPC: System messages using a queue in the thread structure.
  • sw - tty: It has 4 ring 0 kernel virtual consoles in fullscreen raw mode.
  • sw - tty: General use ttys and ptys for ring3 virtual terminals.
  • sw - fs: FAT16 file system for boot partition. No system partition yet.
  • sw - posix libc: Ring0 implementation of libc functions called by the ring3 libraries.
  • sw - network: Small support for sockets.
  • sw - network: Small ring0 implementation of protocol stack. (ETHERNET, ARP, IP, UDP, TCP and DHCP).
  • sw - display: Bootloader display device. VESA.
  • sw - user: Very small implementation of user structure.
  • sw - APIs: See zcall/ folder.
  • sw - One loadable ring0 module, using static address.

Userland features.

  • Display Server. See: userland/services/gramland/
  • Unix-like commands running in the virtual console.
  • Some few clients connected to the display server via unix-sockets.
  • Ring3 processes can access the i/o ports via syscall. (For ring3 drivers only).

userland system programs.

  • zing/graminit/ - The init process.
  • zing/gramlan0/ - Gramland, the display server.
  • zing/netd/ - The network server.

userland libraries, toolkits and apis.

  • posix libc - (rtl)
  • Client-sie library for GUI applications - (libgws)
  • see: zz/omega1/libs/ for all the libraries, toolkits and apis.

userland user programs.

  • see: zz/omega2/apps/ for Client-side GUI application.
  • see: zz/omega2/commands/ for posix commands.
  • see: zz/omega2/drivers/ for ring3 drivers.
  • see: zz/omega2/servers/ for ring3 servers.

userland system data.

  • zz/omega3/assets - Icons for the User Interface.
  • zz/omega3/base - All binaries go here to build the final virtual disk.

The source code.

You can find the source code on Github in the internet, where you can clone the repository, contribute to the project or download the code. The address is https://github.com/gramado/gramado.

A description of the directories in the Gramado source code.

There are only two main subdirectories: core/ and desktop/. core/ is a place for the low level code and desktop/ is a place for the graphical user interface.

Gramado Kernel - core/
Gramado DE     - userland/

The next few lines has a brief description of the subdirectories:
 * `aa/` - Ring 0 first loadable module.
   * `cancun/` - Running gramado commands on Linux host.

 * `ama/` - Low level basic components of the system.  
   * `boot` - The boot loader.
   * `kernel` - The Gramado OS kernel.
   * `kmods` - Kernel module.
   * `xciting` - init process and data.

 * `boring/docs/` - Documentation.

 * `zing/` - Desktop Environment (DE).
   * `gramland` - Display server. (GRAMLAND.BIN)
   * `netd` - The network server.

 * `zz` - 
   * `omega1` - Libraries, toolkits and apis. 
   * `omega2` - apps, commands, drivers and servers. 
   * `omega3` - data 

Who are the developers?

The main developer is Fred Nora, a brazilian developer. Fred Nora is the creator and main maintainer of the project. Contributions are welcome.

Building and running on vm

$ make
$ cd ama
$ ./run

Clean up the unused files to make a fresh compilation

$ cd core
$ make clean-all

What are the host machine to build the project?

For now the system has been compiled on Ubuntu operating system, LTS releases.

    Host machine: Ubuntu 20.04.5 LTS
    Linux 5.4.0-146-generic x86_64
    gcc (Ubuntu) 9.4.0 
    GNU ld (GNU Binutils for Ubuntu) 2.34
    NASM version 2.14.02
    Host machine: Ubuntu 22.04.2 LTS
    Linux 5.15.0-78-generic x86_64
    gcc (Ubuntu) 11.4.0 
    GNU ld (GNU Binutils for Ubuntu) 2.38
    NASM version 2.15.05
    Host machine: Ubuntu 22.04.2 LTS
    Linux 5.15.0-83-generic x86_64
    gcc (Ubuntu) 11.4.0 
    GNU ld (GNU Binutils for Ubuntu) 2.38
    NASM version 2.15.05
    Host machine: Ubuntu 22.04.2 LTS
    Linux 5.15.0-84-generic x86_64
    gcc (Ubuntu) 11.4.0 
    GNU ld (GNU Binutils for Ubuntu) 2.38
    NASM version 2.15.05

Can I test the system on a virtual machine?

Yes, you can test the system on a virtual machine. The system has been tested by Fred Nora on qemu, qemu with kvm and virtualbox. Now, Fred Nora is testing the system only on qemu and virtualbox.

Can I test the system on a real machine?

Yes, we can test the system in the real machines. This way we can improve the system. The older versions of the system were tested for a long period of time on a real machine. That machine was a Gigabyte machine with an Intel Core 2 Duo processor and a VIA chipset.

Do we need some feedback from the users and from the developers?

Yes, we need some feedback. Please make some comments on Github or send messages to Fred Nora.

Author

Contributors

Warning

You're reaching the boring area of this document!

How to Build?

See the Gramado OS build instructions

Documentation

The project has a folder for documentation and design notes. The folder is docs/.

See the docs.

The project is looking for some people to create a better documentation, for free, as a contribuition to the open source community. To create this new documentation we can use the documentation in docs/ and the design notes found all over the project.

License

Gramado is a Free and Open Source operating system. The source code uses the BSD license.

Quotes:

  * "Close to the borders and beyond."
  * "Exciting"
  * "(  spontaneous)"

About

The Amazing Gramado Operating System

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • C 87.2%
  • Assembly 9.8%
  • Makefile 1.7%
  • Logos 0.7%
  • Yacc 0.3%
  • C 0.2%
  • Other 0.1%