source: mainline/kernel/genarch/include/genarch/drivers/ns16550/ns16550.h@ 6ecf5b8

lfn serial ticket/834-toolchain-update topic/msim-upgrade topic/simplify-dev-export
Last change on this file since 6ecf5b8 was 6ecf5b8, checked in by Vojtech Horky <vojtechhorky@…>, 13 years ago

Prevent compile-time symlinks in kernel

So far, architecture specific headers for kernel were in
kernel/arch/$ARCH/include directory.
From kernel sources, they were referenced as arch/header.h.

For example, file kernel/arch/$ARCH/include/whatever.h
was included with <arch/whatever.h>.

To allow that, a symbolic link with name `arch' pointing
to the correct `include/' was created during compilation.

This change adds one arch/ directory and instead of
creating a symbolic link for each compilation, -I flag
was added to the compiler (the header mentioned above would
now reside in kernel/arch/$ARCH/include/arch/whatever.h).

The same goes for genarch/ includes.

This change would be followed by similar changes in userspace
and ABI. To overall goal is to simplify job of documenation
generators or IDEs that might have problems with the dynamically
created symbolic links.

  • Property mode set to 100644
File size: 2.6 KB
Line 
1/*
2 * Copyright (c) 2001-2004 Jakub Jermar
3 * All rights reserved.
4 *
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions
7 * are met:
8 *
9 * - Redistributions of source code must retain the above copyright
10 * notice, this list of conditions and the following disclaimer.
11 * - Redistributions in binary form must reproduce the above copyright
12 * notice, this list of conditions and the following disclaimer in the
13 * documentation and/or other materials provided with the distribution.
14 * - The name of the author may not be used to endorse or promote products
15 * derived from this software without specific prior written permission.
16 *
17 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
18 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
19 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
20 * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
21 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
22 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
23 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
24 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
25 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
26 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27 */
28
29/** @addtogroup genarch
30 * @{
31 */
32/**
33 * @file
34 * @brief Headers for NS 16550 serial controller.
35 */
36
37#ifndef KERN_NS16550_H_
38#define KERN_NS16550_H_
39
40#include <ddi/irq.h>
41#include <typedefs.h>
42#include <console/chardev.h>
43
44#define IER_ERBFI 0x01 /** Enable Receive Buffer Full Interrupt. */
45
46#define LCR_DLAB 0x80 /** Divisor Latch Access bit. */
47
48#define MCR_OUT2 0x08 /** OUT2. */
49
50/** NS16550 registers. */
51typedef struct {
52 ioport8_t rbr; /**< Receiver Buffer Register. */
53 ioport8_t ier; /**< Interrupt Enable Register. */
54 union {
55 ioport8_t iir; /**< Interrupt Ident Register (read). */
56 ioport8_t fcr; /**< FIFO control register (write). */
57 } __attribute__ ((packed));
58 ioport8_t lcr; /**< Line Control register. */
59 ioport8_t mcr; /**< Modem Control Register. */
60 ioport8_t lsr; /**< Line Status Register. */
61} __attribute__ ((packed)) ns16550_t;
62
63/** Structure representing the ns16550 device. */
64typedef struct {
65 irq_t irq;
66 ns16550_t *ns16550;
67 indev_t *kbrdin;
68} ns16550_instance_t;
69
70extern ns16550_instance_t *ns16550_init(ns16550_t *, inr_t, cir_t, void *);
71extern void ns16550_wire(ns16550_instance_t *, indev_t *);
72
73#endif
74
75/** @}
76 */
Note: See TracBrowser for help on using the repository browser.