diff options
| -rw-r--r-- | host/apps/omap_debug/Makefile | 13 | ||||
| -rw-r--r-- | host/apps/omap_debug/clkgen-config.cc | 296 | ||||
| -rw-r--r-- | host/apps/omap_debug/fpga-downloader.cc | 253 | ||||
| -rw-r--r-- | host/apps/omap_debug/usrp-e-timed.c | 233 | 
4 files changed, 1 insertions, 794 deletions
| diff --git a/host/apps/omap_debug/Makefile b/host/apps/omap_debug/Makefile index dd27ba657..f8b9f2bd9 100644 --- a/host/apps/omap_debug/Makefile +++ b/host/apps/omap_debug/Makefile @@ -1,7 +1,7 @@  CFLAGS=-Wall -I../../lib/usrp/usrp_e/ -march=armv7-a -mtune=cortex-a8 -mfpu=neon -O3  CXXFLAGS=-Wall -I../../lib/usrp/usrp_e/ -march=armv7-a -mtune=cortex-a8 -mfpu=neon -O3 -all : usrp-e-spi usrp-e-i2c usrp-e-uart usrp-e-led usrp-e-ctl usrp-e-button usrp-e-uart-rx fpga-downloader usrp-e-gpio usrp-e-debug-pins usrp-e-lb-test usrp-e-crc-rw clkgen-config +all : usrp-e-spi usrp-e-i2c usrp-e-uart usrp-e-led usrp-e-ctl usrp-e-button usrp-e-uart-rx usrp-e-gpio usrp-e-debug-pins  usrp-e-spi : usrp-e-spi.c @@ -17,28 +17,17 @@ usrp-e-ctl : usrp-e-ctl.c  usrp-e-button : usrp-e-button.c -fpga-downloader : fpga-downloader.cc - -clkgen-config : clkgen-config.cc -  usrp-e-gpio : usrp-e-gpio.c  usrp-e-debug-pins : usrp-e-debug-pins.c  clean :  	rm -f usrp-e-spi  	rm -f usrp-e-i2c -	rm -f usrp-e-loopback -	rm -f usrp-e-mm-loopback -	rm -f usrp-e-timed -	rm -f usrp-e-rw-random  	rm -f usrp-e-uart  	rm -f usrp-e-uart-rx  	rm -f usrp-e-led  	rm -f usrp-e-ctl  	rm -f usrp-e-button -	rm -f fpga-downloader  	rm -f usrp-e-gpio  	rm -f usrp-e-debug-pins  	rm -f usrp-e-lb-test -	rm -f usrp-e-crc-rw -	rm -f clkgen-config diff --git a/host/apps/omap_debug/clkgen-config.cc b/host/apps/omap_debug/clkgen-config.cc deleted file mode 100644 index e8279b4ae..000000000 --- a/host/apps/omap_debug/clkgen-config.cc +++ /dev/null @@ -1,296 +0,0 @@ -/* -*- c++ -*- */ -/* - * Copyright 2003,2004,2008,2009 Free Software Foundation, Inc. - * - * This file is part of UHD - * - * GNU Radio is free software; you can redistribute it and/or modify - * it under the terms of the GNU General Public License as published by - * the Free Software Foundation; either version 3, or (at your option) - * any later version. - * - * GNU Radio is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the - * GNU General Public License for more details. - * - * You should have received a copy of the GNU General Public License - * along with GNU Radio; see the file COPYING.  If not, write to - * the Free Software Foundation, Inc., 51 Franklin Street, - * Boston, MA 02110-1301, USA. -*/ - -#include <iostream> -#include <sstream> -#include <fstream> -#include <string> -#include <cstdlib> - -#include <fcntl.h> -#include <sys/types.h> -#include <sys/stat.h> -#include <sys/ioctl.h> - -#include <linux/spi/spidev.h> - - -// Programming data for clock gen chip -static const unsigned int config_data[] = { -	0x000024, -	0x023201, -	0x000081, -	0x000400, -	0x00104c, -	0x001101, -	0x001200, -	0x001300, -	0x001414, -	0x001500, -	0x001604, -	0x001704, -	0x001807, -	0x001900, -	//0x001a00,//for debug -	0x001a32, -	0x001b12, -	0x001c44, -	0x001d00, -	0x001e00, -	0x00f062, -	0x00f162, -	0x00f262, -	0x00f362, -	0x00f462, -	0x00f562, -	0x00f662, -	0x00f762, -	0x00f862, -	0x00f962, -	0x00fa62, -	0x00fb62, -	0x00fc00, -	0x00fd00, -	0x019021, -	0x019100, -	0x019200, -	0x019333, -	0x019400, -	0x019500, -	0x019611, -	0x019700, -	0x019800, -	0x019900, -	0x019a00, -	0x019b00, -	0x01e003, -	0x01e102, -	0x023000, -	0x023201, -	0x0b0201, -	0x0b0300, -	0x001fff, -	0x0a0000, -	0x0a0100, -	0x0a0200, -	0x0a0302, -	0x0a0400, -	0x0a0504, -	0x0a060e, -	0x0a0700, -	0x0a0810, -	0x0a090e, -	0x0a0a00, -	0x0a0bf0, -	0x0a0c0b, -	0x0a0d01, -	0x0a0e90, -	0x0a0f01, -	0x0a1001, -	0x0a11e0, -	0x0a1201, -	0x0a1302, -	0x0a1430, -	0x0a1580, -	0x0a16ff, -	0x023201, -	0x0b0301, -	0x023201, -}; - - -const unsigned int CLKGEN_SELECT = 145; - - -enum gpio_direction {IN, OUT}; - -class gpio { -	public: - -	gpio(unsigned int gpio_num, gpio_direction pin_direction, bool close_action); -	~gpio(); - -	bool get_value(); -	void set_value(bool state); - -	private: - -	unsigned int gpio_num; - -	std::stringstream base_path; -	std::fstream value_file; -	std::fstream direction_file; -	bool close_action; // True set to input and release, false do nothing -}; - -class spidev { -	public: - -	spidev(std::string dev_name); -	~spidev(); - -	void send(char *wbuf, char *rbuf, unsigned int nbytes); - -	private: - -	int fd; - -}; - -gpio::gpio(unsigned int _gpio_num, gpio_direction pin_direction, bool close_action) -{ -	std::fstream export_file; - -	gpio_num = _gpio_num; - -	export_file.open("/sys/class/gpio/export", std::ios::out); -	if (!export_file.is_open())  ///\todo Poor error handling -		std::cout << "Failed to open gpio export file." << std::endl; - -	export_file << gpio_num << std::endl; - -	base_path << "/sys/class/gpio/gpio" << gpio_num << std::flush; - -	std::string direction_file_name; - -	direction_file_name = base_path.str() + "/direction"; - -	direction_file.open(direction_file_name.c_str());  -	if (!direction_file.is_open()) -		std::cout << "Failed to open direction file." << std::endl; -	if (pin_direction == OUT) -		direction_file << "out" << std::endl; -	else -		direction_file << "in" << std::endl; - -	std::string value_file_name; - -	value_file_name = base_path.str() + "/value"; - -	value_file.open(value_file_name.c_str(), std::ios_base::in | std::ios_base::out); -	if (!value_file.is_open()) -		std::cout << "Failed to open value file." << std::endl; -} - -bool gpio::get_value() -{ - -	std::string val; - -	std::getline(value_file, val); -	value_file.seekg(0); - -	if (val == "0") -		return false; -	else if (val == "1") -		return true; -	else -		std::cout << "Data read from value file|" << val << "|" << std::endl; - -	return false; -} - -void gpio::set_value(bool state) -{ - -	if (state) -		value_file << "1" << std::endl; -	else -		value_file << "0" << std::endl; -} - -gpio::~gpio() -{ -	if (close_action) { -		std::fstream unexport_file; - -		direction_file << "in" << std::endl; - -		unexport_file.open("/sys/class/gpio/unexport", std::ios::out); -		if (!unexport_file.is_open())  ///\todo Poor error handling -			std::cout << "Failed to open gpio export file." << std::endl; - -		unexport_file << gpio_num << std::endl; -		 -	 } - -} - -spidev::spidev(std::string fname) -{ -	int ret; -	int mode = 0; -	int speed = 12000; -	int bits = 24; - -	fd = open(fname.c_str(), O_RDWR); - -	ret = ioctl(fd, SPI_IOC_WR_MODE, &mode); -	ret = ioctl(fd, SPI_IOC_WR_MAX_SPEED_HZ, &speed); -	ret = ioctl(fd, SPI_IOC_WR_BITS_PER_WORD, &bits); -} -	 - -spidev::~spidev() -{ -	close(fd); -} - -void spidev::send(char *buf, char *rbuf, unsigned int nbytes) -{ -	int ret; - -	struct spi_ioc_transfer tr; -	tr.tx_buf = (unsigned long) buf; -	tr.rx_buf = (unsigned long) rbuf; -	tr.len = nbytes; -	tr.delay_usecs = 0; -	tr.speed_hz = 12000000; -	tr.bits_per_word = 24; - -	ret = ioctl(fd, SPI_IOC_MESSAGE(1), &tr);	 - -} - -static void send_config_to_clkgen(gpio &chip_select, const unsigned int data[], unsigned int data_size) -{ -	spidev spi("/dev/spidev1.0"); -	unsigned int rbuf; - -	for (unsigned int i = 0; i < data_size; i++) { - -		std::cout << "sending " << std::hex << data[i] << std::endl; -		chip_select.set_value(0); -		spi.send((char *)&data[i], (char *)&rbuf, 4); -		chip_select.set_value(1); - -	}; -} - -int main(int argc, char *argv[]) -{ - -	gpio clkgen_select(CLKGEN_SELECT, OUT, true); - -	send_config_to_clkgen(clkgen_select, config_data, sizeof(config_data)/sizeof(unsigned int)); -} - diff --git a/host/apps/omap_debug/fpga-downloader.cc b/host/apps/omap_debug/fpga-downloader.cc deleted file mode 100644 index 4e475b5c1..000000000 --- a/host/apps/omap_debug/fpga-downloader.cc +++ /dev/null @@ -1,253 +0,0 @@ -/* -*- c++ -*- */ -/* - * Copyright 2003,2004,2008,2009 Free Software Foundation, Inc. - * - * This file is part of GNU Radio - * - * GNU Radio is free software; you can redistribute it and/or modify - * it under the terms of the GNU General Public License as published by - * the Free Software Foundation; either version 3, or (at your option) - * any later version. - * - * GNU Radio is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the - * GNU General Public License for more details. - * - * You should have received a copy of the GNU General Public License - * along with GNU Radio; see the file COPYING.  If not, write to - * the Free Software Foundation, Inc., 51 Franklin Street, - * Boston, MA 02110-1301, USA. -*/ - -#include <iostream> -#include <sstream> -#include <fstream> -#include <string> -#include <cstdlib> - -#include <fcntl.h> -#include <sys/types.h> -#include <sys/stat.h> -#include <sys/ioctl.h> - -#include <linux/spi/spidev.h> - -/* - * Configuration connections - * - * CCK    - MCSPI1_CLK - * DIN    - MCSPI1_MOSI - * PROG_B - GPIO_175     - output (change mux) - * DONE   - GPIO_173     - input  (change mux) - * INIT_B - GPIO_114     - input  (change mux) - * -*/ - -const unsigned int PROG_B = 175; -const unsigned int DONE   = 173; -const unsigned int INIT_B = 114; - -static std::string bit_file = "safe_u1e.bin"; - -const int BUF_SIZE = 4096; - -enum gpio_direction {IN, OUT}; - -class gpio { -	public: - -	gpio(unsigned int gpio_num, gpio_direction pin_direction); - -	bool get_value(); -	void set_value(bool state); - -	private: - -	std::stringstream base_path; -	std::fstream value_file;	 -}; - -class spidev { -	public: - -	spidev(std::string dev_name); -	~spidev(); - -	void send(char *wbuf, char *rbuf, unsigned int nbytes); - -	private: - -	int fd; - -}; - -gpio::gpio(unsigned int gpio_num, gpio_direction pin_direction) -{ -	std::fstream export_file; - -	export_file.open("/sys/class/gpio/export", std::ios::out); -	if (!export_file.is_open())  ///\todo Poor error handling -		std::cout << "Failed to open gpio export file." << std::endl; - -	export_file << gpio_num << std::endl; - -	base_path << "/sys/class/gpio/gpio" << gpio_num << std::flush; - -	std::fstream direction_file; -	std::string direction_file_name; - -	if (gpio_num != 114) { -		direction_file_name = base_path.str() + "/direction"; - -		direction_file.open(direction_file_name.c_str());  -		if (!direction_file.is_open()) -			std::cout << "Failed to open direction file." << std::endl; -		if (pin_direction == OUT) -			direction_file << "out" << std::endl; -		else -			direction_file << "in" << std::endl; -	} - -	std::string value_file_name; - -	value_file_name = base_path.str() + "/value"; - -	value_file.open(value_file_name.c_str(), std::ios_base::in | std::ios_base::out); -	if (!value_file.is_open()) -		std::cout << "Failed to open value file." << std::endl; -} - -bool gpio::get_value() -{ - -	std::string val; - -	std::getline(value_file, val); -	value_file.seekg(0); - -	if (val == "0") -		return false; -	else if (val == "1") -		return true; -	else -		std::cout << "Data read from value file|" << val << "|" << std::endl; - -	return false; -} - -void gpio::set_value(bool state) -{ - -	if (state) -		value_file << "1" << std::endl; -	else -		value_file << "0" << std::endl; -} - -static void prepare_fpga_for_configuration(gpio &prog, gpio &init) -{ - -	prog.set_value(true); -	prog.set_value(false); -	prog.set_value(true); - -#if 0 -	bool ready_to_program(false); -	unsigned int count(0); -	do { -		ready_to_program = init.get_value(); -		count++; - -		sleep(1); -	} while (count < 10 && !ready_to_program); - -	if (count == 10) { -		std::cout << "FPGA not ready for programming." << std::endl; -		exit(-1); -	} -#endif -} - -spidev::spidev(std::string fname) -{ -	int ret; -	int mode = 0; -	int speed = 12000000; -	int bits = 8; - -	fd = open(fname.c_str(), O_RDWR); - -	ret = ioctl(fd, SPI_IOC_WR_MODE, &mode); -	ret = ioctl(fd, SPI_IOC_WR_MAX_SPEED_HZ, &speed); -	ret = ioctl(fd, SPI_IOC_WR_BITS_PER_WORD, &bits); -} -	 - -spidev::~spidev() -{ -	close(fd); -} - -void spidev::send(char *buf, char *rbuf, unsigned int nbytes) -{ -	int ret; - -	struct spi_ioc_transfer tr; -	tr.tx_buf = (unsigned long) buf; -	tr.rx_buf = (unsigned long) rbuf; -	tr.len = nbytes; -	tr.delay_usecs = 0; -	tr.speed_hz = 48000000; -	tr.bits_per_word = 8; - -	ret = ioctl(fd, SPI_IOC_MESSAGE(1), &tr);	 - -} - -static void send_file_to_fpga(std::string &file_name, gpio &error, gpio &done) -{ -	std::ifstream bitstream; - -	std::cout << "File name - " << file_name.c_str() << std::endl; - -	bitstream.open(file_name.c_str(), std::ios::binary); -	if (!bitstream.is_open()) -		std::cout << "File " << file_name << " not opened succesfully." << std::endl; - -	spidev spi("/dev/spidev1.0"); -	char buf[BUF_SIZE]; -	char rbuf[BUF_SIZE]; - -	do { -		bitstream.read(buf, BUF_SIZE); -		spi.send(buf, rbuf, bitstream.gcount()); - -		if (error.get_value()) -			std::cout << "INIT_B went high, error occured." << std::endl; - -		if (!done.get_value()) -			std::cout << "Configuration complete." << std::endl; - -	} while (bitstream.gcount() == BUF_SIZE); -} - -int main(int argc, char *argv[]) -{ - -	gpio gpio_prog_b(PROG_B, OUT); -	gpio gpio_init_b(INIT_B, IN); -	gpio gpio_done  (DONE,   IN); - -	if (argc == 2) -		bit_file = argv[1]; - -	std::cout << "FPGA config file: " << bit_file << std::endl; - -	prepare_fpga_for_configuration(gpio_prog_b, gpio_init_b); - -	std::cout << "Done = " << gpio_done.get_value() << std::endl; - -	send_file_to_fpga(bit_file, gpio_init_b, gpio_done); -} - diff --git a/host/apps/omap_debug/usrp-e-timed.c b/host/apps/omap_debug/usrp-e-timed.c deleted file mode 100644 index 3cb33ce2d..000000000 --- a/host/apps/omap_debug/usrp-e-timed.c +++ /dev/null @@ -1,233 +0,0 @@ -#include <stdio.h> -#include <sys/types.h> -#include <fcntl.h> -#include <pthread.h> -#include <stdlib.h> -#include <unistd.h> -#include <stddef.h> -#include "usrp_e.h" - -// max length #define PKT_DATA_LENGTH 1016 -static int packet_data_length; - -struct pkt { -	int checksum; -	int seq_num; -	short data[]; -}; - -static int fp; - -static int calc_checksum(struct pkt *p) -{ -	int i, sum; - -	i = 0; -	sum = 0; - -	for (i=0; i < packet_data_length; i++) -		sum += p->data[i]; - -	sum += p->seq_num; - -	return sum; -} - -static void *read_thread(void *threadid) -{ -	int cnt, prev_seq_num; -	struct usrp_transfer_frame *rx_data; -	struct pkt *p; -	int rx_pkt_cnt; -	int i; -	unsigned long bytes_transfered, elapsed_seconds; -	struct timeval start_time, finish_time; - -	printf("Greetings from the reading thread!\n"); - -	bytes_transfered = 0; -	gettimeofday(&start_time, NULL); - -	// IMPORTANT: must assume max length packet from fpga -	rx_data = malloc(sizeof(struct usrp_transfer_frame) + sizeof(struct pkt) + (1016 * 2)); -	p = (struct pkt *) ((void *)rx_data + offsetof(struct usrp_transfer_frame, buf)); -	//p = &(rx_data->buf[0]); -	printf("Address of rx_data = %p, p = %p\n", rx_data, p); -	printf("offsetof = %d\n", offsetof(struct usrp_transfer_frame, buf)); -	printf("sizeof rx data = %d\n", sizeof(struct usrp_transfer_frame) + sizeof(struct pkt)); - -	prev_seq_num = 0; - -	rx_pkt_cnt = 0; - -	while (1) { - -		cnt = read(fp, rx_data, 2048); -		if (cnt < 0) -			printf("Error returned from read: %d\n", cnt); -		rx_pkt_cnt++; - -#if 0 -		if (rx_pkt_cnt  == 512) { -			printf("."); -			fflush(stdout); -			rx_pkt_cnt = 0; -		} -#endif - -		if (rx_data->status & RB_OVERRUN) -			printf("O"); - -		bytes_transfered += rx_data->len; - -		if (bytes_transfered > (100 * 1000000)) { -			gettimeofday(&finish_time, NULL); -			elapsed_seconds = finish_time.tv_sec - start_time.tv_sec; - -			printf("RX data transfer rate = %f K Samples/second\n", -				(float) bytes_transfered / (float) elapsed_seconds / 4000); - - -			start_time = finish_time; -			bytes_transfered = 0; -                } -	} - -} - -static void *write_thread(void *threadid) -{ -	int seq_number, i, cnt, tx_pkt_cnt; -	struct usrp_transfer_frame *tx_data; -	struct pkt *p; -	unsigned long bytes_transfered, elapsed_seconds; -	struct timeval start_time, finish_time; - -	printf("Greetings from the write thread!\n"); - -	bytes_transfered = 0; -	gettimeofday(&start_time, NULL); - -	tx_data = malloc(sizeof(struct usrp_transfer_frame) + sizeof(struct pkt) + (packet_data_length * 2)); -	p = (struct pkt *) ((void *)tx_data + offsetof(struct usrp_transfer_frame, buf)); -	printf("Address of tx_data = %p, p = %p\n", tx_data, p); - -	printf("sizeof rp_transfer_frame = %d, sizeof pkt = %d\n", sizeof(struct usrp_transfer_frame), sizeof(struct pkt)); - -	for (i=0; i < packet_data_length; i++) -//		p->data[i] = random() >> 16; -		p->data[i] = i; - -	tx_data->status = 0; -	tx_data->len = 8 + packet_data_length * 2; - -	printf("tx_data->len = %d\n", tx_data->len); - -	seq_number = 1; -	tx_pkt_cnt = 0; - -	while (1) { - -		tx_pkt_cnt++; - -#if 0 -		if (tx_pkt_cnt  == 512) { -			printf("."); -			fflush(stdout); -		} -		if (tx_pkt_cnt  == 1024) { -			printf("'"); -			fflush(stdout); -		} -		if (tx_pkt_cnt  == 1536) { -			printf(":"); -			fflush(stdout); -			tx_pkt_cnt = 0; -		} -#endif - -//		printf("tx status = %X, len = %d\n", tx_data->status, tx_data->len); -		p->seq_num = seq_number++; -		p->checksum = calc_checksum(p); -		cnt = write(fp, tx_data, 2048); -		if (cnt < 0) -			printf("Error returned from write: %d\n", cnt); - -		bytes_transfered += tx_data->len; - -		if (bytes_transfered > (100 * 1000000)) { -			gettimeofday(&finish_time, NULL); -			elapsed_seconds = finish_time.tv_sec - start_time.tv_sec; - -			printf("TX data transfer rate = %f K Samples/second\n", -				(float) bytes_transfered / (float) elapsed_seconds / 4000); - - -			start_time = finish_time; -			bytes_transfered = 0; -                } -//		sleep(1); -	} -} - - -int main(int argc, char *argv[]) -{ -	pthread_t tx, rx; -	long int t; -	int fpga_config_flag ,decimation; -	struct usrp_e_ctl16 d; -	struct sched_param s = { -		.sched_priority = 1 -	}; - -	if (argc < 4) { -		printf("%s r|w|rw decimation data_size\n", argv[0]); -		return -1; -	} - -	decimation = atoi(argv[2]); -	packet_data_length = atoi(argv[3]); - -	fp = open("/dev/usrp_e0", O_RDWR); -	printf("fp = %d\n", fp); - -	fpga_config_flag = 0; -	if (strcmp(argv[1], "w") == 0) -		fpga_config_flag |= (1 << 15); -	else if (strcmp(argv[1], "r") == 0) -		fpga_config_flag |= (1 << 14); -	else if (strcmp(argv[1], "rw") == 0) -		fpga_config_flag |= ((1 << 15) | (1 << 14)); - -	fpga_config_flag |= decimation; - -	d.offset = 14; -	d.count = 1; -	d.buf[0] = fpga_config_flag; -	ioctl(fp, USRP_E_WRITE_CTL16, &d); - -	sleep(1); // in case the kernel threads need time to start. FIXME if so - -	sched_setscheduler(0, SCHED_RR, &s); - -	if (fpga_config_flag & (1 << 14)) { -		if (pthread_create(&rx, NULL, read_thread, (void *) t)) { -			printf("Failed to create rx thread\n"); -			exit(-1); -		} -	} - -	sleep(1); - -	if (fpga_config_flag & (1 << 15)) { -		if (pthread_create(&tx, NULL, write_thread, (void *) t)) { -			printf("Failed to create tx thread\n"); -			exit(-1); -		} -	} - -	sleep(10000); - -	printf("Done sleeping\n"); -} | 
