2007-12-29 02:05:26 +01:00
|
|
|
/****************************************************************************
|
2019-06-10 03:08:42 +02:00
|
|
|
* arch/z80/src/common/z80_internal.h
|
2007-12-29 02:05:26 +01:00
|
|
|
*
|
2020-03-10 19:14:43 +01:00
|
|
|
* Licensed to the Apache Software Foundation (ASF) under one or more
|
|
|
|
* contributor license agreements. See the NOTICE file distributed with
|
|
|
|
* this work for additional information regarding copyright ownership. The
|
|
|
|
* ASF licenses this file to you under the Apache License, Version 2.0 (the
|
|
|
|
* "License"); you may not use this file except in compliance with the
|
|
|
|
* License. You may obtain a copy of the License at
|
2007-12-29 02:05:26 +01:00
|
|
|
*
|
2020-03-10 19:14:43 +01:00
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
2007-12-29 02:05:26 +01:00
|
|
|
*
|
2020-03-10 19:14:43 +01:00
|
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
|
|
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
|
|
|
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
|
|
|
* License for the specific language governing permissions and limitations
|
|
|
|
* under the License.
|
2007-12-29 02:05:26 +01:00
|
|
|
*
|
|
|
|
****************************************************************************/
|
|
|
|
|
2019-06-10 03:08:42 +02:00
|
|
|
#ifndef __ARCH_Z80_SRC_COMMON_Z80_INTERNAL_H
|
|
|
|
#define __ARCH_Z80_SRC_COMMON_Z80_INTERNAL_H
|
2007-12-29 02:05:26 +01:00
|
|
|
|
2008-02-14 18:24:14 +01:00
|
|
|
/****************************************************************************
|
|
|
|
* Included Files
|
|
|
|
****************************************************************************/
|
2007-12-29 02:05:26 +01:00
|
|
|
|
2009-12-16 15:15:34 +01:00
|
|
|
#include <stdint.h>
|
|
|
|
#include <stdbool.h>
|
|
|
|
|
2008-02-14 18:24:14 +01:00
|
|
|
#include <arch/irq.h>
|
2017-10-01 15:43:59 +02:00
|
|
|
#include "chip.h"
|
|
|
|
#include "switch.h"
|
2007-12-29 02:05:26 +01:00
|
|
|
|
|
|
|
/****************************************************************************
|
2014-07-29 15:17:01 +02:00
|
|
|
* Pre-processor Definitions
|
2007-12-29 02:05:26 +01:00
|
|
|
****************************************************************************/
|
|
|
|
|
2013-01-28 16:03:17 +01:00
|
|
|
/* Determine which (if any) console driver to use. If a console is enabled
|
|
|
|
* and no other console device is specified, then a serial console is
|
|
|
|
* assumed.
|
|
|
|
*/
|
2008-02-18 17:27:25 +01:00
|
|
|
|
2020-02-18 02:55:04 +01:00
|
|
|
#if !defined(CONFIG_DEV_CONSOLE)
|
2013-01-28 16:03:17 +01:00
|
|
|
# undef USE_SERIALDRIVER
|
|
|
|
#else
|
2020-02-17 19:10:15 +01:00
|
|
|
# if defined(CONFIG_CONSOLE_SYSLOG)
|
2015-02-08 13:53:24 +01:00
|
|
|
# undef USE_SERIALDRIVER
|
2013-01-28 16:03:17 +01:00
|
|
|
# else
|
|
|
|
# define USE_SERIALDRIVER 1
|
|
|
|
# endif
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/* If some other device is used as the console, then the serial driver may
|
|
|
|
* still be needed. Let's assume that if the upper half serial driver is
|
|
|
|
* built, then the lower half will also be needed. There is no need for
|
|
|
|
* the early serial initialization in this case.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#if !defined(USE_SERIALDRIVER) && defined(CONFIG_STANDARD_SERIAL)
|
2012-02-11 04:50:52 +01:00
|
|
|
# define USE_SERIALDRIVER 1
|
2008-02-18 17:27:25 +01:00
|
|
|
#endif
|
|
|
|
|
2008-02-14 18:24:14 +01:00
|
|
|
/****************************************************************************
|
2019-06-09 06:01:53 +02:00
|
|
|
* Public Function Prototypes
|
2007-12-29 02:05:26 +01:00
|
|
|
****************************************************************************/
|
|
|
|
|
|
|
|
#ifndef __ASSEMBLY__
|
2008-02-14 18:24:14 +01:00
|
|
|
#ifdef __cplusplus
|
2012-12-23 18:32:41 +01:00
|
|
|
extern "C"
|
|
|
|
{
|
2008-02-14 18:24:14 +01:00
|
|
|
#endif
|
2007-12-29 02:05:26 +01:00
|
|
|
|
2019-06-09 06:01:53 +02:00
|
|
|
/* Defined in xyz_doirq.c */
|
2007-12-29 02:05:26 +01:00
|
|
|
|
2019-06-09 06:01:53 +02:00
|
|
|
FAR chipreg_t *z80_doirq(uint8_t irq, FAR chipreg_t *regs);
|
2007-12-29 02:05:26 +01:00
|
|
|
|
2017-02-07 17:35:04 +01:00
|
|
|
/* Define in zyz_sigdeliver */
|
2007-12-29 02:05:26 +01:00
|
|
|
|
2019-06-09 06:01:53 +02:00
|
|
|
void z80_sigdeliver(void);
|
2007-12-29 02:05:26 +01:00
|
|
|
|
2019-06-08 19:36:55 +02:00
|
|
|
#ifdef CONFIG_ARCH_ADDRENV
|
2012-12-11 22:42:15 +01:00
|
|
|
/* Defined in CPU-specific logic (only for Z180) */
|
|
|
|
|
2019-06-09 06:01:53 +02:00
|
|
|
int z80_mmu_initialize(void);
|
2007-12-29 02:05:26 +01:00
|
|
|
#endif
|
|
|
|
|
2017-02-07 17:35:04 +01:00
|
|
|
/* Defined in xyz_serial.c */
|
2007-12-29 02:05:26 +01:00
|
|
|
|
2012-02-11 04:50:52 +01:00
|
|
|
#ifdef USE_SERIALDRIVER
|
2019-06-09 06:01:53 +02:00
|
|
|
void z80_serial_initialize(void);
|
2007-12-29 02:05:26 +01:00
|
|
|
#else
|
2020-03-10 19:14:43 +01:00
|
|
|
# define z80_serial_initialize()
|
2007-12-29 02:05:26 +01:00
|
|
|
#endif
|
|
|
|
|
2019-11-04 15:11:50 +01:00
|
|
|
#ifdef CONFIG_RPMSG_UART
|
|
|
|
void rpmsg_serialinit(void);
|
|
|
|
#else
|
|
|
|
# define rpmsg_serialinit()
|
|
|
|
#endif
|
|
|
|
|
2009-02-28 15:22:57 +01:00
|
|
|
/* Low level string output */
|
|
|
|
|
2015-06-13 03:17:42 +02:00
|
|
|
void up_puts(const char *str);
|
2009-02-28 15:22:57 +01:00
|
|
|
|
2008-12-08 19:44:43 +01:00
|
|
|
/* Architecture specific hook into the timer interrupt handler */
|
|
|
|
|
|
|
|
#ifdef CONFIG_ARCH_TIMERHOOK
|
2012-12-23 18:32:41 +01:00
|
|
|
void up_timerhook(void);
|
2008-12-08 19:44:43 +01:00
|
|
|
#endif
|
|
|
|
|
2007-12-29 02:05:26 +01:00
|
|
|
/* Defined in board/up_network.c */
|
|
|
|
|
2018-08-24 22:50:45 +02:00
|
|
|
#if defined(CONFIG_NET) && !defined(CONFIG_NETDEV_LATEINIT)
|
2012-12-23 18:32:41 +01:00
|
|
|
int up_netinitialize(void);
|
|
|
|
void up_netuninitialize(void);
|
2008-12-12 17:57:52 +01:00
|
|
|
# ifdef CONFIG_ARCH_MCFILTER
|
2020-03-10 19:14:43 +01:00
|
|
|
int up_multicastfilter(FAR struct net_driver_s *dev, FAR uint8_t *mac,
|
|
|
|
bool enable);
|
2008-12-12 17:57:52 +01:00
|
|
|
# else
|
|
|
|
# define up_multicastfilter(dev, mac, enable)
|
|
|
|
# endif
|
2007-12-29 02:05:26 +01:00
|
|
|
#else
|
|
|
|
# define up_netinitialize()
|
2008-12-12 17:57:52 +01:00
|
|
|
# define up_netuninitialize()
|
|
|
|
# define up_multicastfilter(dev, mac, enable)
|
2007-12-29 02:05:26 +01:00
|
|
|
#endif
|
|
|
|
|
|
|
|
/* Return the current value of the stack pointer (used in stack dump logic) */
|
|
|
|
|
2019-06-17 20:25:43 +02:00
|
|
|
uintptr_t z80_getsp(void);
|
2007-12-29 02:05:26 +01:00
|
|
|
|
|
|
|
/* Dump stack and registers */
|
|
|
|
|
|
|
|
#ifdef CONFIG_ARCH_STACKDUMP
|
2012-12-23 18:32:41 +01:00
|
|
|
void up_stackdump(void);
|
2008-02-14 18:24:14 +01:00
|
|
|
# define REGISTER_DUMP() _REGISTER_DUMP()
|
2007-12-29 02:05:26 +01:00
|
|
|
#else
|
|
|
|
# define up_stackdump()
|
2008-02-14 18:24:14 +01:00
|
|
|
# define REGISTER_DUMP()
|
2007-12-29 02:05:26 +01:00
|
|
|
#endif
|
|
|
|
|
2008-02-14 18:24:14 +01:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
#endif
|
2007-12-29 02:05:26 +01:00
|
|
|
|
2020-01-31 19:07:39 +01:00
|
|
|
#endif /* __ARCH_Z80_SRC_COMMON_Z80_INTERNAL_H */
|