ugBASIC 1.18
An isomorphic BASIC language compiler for retrocomputers
Loading...
Searching...
No Matches
serial_write_type.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
37/****************************************************************************
38 * CODE SECTION
39 ****************************************************************************/
40
41extern char DATATYPE_AS_STRING[][16];
42
48
49/* <usermanual>
50@keyword SERIAL WRITE
51
52@target cocob
53
54</usermanual> */
55
56Variable * serial_write_type( Environment * _environment, char * _data, VariableType _type, int _big_endian ) {
57
58
59 Variable * orig;
60 if ( _type == 0 ) {
61 orig = variable_retrieve( _environment, _data );
62 } else {
63 orig = variable_retrieve_or_define( _environment, _data, _type, 0 );
64 }
65
66 Variable * data = NULL;
67
68 if ( !_big_endian ) {
69 switch( VT_BITWIDTH( orig->type ) ) {
70 case 32:
71 data = variable_temporary( _environment, orig->type, "(data)");
72 variable_move( _environment, orig->name, data->name );
73 cpu_swap_8bit( _environment, data->realName, address_displacement( _environment, data->realName, "3" ) );
74 cpu_swap_8bit( _environment, address_displacement( _environment, data->realName, "1" ), address_displacement( _environment, data->realName, "2" ) );
75 break;
76 case 16:
77 data = variable_temporary( _environment, orig->type, "(data)");
78 variable_move( _environment, orig->name, data->name );
79 cpu_swap_8bit( _environment, data->realName, address_displacement( _environment, data->realName, "1" ) );
80 break;
81 case 8:
82 data = variable_temporary( _environment, orig->type, "(data)");
83 variable_move( _environment, orig->name, data->name );
84 break;
85 default:
86 data = orig;
87 break;
88 }
89 } else {
90 data = orig;
91 }
92
93 Variable * result = variable_temporary( _environment, VT_BYTE, "(result)" );
94 Variable * address = variable_temporary( _environment, VT_ADDRESS, "(address)" );
95 Variable * size = variable_temporary( _environment, VT_BYTE, "(size)" );
96
97 switch( VT_BITWIDTH( data->type ) ) {
98 case 32:
99 case 16:
100 case 8: {
101 cpu_store_8bit( _environment, size->realName, VT_BITWIDTH( data->type ) >> 3 );
102 cpu_addressof_16bit( _environment, data->realName, address->realName );
103 break;
104 }
105 case 0: {
106 switch( data->type ) {
107 case VT_STRING: {
108 cpu_move_8bit( _environment, data->realName, size->realName );
109 cpu_addressof_16bit( _environment, data->realName, address->realName );
110 cpu_inc_16bit( _environment, address->realName );
111 break;
112 }
113 case VT_DSTRING: {
114 cpu_dsdescriptor( _environment, data->realName, address->realName, size->realName );
115 break;
116 }
117 default:
119 break;
120 }
121 break;
122 }
123 default:
125 break;
126 }
127
128 cocob_serial_write( _environment, address->realName, size->realName, result->realName );
129
130 return result;
131
132}
void cpu_addressof_16bit(Environment *_environment, char *_source, char *_destination)
Definition 6309.c:1485
void cpu_store_8bit(Environment *_environment, char *_destination, int _value)
CPU 6309: emit code to store 8 bit
Definition 6309.c:761
void cpu_swap_8bit(Environment *_environment, char *_left, char *_right)
Definition 6309.c:4451
void cpu_inc_16bit(Environment *_environment, char *_variable)
Definition 6309.c:4565
void cpu_move_8bit(Environment *_environment, char *_source, char *_destination)
CPU 6309: emit code to move 8 bit
Definition 6309.c:743
void cpu_dsdescriptor(Environment *_environment, char *_index, char *_address, char *_size)
Definition 6309.c:5977
Variable * variable_retrieve(Environment *_environment, char *_name)
Variable * variable_retrieve_or_define(Environment *_environment, char *_name, VariableType _type, int _value)
Variable * variable_move(Environment *_environment, char *_source, char *_destination)
Store the value of a variable inside another variable by converting it.
Variable * variable_temporary(Environment *_environment, VariableType _type, char *_meaning)
Define a temporary variable.
char * address_displacement(Environment *_environment, char *_address, char *_displacement)
int size
Definition _optimizer.c:678
Variable * serial_write_type(Environment *_environment, char *_data, VariableType _type, int _big_endian)
void cocob_serial_write(Environment *_environment, char *_address, char *_size, char *_result)
Definition cocob.c:454
char * name
Definition ugbc.h:979
VariableType type
Definition ugbc.h:988
char * realName
Definition ugbc.h:982
#define CRITICAL_SERIAL_WRITE_UNSUPPORTED(v, t)
Definition ugbc.h:3812
struct _Variable Variable
Structure of a single variable.
struct _Environment Environment
Structure of compilation environment.
@ VT_STRING
Definition ugbc.h:474
@ VT_BYTE
Definition ugbc.h:450
@ VT_ADDRESS
Definition ugbc.h:465
@ VT_DSTRING
Definition ugbc.h:483
enum _VariableType VariableType
Type of variables.
#define VT_BITWIDTH(t)
Definition ugbc.h:595
char DATATYPE_AS_STRING[][16]