- Timestamp:
- Jul 20, 2017, 1:04:15 PM (7 years ago)
- Location:
- trunk/hal/x86_64
- Files:
-
- 1 edited
- 2 moved
Legend:
- Unmodified
- Added
- Removed
-
trunk/hal/x86_64/core/hal_drivers.c
r245 r247 25 25 #include <hal_internal.h> 26 26 27 #include <soclib_tty.h>28 27 #include <soclib_xcu.h> 29 28 #include <ioc_ata.h> 30 29 #include <pic_apic.h> 30 #include <txt_rs232.h> 31 31 32 32 void hal_drivers_txt_init(chdev_t *txt, uint32_t impl) 33 33 { 34 soclib_tty_init(txt);34 txt_rs232_init(txt); 35 35 } 36 36 -
trunk/hal/x86_64/drivers/txt_rs232.c
r244 r247 1 1 /* 2 * soclib_tty.c - soclib tty driver implementation.2 * txt_rs232.c - RS232 driver implementation 3 3 * 4 * Author Alain Greiner (2016)4 * Copyright (c) 2017 Maxime Villard 5 5 * 6 * Copyright (c) UPMC Sorbonne Universites6 * This file is part of ALMOS-MKH. 7 7 * 8 * This file is part of ALMOS-MKH.. 9 * 10 * ALMOS-MKH. is free software; you can redistribute it and/or modify it 8 * ALMOS-MKH is free software; you can redistribute it and/or modify it 11 9 * under the terms of the GNU General Public License as published by 12 10 * the Free Software Foundation; version 2.0 of the License. 13 11 * 14 * ALMOS-MKH .is distributed in the hope that it will be useful, but12 * ALMOS-MKH is distributed in the hope that it will be useful, but 15 13 * WITHOUT ANY WARRANTY; without even the implied warranty of 16 14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU … … 18 16 * 19 17 * You should have received a copy of the GNU General Public License 20 * along with ALMOS-MKH .; if not, write to the Free Software Foundation,18 * along with ALMOS-MKH; if not, write to the Free Software Foundation, 21 19 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA 22 20 */ … … 24 22 #include <dev_txt.h> 25 23 #include <chdev.h> 26 #include < soclib_tty.h>24 #include <txt_rs232.h> 27 25 #include <remote_spinlock.h> 28 26 #include <thread.h> … … 31 29 #include <hal_internal.h> // XXX 32 30 33 void soclib_tty_init( chdev_t * chdev)31 void txt_rs232_init(chdev_t *chdev) 34 32 { 35 chdev->cmd = & soclib_tty_cmd;36 chdev->isr = & soclib_tty_isr;33 chdev->cmd = &txt_rs232_cmd; 34 chdev->isr = &txt_rs232_isr; 37 35 38 36 // nothing to do … … 41 39 // Pour le write: tout en sync, ça part direct sur le VGA/série 42 40 // Pour le read: là on attend l'ISR 43 void __attribute__ ((noinline)) soclib_tty_cmd( xptr_t th_xp)41 void txt_rs232_cmd(xptr_t th_xp) 44 42 { 45 43 // get client thread cluster and local pointer … … 55 53 chdev_t * dev_ptr = (chdev_t *)GET_PTR( dev_xp ); 56 54 57 // get extended pointer on SOCLIB_TTYbase segment55 // get extended pointer on base segment 58 56 xptr_t tty_xp = (xptr_t)hal_remote_lwd( XPTR( dev_cxy , &dev_ptr->base ) ); 59 57 60 // get SOCLIB_TTYbase segment cluster and local pointer58 // get base segment cluster and local pointer 61 59 cxy_t tty_cxy = GET_CXY( tty_xp ); 62 60 uint32_t * tty_ptr = (uint32_t *)GET_PTR( tty_xp ); … … 94 92 } 95 93 96 void __attribute__ ((noinline)) soclib_tty_isr( chdev_t * chdev)94 void txt_rs232_isr(chdev_t *chdev) 97 95 { 98 96 // Cette ISR est juste utile pour le clavier; on arrive ici quand une touche 99 97 // est pressée 100 x86_panic(" soclib_tty_isr not handled");98 x86_panic("txt_rs232_isr not handled"); 101 99 } 102 100 -
trunk/hal/x86_64/drivers/txt_rs232.h
r239 r247 1 1 /* 2 * soclib_tty.c - soclib tty driver definition.2 * txt_rs232.c - RS232 driver definitions 3 3 * 4 * Author Alain Greiner (2016) 5 * 6 * Copyright (c) UPMC Sorbonne Universites 4 * Copyright (c) 2017 Maxime Villard 7 5 * 8 6 * This file is part of ALMOS-MKH. … … 18 16 * 19 17 * You should have received a copy of the GNU General Public License 20 * along with ALMOS- kernel; if not, write to the Free Software Foundation,18 * along with ALMOS-MKH; if not, write to the Free Software Foundation, 21 19 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA 22 20 */ … … 24 22 #include <dev_txt.h> 25 23 #include <chdev.h> 26 #include <spinlock.h>27 24 25 void txt_rs232_init(chdev_t *chdev); 26 void txt_rs232_cmd(xptr_t thread_xp); 27 void txt_rs232_isr(chdev_t *chdev); 28 28 29 /****************************************************************************************30 * This driver supports the soclib_multi_tty component.31 * It implements the generic TXT device API:32 * - transfer one single character from TTY to command "buffer" if to_mem is non-zero.33 * - transfer "count" characters from command "buffer" to TTY if "to_mem is zero.34 ***************************************************************************************/35 36 /****************************************************************************************37 * SOCLIB_TTY registers offsets38 ***************************************************************************************/39 40 #define TTY_WRITE_REG 041 #define TTY_STATUS_REG 142 #define TTY_READ_REG 243 #define TTY_CONFIG_REG 344 45 #define TTY_SPAN 4 // number of registers per channel46 47 /****************************************************************************************48 * masks for TTY_STATUS_REG49 ***************************************************************************************/50 51 #define TTY_STATUS_RX_FULL 1 // TTY_READ_REG full if 152 #define TTY_STATUS_TX_FULL 2 // TTY_WRITE_REG full if 153 54 /****************************************************************************************55 * masks for TTY_CONFIG_REG56 ***************************************************************************************/57 58 #define TTY_CONFIG_RX_ENABLE 1 // TTY_RX IRQ enabled if 159 #define TTY_CONFIG_TX_ENABLE 2 // TTY_TX IRQ enabled if 160 61 /****************************************************************************************62 * This function masks both the TTY_RX and TTY_TX IRQs.63 * These IRQs are unmasked by the soclib_tty_cmd() function.64 ****************************************************************************************65 * @ chdev : pointer on the TXT chdev descriptor.66 ***************************************************************************************/67 void soclib_tty_init( chdev_t * chdev );68 69 /****************************************************************************************70 * This function handles the command registered in the thread descriptor identified71 * by the <xp_thread> argument.72 * - For the TXT_READ and TXT_WRITE commands, it only unmask the proper TTY_RX / TTY_TX73 * IRQ, and blocks the TXT device server thread on the THREAD_BLOCKED_DEV_ISR, as the74 * data transfer is done by the ISR.75 * - For the TXT_SYNC_READ command, that should be only used by the kernel do display76 * log or debug messages, it directly access the SOCLIB_TTY registers, using77 * a busy waiting policy if required.78 ****************************************************************************************79 * @ thread_xp : extended pointer on client thread descriptor.80 ***************************************************************************************/81 void soclib_tty_cmd( xptr_t thread_xp );82 83 /****************************************************************************************84 * This ISR should be executed only for the TXT_READ and TXT_WRITE commands.85 * It gets the command arguments from the first client thread in the TXT chdev queue:86 * - if TXT_READ, it transfers one byte from the TTY_READ_REG to the command buffer.87 * It simply returns for retry if TTY_READ_REG is empty.88 * - if TXT_WRITE, it tries to transfer several bytes from the command buffer to the89 * TTY_WRITE_REG. If the TTY_WRITE_REG is full, it updates the "count" and "buffer"90 * command arguments and returns for retry.91 * When the I/O operation is completed, it sets the status field in the command, unblocks92 * the server thread, and unblocks the client thread.93 ****************************************************************************************94 * @ chdev : local pointer on TXT chdev descriptor.95 ***************************************************************************************/96 void soclib_tty_isr( chdev_t * chdev );97
Note: See TracChangeset
for help on using the changeset viewer.