source: rtems/c/src/lib/libbsp/arm/edb7312/network/network.c @ c193baad

4.104.115
Last change on this file since c193baad was c193baad, checked in by Thomas Doerfler <Thomas.Doerfler@…>, on 04/09/10 at 20:24:57

unify irq data types and code, merge s3c2400/s3c2410 support

  • Property mode set to 100644
File size: 2.9 KB
Line 
1#include <rtems.h>
2#include <sys/mbuf.h>
3#include <irq.h>
4#include <libchip/cs8900.h>
5
6#define CS8900_BASE 0x20000300
7unsigned int bsp_cs8900_io_base = 0;
8unsigned int bsp_cs8900_memory_base = 0;
9cs8900_device *g_cs;
10void cs8900_isr(rtems_irq_hdl_param unused);
11rtems_irq_connect_data cs8900_isr_data = {BSP_EINT3,
12                                          cs8900_isr,
13                                          NULL,
14                                          NULL,
15                                          NULL,
16                                          NULL};
17
18char g_enetbuf[1520];
19
20void cs8900_isr(rtems_irq_hdl_param unused)
21{
22    cs8900_interrupt(BSP_EINT3, g_cs);
23}
24
25/* cs8900_io_set_reg - set one of the I/O addressed registers */
26void cs8900_io_set_reg (cs8900_device *cs, unsigned short reg, unsigned short data)
27{
28    /* works the same for all values of dev */
29/*
30    printf("cs8900_io_set_reg: reg: %#6x, val %#6x\n",
31           CS8900_BASE + reg,
32           data);
33*/
34   *(unsigned short *)(CS8900_BASE + reg) = data;
35}
36
37/* cs8900_io_get_reg - reads one of the I/O addressed registers */
38unsigned short cs8900_io_get_reg (cs8900_device *cs, unsigned short reg)
39{
40    unsigned short val;
41    /* works the same for all values of dev */
42    val = *(unsigned short *)(CS8900_BASE + reg);
43/*
44    printf("cs8900_io_get_reg: reg: %#6x, val %#6x\n", reg, val);
45*/
46    return val;
47}
48
49/* cs8900_mem_set_reg - sets one of the registers mapped through
50 *                      PacketPage
51 */
52void cs8900_mem_set_reg (cs8900_device *cs, unsigned long reg, unsigned short data)
53{
54    /* works the same for all values of dev */
55    cs8900_io_set_reg(cs, CS8900_IO_PACKET_PAGE_PTR, reg);
56    cs8900_io_set_reg(cs, CS8900_IO_PP_DATA_PORT0, data);
57}
58
59/* cs8900_mem_get_reg - reads one of the registers mapped through
60 *                      PacketPage
61 */
62unsigned short cs8900_mem_get_reg (cs8900_device *cs, unsigned long reg)
63{
64    /* works the same for all values of dev */
65    cs8900_io_set_reg(cs, CS8900_IO_PACKET_PAGE_PTR, reg);
66    return cs8900_io_get_reg(cs, CS8900_IO_PP_DATA_PORT0);
67}
68
69void cs8900_attach_interrupt (cs8900_device *cs)
70{
71    g_cs = cs;
72    BSP_install_rtems_irq_handler(&cs8900_isr_data);
73}
74
75void cs8900_detach_interrupt (cs8900_device *cs)
76{
77    BSP_remove_rtems_irq_handler(&cs8900_isr_data);
78}
79
80unsigned short cs8900_get_data_block (cs8900_device *cs, unsigned char *data)
81{
82    int len;
83    int i;
84
85    len = cs8900_mem_get_reg(cs, CS8900_PP_RxLength);
86
87    for (i = 0; i < ((len + 1) / 2); i++) {
88        ((short *)data)[i] = cs8900_io_get_reg(cs,
89                                               CS8900_IO_RX_TX_DATA_PORT0);
90    }
91    return len;
92}
93
94void cs8900_tx_load (cs8900_device *cs, struct mbuf *m)
95{
96    int len;
97    unsigned short *data;
98    int i;
99
100    len = 0;
101
102    do {
103        memcpy(&g_enetbuf[len], mtod(m, const void *), m->m_len);
104        len += m->m_len;
105        m = m->m_next;
106    } while (m != 0);
107
108    data = (unsigned short *) &g_enetbuf[0];
109    for (i = 0; i < ((len + 1) / 2); i++) {
110        cs8900_io_set_reg(cs,
111                          CS8900_IO_RX_TX_DATA_PORT0,
112                          data[i]);
113    }
114}
Note: See TracBrowser for help on using the repository browser.