-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathsramsw.c
113 lines (101 loc) · 3.23 KB
/
sramsw.c
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
/*! \file sramsw.c \brief Software-driven SRAM memory bus access functions. */
//*****************************************************************************
//
// File Name : 'sramsw.c'
// Title : Software-driven SRAM memory bus access functions
// Author : Pascal Stang - Copyright (C) 2002
// Created : 11/11/2002
// Revised : 11/13/2002
// Version : 1.0
// Target MCU : Atmel AVR series
// Editor Tabs : 4
//
// This code is distributed under the GNU Public License
// which can be found at http://www.gnu.org/licenses/gpl.txt
//
//*****************************************************************************
#include <avr/io.h>
#include <avr/interrupt.h>
#include "global.h"
#include "sramsw.h"
// global variables
// functions
void sramswInit(void)
{
// initialize port state
outb(SRAM_ADL, 0xFF); // addr/data port set to 0xFF (pull-ups enabled)
outb(SRAM_AH, 0x00); // high addr port set to 0x00
// initialize port directions
outb(SRAM_ADL_DDR, 0x00); // addr/data port set to input
outb(SRAM_AH_DDR, 0xFF); // high addr port set to output
// initialize control line states
sbi(SRAM_CTRL, SRAM_WR); // de-assert write (active low)
sbi(SRAM_CTRL, SRAM_RD); // de-assert read (active low)
cbi(SRAM_CTRL, SRAM_ALE); // de-assert ALE (active high)
// set control line direction
sbi(SRAM_CTRL_DDR, SRAM_WR);
sbi(SRAM_CTRL_DDR, SRAM_RD);
sbi(SRAM_CTRL_DDR, SRAM_ALE);
// set page lines direction
outb(SRAM_PAGE_DDR, inb(SRAM_PAGE_DDR) | SRAM_PAGE_MASK );
// initialize page
sramswSetPage(0);
}
void sramswOff(void)
{
}
void sramswWrite(u32 addr, u08 data)
{
// set page
sramswSetPage( (addr & 0x00FF0000)>>16 );
// set high-order address
outb(SRAM_AH, (addr & 0x0000FF00)>>8 );
// set low-order address
outb(SRAM_ADL, addr & 0x000000FF);
// apply low-order address to latch
outb(SRAM_ADL_DDR, 0xFF);
// clock latch to save low-order address
sbi(SRAM_CTRL, SRAM_ALE); // assert ALE (active high)
asm volatile ("nop");
cbi(SRAM_CTRL, SRAM_ALE); // de-assert ALE (active high)
// apply data to memory
outb(SRAM_ADL, data);
// clock write line to store data
cbi(SRAM_CTRL, SRAM_WR); // assert write (active low)
asm volatile ("nop");
sbi(SRAM_CTRL, SRAM_WR); // de-assert write (active low)
}
u08 sramswRead(u32 addr)
{
u08 data;
// set page
sramswSetPage( (addr & 0x00FF0000)>>16 );
// set high-order address
outb(SRAM_AH, (addr & 0x0000FF00)>>8 );
// set low-order address
outb(SRAM_ADL, addr & 0x000000FF);
// apply low-order address to latch
outb(SRAM_ADL_DDR, 0xFF);
// clock latch to save low-order address
sbi(SRAM_CTRL, SRAM_ALE); // assert ALE (active high)
asm volatile ("nop");
cbi(SRAM_CTRL, SRAM_ALE); // de-assert ALE (active high)
// switch data bus to input
outb(SRAM_ADL_DDR, 0x00);
// clear pullups
outb(SRAM_ADL, 0x00);
// request data from memory
cbi(SRAM_CTRL, SRAM_RD); // assert read (active low)
// retrieve data
asm volatile ("nop");
data = inb(SRAM_ADL_IN);
// release read line
sbi(SRAM_CTRL, SRAM_RD); // de-assert read (active low)
// switch data bus to output
outb(SRAM_ADL_DDR, 0xFF);
return data;
}
void sramswSetPage(u08 page)
{
outb(SRAM_PAGE, (page & SRAM_PAGE_MASK));
}