The Serenity Operating System 🐞
Find a file
Jesse 10ffaf019f Kernel: Initial FDC Device Driver (#315)
A basic Floppy Disk Controller device driver for any system later than (and including) the IBM AT. The driver is based on the documentation supplied by QEMU, which is the datasheet for the Intel 82078 Floppy Disk controller (found here: https://wiki.qemu.org/images/f/f0/29047403.pdf)

Naturally, floppy disks are a _very_ outdated storage medium, however, as Serenity is a throwback to aesthetic 90s computing, it's a definite must have. Not to mention that there are still a lot of floppy disks around, with countless petabytes of software on them, so it would be nice if people could create images of said disks with serenity.

The code for this is mostly clean. however there are a LOT of values specified in the datasheet, so some of them might be wrong, not to mention that the actual specification itself is rather dirt and seemingly hacked together.

I'm also only supporting 3.5" floppy disks, without PIO polling (DMA only), so if you want anything more/less than 1.44MB HD Floppys, you'll have to do it yourself.
2019-07-17 15:51:51 +02:00
AK AK: Add a new TestSuite.h from my own work, adapted to match the existing one a bit 2019-07-16 11:03:38 +02:00
Applications LibGUI: Add input types to GMessageBox. 2019-07-16 21:41:13 +02:00
Base Piano: Add 16x16 window icon. 2019-07-13 23:12:40 +02:00
Demos HelloWorld: Make the demo label say "Hello\nWorld!". 2019-07-12 19:54:10 +02:00
DevTools LibGUI: Add input types to GMessageBox. 2019-07-16 21:41:13 +02:00
Documentation Documentation: Update SmartPointers.md with new pointer names. 2019-06-21 18:42:17 +02:00
Games Minesweeper: Remove use of copy_ref(). 2019-07-11 15:53:01 +02:00
Kernel Kernel: Initial FDC Device Driver (#315) 2019-07-17 15:51:51 +02:00
Libraries LibC: Fix MALLOC_DEBUG to work 2019-07-17 12:55:47 +02:00
Meta Meta: Removed all gitignore in the source tree only keeping the root one 2019-06-30 10:41:26 +02:00
Ports Ports: Force curl to follow redirects in run_fetch_web() (#266) 2019-07-01 20:57:46 +02:00
Servers ABuffer: clamp -> clip 2019-07-17 09:47:52 +02:00
SharedGraphics AK: Add a canonicalized_path() convenience function. 2019-07-15 06:50:32 +02:00
Shell Kernel: Add support for the WSTOPPED flag to the waitpid() syscall. 2019-07-14 11:35:49 +02:00
Toolchain Libraries: Create top level directory for libraries. 2019-07-04 16:16:50 +02:00
Userland top: Widen "state" field slightly to accomodate "Condition". 2019-07-17 11:23:31 +02:00
.clang-format Meta: Tweak .clang-format to not wrap braces after enums. 2019-06-07 17:13:23 +02:00
.gitignore Meta: Removed all gitignore in the source tree only keeping the root one 2019-06-30 10:41:26 +02:00
.travis.yml Travis: Try to install a modern C++ compiler for host compilations. 2019-07-10 22:03:46 +02:00
LICENSE Let's go with a 2-clause BSD license. 2019-04-15 14:04:23 +02:00
Makefile.common AudioServer: Assorted infrastructure work 2019-07-13 22:57:24 +02:00
ReadMe.md Meta: Add note about rebuilding after pulling new changes. 2019-07-01 14:33:31 +02:00

Serenity

Graphical Unix-like operating system for x86 computers.

Travis CI status

About

I always wondered what it would be like to write my own operating system, but I never took it seriously. Until now.

Serenity is a love letter to '90s user interfaces with a custom Unix-like core. It flatters with sincerity by stealing beautiful ideas from various other systems.

Roughly speaking, the goal is a marriage between the aesthetic of late-1990s productivity software and the power-user accessibility of late-2000s *nix. This is a system by me, for me, based on the things I like.

If you like some of the same things, you are welcome to join the project. It would be great to one day change the above to say "this is a system by us, for us, based on the things we like." :^)

I regularly post raw hacking sessions and demos on my YouTube channel.

Sometimes I write about about the system on my github.io blog.

There's also a Patreon if you would like to show some support that way.

Screenshot

Screenshot as of 191112e

Current features

  • Pre-emptive multitasking
  • Multithreading
  • Compositing window server
  • IPv4 networking with ARP, TCP, UDP and ICMP
  • ext2 filesystem
  • Unix-like libc and userland
  • POSIX signals
  • Shell with pipes and I/O redirection
  • mmap()
  • /proc filesystem
  • Local sockets
  • Pseudoterminals (with /dev/pts filesystem)
  • JSON framework
  • Low-level utility library (LibCore)
  • High-level GUI library (LibGUI)
  • Visual GUI design tool
  • PNG format support
  • Text editor
  • IRC client
  • Simple painting application
  • DNS lookup
  • Desktop games: Minesweeper and Snake
  • Ports system (needs more packages!)
  • Other stuff I can't think of right now...

How do I build and run this?

Make sure you have all the dependencies installed:

sudo apt install libmpfr-dev libmpc-dev libgmp-dev e2fsprogs qemu-system-i386 qemu-utils

Go into the Toolchain/ directory and run the BuildIt.sh script. Then source the UseIt.sh script to put the i686-pc-serenity toolchain in your $PATH.

Once you've done both of those, go into the Kernel/ directory, then run ./makeall.sh, and if nothing breaks too much, take it for a spin by using ./run.

Later on, when you git pull to get the latest changes, there's no need to rebuild the toolchain. You can simply rerun ./makeall.sh in the Kernel/ directory and you'll be good to ./run again.

IRC

Come chat in #serenityos on the Freenode IRC network.

Author

Contributors

Feel free to append yourself here if you've made some sweet contributions. :)

License

Serenity is licensed under a 2-clause BSD license.