aboutsummaryrefslogtreecommitdiffstats
path: root/host/usrp_e_utils/usrp-e-debug-pins.c
diff options
context:
space:
mode:
authorJosh Blum <josh@joshknows.com>2011-01-23 18:48:16 +0000
committerJosh Blum <josh@joshknows.com>2011-01-23 18:48:16 +0000
commitb3df6a0ebfa288d032d917b48b69f036444e57b6 (patch)
tree244ddbd86e71bd40dd4a1ed81e168ed4627cc95d /host/usrp_e_utils/usrp-e-debug-pins.c
parent3db02acdfd44b22c05eaafe66e751f8fbfb29dcd (diff)
downloaduhd-b3df6a0ebfa288d032d917b48b69f036444e57b6.tar.gz
uhd-b3df6a0ebfa288d032d917b48b69f036444e57b6.tar.bz2
uhd-b3df6a0ebfa288d032d917b48b69f036444e57b6.zip
usrp-e100: created component for stand-alone usrp-e utils and added wb test util
Diffstat (limited to 'host/usrp_e_utils/usrp-e-debug-pins.c')
-rw-r--r--host/usrp_e_utils/usrp-e-debug-pins.c78
1 files changed, 78 insertions, 0 deletions
diff --git a/host/usrp_e_utils/usrp-e-debug-pins.c b/host/usrp_e_utils/usrp-e-debug-pins.c
new file mode 100644
index 000000000..94f898b67
--- /dev/null
+++ b/host/usrp_e_utils/usrp-e-debug-pins.c
@@ -0,0 +1,78 @@
+#include <stdio.h>
+#include <stdlib.h>
+#include <unistd.h>
+#include <sys/types.h>
+#include <fcntl.h>
+#include <string.h>
+#include <sys/ioctl.h>
+
+#include <linux/usrp_e.h>
+#include "usrp_e100_regs.hpp"
+
+// Usage: usrp_e_gpio <string>
+
+static int fp;
+
+static int read_reg(__u16 reg)
+{
+ int ret;
+ struct usrp_e_ctl16 d;
+
+ d.offset = reg;
+ d.count = 1;
+ ret = ioctl(fp, USRP_E_READ_CTL16, &d);
+ return d.buf[0];
+}
+
+static void write_reg(__u16 reg, __u16 val)
+{
+ int ret;
+ struct usrp_e_ctl16 d;
+
+ d.offset = reg;
+ d.count = 1;
+ d.buf[0] = val;
+ ret = ioctl(fp, USRP_E_WRITE_CTL16, &d);
+}
+
+int main(int argc, char *argv[])
+{
+ int test;
+
+ test = 0;
+ if (argc < 2) {
+ printf("%s 0|1|off\n", argv[0]);
+ return -1;
+ }
+
+ fp = open("/dev/usrp_e0", O_RDWR);
+ printf("fp = %d\n", fp);
+ if (fp < 0) {
+ perror("Open failed");
+ return -1;
+ }
+
+ if (strcmp(argv[1], "0") == 0) {
+ printf("Selected 0 based on %s\n", argv[1]);
+ write_reg(UE_REG_GPIO_TX_DDR, 0xFFFF);
+ write_reg(UE_REG_GPIO_RX_DDR, 0xFFFF);
+ write_reg(UE_REG_GPIO_TX_SEL, 0x0);
+ write_reg(UE_REG_GPIO_RX_SEL, 0x0);
+ write_reg(UE_REG_GPIO_TX_DBG, 0xFFFF);
+ write_reg(UE_REG_GPIO_RX_DBG, 0xFFFF);
+ } else if (strcmp(argv[1], "1") == 0) {
+ printf("Selected 1 based on %s\n", argv[1]);
+ write_reg(UE_REG_GPIO_TX_DDR, 0xFFFF);
+ write_reg(UE_REG_GPIO_RX_DDR, 0xFFFF);
+ write_reg(UE_REG_GPIO_TX_SEL, 0xFFFF);
+ write_reg(UE_REG_GPIO_RX_SEL, 0xFFFF);
+ write_reg(UE_REG_GPIO_TX_DBG, 0xFFFF);
+ write_reg(UE_REG_GPIO_RX_DBG, 0xFFFF);
+ } else {
+ printf("Selected off based on %s\n", argv[1]);
+ write_reg(UE_REG_GPIO_TX_DDR, 0x0);
+ write_reg(UE_REG_GPIO_RX_DDR, 0x0);
+ }
+
+ return 0;
+}