summaryrefslogtreecommitdiff
path: root/src/kernel/serial.asm
blob: 2213fd8108745ccd30f46bcd9b5fcf7c537ff101 (plain) (blame)
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
;Copyright 2019 Benji Dial

;Permission to use, copy, modify, and/or distribute this
;software for any purpose with or without fee is hereby
;granted, provided that the above copyright notice and this
;permission notice appear in all copies.

;THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS
;ALL WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL
;IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO
;EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,
;INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER
;RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
;ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION,
;ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE
;OF THIS SOFTWARE.

global send_byte
global read_byte
global poll_port

section .text
send_byte:;void send_byte(uint8_t value, uint8_t port)
  push ebp
  mov ebp, esp

  xor ecx, ecx
  mov cl, byte [ebp + 12];port

  test cl, 0xfc
  jnz .leave

  shl cl, 1
  mov dx, word [ecx + com_ports]

  or dx, 5

.check_ready:
  in al, dx
  test al, 0x20
  jz .check_ready

  and dx, 0xfff8

  mov al, byte [ebp + 8];value
  out dx, al

.leave:
  leave
  ret

read_byte:;uint8_t read_byte(uint8_t port)
  push ebp
  mov ebp, esp

  xor eax, eax

  xor ecx, ecx
  mov cl, byte [ebp + 8];port

  test cl, 0xfc
  jnz .leave

  shl cl, 1
  mov dx, word [ecx + com_ports]

  or dx, 5

.check_ready:
  in al, dx
  test al, 0x01
  jz .check_ready

  and dx, 0xfff8

  in al, dx

.leave:
  leave
  ret

poll_port:;bool poll_port(uint8_t port)
  push ebp
  mov ebp, esp

  xor eax, eax

  xor ecx, ecx
  mov cl, byte [ebp + 8];port

  test cl, 0xfc
  jnz .leave

  shl cl, 1
  mov dx, word [ecx + com_ports]

  or dx, 5

  in al, dx
  and al, 0x01

.leave:
  leave
  ret

section .rodata
com_ports dw 0x03f8, 0x02f8, 0x03e8, 0x02e8