Browse Source

Add a variable time_res

Yann Weber 6 years ago
parent
commit
4f74b3540c
1 changed files with 21 additions and 4 deletions
  1. 21
    4
      wtfstopw.asm

+ 21
- 4
wtfstopw.asm View File

82
 	startmsglen: equ $ - startmsg
82
 	startmsglen: equ $ - startmsg
83
 
83
 
84
 	hours: db "000000000"
84
 	hours: db "000000000"
85
-	timestr: db ":00:00.0000    ", 0x0a
85
+	timestr: db ":00:00.0           ", 0x0a
86
 	timestrlen: equ $ - timestr
86
 	timestrlen: equ $ - timestr
87
 
87
 
88
+	time_res: dq 3 ; 3 digits bellow seconds
89
+
88
 	nl: db 0x0A
90
 	nl: db 0x0A
89
 	buf: db 0
91
 	buf: db 0
90
 
92
 
254
 	sub rbx, 1
256
 	sub rbx, 1
255
 	mov [ts_cur.tv_sec], rbx
257
 	mov [ts_cur.tv_sec], rbx
256
 	print_time_us_cont:
258
 	print_time_us_cont:
259
+	
260
+	; Divide result given time_res
261
+	mov r10, rax
262
+	mov rax, 1000000000
263
+	mov r9, [time_res]
264
+	mov r8, 10
265
+	xor rdx, rdx
266
+	print_time_respow:
267
+		div r8
268
+		sub r9, 1
269
+		cmp r9, 0
270
+		jg print_time_respow
271
+	mov rcx, rax
272
+	mov rax, r10
257
 	xor rdx, rdx
273
 	xor rdx, rdx
258
-	mov rcx, 100000
259
 	div rcx
274
 	div rcx
275
+
260
 	; set the us char in timestr
276
 	; set the us char in timestr
261
 	mov r8, timestr
277
 	mov r8, timestr
262
-	add r8, 10 ; r8 points on last char before \r
263
-	mov r9, 4 ; r9 count the number of digits
278
+	mov r9, [time_res] ; r9 count the number of digits
279
+	add r8, 6 ; first digits after seconds
280
+	add r8, r9 ; r8 points on last char before \r
264
 	print_time_us_loop:
281
 	print_time_us_loop:
265
 		xor rdx, rdx
282
 		xor rdx, rdx
266
 		mov rcx, 10
283
 		mov rcx, 10

Loading…
Cancel
Save