fx2/linux/apps/strm_ddr2.c
2013-10-02 10:43:54 +02:00

120 lines
2.8 KiB
C

/*********************************************
* (2013) Benjamin Krill <ben@codiert.org>
*********************************************/
#include <stdlib.h>
#include <stdio.h>
#include <errno.h>
#include <string.h>
#include <time.h>
#include <usb.h>
#include <strm.h>
static void
show_usage(char *name)
{
printf("USAGE: %s <r|w> <address> <size> [<pattern>]\n"
"\tw - write needs address, size, pattern\n"
"\tr - read needs address, size\n"
"\t\tsize in DW (4bytes)\n"
, name);
return;
}
int
main(int argc, char **argv)
{
uint32_t *buf, pattern;
int address, size, size_dw, i;
clock_t start, end;
int ret = -1;
usb_dev_handle *hd;
if (argc < 3 || (strncmp(argv[1], "w", 1) == 0 && argc < 5)) {
show_usage(argv[0]);
exit(1);
}
if ((hd = strm_init(0x04b4, 0x2342)) == NULL) {
perror("cannot init usb2strm interface");
exit(1);
}
address = strtoull(argv[2], NULL, 0);
size_dw = strtoull(argv[3], NULL, 0);
size = size_dw*4;
if (size_dw > 0xffffff) {
perror("size cannot larger than 0xffffff DW");
goto out;
}
buf = (uint32_t*)malloc(size+8);
if (buf == NULL) {
perror("cannot allocate memory\n");
goto out;
}
if (strncmp(argv[1], "w", 1) == 0) {
pattern = strtoull(argv[4], NULL, 0);
for (i=0; i < size_dw; i++) {
buf[i+2] = pattern;
}
buf[0] = STRM_TYPE_DDR2 << 28 | ((size_dw+1) & 0xffffff);
buf[1] = STRM_DDR2_WRITE_HDR_INIT(address >> 2);
printf("address=0x%x size=%d pattern=0x%06x - ", address, size, pattern);
start = clock();
if ((ret = usb_bulk_write(hd, 2, (const char *)buf, size+8, 1000)) < 0) {
fprintf(stderr, "\nFAILED: write bulk transfer (%d) [%s].\n\t%s\n", ret,
__func__, usb_strerror());
} else {
printf("wrote: %d bytes\n", ret);
}
end = clock();
printf("Number of seconds: %f\n", (end-start)/(double)CLOCKS_PER_SEC);
} else if (strncmp(argv[1], "r", 1) == 0) {
buf[0] = STRM_TYPE_DDR2 << 28 | 2;
buf[1] = STRM_DDR2_READ_HDR_INIT(address >> 2);
buf[2] = ((size_dw) & 0xffffff);
printf("address=0x%x size=%d - ", address, size);
if ((ret = usb_bulk_write(hd, 2, (const char *)buf, 12, 1000)) < 0) {
fprintf(stderr, "\nFAILED: write bulk transfer (%d) [%s].\n\t%s\n", ret,
__func__, usb_strerror());
goto free;
} else {
printf("wrote: %d bytes\n", ret);
}
if ((ret = usb_bulk_read(hd, 6, (char *)buf, size+4, 6000000)) < 0) {
fprintf(stderr, "\nFAILED: read bulk transfer (%d) [%s].\n\t%s\n", ret,
__func__, usb_strerror());
goto free;
} else {
printf("read: %d bytes\n", ret);
}
for (i=0; i < size+4; i++) {
if (!(i%0x10))
printf("\n");
printf("%02x ", ((uint8_t*)buf)[i]);
}
printf("\n");
} else {
printf("Unknown argument.\n");
return -1;
}
free:
free(buf);
out:
strm_fini();
return 0;
}