.\" Hey, EMACS: -*- nroff -*- .\" First parameter, NAME, should be all caps .\" Second parameter, SECTION, should be 1-8, maybe w/ subsection .\" other parameters are allowed: see man(7), man(1) .\" Please adjust this date whenever revising the manpage. .\" .\" Some roff macros, for reference: .\" .nh disable hyphenation .\" .hy enable hyphenation .\" .ad l left justify .\" .ad b justify to both left and right margins .\" .nf disable filling .\" .fi enable filling .\" .br insert line break .\" .sp insert n+1 empty lines .\" for manpage-specific macros, see man(7) .TH "GHDL" "1" "Jun 24, 2006" "" "" .SH "NAME" ghdl \- VHDL compiler/simulator .SH "SYNOPSIS" .B ghdl .RI [ command ] " " [ options ] " files" ... .br .SH "DESCRIPTION" This manual page documents briefly the .B ghdl command. This manual page was written for user of man, but is not as complete as the reference documentation. .PP Instead, users should read the GHDL texinfo manual .SH "OPTIONS" This program follows the usual GNU command line syntax, with long options starting with two dashes (`\-'). A summary of the main modes and options is included below. For a complete description, refer to the GHDL texinfo manual. .PP Basic commands: .TP .B \-a Analysis, i.e. \fIghdl \-a file.vhdl\fP .TP .B \-e Elabortation, i.e. \fIghdl \-e unit_name\fP .TP .B \-r Run: run the simulation, i.e. \fIghdl \-r unit_name\fP .TP .B \-s Syntax\-check, i.e. \fIghdl \-s file.vhdl\fP .TP .B \-\-clean Clean: remove generated files, i.e. \fIghdl \-\-clean\fP .TP .B \-h, \-\-help Help, i.e. \fIghdl \-\-help\fP .TP .B \-\-version Version, i.e. \fIghdl \-\-version\fP .PP Basic options: .TP .B \-\-work=NAME Name of the WORK library, i.e. \fI ghdl \-a \-\-work=foo foo.vhdl\fP .TP .B \-\-std=STD Which VHDL standard (87|93|93c|00|02), i.e. \fIghdl \-a \-\-std=87 old.vhdl\fP .TP .B \-\-ieee=VER Which IEEE library (none|standard|synopsys|mentor), i.e. \fIghdl \-a \-\-ieee=synopsys broken.vhdl\fP .TP .B \-\-no\-vital\-checks Disable VITAL restriction checking, i.e. \fIghdl \-a \-\-no\-vital\-checks unsupported_vital.vhdl\fP .PP There are many more modes and options; please consult the documentation. .PP Executables created by GHDL have addition simulation options. The most important ones are listed below: .TP .B \-\-help Show options for simulation and execution. .TP .B \-\-assert\-level=LEVEL Assert level at which to stop simulation (none|note|warning|error|failure), i.e. \fI./touchy_design \-\-assert\-level=note\fB .TP .B \-\-stop\-time=TIME Stop simuation after TIME, i.e. \fI./design \-\-stop\-time=50ns .TP .B \-\-vcd=FILENAME Dump VCD to FILENAME (a waveform dump, viewable with\-\-for instance\-\-\fBgtkwave\fP), i.e. \fI./design \-\-vcd=design.vcd .TP .B \-\-sdf=[TYPE=]PATH=FILENAME Back annotate SDF onto design using TYPE (min|typ|max), instance PATH, and SDF file FILENAME, i.e. \fI./sdf_design \-\-sdf=typ=top/inst=inst.sdf\fP .SH "SEE ALSO" .TP .B gtkwave (1) .PP .br The texinfo manual fully documents GHDL. You may also browse it at \fB\fP. .SH "AUTHOR" This manual page was written by Wesley J. Landaker , for the Debian project (but may be used by others). It is released under the same terms as GHDL, i.e. the GNU General Public License. It was modified by Tristan Gingold to include it in the GHDL sources. href='#n10'>10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92
/*
Copyright 2011,2012 Jun WAKO <wakojun@gmail.com>

This software is licensed with a Modified BSD License.
All of this is supposed to be Free Software, Open Source, DFSG-free,
GPL-compatible, and OK to use in both free and proprietary applications.
Additions and corrections to this file are welcome.


Redistribution and use in source and binary forms, with or without
modification, are permitted provided that the following conditions are met:

* Redistributions of source code must retain the above copyright
  notice, this list of conditions and the following disclaimer.

* Redistributions in binary form must reproduce the above copyright
  notice, this list of conditions and the following disclaimer in
  the documentation and/or other materials provided with the
  distribution.

* Neither the name of the copyright holders nor the names of
  contributors may be used to endorse or promote products derived
  from this software without specific prior written permission.

THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
POSSIBILITY OF SUCH DAMAGE.
*/

#ifndef M0110_H
#define M0110_H


/* port settings for clock and data line */
#if !(defined(M0110_CLOCK_PORT) && \
      defined(M0110_CLOCK_PIN) && \
      defined(M0110_CLOCK_DDR) && \
      defined(M0110_CLOCK_BIT))
#   error "M0110 clock port setting is required in config.h"
#endif

#if !(defined(M0110_DATA_PORT) && \
      defined(M0110_DATA_PIN) && \
      defined(M0110_DATA_DDR) && \
      defined(M0110_DATA_BIT))
#   error "M0110 data port setting is required in config.h"
#endif

/* Commands */
#define M0110_INQUIRY       0x10
#define M0110_INSTANT       0x14
#define M0110_MODEL         0x16
#define M0110_TEST          0x36

/* Response(raw byte from M0110) */
#define M0110_NULL          0x7B
#define M0110_KEYPAD        0x79
#define M0110_TEST_ACK      0x7D
#define M0110_TEST_NAK      0x77
#define M0110_SHIFT         0x71
#define M0110_ARROW_UP      0x1B
#define M0110_ARROW_DOWN    0x11
#define M0110_ARROW_LEFT    0x0D
#define M0110_ARROW_RIGHT   0x05

/* This inidcates no response. */
#define M0110_ERROR         0xFF

/* scan code offset for keypad and arrow keys */
#define M0110_KEYPAD_OFFSET 0x40
#define M0110_CALC_OFFSET   0x60


extern uint8_t m0110_error;

/* host role */
void m0110_init(void);
uint8_t m0110_send(uint8_t data);
uint8_t m0110_recv(void);
uint8_t m0110_recv_key(void);
uint8_t m0110_inquiry(void);
uint8_t m0110_instant(void);

#endif