File: chip_gen_74612.c

package info (click to toggle)
faumachine 20100527-2
  • links: PTS
  • area: main
  • in suites: squeeze
  • size: 53,836 kB
  • ctags: 20,552
  • sloc: ansic: 179,550; asm: 3,645; makefile: 3,611; perl: 2,103; sh: 1,529; python: 600; xml: 563; lex: 210; vhdl: 204
file content (123 lines) | stat: -rw-r--r-- 2,390 bytes parent folder | download | duplicates (2)
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
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
/*
 * $Id: chip_gen_74612.c,v 1.19 2009-06-03 11:34:03 vrsieh Exp $
 *
 * Copyright (C) 2003-2009 FAUmachine Team <info@faumachine.org>.
 * This program is free software. You can redistribute it and/or modify it
 * under the terms of the GNU General Public License, either version 2 of
 * the License, or (at your option) any later version. See COPYING.
 */

#include <assert.h>
#include <stdio.h>
#include <stdlib.h>

#include "fixme.h"

#include "chip_gen_74612.h"

struct cpssp {
	/*
	 * Config
	 */

	/*
	 * Signals
	 */
	unsigned int state_power;
	struct sig_cs *port_cs;
	struct sig_integer *port_ma;
	struct sig_integer *port_md;

	/*
	 * State
	 */
	uint8_t page[16];
};

static void
chip_gen_74612_power_set(void *_css, unsigned int val)
{
	struct cpssp *cpssp = (struct cpssp *) _css;

	cpssp->state_power = val;
}

static int
chip_gen_74612_inb(void *_css, uint8_t *valp, unsigned long port)
{
	struct cpssp *cpssp = (struct cpssp *) _css;	
	
	*valp = cpssp->page[port & 0xf];

	return 0;
}

static int
chip_gen_74612_outb(void *_css, uint8_t value, unsigned long port)
{
	struct cpssp *cpssp = (struct cpssp *) _css;	
	
	cpssp->page[port & 0xf] = value;

	return 0;
}

static void
chip_gen_74612_ma_set(void *_css, int val)
{
	struct cpssp *cpssp = (struct cpssp *) _css;	
	
	sig_integer_set(cpssp->port_md, cpssp, cpssp->page[val & 0xf]);
}

void *
chip_gen_74612_create(
	const char *name,
	struct sig_manage *port_manage,
	struct sig_boolean *port_power,
	struct sig_cs *port_cs,
	struct sig_isa_bus_main *port_bus,
	struct sig_integer *port_ma,
	struct sig_integer *port_md
)
{
	static const struct sig_boolean_funcs power_funcs = {
		.set = chip_gen_74612_power_set,
	};
	static const struct sig_cs_funcs cs_funcs = {
		.readb = chip_gen_74612_inb,
		.writeb = chip_gen_74612_outb,
	};
	static const struct sig_integer_funcs ma_funcs = {
		.set = chip_gen_74612_ma_set,
	};
	struct cpssp *cpssp;

	cpssp = malloc(sizeof(*cpssp));
	assert(cpssp);

	cpssp->port_md = port_md;

	/* Out */
	sig_integer_connect_out(port_md, cpssp, 0);

	/* Call */
	cpssp->port_cs = port_cs;
	sig_cs_connect(port_cs, cpssp, &cs_funcs);

	/* In */
	cpssp->state_power = 0;
	sig_boolean_connect_in(port_power, cpssp, &power_funcs);

	sig_integer_connect_in(port_ma, cpssp, &ma_funcs);

	return cpssp;
}

void
chip_gen_74612_destroy(void *_cpssp)
{
	struct cpssp *cpssp = _cpssp;

	free(cpssp);
}