You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

116 lines
8.1 KiB

6 years ago
xinu-avr
========
6 years ago
6 years ago
The **xinu-avr** project is a **Xinu Operating System** subset, modified to run on an AVR atmega328p microcontroller (e.g. Arduino boards).
6 years ago
6 years ago
[Visit its Web Page for detailed instructions.](http://se.fi.uncoma.edu.ar/xinu-avr/)
6 years ago
6 years ago
6 years ago
<a href="https://www.youtube.com/watch?v=JAcUuP-BKIU" title="Demo video: Xinu OS into AVR atmega328p"><img style="float: right;" alt="Demo video: Xinu OS into atmega328p MCU" src="http://se.fi.uncoma.edu.ar/xinu-avr/www/files/placa3.jpg" /></a>
6 years ago
6 years ago
At present, the core pieces of Xinu are working, so you can already integrate it
in the development of multi-tasking embedded systems (you will also need any bare AVR MCU, or Arduino board, of course).
6 years ago
6 years ago
For lovers of "because small is beautiful" (FusixOS, retrobsd, unix in microcontrollers, etc) this project provides a user interface example as well: The **Xinu shell** and some tiny versions of utilities like echo, a text editor, a basic interpreter, ps, kill, free, date, cal, and some more. Check the [demo video](https://www.youtube.com/watch?v=JAcUuP-BKIU) if you want to see a xinu-avr session in a little AVR MCU (like a retro computer system).
6 years ago
6 years ago
The source code is comprise of:
6 years ago
6 years ago
1. The **Xinu OS** for AVR atmega328p (microkernel)
2. Basic examples (**apps**) of how to use Xinu
6 years ago
3. A complete example: **The Xinu shell** and tiny versions of several **UNIX-like utilities**
6 years ago
6 years ago
<a name="whatisxinu"></a>
### What is Xinu?
6 years ago
6 years ago
Xinu is a small, elegant, and easy to understand operating system, originally developed by Douglas Comer for instructional purposes at Purdue University in the 1980s. Since then it has been ported to many architectures and hardware platforms.
6 years ago
Xinu uses powerful primitives to provides all the componentes and the same functionality many conventional operating sytems supply. Because the whole source code size is small, **Xinu is suitable for embedded systems**.
6 years ago
<strong>The Xinu Operating System includes</strong>: dynamic process creation, dynamic memory allocation, real-time clock management, process coordination and synchronization, local and remote file systems, a shell, and device-independent I/O functions.
6 years ago
6 years ago
The Xinu Operating System is
6 years ago
documented in the book
6 years ago
[D. Comer, Operating System Design - The Xinu Approach, Second Edition CRC Press, 2015. ISBN 9781498712439](https://xinu.cs.purdue.edu/#textbook)
6 years ago
6 years ago
Many sites defines Xinu as a free Unix system, or similar statements. It is not. Xinu differs completely from the internal structure of Unix (or Linux). For academic purposes Xinu is smaller, elegant, and easier to understand. Applications written for one system will not run on the other without modification. **Xinu is not Unix**.
6 years ago
6 years ago
#### History
6 years ago
6 years ago
Xinu originally ran on Digital Equipment Corporation LSI 11's with only 64K bytes of memory, at the end of 1979 and the inning of 1980. Over the years Xinu have been expanded and ported to a wide variety of architectures and platforms, including: IBM PC, Macintosh, Digital Equipment Corporation VAX and DECStation 3100, Sun Microsystems Sun 2, Sun 3 and Sparcstations, and for several ARM, MIPS and x86 embedded boards. It has been used as the basis for many research projects. Furthermore, Xinu has been used as an embedded system in products by companies such as Motorola, Mitsubishi, Hewlett-Packard, and Lexmark. There is a full TCP/IP stack, and even the original version of Xinu (for the PDP-11) supported arbitrary processes and network I/O.
6 years ago
There are current versions of Xinu for Galileo Intel boards, ARM Beagle Boards, several MIPS platforms, and for x86 PC hardware and virtual machines.
6 years ago
6 years ago
<a name="code"></a>
6 years ago
### source code:
6 years ago
6 years ago
There is just one git repository, and it has everything ([git](http://github.com/zrafa/xinu-avr/)). The list below is just for convenience:
6 years ago
* <a href="https://github.com/zrafa/xinu-avr">The Xinu OS for AVR atmega328p</a>
6 years ago
* <a href="https://github.com/zrafa/xinu-avr/tree/master/apps/">example apps</a>
* <a href="https://github.com/zrafa/xinu-avr/tree/master/apps/shell/">The xinu shell and tiny UNIX-like utilities (editor, basic interpreter, ps, kill, echo, uptime, sleep, etc)</a>
6 years ago
* <a href="https://xinu.cs.purdue.edu/">The official Xinu Page and Code</a>
6 years ago
<a name="authors"></a>
6 years ago
#### Authors:
6 years ago
* Xinu OS Copyright (c) 2012, 2015
Douglas E. Comer and CRC Press, Inc.
* This version for AVR atmega328p v0.1 (c) 2020
Rafael Ignacio Zurita <rafa@fi.uncoma.edu.ar>
6 years ago
**Acknowledgments**
6 years ago
* Michael M. Minor: he is the author of another AVR port os Xinu (<a href="https://sites.google.com/site/avrxinu/">avrxinu</a>. We use his context switch code, the addargs in Xinu shell, and a few lines more. His port is for bigger AVR microcontrollers (16KB+ of RAM), and he used an old version of Xinu (Xinu from the 1987 book edition).
6 years ago
6 years ago
6 years ago
<a name="notes"></a>
6 years ago
### Notes about the Xinu OS port for AVR atmega328p
6 years ago
6 years ago
Current official Xinu versions are designed for ARM, MIPS and x86 architectures . The hardware differences between those and the ultra small AVR microcontroller required changes to some low-level data structures of Xinu, mainly using the FLASH memory in the AVR MCU, for keeping several read-only data structures, previously in RAM. Also, several limits were imposed, so the read-write data structures fits into the SRAM AVR memory. The Xinu version for AVR atmega328p has the core functionality of Xinu, and provides some extensions, including an eeprom file system and several UNIX like utilities for the Xinu shell.
6 years ago
6 years ago
This MCU has just 2KB of SRAM, 32KB of FLASH memory, and 1KB of EEPROM. The Xinu version for AVR uses 12KB of FLASH and 0.9KB of RAM, so there is still 50% of room (SRAM and FLASH) for the embedded application running on Xinu (concurrent processes).
6 years ago
So this project might be stimulating and very fun for lovers of embedded systems development and operating system internals.
6 years ago
Notes about the port:
6 years ago
6 years ago
1. Max. number of processes (4 to 8)
2. main process is now the embedded application process
3. Max. number of semaphores (2 to 6) (the size of the table of process queues depends on this)
4. Max. number of devices (4 to 5)
6 years ago
4. The clkhandler() wakeup() a process (preemption) for CPU every 100ms
5. Several limits for buffers: 32bytes for tty input, 16bytes for names of devices, 1byte for the queues keys, and the list continues
6 years ago
6. sleepms() is now delay sleep100ms() (and the key for queue "char" in ms * 100)
6 years ago
7. Many vars in data structures have a smaller size (e.g. before:int32, now:char)
6 years ago
8. sleep sleeps max. 20 seconds (date type)
9. most of the libc are from avr-libc
10. init (load bss and data from flash to ram) from avr-libc
11. shell manages max. 6 tokens
12. date and time is managed by a little lib. No NTP or RTC
6 years ago
13. Most of the const char in source code were moved to FLASH (program space) via __flash directive from gcc, or PROGMEM from avr-libc
14. tty_in is asynchronous (with interrupts) (ok). But tty_out is polled based (synchronous).
15. open, read, write, seek, close use struct dentry. It is on flash on this port
6 years ago
16. remote file systems, local file systems, ram file systems are disabled so far.
17. ports (ptinit, ptsend, ptrecv, etc) are disabled so far.
18. null process has priority 1.
6 years ago
6 years ago
6 years ago
<a name="douglas"></a>
6 years ago
### Douglas Comer
6 years ago
Douglas Comer is a Professor of Computer Science at Purdue University who
was inducted into the Internet Hall of Fame on September, 2019.
6 years ago
As one of the earliest TCP/IP and internetworking researchers, Comer wrote the first series of textbooks explaining the scientific principles underlying the design of the Internet and its communications protocols, providing some of the earliest formal guidance for building efficient networks and applications that use the Internet.
Comer's three-volume textbook series, Internetworking with TCP/IP, written in 1987, is widely considered to be the authoritative reference for Internet protocols. The series played a key role in popularizing Internet protocols by making them more understandable to a new generation of engineers and IT professionals.
6 years ago
6 years ago
Prof. Douglas Comer designed and developed the Xinu operating system in 1979-1980.
6 years ago
6 years ago
[Douglas Comer Page](https://www.cs.purdue.edu/homes/comer/)
6 years ago
6 years ago
[Internet Hall of Fame](https://www.cs.purdue.edu/news/articles/2019/comer_ihof.html)
6 years ago
6 years ago
6 years ago