-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathCreateFile.asm
More file actions
368 lines (337 loc) · 8.62 KB
/
CreateFile.asm
File metadata and controls
368 lines (337 loc) · 8.62 KB
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
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
; Proyecto individual 1
; Eduardo Moya
INCLUDE Irvine32.inc
INCLUDE macros.inc
; ----------------------------- Constants --------------------------------
imageMaxWidth = 3900
imageMaxHeight = 2200
imageMaxResolution = imageMaxWidth * imageMaxHeight ; width x height
extendedImageMaxSize = (imageMaxWidth + 2) * (imageMaxHeight * 2) ; (width + 2) x (height + 2)
BUFFER_SIZE_IN = extendedImageMaxSize + 1
BUFFER_CONSOLE = 10
.data
; User console input (image size)
bufferConsole BYTE BUFFER_CONSOLE DUP(?), 0, 0
stdInHandle HANDLE ?
bytesRead DWORD ?
askForDimensions BYTE "Insert image dimensions (example: 1920x1080): ",0
; File read
imageArray BYTE BUFFER_SIZE_IN DUP(0)
fileNameIn BYTE "input.txt",0
fileHandleIn HANDLE ?
; Convolution
imageWidth WORD ?
imageWidthExtended WORD ?
imageHeight WORD ?
imageHeightExtended WORD ?
imageResolution DWORD ?
extendedImageSize DWORD ?
pixelsIn DWORD ?
sharpeningKernel BYTE 9 DUP(0)
sum WORD 0
imageRowCounter WORD 0
imageColumnCounter WORD 0
kernelRowCounter BYTE 0
kernelColumnCounter BYTE 0
kernelCounter BYTE 0
kernelRowOffset DWORD 0
kernelColumnOffset DWORD 0
imageRowOffset DWORD 0
imageColumnOffset DWORD 0
sharpenedImageCounter DWORD 0
newImage BYTE 0
sharpenedImage BYTE imageMaxResolution DUP(0)
; File Write
fileNameOut BYTE "normSharpened.txt", 0
fileHandleOut HANDLE ?
bytesWrittenOut DWORD ?
str1Out BYTE "Cannot create file",0dh,0ah,0
str2Out BYTE "Bytes written to file: ",0
.code
main PROC
; ----------------------- COVER -------------------------
mWrite <"----------------------------------------------------------",0dh,0ah>
mWrite <"TECNOLOGICO DE COSTA RICA",0dh,0ah>
mWrite <" ",0dh,0ah>
mWrite <"COMPUTER ENGINEERING ACADEMIC AREA",0dh,0ah>
mWrite <"Computer Architecture I",0dh,0ah>
mWrite <" ",0dh,0ah>
mWrite <"INDIVIDUAL PROJECT #1",0dh,0ah>
mWrite <"Image convolution in assembly",0dh,0ah>
mWrite <" ",0dh,0ah>
mWrite <"STUDENT: Eduardo Moya Bello",0dh,0ah>
mWrite <"TEACHER: Eng. Luis Chavarria Zamora",0dh,0ah>
mWrite <" ",0dh,0ah>
mWrite <"Date: 29, May 2020",0dh,0ah>
mWrite <"----------------------------------------------------------",0dh,0ah>
mWrite <"This program sharpens and oversharpens an image",0dh,0ah>
mWrite <"Maximum dimensions: 3900x2200 (width x height)",0dh,0ah>
mWrite <"----------------------------------------------------------",0dh,0ah>
; -------------- GET IMAGE DIMENSIONS FROM CONSOLE ------
; Ask for the input
mov edx,OFFSET askForDimensions
call WriteString
; Get handle to standard input
INVOKE GetStdHandle, STD_INPUT_HANDLE
mov stdInHandle,eax
; Wait for user input
INVOKE ReadConsole, stdInHandle, ADDR bufferConsole,
BUFFER_CONSOLE, ADDR bytesRead, 0
; Transform the dimensions
xor esi, esi ; Position in value counter = 0
xor edi, edi ; Buffer counter = 0
xor eax, eax ; Dimension container
xor ebx, ebx ; Char value container
mov cx, 10 ; Multiplier
getImageWidth:
mov bl, bufferConsole[edi] ; Get actual value in buffer
cmp bl, 120
je endWidth
sub bl, 48 ; Get number
cmp esi, 0
je updateWidthValue
mul cx
updateWidthValue:
add ax, bx
inc edi
inc esi
jmp getImageWidth
endWidth:
mov imageWidth, ax
xor eax, eax
xor esi, esi
inc edi
getImageHeight:
mov bl, bufferConsole[edi] ; Get actual value in buffer
cmp bl, 13
je endHeight
sub bl, 48 ; Get number
cmp esi, 0
je updateHeightValue
mul cx
updateHeightValue:
add ax, bx
inc edi
inc esi
jmp getImageHeight
endHeight:
; Get amount of pixels
mov imageHeight, ax
mov bx, imageWidth
mul bx
mov cx, dx
shl ecx, 16
add cx, ax
mov imageResolution, ecx
; Get amount of pixels (extended)
mov ax, imageHeight
mov bx, imageWidth
add ax, 2
add bx, 2
mov imageHeightExtended, ax
mov imageWidthExtended, bx
mul bx
mov cx, dx
shl ecx, 16
add cx, ax
mov extendedImageSize, ecx
; -------------------- READ FILE ------------------------
; Let user input a filename.
mov edx,OFFSET fileNameIn
mov ecx,SIZEOF fileNameIn
; Open the file for input.
mov edx,OFFSET fileNameIn
call OpenInputFile
mov fileHandleIn,eax
; Check for errors.
cmp eax,INVALID_HANDLE_VALUE ; error opening file?
jne file_ok_in ; no: skip
mWrite <"Cannot open file",0dh,0ah>
jmp quit ; and quit
file_ok_in:
; Read the file into a buffer.
mov edx,OFFSET imageArray
mov ecx,BUFFER_SIZE_IN
call ReadFromFile
jnc check_buffer_size ; error reading?
mWrite "Error reading file. " ; yes: show error message
call WriteWindowsMsg
jmp close_file
check_buffer_size:
cmp eax,BUFFER_SIZE_IN; buffer large enough?
jb buf_size_ok ; yes
mWrite <"Error: Buffer too small for the file",0dh,0ah>
jmp quit
buf_size_ok:
mov imageArray[eax],0 ; insert null terminator
mWrite "File size: "
call WriteDec ; display file size
call Crlf
close_file:
mov eax,fileHandleIn
call CloseFile
; ------------------- TRANSFORM BUFFER TO INT ARRAY --------
; cl: register to hold the char and transform it to integer
; al: register that holds multiplication results
; dl: n as in 10^n
; bl: actual number
cld
mov ax, imageWidthExtended
mov bx, imageHeightExtended
mul bx
mov bx, dx
shl ebx, 16
mov bx, ax
mov pixelsIn, ebx ; pixelIn = (width+2)x(height+2)
xor esi, esi ; esi: counter
xor edi, edi ; edi: pixel counter
xor eax, eax
xor ebx, ebx
xor ecx, ecx
xor edx, edx
; ----------------------- CONVOLUTION -------------------------
convolution:
mov sharpeningKernel[0], 0
mov sharpeningKernel[1], -1
mov sharpeningKernel[2], 0
mov sharpeningKernel[3], -1
mov sharpeningKernel[4], 5
mov sharpeningKernel[5], -1
mov sharpeningKernel[6], 0
mov sharpeningKernel[7], -1
mov sharpeningKernel[8], 0
new_kernel_column:
mov ebx, kernelRowOffset
add ebx, kernelColumnOffset
add ebx, imageRowOffset
add ebx, imageColumnOffset
mov cl, [imageArray + ebx]
xor edx, edx
mov dl, kernelCounter
mov al, [sharpeningKernel + edx]
cbw
imul cx
add sum, ax
inc kernelCounter
inc kernelColumnCounter
cmp kernelColumnCounter, 3
je new_kernel_row
inc kernelColumnOffset
jmp new_kernel_column
new_kernel_row:
inc kernelRowCounter
cmp kernelRowCounter, 3
je new_image_column
mov kernelColumnOffset, 0
mov kernelColumnCounter, 0
xor eax, eax
mov ax, imageWidthExtended
add kernelRowOffset, eax
jmp new_kernel_column
new_image_column:
mov ax, sum
mov ebx, sharpenedImageCounter
cmp ax, 0
jl less_than_zero
cmp ax, 255
jg over_255
mov sharpenedImage[ebx], al
jmp sum_stored
less_than_zero:
mov sharpenedImage[ebx], 0
jmp sum_stored
over_255:
mov sharpenedImage[ebx], 255
sum_stored:
xor eax, eax
xor ebx, ebx
xor ecx, ecx
xor edx, edx
mov kernelRowOffset, 0
mov kernelColumnOffset, 0
mov kernelRowCounter, 0
mov kernelColumnCounter, 0
mov kernelCounter, 0
mov sum, 0
inc imageColumnOffset
inc sharpenedImageCounter
mov ax, imageWidth
inc imageColumnCounter
cmp imageColumnCounter, ax
jne new_kernel_column
new_image_row:
inc imageRowCounter
mov ax, imageHeight
cmp imageRowCounter, ax
je sharpened
mov imageColumnCounter, 0
mov imageColumnOffset, 0
xor eax, eax
mov ax, imageWidthExtended
add imageRowOffset, eax
jmp new_kernel_column
sharpened:
; ----------------------- WRITE FILE ------------------------
; Create a new text file.
mov edx, OFFSET fileNameOut
call CreateOutputFile
mov fileHandleOut,eax
; Check for errors.
cmp eax, INVALID_HANDLE_VALUE ; error found?
jne file_out_ok ; no: skip
mov edx,OFFSET str1Out ; display error
call WriteString
jmp quit
file_out_ok:
; Write the buffer to the output file.
mov eax,fileHandleOut
mov edx,OFFSET sharpenedImage
mov ecx,imageResolution
call WriteToFile
mov bytesWrittenOut,eax ; save return value
call CloseFile
; Do the same process for oversharpening
cmp newImage, 1
je sharpening_successful
inc newImage
; Change settings for oversharpening
mov fileNameOut, "o"
mov fileNameOut[1], "v"
mov fileNameOut[2], "e"
mov fileNameOut[3], "r"
mov sharpeningKernel[0], 0
mov sharpeningKernel[1], -2
mov sharpeningKernel[2], 0
mov sharpeningKernel[3], -2
mov sharpeningKernel[4], 9
mov sharpeningKernel[5], -2
mov sharpeningKernel[6], 0
mov sharpeningKernel[7], -2
mov sharpeningKernel[8], 0
; Reset all convolution values
xor eax, eax
xor ebx, ebx
xor ecx, ecx
xor edx, edx
xor edi, edi
xor esi, esi
mov sum, 0
mov imageRowCounter, 0
mov imageColumnCounter, 0
mov kernelRowCounter, 0
mov kernelColumnCounter, 0
mov kernelCounter, 0
mov kernelRowOffset, 0
mov kernelColumnOffset, 0
mov imageRowOffset, 0
mov imageColumnOffset, 0
mov sharpenedImageCounter, 0
mov bytesWrittenOut, 0
jmp new_kernel_row
sharpening_successful:
mWrite <"Sharpening and oversharpening successful!",0dh,0ah>
quit:
mWrite <"----------------------------------------------------------",0dh,0ah>
exit
main ENDP
END main