Date: Thu, 13 Sep 2007 23:48:29 GMT From: Kip Macy <kmacy@FreeBSD.org> To: Perforce Change Reviews <perforce@freebsd.org> Subject: PERFORCE change 126387 for review Message-ID: <200709132348.l8DNmT4I079871@repoman.freebsd.org>
next in thread | raw e-mail | index | archive | help
http://perforce.freebsd.org/chv.cgi?CH=126387 Change 126387 by kmacy@kmacy_home:ethng on 2007/09/13 23:47:39 add support for WRC Affected files ... .. //depot/projects/ethng/src/usr.sbin/cxgbtool/Makefile#2 edit .. //depot/projects/ethng/src/usr.sbin/cxgbtool/cxgbtool.c#2 edit Differences ... ==== //depot/projects/ethng/src/usr.sbin/cxgbtool/Makefile#2 (text+ko) ==== @@ -4,7 +4,7 @@ SRCS= cxgbtool.c NO_MAN= CFLAGS+= -I${.CURDIR}/../../sys/dev/cxgb -I. -CFLAGS+= -DCONFIG_T3_REGS -DCHELSIO_INTERNAL +CFLAGS+= -DCONFIG_T3_REGS -DCHELSIO_INTERNAL -DWRC install: ==== //depot/projects/ethng/src/usr.sbin/cxgbtool/cxgbtool.c#2 (text+ko) ==== @@ -68,6 +68,41 @@ #include <common/cxgb_regs.h> #include "version.h" +struct toetool_reg { + uint32_t cmd; + uint32_t addr; + uint32_t val; +}; + +struct toetool_mtus { + uint32_t cmd; + uint32_t nmtus; + uint16_t mtus[NMTUS]; +}; + +struct toetool_pm { + uint32_t cmd; + uint32_t tx_pg_sz; + uint32_t tx_num_pg; + uint32_t rx_pg_sz; + uint32_t rx_num_pg; + uint32_t pm_total; +}; + +struct toetool_tcam { + uint32_t cmd; + uint32_t tcam_size; + uint32_t nservers; + uint32_t nroutes; + uint32_t nfilters; +}; + +struct toetool_tcb { + uint32_t cmd; + uint32_t tcb_index; + uint32_t tcb_data[TCB_WORDS]; +}; + struct reg_info { const char *name; uint16_t addr; @@ -75,6 +110,80 @@ }; +struct toetool_tcam_word { + uint32_t cmd; + uint32_t addr; + uint32_t buf[3]; +}; + + +struct toetool_cntxt { + uint32_t cmd; + uint32_t cntxt_type; + uint32_t cntxt_id; + uint32_t data[4]; +}; + +struct toetool_desc { + uint32_t cmd; + uint32_t queue_num; + uint32_t idx; + uint32_t size; + uint8_t data[128]; +}; + +struct toetool_proto { + uint32_t cmd; + uint32_t data[5 * 128]; +}; + +struct toetool_qset_params { + uint32_t cmd; + uint32_t qset_idx; + int32_t txq_size[3]; + int32_t rspq_size; + int32_t fl_size[2]; + int32_t intr_lat; + int32_t polling; + int32_t lro; + int32_t cong_thres; + int32_t vector; + int32_t qnum; +}; + +struct toetool_trace { + uint32_t cmd; + uint32_t sip; + uint32_t sip_mask; + uint32_t dip; + uint32_t dip_mask; + uint16_t sport; + uint16_t sport_mask; + uint16_t dport; + uint16_t dport_mask; + uint32_t vlan:12; + uint32_t vlan_mask:12; + uint32_t intf:4; + uint32_t intf_mask:4; + uint8_t proto; + uint8_t proto_mask; + uint8_t invert_match:1; + uint8_t config_tx:1; + uint8_t config_rx:1; + uint8_t trace_tx:1; + uint8_t trace_rx:1; +}; + +struct toetool_pktsched_params { + uint32_t cmd; + uint8_t sched; + uint8_t idx; + uint8_t min; + uint8_t max; + uint8_t binding; +}; + + #include "reg_defs.c" #if defined(CONFIG_T3_REGS) # include "reg_defs_t3.c" @@ -447,7 +556,7 @@ if (revision == 0) return dump_regs_t3(argc, argv, start_arg, (uint32_t *)regs.data, is_pcie); - if (revision == 2) + if (revision == 2 || revision == 3) return dump_regs_t3b(argc, argv, start_arg, (uint32_t *)regs.data, is_pcie); } @@ -562,14 +671,14 @@ if (argc == start_arg) { op.cmd = TOETOOL_GETMTUTAB; - op.nmtus = MAX_NMTUS; + op.nmtus = NMTUS; if (doit(iff_name, &op) < 0) err(1, "get MTU table"); for (i = 0; i < op.nmtus; ++i) printf("%u ", op.mtus[i]); printf("\n"); - } else if (argc <= start_arg + MAX_NMTUS) { + } else if (argc <= start_arg + NMTUS) { op.cmd = TOETOOL_SETMTUTAB; op.nmtus = argc - start_arg; @@ -830,14 +939,10 @@ #define FBUF_WRAP_FSZ (FBUF_WRAP_SZ >> 3) #define MEM_CM_WRC_SIZE WRC_SIZE -typedef char int8_t; -typedef short int16_t; -typedef int int32_t; typedef long long _s64; typedef unsigned char _u8; typedef unsigned short _u16; typedef unsigned int _uint32_t; -typedef unsigned long long uint64_t; enum fw_ri_mpa_attrs { FW_RI_MPA_RX_MARKER_ENABLE = 0x1, @@ -1005,7 +1110,7 @@ static void print_wrc(unsigned int wrc_idx, struct wrc *p) { - u32 *buf = (u32 *)p; + uint32_t *buf = (uint32_t *)p; unsigned int i, j; printf("WRC STATE (raw)\n"); @@ -1094,7 +1199,7 @@ static int get_wrc(int argc, char *argv[], int start_arg, const char *iff_name) { - struct toetool_mem_range *op; + struct ch_mem_range op; uint64_t *p; uint32_t *buf; unsigned int idx, i = 0; @@ -1105,34 +1210,33 @@ if (get_int_arg(argv[start_arg], &idx)) return -1; - op = malloc(sizeof(*op) + MEM_CM_WRC_SIZE); - if (!op) + op.buf =malloc(MEM_CM_WRC_SIZE); + if (!op.buf) err(1, "get_wrc: malloc failed"); - op->cmd = TOETOOL_GET_MEM; - op->mem_id = MEM_CM; - op->addr = read_reg(iff_name, 0x28c) + CM_WRCONTEXT_OFFSET + + buf = (uint32_t *)op.buf; + op.mem_id = MEM_CM; + op.addr = read_reg(iff_name, 0x28c) + CM_WRCONTEXT_OFFSET + idx * MEM_CM_WRC_SIZE; - op->len = MEM_CM_WRC_SIZE; - buf = (uint32_t *)op->buf; + op.len = MEM_CM_WRC_SIZE; - if (doit(iff_name, op) < 0) + if (doit(iff_name, CHELSIO_GET_MEM, &op) < 0) err(1, "get_wrc"); - + /* driver manges with the data... put it back into the the FW's view */ - for (p = (uint64_t *)op->buf; - p < (uint64_t *)(op->buf + MEM_CM_WRC_SIZE); p++) { + for (p = (uint64_t *)op.buf; + p < (uint64_t *)(op.buf + MEM_CM_WRC_SIZE); p++) { uint64_t flit = *p; buf[i++] = htonl((uint32_t)(flit >> 32)); buf[i++] = htonl((uint32_t)flit); } - print_wrc(idx, (struct wrc *)op->buf); - print_wrc_zero(idx, (struct wrc *)op->buf); - print_wrc_history((struct wrc *)op->buf); + print_wrc(idx, (struct wrc *)op.buf); + print_wrc_zero(idx, (struct wrc *)op.buf); + print_wrc_history((struct wrc *)op.buf); - free(op); + free(buf); return 0; } #endif @@ -1737,7 +1841,8 @@ } } - if (argc < 3) usage(stderr); + if (argc < 3) + usage(stderr); iff_name = argv[1]; if (!strcmp(argv[2], "reg")) @@ -1757,11 +1862,12 @@ r = conf_tcam(argc, argv, 3, iff_name); else if (!strcmp(argv[2], "tcb")) r = get_tcb(argc, argv, 3, iff_name); +#endif #ifdef WRC - else if (!strcmp(argv[2], "wrc")) + else if (!strcmp(argv[2], "wrc")) r = get_wrc(argc, argv, 3, iff_name); #endif -#endif + else if (!strcmp(argv[2], "regdump")) r = dump_regs(argc, argv, 3, iff_name); #ifdef CHELSIO_INTERNAL
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?200709132348.l8DNmT4I079871>