2
* Copyright (c) 2008 Pavel Rimsky
5
* Redistribution and use in source and binary forms, with or without
6
* modification, are permitted provided that the following conditions
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.
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.
29
/** @addtogroup sparc64
35
#ifndef KERN_sparc64_SGCN_H_
36
#define KERN_sparc64_SGCN_H_
38
#include <arch/types.h>
39
#include <console/chardev.h>
40
#include <proc/thread.h>
42
/* number of bytes in the TOC magic, including the NULL-terminator */
43
#define TOC_MAGIC_BYTES 8
45
/* number of bytes in the TOC key, including the NULL-terminator */
46
#define TOC_KEY_SIZE 8
48
/* maximum number of entries in the SRAM table of contents */
49
#define MAX_TOC_ENTRIES 32
51
/* number of bytes in the SGCN buffer magic, including the NULL-terminator */
52
#define SGCN_MAGIC_BYTES 4
55
* Entry in the SRAM table of contents. Describes one segment of the SRAM
56
* which serves a particular purpose (e.g. OBP serial console, Solaris serial
57
* console, Solaris mailbox,...).
60
/** key (e.g. "OBPCONS", "SOLCONS", "SOLMBOX",...) */
61
char key[TOC_KEY_SIZE];
63
/** size of the segment in bytes */
66
/** offset of the segment within SRAM */
68
} __attribute ((packed)) toc_entry_t;
71
* SRAM table of contents. Describes all segments within the SRAM.
74
/** hard-wired to "TOCSRAM" */
75
char magic[TOC_MAGIC_BYTES];
77
/** we don't need this */
81
toc_entry_t keys[MAX_TOC_ENTRIES];
82
} __attribute__ ((packed)) iosram_toc_t;
85
* SGCN buffer header. It is placed at the very beginning of the SGCN
89
/** hard-wired to "CON" */
90
char magic[SGCN_MAGIC_BYTES];
92
/** we don't need this */
95
/** offset within the SGCN buffer of the input buffer start */
98
/** offset within the SGCN buffer of the input buffer end */
101
/** offset within the SGCN buffer of the input buffer read pointer */
104
/** offset within the SGCN buffer of the input buffer write pointer */
107
/** offset within the SGCN buffer of the output buffer start */
110
/** offset within the SGCN buffer of the output buffer end */
113
/** offset within the SGCN buffer of the output buffer read pointer */
116
/** offset within the SGCN buffer of the output buffer write pointer */
118
} __attribute__ ((packed)) sgcn_buffer_header_t;
125
extern void sgcn_grab(void);
126
extern void sgcn_release(void);
127
extern sgcn_instance_t *sgcnin_init(void);
128
extern void sgcnin_wire(sgcn_instance_t *, indev_t *);
129
extern void sgcnout_init(void);