ugBASIC 1.18
An isomorphic BASIC language compiler for retrocomputers
Loading...
Searching...
No Matches
bank_write.c
Go to the documentation of this file.
1/*****************************************************************************
2 * ugBASIC - an isomorphic BASIC language compiler for retrocomputers *
3 *****************************************************************************
4 * Copyright 2021-2026 Marco Spedaletti (asimov@mclink.it)
5 *
6 * Licensed under the Apache License, Version 2.0 (the "License");
7 * you may not use this file except in compliance with the License.
8 * You may obtain a copy of the License at
9 *
10 * http://www.apache.org/licenses/LICENSE-2.0
11 *
12 * Unless required by applicable law or agreed to in writing, software
13 * distributed under the License is distributed on an "AS IS" BASIS,
14 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15 * See the License for the specific language governing permissions and
16 * limitations under the License.
17 *----------------------------------------------------------------------------
18 * Concesso in licenza secondo i termini della Licenza Apache, versione 2.0
19 * (la "Licenza"); è proibito usare questo file se non in conformità alla
20 * Licenza. Una copia della Licenza è disponibile all'indirizzo:
21 *
22 * http://www.apache.org/licenses/LICENSE-2.0
23 *
24 * Se non richiesto dalla legislazione vigente o concordato per iscritto,
25 * il software distribuito nei termini della Licenza è distribuito
26 * "COSÌ COM'È", SENZA GARANZIE O CONDIZIONI DI ALCUN TIPO, esplicite o
27 * implicite. Consultare la Licenza per il testo specifico che regola le
28 * autorizzazioni e le limitazioni previste dalla medesima.
29 ****************************************************************************/
30
31/****************************************************************************
32 * INCLUDE SECTION
33 ****************************************************************************/
34
35#include "../../ugbc.h"
36
49void bank_write_vars( Environment * _environment, char * _address1, char * _bank, char * _address2, char * _size ) {
50
51 deploy_preferred( duff, src_hw_6809_duff_asm );
52 deploy_preferred( msc1, src_hw_6809_msc1_asm );
53 deploy_preferred( bank, src_hw_mo5_bank_asm );
54
55 Variable * bank = variable_retrieve_or_define( _environment, _bank, VT_WORD, 0 );
56 Variable * bankAddress = bank_get_address_var( _environment, _bank );
57 Variable * address1 = variable_retrieve_or_define( _environment, _address1, VT_ADDRESS, 0 );
58 Variable * address2 = variable_retrieve_or_define( _environment, _address2, VT_ADDRESS, 0 );
59 Variable * realAddress = variable_add( _environment, bankAddress->name, address2->name );
60 Variable * size = variable_retrieve_or_define( _environment, _size, VT_WORD, 0 );
61
62 outline0("; bank write rv")
63 outline1("LDY %s", address1->realName );
64 outline1("LDD %s", size->realName );
65 outline1("LDU %s", bank->realName );
66 outline1("LDX %s", realAddress->realName );
67 outline0("JSR BANKWRITE");
68 outline0("; end bank write");
69
70}
71
72void bank_write_semi_var( Environment * _environment, char * _address2, int _bank, int _address1, int _size ) {
73
74 deploy_preferred( duff, src_hw_6809_duff_asm );
75 deploy_preferred( msc1, src_hw_6809_msc1_asm );
76 deploy_preferred( bank, src_hw_mo5_bank_asm );
77
78 int realAddress = 0x6000 + _address1;
79
80 outline0("; bank read sv")
81 outline1("LDU #$%4.4x", _bank );
82 outline1("LDY #%s", _address2 );
83 outline1("LDX #$%4.4x", realAddress );
84
85 switch( _size ) {
86 case 1:
87 outline0("JSR BANKWRITE1");
88 _environment->bankAccessOptimization.write1 = 1;
89 break;
90 case 2:
91 outline0("JSR BANKWRITE2");
92 _environment->bankAccessOptimization.write2 = 1;
93 break;
94 case 4:
95 outline0("JSR BANKWRITE4");
96 _environment->bankAccessOptimization.write4 = 1;
97 break;
98 default:
99 outline1("LDD #$%4.4x", _size );
100 outline0("JSR BANKWRITE");
101 _environment->bankAccessOptimization.writen = 1;
102 break;
103
104 }
105 outline0("; end bank read");
106
107}
108
109void bank_write_vars_direct( Environment * _environment, char * _address1, char * _bank, char * _address2, char * _size ) {
110
111 deploy_preferred( duff, src_hw_6809_duff_asm );
112 deploy_preferred( msc1, src_hw_6809_msc1_asm );
113 deploy_preferred( bank, src_hw_mo5_bank_asm );
114
115 Variable * bank = variable_retrieve_or_define( _environment, _bank, VT_WORD, 0 );
116 Variable * bankAddress = bank_get_address_var( _environment, _bank );
117 Variable * address2 = variable_retrieve_or_define( _environment, _address2, VT_ADDRESS, 0 );
118 Variable * realAddress = variable_add( _environment, bankAddress->name, address2->name );
119 Variable * size = variable_retrieve_or_define( _environment, _size, VT_WORD, 0 );
120
121 outline0("; bank write rv")
122 outline1("LDY #%s", _address1 );
123 outline1("LDD %s", size->realName );
124 outline1("LDU %s", bank->realName );
125 outline1("LDX %s", realAddress->realName );
126 outline0("JSR BANKWRITE");
127 outline0("; end bank write");
128
129}
130
131void bank_write_vars_bank_direct_size( Environment * _environment, char * _address1, int _bank, char * _address2, int _size ) {
132
133 deploy_preferred( duff, src_hw_6809_duff_asm );
134 deploy_preferred( msc1, src_hw_6809_msc1_asm );
135 deploy_preferred( bank, src_hw_mo5_bank_asm );
136
137 Variable * address1 = variable_retrieve( _environment, _address1 );
138 Variable * address2 = variable_retrieve_or_define( _environment, _address2, VT_ADDRESS, 0 );
139 Variable * bankAddress = bank_get_address( _environment, _bank );
140 Variable * realAddress = variable_add( _environment, bankAddress->name, address2->name );
141
142 outline0("; bank write rv")
143 outline1("LDY #%s", address1->realName );
144 outline1("LDU #$%4.4x", _bank );
145 outline1("LDX %s", realAddress->realName );
146
147 switch( _size ) {
148 case 1:
149 outline0("JSR BANKWRITE1");
150 _environment->bankAccessOptimization.write1 = 1;
151 break;
152 case 2:
153 outline0("JSR BANKWRITE2");
154 _environment->bankAccessOptimization.write2 = 1;
155 break;
156 case 4:
157 outline0("JSR BANKWRITE4");
158 _environment->bankAccessOptimization.write4 = 1;
159 break;
160 default:
161 outline1("LDD #$%4.4x", _size );
162 outline0("JSR BANKWRITE");
163 _environment->bankAccessOptimization.writen = 1;
164 break;
165
166 }
167 outline0("; end bank write");
168
169}
170
Variable * variable_add(Environment *_environment, char *_source, char *_destination)
Add two variable and return the sum of them.
Variable * variable_retrieve(Environment *_environment, char *_name)
Variable * variable_retrieve_or_define(Environment *_environment, char *_name, VariableType _type, int _value)
int size
Definition _optimizer.c:678
Variable * bank_get_address_var(Environment *_environment, char *_bank)
Emit ASM code for instruction = BANK ADDRESS( ).
Variable * bank_get_address(Environment *_environment, int _bank)
Emit ASM code for instruction = BANK ADDRESS( ).
void bank_write_vars_direct(Environment *_environment, char *_address1, char *_bank, char *_address2, char *_size)
Definition bank_write.c:80
void bank_write_vars_bank_direct_size(Environment *_environment, char *_address1, int _bank, char *_address2, int _size)
Definition bank_write.c:111
void bank_write_vars(Environment *_environment, char *_address1, char *_bank, char *_address2, char *_size)
Emit ASM code for instruction BANK WRITE ....
Definition bank_write.c:49
void bank_write_semi_var(Environment *_environment, char *_address2, int _bank, int _address1, int _size)
Definition bank_write.c:127
BankAccessOptimization bankAccessOptimization
Definition ugbc.h:3269
char * name
Definition ugbc.h:979
char * realName
Definition ugbc.h:982
struct _Variable Variable
Structure of a single variable.
struct _Environment Environment
Structure of compilation environment.
@ VT_WORD
Definition ugbc.h:455
@ VT_ADDRESS
Definition ugbc.h:465
#define deploy_preferred(s, e)
Definition ugbc.h:4299
#define outline0(s)
Definition ugbc.h:4252
#define outline1(s, a)
Definition ugbc.h:4253