2 # Copyright (c) 1998 Robert Nordier
5 # Redistribution and use in source and binary forms are freely
6 # permitted provided that the above copyright notice and this
7 # paragraph and the following disclaimer are duplicated in all
10 # This software is provided "AS IS" and without any express or
11 # implied warranties, including, without limitation, the implied
12 # warranties of merchantability and fitness for a particular
16 # $FreeBSD: src/sys/boot/i386/boot2/sio.s,v 1.4 1999/08/28 00:40:02 peter Exp $
17 # $DragonFly: src/sys/boot/pc32/boot2/sio.S,v 1.3 2003/11/10 06:08:35 dillon Exp $
19 .set SIO_PRT,SIOPRT # Base port
20 .set SIO_FMT,SIOFMT # 8N1
21 .set SIO_DIV,(115200/SIOSPD) # 115200 / SPD
31 sio_init: movw $SIO_PRT+0x3,%dx # Data format reg
32 movb $SIO_FMT|0x80,%al # Set format
33 outb %al,(%dx) # and DLAB
35 subb $0x3,%dl # Divisor latch reg
36 movw $SIO_DIV,%ax # Set
39 movb $SIO_FMT,%al # Clear
41 incl %edx # Modem control reg
42 movb $0x3,%al # Set RTS,
44 incl %edx # Line status reg
46 # void sio_flush(void)
48 sio_flush.0: call sio_getc.1 # Get character
49 sio_flush: call sio_ischar # Check for character
50 jnz sio_flush.0 # Till none
53 # void sio_putc(int c)
55 sio_putc: movw $SIO_PRT+0x5,%dx # Line status reg
56 xor %ecx,%ecx # Timeout
57 movb $0x40,%ch # counter
58 sio_putc.1: inb (%dx),%al # Transmitter
59 testb $0x20,%al # buffer empty?
61 jz sio_putc.2 # If timeout
62 movb 0x4(%esp,1),%al # Get character
63 subb $0x5,%dl # Transmitter hold reg
64 outb %al,(%dx) # Write character
65 sio_putc.2: ret $0x4 # To caller
69 sio_getc: call sio_ischar # Character available?
71 sio_getc.1: subb $0x5,%dl # Receiver buffer reg
72 inb (%dx),%al # Read character
75 # int sio_ischar(void)
77 sio_ischar: movw $SIO_PRT+0x5,%dx # Line status register
79 inb (%dx),%al # Received data
80 andb $0x1,%al # ready?