You cannot select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
	
	
		
			91 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			C
		
	
			
		
		
	
	
			91 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			C
		
	
| #include <stdint.h>
 | |
| #include <stdio.h>
 | |
| #include <stdlib.h>
 | |
| #include <stdbool.h>
 | |
| #include <string.h>
 | |
| #include <termios.h>
 | |
| #include <unistd.h>
 | |
| #include <poll.h>
 | |
| #include "sim_vhpi_c.h"
 | |
| 
 | |
| /* Should we exit simulation on ctrl-c or pass it through? */
 | |
| #define EXIT_ON_CTRL_C
 | |
| 
 | |
| static struct termios oldt;
 | |
| 
 | |
| static void disable_raw_mode(void)
 | |
| {
 | |
| 	tcsetattr(STDIN_FILENO, TCSANOW, &oldt);
 | |
| }
 | |
| 
 | |
| static void enable_raw_mode(void)
 | |
| {
 | |
| 	static bool initialized = false;
 | |
| 
 | |
| 	if (!initialized) {
 | |
| 		static struct termios newt;
 | |
| 
 | |
| 		tcgetattr(STDIN_FILENO, &oldt);
 | |
| 		newt = oldt;
 | |
| 		cfmakeraw(&newt);
 | |
| #ifdef EXIT_ON_CTRL_C
 | |
| 		newt.c_lflag |= ISIG;
 | |
| #endif
 | |
| 		tcsetattr(STDIN_FILENO, TCSANOW, &newt);
 | |
| 		initialized = true;
 | |
| 		atexit(disable_raw_mode);
 | |
| 	}
 | |
| }
 | |
| 
 | |
| void sim_console_read(unsigned char *__rt)
 | |
| {
 | |
| 	int ret;
 | |
| 	unsigned long val = 0;
 | |
| 
 | |
| 	enable_raw_mode();
 | |
| 
 | |
| 	ret = read(STDIN_FILENO, &val, 1);
 | |
| 	if (ret != 1) {
 | |
| 		fprintf(stderr, "%s: read of stdin returns %d\n", __func__, ret);
 | |
| 		exit(1);
 | |
| 	}
 | |
| 
 | |
| 	//fprintf(stderr, "read returns %c\n", val);
 | |
| 
 | |
| 	to_std_logic_vector(val, __rt, 64);
 | |
| }
 | |
| 
 | |
| void sim_console_poll(unsigned char *__rt)
 | |
| {
 | |
| 	int ret;
 | |
| 	struct pollfd fdset[1];
 | |
| 	uint8_t val = 0;
 | |
| 
 | |
| 	enable_raw_mode();
 | |
| 
 | |
| 	memset(fdset, 0, sizeof(fdset));
 | |
| 
 | |
| 	fdset[0].fd = STDIN_FILENO;
 | |
| 	fdset[0].events = POLLIN;
 | |
| 
 | |
| 	ret = poll(fdset, 1, 0);
 | |
| 	//fprintf(stderr, "poll returns %d\n", ret);
 | |
| 
 | |
| 	if (ret == 1) {
 | |
| 		if (fdset[0].revents & POLLIN)
 | |
| 			val = 1;
 | |
| //		fprintf(stderr, "poll revents: 0x%x\n", fdset[0].revents);
 | |
| 	}
 | |
| 
 | |
| 	to_std_logic_vector(val, __rt, 64);
 | |
| }
 | |
| 
 | |
| void sim_console_write(unsigned char *__rs)
 | |
| {
 | |
| 	uint8_t val;
 | |
| 
 | |
| 	val = from_std_logic_vector(__rs, 64);
 | |
| 
 | |
| 	fprintf(stderr, "%c", val);
 | |
| }
 |