summaryrefslogtreecommitdiffstats
path: root/bsps/arm/csb337/include/bsp.h
blob: c757bf1bc98dbb3b992d658114e5b71144df1d6a (plain) (blame)
1
2
3
4
5
6
7
8
9
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
/**
 * @file
 *
 * @ingroup arm_csb337
 *
 * @brief Global BSP definitions.
 */

/*
 * CSB337 BSP header file
 *
 * Copyright (c) 2004 by Cogent Computer Systems
 * Writtent by Jay Monkman <jtm@lopingdog.com>
 *
 *  The license and distribution terms for this file may be
 *  found in the file LICENSE in this distribution or at
 *  http://www.rtems.org/license/LICENSE.
 */
#ifndef LIBBSP_ARM_CSB337_BSP_H
#define LIBBSP_ARM_CSB337_BSP_H

#include <bspopts.h>
#include <bsp/default-initial-extension.h>

#include <rtems.h>

#ifdef __cplusplus
extern "C" {
#endif

/**
 * @defgroup arm_csb337 CSB337 Support
 *
 * @ingroup RTEMSBSPsARM
 *
 * @brief CSB337 support package.
 *
 * @{
 */

#define BSP_FEATURE_IRQ_EXTENSION

/* What is the input clock freq in hertz? */
#define BSP_MAIN_FREQ 3686400      /* 3.6864 MHz */
#define BSP_SLCK_FREQ   32768      /* 32.768 KHz */

/* What is the last interrupt? */
#define BSP_MAX_INT AT91RM9200_MAX_INT

/*
 * forward reference the type to avoid conflicts between libchip serial
 * and libchip rtc get and set register types.
 */
typedef struct _console_tbl console_tbl;
console_tbl *BSP_get_uart_from_minor(int minor);

static inline int32_t BSP_get_baud(void) {return 38400;}

#define ST_PIMR_PIV	33	/* 33 ticks of the 32.768Khz clock ~= 1msec */

/**
 * @brief Network driver configuration
 */
extern struct rtems_bsdnet_ifconfig *config;

/* Change these to match your board */
int rtems_at91rm9200_emac_attach(struct rtems_bsdnet_ifconfig *config, int attaching);
#define RTEMS_BSP_NETWORK_DRIVER_NAME	"eth0"
#define RTEMS_BSP_NETWORK_DRIVER_ATTACH	rtems_at91rm9200_emac_attach

/** @} */

#ifdef __cplusplus
}
#endif

#endif /* _BSP_H */