The Pedigree Project  0.1
kernel/machine/au1500/Serial.h
1 /*
2  * Copyright (c) 2008-2014, Pedigree Developers
3  *
4  * Please see the CONTRIB file in the root of the source tree for a full
5  * list of contributors.
6  *
7  * Permission to use, copy, modify, and distribute this software for any
8  * purpose with or without fee is hereby granted, provided that the above
9  * copyright notice and this permission notice appear in all copies.
10  *
11  * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
12  * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
13  * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
14  * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
15  * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
16  * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
17  * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
18  */
19 
20 #ifndef MACHINE_AU1500_SERIAL_H
21 #define MACHINE_AU1500_SERIAL_H
22 
23 #include "pedigree/kernel/machine/Serial.h"
24 
43 class Au1500Serial : public Serial
44 {
45  public:
46  Au1500Serial();
47  virtual ~Au1500Serial();
48 
49  virtual void setBase(uintptr_t nBaseAddr);
50  virtual char read();
51  virtual char readNonBlock();
52  virtual void write(char c);
53 
54  struct serial
55  {
56  uint32_t rxdata;
57  uint32_t txdata;
58  uint32_t inten;
59  uint32_t intcause;
60  uint32_t fifoctrl;
61  uint32_t linectrl;
62  uint32_t mdmstat;
63  uint32_t autoflow;
64  uint32_t clkdiv;
65  uint32_t enable;
66  } PACKED;
67 
71  volatile serial *m_pRegs;
72 };
73 
74 #endif
volatile serial * m_pRegs
virtual void setBase(uintptr_t nBaseAddr)