Index: head/contrib/ofed/libcxgb4/AUTHORS =================================================================== --- head/contrib/ofed/libcxgb4/AUTHORS (nonexistent) +++ head/contrib/ofed/libcxgb4/AUTHORS (revision 273806) @@ -0,0 +1 @@ +Chelsio Communications, Inc. Index: head/contrib/ofed/libcxgb4/COPYING =================================================================== --- head/contrib/ofed/libcxgb4/COPYING (nonexistent) +++ head/contrib/ofed/libcxgb4/COPYING (revision 273806) @@ -0,0 +1,29 @@ +Copyright (c) 2010-2013. Chelsio Communications. All rights reserved. + +This software is available to you under a choice of one of two +licenses. You may choose to be licensed under the terms of the GNU +General Public License (GPL) Version 2, available from the file +COPYING in the main directory of this source tree, or the +OpenIB.org BSD license below: + + Redistribution and use in source and binary forms, with or + without modification, are permitted provided that the following + conditions are met: + + - Redistributions of source code must retain the above + copyright notice, this list of conditions and the following + disclaimer. + + - Redistributions in binary form must reproduce the above + copyright notice, this list of conditions and the following + disclaimer in the documentation and/or other materials + provided with the distribution. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, +EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND +NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS +BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN +ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN +CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +SOFTWARE. Index: head/contrib/ofed/libcxgb4/ChangeLog =================================================================== --- head/contrib/ofed/libcxgb4/ChangeLog (nonexistent) +++ head/contrib/ofed/libcxgb4/ChangeLog (revision 273806) @@ -0,0 +1,1054 @@ +commit 6a417d903b9add7c8ab2b71ac11c85c46671e020 +Author: Steve Wise +Date: Thu Jul 31 11:25:22 2014 -0500 + + Spin release 1.3.5. + + Signed-off-by: Steve Wise + +commit 52ecbea1b908d3b449022e2d75ebe0ca3885bcf2 +Author: Steve Wise +Date: Thu Jul 31 11:14:05 2014 -0500 + + libcxb4: use wc_wmb() instead of wmb(). + + The user mode RDMA macro for wmb() is not sufficient to provide the + fencing needed. This was causing corrupted packets when running multiple + WD-UDP sockperf processes. The correct "sfence" instruction is provided + with the wc_wmb() macro. See /usr/include/infiniband/arch.h. + + Note: The kernel implementation of wmb() is sufficient. This is a + libcxgb4 issue only... + + Signed-off-by: Steve Wise + +commit 242c29715372bf6999aa343a5aad5654da3ecf3a +Author: Steve Wise +Date: Wed Jun 18 10:17:00 2014 -0500 + + Spin release 1.3.4 + + Signed-off-by: Steve Wise + +commit 2d54f4c5604cae24caac493aaf6d8b0907ac2ed2 +Author: Steve Wise +Date: Wed Jun 18 10:16:52 2014 -0500 + + Support the query_qp() verb + + Signed-off-by: Steve Wise + +commit f80159d12148774646ad65d03cd070f6d5f86eb4 +Author: Steve Wise +Date: Mon Jun 9 15:20:47 2014 -0500 + + Account for the full qid range. + + The total qid range is should really be based on the max_cq attribute. + + Signed-off-by: Steve Wise + +commit 5aaf5e7277a1c12964aac11a4cff94520717e805 +Author: Yann Droneaud +Date: Mon May 5 12:59:23 2014 -0500 + + kernel abi: adds explicit padding in struct c4iw_alloc_ucontext_resp + + i386 ABI disagree with most other ABIs regarding alignment + of data type larger than 4 bytes: on most ABIs a padding must + be added at end of the structures, while it is not + required on i386. + + Such ABI disagreement will make an x86_64 kernel try to write past + the struct c4iw_alloc_ucontext_resp buffer provided by an i386 + userspace binary. As struct c4iw_alloc_ucontext_resp is likely + on stack, see function c4iw_alloc_context(), side effects are + expected. + + On kernel side, this structure was modified for kernel v3.15-rc1 + by following commit: + + Commit 05eb23893c2cf9502a9cec0c32e7f1d1ed2895c8 + Author: Steve Wise + Date: Fri Mar 14 21:52:08 2014 +0530 + + cxgb4/iw_cxgb4: Doorbell Drop Avoidance Bug Fixes + + If boundary check is implemented on kernel side, the x86_64 + kernel will instead refuse to write past the i386 userspace + provided buffer and the uverbs will fail. + + To fix these issues, this patch adds an explicit padding at end + of structure so that i386 and others ABI share the same structure + layout. This patch makes c4iw_alloc_context() check for a value + in the padding field to detect newer kernel using the field for + a future purpose (only activated in debug). + + With this patch, libcxgb4 will work against older kernel and + newer patched kernel. + + Link: http://marc.info/?i=cover.1399216475.git.ydroneaud@opteya.com + Signed-off-by: Yann Droneaud + Signed-off-by: Steve Wise + +commit 5c65bf17913949368db8802656dc7dbc291271ed +Author: Yann Droneaud +Date: Mon May 5 12:59:23 2014 -0500 + + kernel abi: adds explicit padding in struct c4iw_create_cq_resp + + i386 ABI disagree with most other ABIs regarding alignment + of data type larger than 4 bytes: on most ABIs a padding must + be added at end of the structures, while it is not required + on i386. + + Such ABI disagreement will make an x86_64 kernel try to write past + the struct c4iw_create_cq_resp buffer provided by an i386 + userspace binary. As struct c4iw_create_cq_resp is likely + on stack, see function c4iw_create_cq(), side effects are + expected. + + On kernel side, this structure was added for kernel v2.6.35-rc1 + by following commit. + + Commit cfdda9d764362ab77b11a410bb928400e6520d57 + Author: Steve Wise + Date: Wed Apr 21 15:30:06 2010 -0700 + + RDMA/cxgb4: Add driver for Chelsio T4 RNIC + + If boundary check is implemented on kernel side, the x86_64 kernel + will refuse to write past the i386 userspace provided buffer and the + uverbs will fail. + + To fix these issues, this patch adds an explicit padding at end + of structure so that i386 and others ABI share the same structure + layout. This patch makes c4iw_create_cq() check for a value in the + padding field to detect newer kernel using the field for a future + purpose (only activated in debug). + + With this patch, libcxgb4 will work against older kernel and + newer patched kernel. + + Link: http://marc.info/?i=cover.1399216475.git.ydroneaud@opteya.com + + Signed-off-by: Yann Droneaud + Signed-off-by: Steve Wise + +commit 4f334446f63e3a34006f504f7c89075423c412b4 +Author: Steve Wise +Date: Tue Mar 11 11:47:19 2014 -0500 + + Spin release 1.3.3. + + Signed-off-by: Steve Wise + +commit 98cea522707232b99ff5c07dd9f57937aa8a7d91 +Author: Steve Wise +Date: Tue Mar 11 11:44:16 2014 -0500 + + Zero the status_page_size before calling get_context. + + Signed-off-by: Steve Wise + +commit a373e16a94524e20492301b0e97f53930133739b +Author: Steve Wise +Date: Tue Feb 18 12:07:19 2014 -0600 + + Spin release 1.3.2. + + Signed-off-by: Steve Wise + +commit a2f25730971e8b76033e283f03e79ef4c5dbc4bc +Author: Steve Wise +Date: Tue Feb 18 11:29:50 2014 -0600 + + Fixed compilation error with debug enabled. + + Signed-off-by: Steve Wise + +commit f484e0f4c5a4cb249f86a050efd659be37a51204 +Author: Steve Wise +Date: Tue Feb 18 11:24:06 2014 -0600 + + Use V_PIDX_T5() for T5 devices in ring_db funcs. + + Signed-off-by: Steve Wise + +commit 32b74074808da51e5918295bfc63d347548478a0 +Author: Steve Wise +Date: Tue Feb 18 11:24:05 2014 -0600 + + Call wc_wmb() needed after DB writes. + + Need to do an sfence after botht he WC and regular PIDX DB write. + Otherwise the host might reorder things and cause work request corruption + (seen with NFSRDMA). + + Signed-off-by: Steve Wise + +commit c078eed091a32b930f5bbdf0a12a3be0d0a79cf0 +Author: Steve Wise +Date: Tue Feb 18 11:23:57 2014 -0600 + + Call rmb() after reading valid gen bit. + + Some HW platforms can reorder read operations, so we must rmb() after + we see a valid gen bit in a CQE but before we read any other fields + from the CQE. + + Signed-off-by: Steve Wise + +commit 7b482dcdbbd187fd8372f744157ac2b323d32f45 +Author: Steve Wise +Date: Tue Feb 18 11:12:06 2014 -0600 + + Update copyrights. + + Signed-off-by: Steve Wise + +commit f74316373c0b2a2bd2872ae38f7be516a10503c9 +Author: Steve Wise +Date: Tue Feb 18 11:12:06 2014 -0600 + + Refresh t4 fw/hw reg files. + + Signed-off-by: Steve Wise + +commit 1b8434f22deb30f700246dd2f474eaa2512e4867 +Author: Steve Wise +Date: Tue Feb 18 11:12:03 2014 -0600 + + Add common device id table and chip types. + + This will make it easier to merge in new devices. + +commit 18e5bc32bbe7e19eb9ea5a34d8b2f7d1e6355105 +Author: Steve Wise +Date: Tue Feb 18 10:25:33 2014 -0600 + + Remove dead SIM code. + + Signed-off-by: Steve Wise + +commit c8c793385de1d3e9c1edeb7b13cbc964049b8362 +Author: Steve Wise +Date: Tue Feb 18 10:23:05 2014 -0600 + + Remove dead raw qp code. + + Signed-off-by: Steve Wise + +commit 9302c092d46e4c40cbf6b2189aeda08e5ca3fea4 +Author: Steve Wise +Date: Tue Feb 18 10:17:52 2014 -0600 + + iw_cxgb4/libcxgb4: swsq "signaled" state needs to mind sq_sig_all. + + When a qp is created, the ULP can request that all sq wrs be signaled. + The swsqe entries need to take this into account when marking the entry + as signaled. + + This bug will cause read request CQEs to be silently discarded, and can + cause flush problems because the swsqe entry will be mismarked for qps + created with sq_sig_all set in the qp init attributes. + + Signed-off-by: Steve Wise + +commit 48c6633d4a6510a8c1832ac800f45c2099eb28b4 +Author: Steve Wise +Date: Tue Feb 18 10:17:52 2014 -0600 + + never consume a pending wr in sq flush. + + There is a race when moving a QP from RTS->CLOSING where a SQ work + request could be posted after the FW receives the RDMA_RI/FINI WR. + The SQ work request will never get processed, and should be completed + with FLUSHED status. Function c4iw_flush_sq(), however was dropping + the oldest SQ work request when in CLOSING or IDLE states, instead of + completing the pending work request. If that oldest pending work request + was actually complete and has a CQE in the CQ, then when that CQE is + proceessed in poll_cq, we'll BUG_ON() due to the inconsistent SQ/CQ state. + + This is a very small timing hole and has only been hit once so far. + + c4iw_flush_sq() MUST always flush all non-completed WRs with FLUSHED + status regardless of the QP state. + + Signed-off-by: Steve Wise + +commit 1a3a3e8e8da7463e59b74d5c5396e7bd5e303cd4 +Author: Steve Wise +Date: Tue Feb 18 10:11:35 2014 -0600 + + unmap status page when freeing the context. + + Signed-off-by: Steve Wise + +commit 81e83780e44af2ff25c2572b15fe7e8b8cc6e134 +Author: Steve Wise +Date: Tue Feb 18 10:05:54 2014 -0600 + + DB Drop Avoidance, Version 2. + + Add support for the device status page mapped per device that is used + to enable/disable user db usage. + + Signed-off-by: Steve Wise + +commit 5830447cef866432c4d3e65f7e58c51a0c687798 +Author: Steve Wise +Date: Tue Feb 18 09:40:39 2014 -0600 + + Fix DEBUG code in c4iw_flush_hw_cq(). + + Signed-off-by: Steve Wise + +commit 127bc437797ca34e14b261fa653c1d0524d07272 +Author: Steve Wise +Date: Tue Feb 18 09:40:38 2014 -0600 + + T4 onchip workaround: do the 16 4B MA writes just before DB ring. + + This is a merge of sw repo changesets 1576, 2149, and 2246. + + Signed-off-by: Steve Wise + +commit ac38281728d12a91725aa67e0273dc26976598fb +Author: Steve Wise +Date: Fri Jul 19 09:37:10 2013 -0500 + + Spin release 1.3.1. + + Signed-off-by: Steve Wise + +commit 272fcac194318e13f563b46463726cc03ae83dbe +Author: Steve Wise +Date: Fri Jul 19 09:36:35 2013 -0500 + + Update copyright. + + Signed-off-by: Steve Wise + +commit ba3183d18168f764700ded52651033a79d2a9a86 +Author: Steve Wise +Date: Mon Jun 10 14:10:02 2013 -0500 + + get rid of hard coded queue iqs. + + Since we now get the number of queues available from the driver, + we shouldn't be using the hard coded defines anymore. + + Signed-off-by: Steve Wise + +commit 2095e0a04bc5357da1b9d346e00d52cf7c236cf6 +Author: Steve Wise +Date: Mon Jun 10 14:09:35 2013 -0500 + + update configure.in + + Signed-off-by: Steve Wise + +commit a7a4de4f37a60ffbd8addd8f9ab5505adb86c63f +Author: Steve Wise +Date: Mon Jun 10 14:09:34 2013 -0500 + + Mind the sq_sig_all/sq_sig_type QP attributes. + + Signed-off-by: Steve Wise + +commit 4a485c8dc1c7c70ab85c708bb4c530eef385424d +Author: Steve Wise +Date: Mon Jun 10 14:09:34 2013 -0500 + + always do GTS write if cidx_inc == M_CIDXINC. + + When polling, we do a GTS update if the accumulated cidx_inc == the cq + depth / 16. This works around a T4 bug. However, if the cq is large + enough, cq depth / 16 exceeds the size of the field in the GTS word. + So we also need to update if cidx_inc hits M_CIDXINC to avoid overflowing + the field. + + Signed-off-by: Steve Wise + +commit a276f65add45933cf8b16bb09361786cf1932c4b +Author: Steve Wise +Date: Mon Jun 10 14:09:34 2013 -0500 + + fixed bug where sq.udb was getting overwritten. + + There was an erroneous statement in create_rc_qp() which caused the + sq.udb va to be overwritten with the rq.udb va only for on-chip queues. + This error only affected unmapping of that mapped va when destroying + a qp. In the presence of multiple threads creating/destroying qps, the + erroneously unmapped va could have been assigned to another qp mapping. + This causes intermittent seg faults as libcxgb4 tries to access memory + that has been unmapped in error. + + Signed-off-by: Steve Wise + +commit 1cb6249cf722e265d8e2364de0ee5b0d59a8e4cd +Author: Steve Wise +Date: Mon Jun 10 14:09:34 2013 -0500 + + flush problem with unsignaled wrs. + + c4iw_flush_sq() should only flush wrs that have not already been + flushed. Since we already track where in the sq we've flushed via + sq.cidx_flush, just start at that point and flush any remaining. This bug + only caused a problem in the presence of unsignaled work requests. + + Signed-off-by: Steve Wise + +commit 4132e3434d8ffc2b92055649f42c56be77111216 +Author: Steve Wise +Date: Mon Jun 10 14:09:31 2013 -0500 + + clean up queue dump logic. + + Signed-off-by: Steve Wise + +commit a5e390613548f1dc62d9fe142b6a30a943fc56cf +Author: Steve Wise +Date: Tue Jun 4 12:09:21 2013 -0500 + + accounting for unsignled sq wrs fails to deal with wrap. + + When determining how many wrs are completed with a signaled cqe, + correctly deal with queue wraps. + + Signed-off-by: Steve Wise + +commit 0c1906cec82443e2323dc69dd5c23ae4314087c0 +Author: Steve Wise +Date: Tue Jun 4 12:09:19 2013 -0500 + + Handle qp flushes with pending sw cqes. + + The flush and out of order completion logic has a bug: If out of order + completions are flushed but not yet polled by the consumer and the qp + is then flushed, we end up inserting duplicate completions. + + Signed-off-by: Steve Wise + +commit 26a19bf6d020dbaab8c6cf13396b39a64f952dba +Author: Steve Wise +Date: Tue Jun 4 11:57:00 2013 -0500 + + fixed false uninitialized var warning. + + Signed-off-by: Steve Wise + +commit 119e11e72d20a07a806c3385b8cfa6de93f7d114 +Author: Steve Wise +Date: Thu Mar 28 15:15:39 2013 -0500 + + Spin release 1.3.0 + + Signed-off-by: Steve Wise + +commit a4a0d3fe768ffa33a75ab3df4bd8c678e7f7180b +Author: Steve Wise +Date: Thu Mar 28 15:15:38 2013 -0500 + + Remove aclocal.m4. + + Signed-off-by: Steve Wise + +commit 3c22ddca7cf627d62d06b0ff374fa04192a8cc4c +Author: Steve Wise +Date: Thu Mar 28 15:15:37 2013 -0500 + + libcxgb4: unmap the correct udb/ugts address. + + The various db and gts variables holding the mapped bar2 pointer + get incremented at creation time as a normal part of object creation. + However this causes the wrong address to get unmapped when the object is + destroyed. The result is a mapping leak because the munmap() fails. + So align them back to their proper page boundary when calling munmap(). + + Singed-off-by: Steve Wise + +commit 9b2d3af5735e4067b83cde79e08a37142e8fb895 +Author: Steve Wise +Date: Thu Mar 28 15:15:35 2013 -0500 + + Query device to get the max supported stags, qps, and cqs. + + Signed-off-by: Steve Wise + +commit e8a595da9129d650caf162b7103368af03e07fcc +Author: Steve Wise +Date: Thu Mar 28 15:15:33 2013 -0500 + + Add T5 support. + + This commit is composed of a series of patches to enable T5 support. I + folded them into one commit for simplicity. Plus intermittent patches + caused problems/regressions/etc, so its cleaner to have 1 commit to enable + the new device. + + Signed-off-by: Vipul Pandya + Signed-off-by: Steve Wise + +commit 7cb73aba54eb47d6902c9a3f952c0e37500cac8f +Author: Steve Wise +Date: Mon Mar 4 10:28:32 2013 -0600 + + zero out r3 and r4 fields of fw_ri_send_wr messages. + + Signed-off-by: Steve Wise + +commit f61c762e82b3e6e1c27496eecaf2bf8d00f009e3 +Author: Steve Wise +Date: Mon Mar 4 10:21:39 2013 -0600 + + Add new T4 device IDs. + + Signed-off-by: Steve Wise + +commit c66a627e1e964bad794e9dc40e9a39dc6977aa1e +Author: Steve Wise +Date: Mon Mar 4 10:08:59 2013 -0600 + + flush bug can cause application crash + + This fixes a problem in the flush logic that could occur if the + current position is near the end of the queue and the 'count' being + retired plus this position was greater than the queue size. In this + case the index wasn't being wrapped and the associated swcqe pointer + would point past the end of the CQ. + + Asserts were added to check other possible wrap-error paths. + + This bug was causing mbw to occasionally crash when flushing the qp. + + Signed-off-by: Steve Wise + +commit c5cdab8ad79cecc996d735011b210729fcc95ecd +Author: Steve Wise +Date: Mon Mar 4 10:08:58 2013 -0600 + + Silently eat unsignaled read response cqes. + + Terminator HW always generates read response cqes. We need to silently + eat them vs returning them to the user. The perftest benchmark ib_read_bw + relies on unsignaled work requests and will crash with this fix. + + Signed-off-by: Steve Wise + +commit 1eefdaae19110deae2c20a08ea53cab451fc00bb +Author: Steve Wise +Date: Fri Feb 8 13:51:37 2013 -0600 + + Remove useless dma_addr_t define. + + Signed-off-by: Steve Wise + +commit c551f4632cfcd284ad82d1d9b36d1449d109a5de +Author: Steve Wise +Date: Fri Feb 8 13:51:00 2013 -0600 + + Disable strict aliasing warnings. + + Signed-off-by: Steve Wise + +commit 695a5a4be21f44d49999c83e6ac0699ce90d97c7 +Author: Steve Wise +Date: Wed Nov 9 09:50:32 2011 -0600 + + Spin release 1.2.0. + + Signed-off-by: Steve Wise + +commit 721cfb11ca5697d017bc60167805aea9bbb13ba0 +Author: Vipul Pandya +Date: Mon Nov 7 15:08:45 2011 +0530 + + libcxgb4: Reset flush_cidx before incrementing cidx. + + Signed-off-by: Vipul Pandya + +commit db4fe38c7ee2b3ad9dc8c33f2b54f0c8cdf8b4d2 +Author: Vipul Pandya +Date: Mon Nov 7 15:06:29 2011 +0530 + + libcxgb4: Fix multi-flush logic path....again + + Signed-off-by: Vipul Pandya + +commit 19198bdc2f7feb05babcc2a544ae8b48e4943c41 +Author: Vipul Pandya +Date: Mon Nov 7 15:02:57 2011 +0530 + + libcxgb4: Reset cidx_flush if a active queue starts getting hw cqes + + Signed-off-by: Vipul Pandya + +commit 98545f3a8cbe1670efad080cf908db42269f76ff +Author: Vipul Pandya +Date: Mon Nov 7 14:56:44 2011 +0530 + + libcxgb4: Support for flushing a CQ bound to multiple QPs + + Signed-off-by: Vipul Pandya + +commit 86ba968706b3dc8cb232a303201bb03a2d919c88 +Author: Vipul Pandya +Date: Mon Nov 7 13:06:43 2011 +0530 + + libcxgb4: Checks iw_cxgb4 ABI version to know door bell drop recovery support + + Store iw_cxgb4 ABI version in a global state. Read that global state in + t4_wq_db_enabled to know if iw_cxgb4 driver supports door bell drop recovery. + + Signed-off-by: Vipul Pandya + +commit 2b6563ed5b377dac56c218b809d387089d70312d +Author: Vipul Pandya +Date: Sun Oct 23 16:50:16 2011 +0530 + + libcxgb4: fixed compilation warnings + + Signed-off-by: Vipul Pandya + +commit c5c120969c22a04d34adc566085192afc99d0db9 +Author: Vipul Pandya +Date: Fri Oct 21 19:05:20 2011 +0530 + + libcxgb4: Bug Fix#4410 - Fix 3 segfaults + + This patch fixes 3 segfaults with below signatures: + ---- + 1) + Program received signal SIGSEGV, Segmentation fault. + [Switching to Thread 0x7ffff7fef710 (LWP 22624)] + 0x00007ffff75613e4 in create_read_req_cqe (wq=0x7fffe800ada0, + hw_cqe=0x7ffff7fc7880, read_cqe=0x7ffff7fee860) at src/cq.c:162 + 162 read_cqe->u.rdma.u.scqe.cidx = wq->sq.oldest_read->idx; + (gdb) bt + hw_cqe=0x7ffff7fc7880, read_cqe=0x7ffff7fee860) at src/cq.c:162 + attr=0x7ffff7feeae0, attr_mask=1) at src/verbs.c:691 + src/verbs.c:721 + + 2) + Program received signal SIGSEGV, Segmentation fault. + [Switching to Thread 0x7ffff6e07710 (LWP 22218)] + 0x00007ffff71563e4 in create_read_req_cqe (wq=0x7fffe800ada0, + hw_cqe=0x7ffff7fc7880, read_cqe=0x7ffff6e02b70) at src/cq.c:162 + 162 read_cqe->u.rdma.u.scqe.cidx = wq->sq.oldest_read->idx; + (gdb) bt + hw_cqe=0x7ffff7fc7880, read_cqe=0x7ffff6e02b70) at src/cq.c:162 + src/verbs.c:887 + + 3) + (gdb) bt + wc=0x7ffff51378d0) at src/cq.c:776 + evd_ptr=, wc_ptr=) + at /usr/include/infiniband/verbs.h:957 + ---- + + Signed-off-by: Vipul Pandya + +commit 075adec1159606303b40f4b29ef3cea7ab780ac2 +Author: Vipul Pandya +Date: Fri Oct 21 18:59:16 2011 +0530 + + libcxgb4: return -ENOSYS in c4iw_resize_cq(). + + I fixed a "bug" in c4iw_resize_cq() in an earlier commit which regressed + us. c4iw_resize_cq() was returning 0 always even though we don't support + resizing the CQ. So I change libcxgb4 to return whatever errno is + returned by the kernel driver. However, because the driver didn't set + the uverbs capabilities for resize_cq, uverbs returned EINVAL. The OMPI + code checks for -ENOSYS and handles providers that don't support it. + If, however, ibv_resize_cq() returns any other error, OMPI bails out. + So we need to return -ENOSYS. + + I didn't see this error, however, running NP192 OMPI/IMB all night long. + So it must only try to resize for small jobs and thus I missed the + regression. + + Signed-off-by: Vipul Pandya + +commit 320285a3a3a93a614e24a78f7a68780d7791e3c5 +Author: Vipul Pandya +Date: Fri Oct 21 18:53:47 2011 +0530 + + libcxgb4: Don't flush unsignaled WRs if the QP closed normally + + - add query_qp support in driver to query the qp state before flushing. + + - fixed flush logic (again). + + - don't flush unsignaled WRs is QP had a normal close. + + - support up to 64K QIDs. + + Signed-off-by: Vipul Pandya + +commit 4c98bebe97aeef1c5cda2f071eb9c1d4fa29c37e +Author: Vipul Pandya +Date: Fri Oct 21 17:58:38 2011 +0530 + + libcxgb4: Correctly flush unsignaled WRs followed by a signaled WR. + + The cq flush logic was not accounting for unsignaled SQ WRs followed by + a signaled WR. The result was too many flushed CQEs causing application + faults or assert() failures in libcxgb4 because the SQ state is corrupted. + + Signed-off-by: Vipul Pandya + +commit 8196f85bdefb1511d6d834240a92fdaf815834b8 +Author: Vipul Pandya +Date: Fri Oct 21 17:31:03 2011 +0530 + + libcxgb4: Remove auto generated ltmain.sh file. + + Signed-off-by: Vipul Pandya + +commit 230d12f42d143eeb53d8c4935ba27620c13e6165 +Author: Vipul Pandya +Date: Fri Oct 21 17:20:37 2011 +0530 + + libcxgb4: Add debug code to dump state on a stall condition. + + Signed-off-by: Vipul Pandya + +commit 2df0677b22aebb7a22d0e8ca11beb90250b363c7 +Author: Vipul Pandya +Date: Fri Oct 21 15:04:46 2011 +0530 + + libcxgb4: don't write host idx values when wq is in error. + + This fixes a regression introduced by the db recovery changes. The host + idx shadow fields at the end of the wq should only be written if the wq + is not in error. Otherwise, a seg fault can occur. + + Signed-off-by: Vipul Pandya + +commit 4eaf4b9added6ca660ef2f9363b24d754185fddf +Author: Vipul Pandya +Date: Thu Oct 20 19:55:57 2011 +0530 + + libcxgb4: cq debug changes + + - turn on cq overflow detection by default + + - shadow cq->cidx in the cq status page + + Signed-off-by: Vipul Pandya + +commit b15d02248dd1029706d07fa229767d8b68d16c65 +Author: Vipul Pandya +Date: Thu Oct 20 19:43:07 2011 +0530 + + libcxgb4: DB Drop Recovery for RDMA and LLD queues. + + Signed-off-by: Vipul Pandya + +commit b2c7499eab73cf28cbd9cf86f6ea134e2450cdd3 +Author: Vipul Pandya +Date: Sun Oct 23 12:59:24 2011 +0530 + + libcxgb4: put queue idx values in status page for debug. + + Signed-off-by: Vipul Pandya + +commit 60a30673a4072b6727e7266f7782607ddcbc8de7 +Author: Vipul Pandya +Date: Thu Oct 20 18:07:13 2011 +0530 + + libcxgb4: DB Overflow Avoidance. + + - when user dbs are disabled, call into the kernel driver via modify_qp() + to ring the dbs. + + Signed-off-by: Vipul Pandya + +commit c8651d01a2d69d83caff8c01b32be0b23624d8da +Author: Steve Wise +Date: Thu Mar 10 09:45:00 2011 -0600 + + Spin release 1.1.1. + + Signed-off-by: Steve Wise + +commit ace467085deb7327522faeb19e20e13d691f66a2 +Author: Steve Wise +Date: Thu Mar 10 09:34:11 2011 -0600 + + Flush MA FIFO for on-chip queues. + + Signed-off-by: Steve Wise + +commit 7cb87f46c1784c791d29646104ab355ed920747d +Author: Steve Wise +Date: Thu Mar 10 09:27:57 2011 -0600 + + increase the frequency of CIDX-INC updates. + + Heavy IMB loads reveal that my current algorithm of doing CIDX-INC + GTS writes every 1/2 the CQ depth was not sufficient. This patch + increases the frequency to 1/16. + + Signed-off-by: Steve Wise + +commit 7652d71daadda0c3aba9b96311ea623a1e324d77 +Author: Steve Wise +Date: Wed Sep 15 16:57:04 2010 -0500 + + Spin release 1.1.0. + + Signed-off-by: Steve Wise + +commit ed05d22592bc96987635b2c255a99663f286b812 +Author: Steve Wise +Date: Wed Sep 15 16:56:51 2010 -0500 + + Support all T4 device IDs. + + Signed-off-by: Steve Wise + +commit b051a2ea9dc7b6ffa08f955e60b331e42fec8672 +Author: Steve Wise +Date: Wed Sep 15 15:54:35 2010 -0500 + + Support ABI 0 and 1 versions of the iwarp driver. + + Signed-off-by: Steve Wise + +commit 62f1363bb716e2283f9e2b885e5f02a6d5c692d1 +Author: Steve Wise +Date: Wed Sep 15 14:06:17 2010 -0500 + + Bump the slots per SQ to 5 to allow up to 128MB fast registers. + + Signed-off-by: Steve Wise + +commit d51e041839254d656cc260dba3f26a7c9d73aa56 +Author: Steve Wise +Date: Wed Sep 15 14:06:16 2010 -0500 + + Raw QP implementation + + Signed-off-by: Steve Wise + +commit 8f55539d0b8aea70084edf31687e590cf5a57221 +Author: Steve Wise +Date: Wed Sep 15 14:03:55 2010 -0500 + + Add compile-time user mode rdma stats. + + Signed-off-by: Steve Wise + +commit 2e3531bbd91d7a6f057b3503132aef5e64adb548 +Author: Steve Wise +Date: Wed Sep 15 13:57:03 2010 -0500 + + Support on-chip SQs. + + Signed-off-by: Steve Wise + +commit 65bb173b86c2e0a9ff5f877e4d3951cb8daa6e97 +Author: Steve Wise +Date: Wed Sep 15 13:54:44 2010 -0500 + + Work around TERM CQE hw bug. + + Signed-off-by: Steve Wise + +commit 6bb37d1f72652d4ed0c1972bc673f4418cc7a856 +Author: Steve Wise +Date: Wed Sep 15 13:54:44 2010 -0500 + + Zero out padding in iSGLs. + + Signed-off-by: Steve Wise + +commit aad128404c494ec4779055b5e550c2d7de7d5ca9 +Author: Steve Wise +Date: Thu Jul 22 14:58:51 2010 -0500 + + Spin release 1.0.4 + + Signed-off-by: Steve Wise + +commit 07ac253a8a479fd59fe654baf5a94ffc1de13765 +Author: Steve Wise +Date: Thu Jul 22 14:57:27 2010 -0500 + + Do GTS/CIDX_INC writes in the poll path to avoid drops. + + With T4 asic, we still see the CIDX_INC overflow/drops. + + Signed-off-by: Steve Wise + +commit 3394198639f811c86ab519c43197a9b724435cb0 +Author: Steve Wise +Date: Thu Jul 22 14:56:53 2010 -0500 + + Support T420 and T440 cards. + + Signed-off-by: Steve Wise + +commit 311dd1c8ec3e38287895053dce52dfef5ed5f0b1 +Author: Steve Wise +Date: Fri Jun 11 10:40:53 2010 -0500 + + Spin release 1.0.3. + + Signed-off-by: Steve Wise + +commit a62d7cf38f7b6c731486ff969ee7e3a4238ebc3f +Author: Steve Wise +Date: Fri Jun 11 10:37:17 2010 -0500 + + Support variable sized work requests. + + T4 EQ entries are in multiples of 64B. Currently the RDMA SQ and RQ + use fixed sized entries composed of 4 EQ entries for the SQ and 2 EQ + entries for the RQ. For optimial latency with small IO, we need to + change this so the HW only needs to DMA the EQ entries actually used by + a given work request. + + Implementation: + + - add wq_pidx counter to track where we are in the EQ. cidx/pidx are + used for the sw sq/rq tracking and flow control. + + - the variable part of work requests is the SGL. Add new functions to + build the SGL and/or immediate data directly in the EQ memory wrapping + when needed. + + - adjust the min burst size for the EQ contexts to 64B. + +commit 3be829d117a8ca7957370b09b477fe551de0cea5 +Author: Steve Wise +Date: Thu May 20 15:52:59 2010 -0500 + + Spin release 1.0.2. + + Signed-off-by: Steve Wise + +commit dc1ea232e8ece4ba53d2496befad14bd433e2e3e +Author: Steve Wise +Date: Thu May 20 15:48:37 2010 -0500 + + only insert sq qid in lookup tables. + + Signed-off-by: Steve Wise + +commit 00c60fd47b71dac42d864662567701e2618ff45d +Author: Steve Wise +Date: Thu May 20 15:47:37 2010 -0500 + + Update some driver limits. + + Signed-off-by: Steve Wise + +commit f25661e19d728a0a33a221c0646a9fce9b160f8b +Author: Steve Wise +Date: Thu May 20 15:46:38 2010 -0500 + + Fix cq arm overflow. + + - wrap cq->cqidx_inc based on cq size + - optimize t4_arm_cq() logic + + Signed-off-by: Steve Wise + +commit 8c224aca8f1acd219010e46da538ae4c9a4f9d1a +Author: Steve Wise +Date: Thu May 20 15:45:54 2010 -0500 + + Optimize cq overflow detection. + + 1) save the timestamp flit in the cq when we consume a CQE + + 2) always compare the saved flit with the previous entry flit when reading + the next CQE entry. If the flits don't compare, then we've overflowed. + + Signed-off-by: Steve Wise + +commit 0c0cfbdbeb32548994d94a6278c74e2a4f11d9ba +Author: Steve Wise +Date: Thu May 6 17:57:56 2010 -0500 + + Spin release 1.0.1. + + Signed-off-by: Steve Wise + +commit 5b9ebdfbcd6df0f02375717aff20400ac33dc47f +Author: Steve Wise +Date: Thu May 6 17:34:07 2010 -0500 + + Update code with new t4fw interface. + + Signed-off-by: Steve Wise + +commit 0116d75d8dcc2f4018d0c0074728ca7d127a5065 +Author: Steve Wise +Date: Thu May 6 17:32:10 2010 -0500 + + Refresh t4fw-interface.h + + Signed-off-by: Steve Wise + +commit ad7a3f8dea2873a3a600859cfe8eb10ad979ddb1 +Author: Steve Wise +Date: Thu May 6 17:30:42 2010 -0500 + + Avoid CQ arm overflows. + + There are 2 limits that need to be taken into account when arming the CQ. + 1) the GTS register limits the delta idx to <= M_CIDXINC. + 2) T4 HW limits it to < cq size. + + Update t4_arm_cq() to account for these limits. + +commit 2905808680aad82b4f295850551bbe15711c2f42 +Author: Steve Wise +Date: Thu May 6 17:30:12 2010 -0500 + + Poll fixes. + + - when synthesizing CQEs for the SWCQ, always use SQ QID. + - when flushing, ignore target side read response errors. + + Signed-off-by: Steve Wise + +commit 7a7962e856eb606e25a1529bc7f2945e639042b7 +Author: Steve Wise +Date: Thu May 6 17:24:07 2010 -0500 + + Fix CQ overflow detection. + + CQ overflow detection needs to read the gen bit and the timestamp in + one read operation. Otherwise false overflows can result. + + Signed-off-by: Steve Wise + +commit 5ca340c298c61c9019d8593ee7acdbda93fdd498 +Author: Steve Wise +Date: Thu May 6 17:23:53 2010 -0500 + + libcxgb3: create_read_req_cqe() needs to swap read length. + + Signed-off-by: Steve Wise + +commit 9bd1e60d3aea10dbe7cb9920363e485b845d85a3 +Author: Steve Wise +Date: Wed Apr 14 10:36:41 2010 -0500 + + Refresh t4fw_interface.h + + Signed-off-by: Steve Wise + +commit d6e6ae69be5edffc566178e1b7e6402d61a5a786 +Author: Steve Wise +Date: Fri Apr 2 16:01:31 2010 -0500 + + Add libcxgb4 files. + + Signed-off-by: Steve Wise Index: head/contrib/ofed/libcxgb4/README =================================================================== --- head/contrib/ofed/libcxgb4/README (nonexistent) +++ head/contrib/ofed/libcxgb4/README (revision 273806) @@ -0,0 +1,19 @@ +Introduction +============ + +libcxgb4 is a userspace driver for the Chelsio T5 iWARP RNICs. It works +as a plug-in module for libibverbs that allows programs to use Chelsio +RNICs directly from userspace. See the libibverbs package for more +information. + +Using libcxgb4 +=================== + +libcxgb4 will be loaded and used automatically by programs linked with +libibverbs. The iw_cxgbe kernel module must be loaded for Chelsio RNIC +devices to be detected and used. + +Supported Hardware +================== + +libcxgb4 supports the Chelsio T5 family of adapters. Index: head/contrib/ofed/libcxgb4/cxgb4.driver =================================================================== --- head/contrib/ofed/libcxgb4/cxgb4.driver (nonexistent) +++ head/contrib/ofed/libcxgb4/cxgb4.driver (revision 273806) @@ -0,0 +1 @@ +driver cxgb4 Index: head/contrib/ofed/libcxgb4/src/cq.c =================================================================== --- head/contrib/ofed/libcxgb4/src/cq.c (nonexistent) +++ head/contrib/ofed/libcxgb4/src/cq.c (revision 273806) @@ -0,0 +1,753 @@ +/* + * Copyright (c) 2006-2014 Chelsio, Inc. All rights reserved. + * + * This software is available to you under a choice of one of two + * licenses. You may choose to be licensed under the terms of the GNU + * General Public License (GPL) Version 2, available from the file + * COPYING in the main directory of this source tree, or the + * OpenIB.org BSD license below: + * + * Redistribution and use in source and binary forms, with or + * without modification, are permitted provided that the following + * conditions are met: + * + * - Redistributions of source code must retain the above + * copyright notice, this list of conditions and the following + * disclaimer. + * + * - Redistributions in binary form must reproduce the above + * copyright notice, this list of conditions and the following + * disclaimer in the documentation and/or other materials + * provided with the distribution. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, + * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF + * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND + * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS + * BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN + * ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN + * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE + * SOFTWARE. + */ +#if HAVE_CONFIG_H +# include +#endif /* HAVE_CONFIG_H */ + +#include +#include +#include +#include +#include +#include +#include "libcxgb4.h" +#include "cxgb4-abi.h" + +static void insert_recv_cqe(struct t4_wq *wq, struct t4_cq *cq) +{ + struct t4_cqe cqe; + + PDBG("%s wq %p cq %p sw_cidx %u sw_pidx %u\n", __func__, + wq, cq, cq->sw_cidx, cq->sw_pidx); + memset(&cqe, 0, sizeof(cqe)); + cqe.header = cpu_to_be32(V_CQE_STATUS(T4_ERR_SWFLUSH) | + V_CQE_OPCODE(FW_RI_SEND) | + V_CQE_TYPE(0) | + V_CQE_SWCQE(1) | + V_CQE_QPID(wq->sq.qid)); + cqe.bits_type_ts = cpu_to_be64(V_CQE_GENBIT((u64)cq->gen)); + cq->sw_queue[cq->sw_pidx] = cqe; + t4_swcq_produce(cq); +} + +int c4iw_flush_rq(struct t4_wq *wq, struct t4_cq *cq, int count) +{ + int flushed = 0; + int in_use = wq->rq.in_use - count; + + BUG_ON(in_use < 0); + PDBG("%s wq %p cq %p rq.in_use %u skip count %u\n", __func__, + wq, cq, wq->rq.in_use, count); + while (in_use--) { + insert_recv_cqe(wq, cq); + flushed++; + } + return flushed; +} + +static void insert_sq_cqe(struct t4_wq *wq, struct t4_cq *cq, + struct t4_swsqe *swcqe) +{ + struct t4_cqe cqe; + + PDBG("%s wq %p cq %p sw_cidx %u sw_pidx %u\n", __func__, + wq, cq, cq->sw_cidx, cq->sw_pidx); + memset(&cqe, 0, sizeof(cqe)); + cqe.header = cpu_to_be32(V_CQE_STATUS(T4_ERR_SWFLUSH) | + V_CQE_OPCODE(swcqe->opcode) | + V_CQE_TYPE(1) | + V_CQE_SWCQE(1) | + V_CQE_QPID(wq->sq.qid)); + CQE_WRID_SQ_IDX(&cqe) = swcqe->idx; + cqe.bits_type_ts = cpu_to_be64(V_CQE_GENBIT((u64)cq->gen)); + cq->sw_queue[cq->sw_pidx] = cqe; + t4_swcq_produce(cq); +} + +static void advance_oldest_read(struct t4_wq *wq); + +void c4iw_flush_sq(struct c4iw_qp *qhp) +{ + unsigned short flushed = 0; + struct t4_wq *wq = &qhp->wq; + struct c4iw_cq *chp = to_c4iw_cq(qhp->ibv_qp.send_cq); + struct t4_cq *cq = &chp->cq; + int idx; + struct t4_swsqe *swsqe; + + if (wq->sq.flush_cidx == -1) + wq->sq.flush_cidx = wq->sq.cidx; + idx = wq->sq.flush_cidx; + BUG_ON(idx >= wq->sq.size); + while (idx != wq->sq.pidx) { + swsqe = &wq->sq.sw_sq[idx]; + BUG_ON(swsqe->flushed); + swsqe->flushed = 1; + insert_sq_cqe(wq, cq, swsqe); + if (wq->sq.oldest_read == swsqe) { + BUG_ON(swsqe->opcode != FW_RI_READ_REQ); + advance_oldest_read(wq); + } + flushed++; + if (++idx == wq->sq.size) + idx = 0; + } + wq->sq.flush_cidx += flushed; + if (wq->sq.flush_cidx >= wq->sq.size) + wq->sq.flush_cidx -= wq->sq.size; +} + +static void flush_completed_wrs(struct t4_wq *wq, struct t4_cq *cq) +{ + struct t4_swsqe *swsqe; + unsigned short cidx; + + if (wq->sq.flush_cidx == -1) + wq->sq.flush_cidx = wq->sq.cidx; + cidx = wq->sq.flush_cidx; + BUG_ON(cidx >= wq->sq.size); + + while (cidx != wq->sq.pidx) { + swsqe = &wq->sq.sw_sq[cidx]; + if (!swsqe->signaled) { + if (++cidx == wq->sq.size) + cidx = 0; + } else if (swsqe->complete) { + + BUG_ON(swsqe->flushed); + + /* + * Insert this completed cqe into the swcq. + */ + PDBG("%s moving cqe into swcq sq idx %u cq idx %u\n", + __func__, cidx, cq->sw_pidx); + + swsqe->cqe.header |= htonl(V_CQE_SWCQE(1)); + cq->sw_queue[cq->sw_pidx] = swsqe->cqe; + t4_swcq_produce(cq); + swsqe->flushed = 1; + if (++cidx == wq->sq.size) + cidx = 0; + wq->sq.flush_cidx = cidx; + } else + break; + } +} + +static void create_read_req_cqe(struct t4_wq *wq, struct t4_cqe *hw_cqe, + struct t4_cqe *read_cqe) +{ + read_cqe->u.scqe.cidx = wq->sq.oldest_read->idx; + read_cqe->len = ntohl(wq->sq.oldest_read->read_len); + read_cqe->header = htonl(V_CQE_QPID(CQE_QPID(hw_cqe)) | + V_CQE_SWCQE(SW_CQE(hw_cqe)) | + V_CQE_OPCODE(FW_RI_READ_REQ) | + V_CQE_TYPE(1)); + read_cqe->bits_type_ts = hw_cqe->bits_type_ts; +} + +static void advance_oldest_read(struct t4_wq *wq) +{ + + u32 rptr = wq->sq.oldest_read - wq->sq.sw_sq + 1; + + if (rptr == wq->sq.size) + rptr = 0; + while (rptr != wq->sq.pidx) { + wq->sq.oldest_read = &wq->sq.sw_sq[rptr]; + + if (wq->sq.oldest_read->opcode == FW_RI_READ_REQ) + return; + if (++rptr == wq->sq.size) + rptr = 0; + } + wq->sq.oldest_read = NULL; +} + +/* + * Move all CQEs from the HWCQ into the SWCQ. + * Deal with out-of-order and/or completions that complete + * prior unsignalled WRs. + */ +void c4iw_flush_hw_cq(struct c4iw_cq *chp) +{ + struct t4_cqe *hw_cqe, *swcqe, read_cqe; + struct c4iw_qp *qhp; + struct t4_swsqe *swsqe; + int ret; + + PDBG("%s cqid 0x%x\n", __func__, chp->cq.cqid); + ret = t4_next_hw_cqe(&chp->cq, &hw_cqe); + + /* + * This logic is similar to poll_cq(), but not quite the same + * unfortunately. Need to move pertinent HW CQEs to the SW CQ but + * also do any translation magic that poll_cq() normally does. + */ + while (!ret) { + qhp = get_qhp(chp->rhp, CQE_QPID(hw_cqe)); + + /* + * drop CQEs with no associated QP + */ + if (qhp == NULL) + goto next_cqe; + + if (CQE_OPCODE(hw_cqe) == FW_RI_TERMINATE) + goto next_cqe; + + if (CQE_OPCODE(hw_cqe) == FW_RI_READ_RESP) { + + /* + * If we have reached here because of async + * event or other error, and have egress error + * then drop + */ + if (CQE_TYPE(hw_cqe) == 1) { + syslog(LOG_CRIT, "%s: got egress error in \ + read-response, dropping!\n", __func__); + goto next_cqe; + } + + /* + * drop peer2peer RTR reads. + */ + if (CQE_WRID_STAG(hw_cqe) == 1) + goto next_cqe; + + /* + * Eat completions for unsignaled read WRs. + */ + if (!qhp->wq.sq.oldest_read->signaled) { + advance_oldest_read(&qhp->wq); + goto next_cqe; + } + + /* + * Don't write to the HWCQ, create a new read req CQE + * in local memory and move it into the swcq. + */ + create_read_req_cqe(&qhp->wq, hw_cqe, &read_cqe); + hw_cqe = &read_cqe; + advance_oldest_read(&qhp->wq); + } + + /* if its a SQ completion, then do the magic to move all the + * unsignaled and now in-order completions into the swcq. + */ + if (SQ_TYPE(hw_cqe)) { + int idx = CQE_WRID_SQ_IDX(hw_cqe); + + BUG_ON(idx >= qhp->wq.sq.size); + swsqe = &qhp->wq.sq.sw_sq[idx]; + swsqe->cqe = *hw_cqe; + swsqe->complete = 1; + flush_completed_wrs(&qhp->wq, &chp->cq); + } else { + swcqe = &chp->cq.sw_queue[chp->cq.sw_pidx]; + *swcqe = *hw_cqe; + swcqe->header |= cpu_to_be32(V_CQE_SWCQE(1)); + t4_swcq_produce(&chp->cq); + } +next_cqe: + t4_hwcq_consume(&chp->cq); + ret = t4_next_hw_cqe(&chp->cq, &hw_cqe); + } +} + +static int cqe_completes_wr(struct t4_cqe *cqe, struct t4_wq *wq) +{ + if (CQE_OPCODE(cqe) == FW_RI_TERMINATE) + return 0; + + if ((CQE_OPCODE(cqe) == FW_RI_RDMA_WRITE) && RQ_TYPE(cqe)) + return 0; + + if ((CQE_OPCODE(cqe) == FW_RI_READ_RESP) && SQ_TYPE(cqe)) + return 0; + + if (CQE_SEND_OPCODE(cqe) && RQ_TYPE(cqe) && t4_rq_empty(wq)) + return 0; + return 1; +} + +void c4iw_count_rcqes(struct t4_cq *cq, struct t4_wq *wq, int *count) +{ + struct t4_cqe *cqe; + u32 ptr; + + *count = 0; + ptr = cq->sw_cidx; + BUG_ON(ptr >= cq->size); + while (ptr != cq->sw_pidx) { + cqe = &cq->sw_queue[ptr]; + if (RQ_TYPE(cqe) && (CQE_OPCODE(cqe) != FW_RI_READ_RESP) && + (CQE_QPID(cqe) == wq->sq.qid) && cqe_completes_wr(cqe, wq)) + (*count)++; + if (++ptr == cq->size) + ptr = 0; + } + PDBG("%s cq %p count %d\n", __func__, cq, *count); +} + +static void dump_cqe(void *arg) +{ + u64 *p = arg; + syslog(LOG_NOTICE, "cxgb4 err cqe %016lx %016lx %016lx %016lx\n", + be64_to_cpu(p[0]), + be64_to_cpu(p[1]), + be64_to_cpu(p[2]), + be64_to_cpu(p[3])); +} + +/* + * poll_cq + * + * Caller must: + * check the validity of the first CQE, + * supply the wq assicated with the qpid. + * + * credit: cq credit to return to sge. + * cqe_flushed: 1 iff the CQE is flushed. + * cqe: copy of the polled CQE. + * + * return value: + * 0 CQE returned ok. + * -EAGAIN CQE skipped, try again. + * -EOVERFLOW CQ overflow detected. + */ +static int poll_cq(struct t4_wq *wq, struct t4_cq *cq, struct t4_cqe *cqe, + u8 *cqe_flushed, u64 *cookie, u32 *credit) +{ + int ret = 0; + struct t4_cqe *hw_cqe, read_cqe; + + *cqe_flushed = 0; + *credit = 0; + + ret = t4_next_cqe(cq, &hw_cqe); + if (ret) + return ret; + + PDBG("%s CQE OVF %u qpid 0x%0x genbit %u type %u status 0x%0x" + " opcode 0x%0x len 0x%0x wrid_hi_stag 0x%x wrid_low_msn 0x%x\n", + __func__, CQE_OVFBIT(hw_cqe), CQE_QPID(hw_cqe), + CQE_GENBIT(hw_cqe), CQE_TYPE(hw_cqe), CQE_STATUS(hw_cqe), + CQE_OPCODE(hw_cqe), CQE_LEN(hw_cqe), CQE_WRID_HI(hw_cqe), + CQE_WRID_LOW(hw_cqe)); + + /* + * skip cqe's not affiliated with a QP. + */ + if (wq == NULL) { + ret = -EAGAIN; + goto skip_cqe; + } + + /* + * Gotta tweak READ completions: + * 1) the cqe doesn't contain the sq_wptr from the wr. + * 2) opcode not reflected from the wr. + * 3) read_len not reflected from the wr. + * 4) T4 HW (for now) inserts target read response failures which + * need to be skipped. + */ + if (CQE_OPCODE(hw_cqe) == FW_RI_READ_RESP) { + + /* + * If we have reached here because of async + * event or other error, and have egress error + * then drop + */ + if (CQE_TYPE(hw_cqe) == 1) { + syslog(LOG_CRIT, "%s: got egress error in \ + read-response, dropping!\n", __func__); + if (CQE_STATUS(hw_cqe)) + t4_set_wq_in_error(wq); + ret = -EAGAIN; + goto skip_cqe; + } + + /* + * If this is an unsolicited read response, then the read + * was generated by the kernel driver as part of peer-2-peer + * connection setup, or a target read response failure. + * So skip the completion. + */ + if (CQE_WRID_STAG(hw_cqe) == 1) { + if (CQE_STATUS(hw_cqe)) + t4_set_wq_in_error(wq); + ret = -EAGAIN; + goto skip_cqe; + } + + /* + * Eat completions for unsignaled read WRs. + */ + if (!wq->sq.oldest_read->signaled) { + advance_oldest_read(wq); + ret = -EAGAIN; + goto skip_cqe; + } + + /* + * Don't write to the HWCQ, so create a new read req CQE + * in local memory. + */ + create_read_req_cqe(wq, hw_cqe, &read_cqe); + hw_cqe = &read_cqe; + advance_oldest_read(wq); + } + + if (CQE_STATUS(hw_cqe) || t4_wq_in_error(wq)) { + *cqe_flushed = (CQE_STATUS(hw_cqe) == T4_ERR_SWFLUSH); + wq->error = 1; + + if (!*cqe_flushed && CQE_STATUS(hw_cqe)) + dump_cqe(hw_cqe); + + BUG_ON((cqe_flushed == 0) && !SW_CQE(hw_cqe)); + goto proc_cqe; + } + + if (CQE_OPCODE(hw_cqe) == FW_RI_TERMINATE) { + ret = -EAGAIN; + goto skip_cqe; + } + + /* + * RECV completion. + */ + if (RQ_TYPE(hw_cqe)) { + + /* + * HW only validates 4 bits of MSN. So we must validate that + * the MSN in the SEND is the next expected MSN. If its not, + * then we complete this with T4_ERR_MSN and mark the wq in + * error. + */ + + if (t4_rq_empty(wq)) { + t4_set_wq_in_error(wq); + ret = -EAGAIN; + goto skip_cqe; + } + if (unlikely((CQE_WRID_MSN(hw_cqe) != (wq->rq.msn)))) { + t4_set_wq_in_error(wq); + hw_cqe->header |= htonl(V_CQE_STATUS(T4_ERR_MSN)); + goto proc_cqe; + } + goto proc_cqe; + } + + /* + * If we get here its a send completion. + * + * Handle out of order completion. These get stuffed + * in the SW SQ. Then the SW SQ is walked to move any + * now in-order completions into the SW CQ. This handles + * 2 cases: + * 1) reaping unsignaled WRs when the first subsequent + * signaled WR is completed. + * 2) out of order read completions. + */ + if (!SW_CQE(hw_cqe) && (CQE_WRID_SQ_IDX(hw_cqe) != wq->sq.cidx)) { + struct t4_swsqe *swsqe; + int idx = CQE_WRID_SQ_IDX(hw_cqe); + + PDBG("%s out of order completion going in sw_sq at idx %u\n", + __func__, idx); + BUG_ON(idx >= wq->sq.size); + swsqe = &wq->sq.sw_sq[idx]; + swsqe->cqe = *hw_cqe; + swsqe->complete = 1; + ret = -EAGAIN; + goto flush_wq; + } + +proc_cqe: + *cqe = *hw_cqe; + + /* + * Reap the associated WR(s) that are freed up with this + * completion. + */ + if (SQ_TYPE(hw_cqe)) { + int idx = CQE_WRID_SQ_IDX(hw_cqe); + BUG_ON(idx >= wq->sq.size); + + /* + * Account for any unsignaled completions completed by + * this signaled completion. In this case, cidx points + * to the first unsignaled one, and idx points to the + * signaled one. So adjust in_use based on this delta. + * if this is not completing any unsigned wrs, then the + * delta will be 0. Handle wrapping also! + */ + if (idx < wq->sq.cidx) + wq->sq.in_use -= wq->sq.size + idx - wq->sq.cidx; + else + wq->sq.in_use -= idx - wq->sq.cidx; + BUG_ON(wq->sq.in_use <= 0 || wq->sq.in_use >= wq->sq.size); + + wq->sq.cidx = (u16)idx; + PDBG("%s completing sq idx %u\n", __func__, wq->sq.cidx); + *cookie = wq->sq.sw_sq[wq->sq.cidx].wr_id; + t4_sq_consume(wq); + } else { + PDBG("%s completing rq idx %u\n", __func__, wq->rq.cidx); + BUG_ON(wq->rq.cidx >= wq->rq.size); + *cookie = wq->rq.sw_rq[wq->rq.cidx].wr_id; + BUG_ON(t4_rq_empty(wq)); + t4_rq_consume(wq); + goto skip_cqe; + } + +flush_wq: + /* + * Flush any completed cqes that are now in-order. + */ + flush_completed_wrs(wq, cq); + +skip_cqe: + if (SW_CQE(hw_cqe)) { + PDBG("%s cq %p cqid 0x%x skip sw cqe cidx %u\n", + __func__, cq, cq->cqid, cq->sw_cidx); + t4_swcq_consume(cq); + } else { + PDBG("%s cq %p cqid 0x%x skip hw cqe cidx %u\n", + __func__, cq, cq->cqid, cq->cidx); + t4_hwcq_consume(cq); + } + return ret; +} + +/* + * Get one cq entry from c4iw and map it to openib. + * + * Returns: + * 0 cqe returned + * -ENODATA EMPTY; + * -EAGAIN caller must try again + * any other -errno fatal error + */ +static int c4iw_poll_cq_one(struct c4iw_cq *chp, struct ibv_wc *wc) +{ + struct c4iw_qp *qhp = NULL; + struct t4_cqe cqe, *rd_cqe; + struct t4_wq *wq; + u32 credit = 0; + u8 cqe_flushed; + u64 cookie = 0; + int ret; + + ret = t4_next_cqe(&chp->cq, &rd_cqe); + + if (ret) { +#ifdef STALL_DETECTION + if (ret == -ENODATA && stall_to && !chp->dumped) { + struct timeval t; + + gettimeofday(&t, NULL); + if ((t.tv_sec - chp->time.tv_sec) > stall_to) { + dump_state(); + chp->dumped = 1; + } + } +#endif + return ret; + } + +#ifdef STALL_DETECTION + gettimeofday(&chp->time, NULL); +#endif + + qhp = get_qhp(chp->rhp, CQE_QPID(rd_cqe)); + if (!qhp) + wq = NULL; + else { + pthread_spin_lock(&qhp->lock); + wq = &(qhp->wq); + } + ret = poll_cq(wq, &(chp->cq), &cqe, &cqe_flushed, &cookie, &credit); + if (ret) + goto out; + + INC_STAT(cqe); + wc->wr_id = cookie; + wc->qp_num = qhp->wq.sq.qid; + wc->vendor_err = CQE_STATUS(&cqe); + wc->wc_flags = 0; + + PDBG("%s qpid 0x%x type %d opcode %d status 0x%x wrid hi 0x%x " + "lo 0x%x cookie 0x%llx\n", __func__, + CQE_QPID(&cqe), CQE_TYPE(&cqe), + CQE_OPCODE(&cqe), CQE_STATUS(&cqe), CQE_WRID_HI(&cqe), + CQE_WRID_LOW(&cqe), (unsigned long long)cookie); + + if (CQE_TYPE(&cqe) == 0) { + if (!CQE_STATUS(&cqe)) + wc->byte_len = CQE_LEN(&cqe); + else + wc->byte_len = 0; + wc->opcode = IBV_WC_RECV; + } else { + switch (CQE_OPCODE(&cqe)) { + case FW_RI_RDMA_WRITE: + wc->opcode = IBV_WC_RDMA_WRITE; + break; + case FW_RI_READ_REQ: + wc->opcode = IBV_WC_RDMA_READ; + wc->byte_len = CQE_LEN(&cqe); + break; + case FW_RI_SEND: + case FW_RI_SEND_WITH_SE: + case FW_RI_SEND_WITH_INV: + case FW_RI_SEND_WITH_SE_INV: + wc->opcode = IBV_WC_SEND; + break; + case FW_RI_BIND_MW: + wc->opcode = IBV_WC_BIND_MW; + break; + default: + PDBG("Unexpected opcode %d " + "in the CQE received for QPID=0x%0x\n", + CQE_OPCODE(&cqe), CQE_QPID(&cqe)); + ret = -EINVAL; + goto out; + } + } + + if (cqe_flushed) + wc->status = IBV_WC_WR_FLUSH_ERR; + else { + + switch (CQE_STATUS(&cqe)) { + case T4_ERR_SUCCESS: + wc->status = IBV_WC_SUCCESS; + break; + case T4_ERR_STAG: + wc->status = IBV_WC_LOC_ACCESS_ERR; + break; + case T4_ERR_PDID: + wc->status = IBV_WC_LOC_PROT_ERR; + break; + case T4_ERR_QPID: + case T4_ERR_ACCESS: + wc->status = IBV_WC_LOC_ACCESS_ERR; + break; + case T4_ERR_WRAP: + wc->status = IBV_WC_GENERAL_ERR; + break; + case T4_ERR_BOUND: + wc->status = IBV_WC_LOC_LEN_ERR; + break; + case T4_ERR_INVALIDATE_SHARED_MR: + case T4_ERR_INVALIDATE_MR_WITH_MW_BOUND: + wc->status = IBV_WC_MW_BIND_ERR; + break; + case T4_ERR_CRC: + case T4_ERR_MARKER: + case T4_ERR_PDU_LEN_ERR: + case T4_ERR_OUT_OF_RQE: + case T4_ERR_DDP_VERSION: + case T4_ERR_RDMA_VERSION: + case T4_ERR_DDP_QUEUE_NUM: + case T4_ERR_MSN: + case T4_ERR_TBIT: + case T4_ERR_MO: + case T4_ERR_MSN_RANGE: + case T4_ERR_IRD_OVERFLOW: + case T4_ERR_OPCODE: + case T4_ERR_INTERNAL_ERR: + wc->status = IBV_WC_FATAL_ERR; + break; + case T4_ERR_SWFLUSH: + wc->status = IBV_WC_WR_FLUSH_ERR; + break; + default: + PDBG("Unexpected cqe_status 0x%x for QPID=0x%0x\n", + CQE_STATUS(&cqe), CQE_QPID(&cqe)); + ret = -EINVAL; + } + } + if (wc->status && wc->status != IBV_WC_WR_FLUSH_ERR) + syslog(LOG_NOTICE, "cxgb4 app err cqid %u qpid %u " + "type %u opcode %u status 0x%x\n", + chp->cq.cqid, CQE_QPID(&cqe), CQE_TYPE(&cqe), + CQE_OPCODE(&cqe), CQE_STATUS(&cqe)); +out: + if (wq) + pthread_spin_unlock(&qhp->lock); + return ret; +} + +int c4iw_poll_cq(struct ibv_cq *ibcq, int num_entries, struct ibv_wc *wc) +{ + struct c4iw_cq *chp; + int npolled; + int err = 0; + + chp = to_c4iw_cq(ibcq); + + if (t4_cq_in_error(&chp->cq)) { + t4_reset_cq_in_error(&chp->cq); + c4iw_flush_qps(chp->rhp); + } + + if (!num_entries) + return t4_cq_notempty(&chp->cq); + + pthread_spin_lock(&chp->lock); + for (npolled = 0; npolled < num_entries; ++npolled) { + do { + err = c4iw_poll_cq_one(chp, wc + npolled); + } while (err == -EAGAIN); + if (err) + break; + } + pthread_spin_unlock(&chp->lock); + return !err || err == -ENODATA ? npolled : err; +} + +int c4iw_arm_cq(struct ibv_cq *ibcq, int solicited) +{ + struct c4iw_cq *chp; + int ret; + + INC_STAT(arm); + chp = to_c4iw_cq(ibcq); + pthread_spin_lock(&chp->lock); + ret = t4_arm_cq(&chp->cq, solicited); + pthread_spin_unlock(&chp->lock); + return ret; +} Index: head/contrib/ofed/libcxgb4/src/cxgb4-abi.h =================================================================== --- head/contrib/ofed/libcxgb4/src/cxgb4-abi.h (nonexistent) +++ head/contrib/ofed/libcxgb4/src/cxgb4-abi.h (revision 273806) @@ -0,0 +1,95 @@ +/* + * Copyright (c) 2006-2014 Chelsio, Inc. All rights reserved. + * + * This software is available to you under a choice of one of two + * licenses. You may choose to be licensed under the terms of the GNU + * General Public License (GPL) Version 2, available from the file + * COPYING in the main directory of this source tree, or the + * OpenIB.org BSD license below: + * + * Redistribution and use in source and binary forms, with or + * without modification, are permitted provided that the following + * conditions are met: + * + * - Redistributions of source code must retain the above + * copyright notice, this list of conditions and the following + * disclaimer. + * + * - Redistributions in binary form must reproduce the above + * copyright notice, this list of conditions and the following + * disclaimer in the documentation and/or other materials + * provided with the distribution. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, + * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF + * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND + * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS + * BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN + * ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN + * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE + * SOFTWARE. + */ +#ifndef IWCH_ABI_H +#define IWCH_ABI_H + +#include + +struct c4iw_alloc_ucontext_resp { + struct ibv_get_context_resp ibv_resp; + __u64 status_page_key; + __u32 status_page_size; + __u32 reserved; +}; + +struct c4iw_alloc_pd_resp { + struct ibv_alloc_pd_resp ibv_resp; + uint32_t pdid; +}; + +struct c4iw_create_cq_resp { + struct ibv_create_cq_resp ibv_resp; + __u64 key; + __u64 gts_key; + __u64 memsize; + __u32 cqid; + __u32 size; + __u32 qid_mask; + __u32 reserved; +}; + +enum { + C4IW_QPF_ONCHIP = (1<<0), +}; + +struct c4iw_create_qp_resp_v0 { + struct ibv_create_qp_resp ibv_resp; + __u64 sq_key; + __u64 rq_key; + __u64 sq_db_gts_key; + __u64 rq_db_gts_key; + __u64 sq_memsize; + __u64 rq_memsize; + __u32 sqid; + __u32 rqid; + __u32 sq_size; + __u32 rq_size; + __u32 qid_mask; +}; + +struct c4iw_create_qp_resp { + struct ibv_create_qp_resp ibv_resp; + __u64 ma_sync_key; + __u64 sq_key; + __u64 rq_key; + __u64 sq_db_gts_key; + __u64 rq_db_gts_key; + __u64 sq_memsize; + __u64 rq_memsize; + __u32 sqid; + __u32 rqid; + __u32 sq_size; + __u32 rq_size; + __u32 qid_mask; + __u32 flags; +}; +#endif /* IWCH_ABI_H */ Index: head/contrib/ofed/libcxgb4/src/cxgb4.map =================================================================== --- head/contrib/ofed/libcxgb4/src/cxgb4.map (nonexistent) +++ head/contrib/ofed/libcxgb4/src/cxgb4.map (revision 273806) @@ -0,0 +1,6 @@ +{ + global: + ibv_driver_init; + openib_driver_init; + local: *; +}; Index: head/contrib/ofed/libcxgb4/src/dev.c =================================================================== --- head/contrib/ofed/libcxgb4/src/dev.c (nonexistent) +++ head/contrib/ofed/libcxgb4/src/dev.c (revision 273806) @@ -0,0 +1,558 @@ +/* + * Copyright (c) 2006-2014 Chelsio, Inc. All rights reserved. + * + * This software is available to you under a choice of one of two + * licenses. You may choose to be licensed under the terms of the GNU + * General Public License (GPL) Version 2, available from the file + * COPYING in the main directory of this source tree, or the + * OpenIB.org BSD license below: + * + * Redistribution and use in source and binary forms, with or + * without modification, are permitted provided that the following + * conditions are met: + * + * - Redistributions of source code must retain the above + * copyright notice, this list of conditions and the following + * disclaimer. + * + * - Redistributions in binary form must reproduce the above + * copyright notice, this list of conditions and the following + * disclaimer in the documentation and/or other materials + * provided with the distribution. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, + * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF + * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND + * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS + * BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN + * ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN + * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE + * SOFTWARE. + */ +#if HAVE_CONFIG_H +# include +#endif /* HAVE_CONFIG_H */ + +#include +#include +#include +#include +#include +#include +#include +#include + +#include "libcxgb4.h" +#include "cxgb4-abi.h" + +#define PCI_VENDOR_ID_CHELSIO 0x1425 + +/* + * Macros needed to support the PCI Device ID Table ... + */ +#define CH_PCI_DEVICE_ID_TABLE_DEFINE_BEGIN \ + struct { \ + unsigned vendor; \ + unsigned device; \ + unsigned chip_version; \ + } hca_table[] = { + +#define CH_PCI_DEVICE_ID_FUNCTION \ + 0x4 + +#define CH_PCI_ID_TABLE_ENTRY(__DeviceID) \ + { \ + .vendor = PCI_VENDOR_ID_CHELSIO, \ + .device = (__DeviceID), \ + .chip_version = CHELSIO_PCI_ID_CHIP_VERSION(__DeviceID), \ + } + +#define CH_PCI_DEVICE_ID_TABLE_DEFINE_END \ + } + +#include "t4_chip_type.h" +#include "t4_pci_id_tbl.h" + +unsigned long c4iw_page_size; +unsigned long c4iw_page_shift; +unsigned long c4iw_page_mask; +int ma_wr; +int t5_en_wc = 1; + +SLIST_HEAD(devices_struct, c4iw_dev) devices; + +static struct ibv_context_ops c4iw_ctx_ops = { + .query_device = c4iw_query_device, + .query_port = c4iw_query_port, + .alloc_pd = c4iw_alloc_pd, + .dealloc_pd = c4iw_free_pd, + .reg_mr = c4iw_reg_mr, + .dereg_mr = c4iw_dereg_mr, + .create_cq = c4iw_create_cq, + .resize_cq = c4iw_resize_cq, + .destroy_cq = c4iw_destroy_cq, + .create_srq = c4iw_create_srq, + .modify_srq = c4iw_modify_srq, + .destroy_srq = c4iw_destroy_srq, + .create_qp = c4iw_create_qp, + .modify_qp = c4iw_modify_qp, + .destroy_qp = c4iw_destroy_qp, + .query_qp = c4iw_query_qp, + .create_ah = c4iw_create_ah, + .destroy_ah = c4iw_destroy_ah, + .attach_mcast = c4iw_attach_mcast, + .detach_mcast = c4iw_detach_mcast, + .post_srq_recv = c4iw_post_srq_recv, + .req_notify_cq = c4iw_arm_cq, +}; + +static struct ibv_context *c4iw_alloc_context(struct ibv_device *ibdev, + int cmd_fd) +{ + struct c4iw_context *context; + struct ibv_get_context cmd; + struct c4iw_alloc_ucontext_resp resp; + struct c4iw_dev *rhp = to_c4iw_dev(ibdev); + struct ibv_query_device qcmd; + uint64_t raw_fw_ver; + struct ibv_device_attr attr; + + context = malloc(sizeof *context); + if (!context) + return NULL; + + memset(context, 0, sizeof *context); + context->ibv_ctx.cmd_fd = cmd_fd; + + resp.status_page_size = 0; + resp.reserved = 0; + if (ibv_cmd_get_context(&context->ibv_ctx, &cmd, sizeof cmd, + &resp.ibv_resp, sizeof resp)) + goto err_free; + + if (resp.reserved) + PDBG("%s c4iw_alloc_ucontext_resp reserved field modified by kernel\n", + __FUNCTION__); + + context->status_page_size = resp.status_page_size; + if (resp.status_page_size) { + context->status_page = mmap(NULL, resp.status_page_size, + PROT_READ, MAP_SHARED, cmd_fd, + resp.status_page_key); + if (context->status_page == MAP_FAILED) + goto err_free; + } + + context->ibv_ctx.device = ibdev; + context->ibv_ctx.ops = c4iw_ctx_ops; + + switch (rhp->chip_version) { + case CHELSIO_T5: + PDBG("%s T5/T4 device\n", __FUNCTION__); + case CHELSIO_T4: + PDBG("%s T4 device\n", __FUNCTION__); + context->ibv_ctx.ops.async_event = c4iw_async_event; + context->ibv_ctx.ops.post_send = c4iw_post_send; + context->ibv_ctx.ops.post_recv = c4iw_post_receive; + context->ibv_ctx.ops.poll_cq = c4iw_poll_cq; + context->ibv_ctx.ops.req_notify_cq = c4iw_arm_cq; + break; + default: + PDBG("%s unknown hca type %d\n", __FUNCTION__, + rhp->chip_version); + goto err_unmap; + break; + } + + if (!rhp->mmid2ptr) { + int ret; + + ret = ibv_cmd_query_device(&context->ibv_ctx, &attr, &raw_fw_ver, &qcmd, + sizeof qcmd); + if (ret) + goto err_unmap; + rhp->max_mr = attr.max_mr; + rhp->mmid2ptr = calloc(attr.max_mr, sizeof(void *)); + if (!rhp->mmid2ptr) { + goto err_unmap; + } + rhp->max_qp = T4_QID_BASE + attr.max_cq; + rhp->qpid2ptr = calloc(T4_QID_BASE + attr.max_cq, sizeof(void *)); + if (!rhp->qpid2ptr) { + goto err_unmap; + } + rhp->max_cq = T4_QID_BASE + attr.max_cq; + rhp->cqid2ptr = calloc(T4_QID_BASE + attr.max_cq, sizeof(void *)); + if (!rhp->cqid2ptr) + goto err_unmap; + } + + return &context->ibv_ctx; + +err_unmap: + munmap(context->status_page, context->status_page_size); +err_free: + if (rhp->cqid2ptr) + free(rhp->cqid2ptr); + if (rhp->qpid2ptr) + free(rhp->cqid2ptr); + if (rhp->mmid2ptr) + free(rhp->cqid2ptr); + free(context); + return NULL; +} + +static void c4iw_free_context(struct ibv_context *ibctx) +{ + struct c4iw_context *context = to_c4iw_context(ibctx); + + if (context->status_page_size) + munmap(context->status_page, context->status_page_size); + free(context); +} + +static struct ibv_device_ops c4iw_dev_ops = { + .alloc_context = c4iw_alloc_context, + .free_context = c4iw_free_context +}; + +#ifdef STALL_DETECTION + +int stall_to; + +static void dump_cq(struct c4iw_cq *chp) +{ + int i; + + fprintf(stderr, + "CQ: %p id %u queue %p cidx 0x%08x sw_queue %p sw_cidx %d sw_pidx %d sw_in_use %d depth %u error %u gen %d " + "cidx_inc %d bits_type_ts %016" PRIx64 " notempty %d\n", chp, + chp->cq.cqid, chp->cq.queue, chp->cq.cidx, + chp->cq.sw_queue, chp->cq.sw_cidx, chp->cq.sw_pidx, chp->cq.sw_in_use, + chp->cq.size, chp->cq.error, chp->cq.gen, chp->cq.cidx_inc, be64_to_cpu(chp->cq.bits_type_ts), + t4_cq_notempty(&chp->cq) || (chp->iq ? t4_iq_notempty(chp->iq) : 0)); + + for (i=0; i < chp->cq.size; i++) { + u64 *p = (u64 *)(chp->cq.queue + i); + + fprintf(stderr, "%02x: %016" PRIx64 " %016" PRIx64, i, be64_to_cpu(p[0]), be64_to_cpu(p[1])); + if (i == chp->cq.cidx) + fprintf(stderr, " <-- cidx\n"); + else + fprintf(stderr, "\n"); + p+= 2; + fprintf(stderr, "%02x: %016" PRIx64 " %016" PRIx64 "\n", i, be64_to_cpu(p[0]), be64_to_cpu(p[1])); + p+= 2; + fprintf(stderr, "%02x: %016" PRIx64 " %016" PRIx64 "\n", i, be64_to_cpu(p[0]), be64_to_cpu(p[1])); + p+= 2; + fprintf(stderr, "%02x: %016" PRIx64 " %016" PRIx64 "\n", i, be64_to_cpu(p[0]), be64_to_cpu(p[1])); + p+= 2; + } +} + +static void dump_qp(struct c4iw_qp *qhp) +{ + int i; + int j; + struct t4_swsqe *swsqe; + struct t4_swrqe *swrqe; + u16 cidx, pidx; + u64 *p; + + fprintf(stderr, + "QP: %p id %u error %d flushed %d qid_mask 0x%x\n" + " SQ: id %u queue %p sw_queue %p cidx %u pidx %u in_use %u wq_pidx %u depth %u flags 0x%x flush_cidx %d\n" + " RQ: id %u queue %p sw_queue %p cidx %u pidx %u in_use %u depth %u\n", + qhp, + qhp->wq.sq.qid, + qhp->wq.error, + qhp->wq.flushed, + qhp->wq.qid_mask, + qhp->wq.sq.qid, + qhp->wq.sq.queue, + qhp->wq.sq.sw_sq, + qhp->wq.sq.cidx, + qhp->wq.sq.pidx, + qhp->wq.sq.in_use, + qhp->wq.sq.wq_pidx, + qhp->wq.sq.size, + qhp->wq.sq.flags, + qhp->wq.sq.flush_cidx, + qhp->wq.rq.qid, + qhp->wq.rq.queue, + qhp->wq.rq.sw_rq, + qhp->wq.rq.cidx, + qhp->wq.rq.pidx, + qhp->wq.rq.in_use, + qhp->wq.rq.size); + cidx = qhp->wq.sq.cidx; + pidx = qhp->wq.sq.pidx; + if (cidx != pidx) + fprintf(stderr, "SQ: \n"); + while (cidx != pidx) { + swsqe = &qhp->wq.sq.sw_sq[cidx]; + fprintf(stderr, "%04u: wr_id %016" PRIx64 + " sq_wptr %08x read_len %u opcode 0x%x " + "complete %u signaled %u cqe %016" PRIx64 " %016" PRIx64 " %016" PRIx64 " %016" PRIx64 "\n", + cidx, + swsqe->wr_id, + swsqe->idx, + swsqe->read_len, + swsqe->opcode, + swsqe->complete, + swsqe->signaled, + cpu_to_be64(swsqe->cqe.u.flits[0]), + cpu_to_be64(swsqe->cqe.u.flits[1]), + cpu_to_be64((u64)swsqe->cqe.reserved), + cpu_to_be64(swsqe->cqe.bits_type_ts)); + if (++cidx == qhp->wq.sq.size) + cidx = 0; + } + + fprintf(stderr, "SQ WQ: \n"); + p = (u64 *)qhp->wq.sq.queue; + for (i=0; i < qhp->wq.sq.size * T4_SQ_NUM_SLOTS; i++) { + for (j=0; j < T4_EQ_ENTRY_SIZE / 16; j++) { + fprintf(stderr, "%04u %016" PRIx64 " %016" PRIx64 " ", + i, ntohll(p[0]), ntohll(p[1])); + if (j == 0 && i == qhp->wq.sq.wq_pidx) + fprintf(stderr, " <-- pidx"); + fprintf(stderr, "\n"); + p += 2; + } + } + cidx = qhp->wq.rq.cidx; + pidx = qhp->wq.rq.pidx; + if (cidx != pidx) + fprintf(stderr, "RQ: \n"); + while (cidx != pidx) { + swrqe = &qhp->wq.rq.sw_rq[cidx]; + fprintf(stderr, "%04u: wr_id %016" PRIx64 "\n", + cidx, + swrqe->wr_id ); + if (++cidx == qhp->wq.rq.size) + cidx = 0; + } + + fprintf(stderr, "RQ WQ: \n"); + p = (u64 *)qhp->wq.rq.queue; + for (i=0; i < qhp->wq.rq.size * T4_RQ_NUM_SLOTS; i++) { + for (j=0; j < T4_EQ_ENTRY_SIZE / 16; j++) { + fprintf(stderr, "%04u %016" PRIx64 " %016" PRIx64 " ", + i, ntohll(p[0]), ntohll(p[1])); + if (j == 0 && i == qhp->wq.rq.pidx) + fprintf(stderr, " <-- pidx"); + if (j == 0 && i == qhp->wq.rq.cidx) + fprintf(stderr, " <-- cidx"); + fprintf(stderr, "\n"); + p+=2; + } + } +} + +void dump_state() +{ + struct c4iw_dev *dev; + int i; + + fprintf(stderr, "STALL DETECTED:\n"); + SLIST_FOREACH(dev, &devices, list) { + //pthread_spin_lock(&dev->lock); + fprintf(stderr, "Device %s\n", dev->ibv_dev.name); + for (i=0; i < dev->max_cq; i++) { + if (dev->cqid2ptr[i]) { + struct c4iw_cq *chp = dev->cqid2ptr[i]; + //pthread_spin_lock(&chp->lock); + dump_cq(chp); + //pthread_spin_unlock(&chp->lock); + } + } + for (i=0; i < dev->max_qp; i++) { + if (dev->qpid2ptr[i]) { + struct c4iw_qp *qhp = dev->qpid2ptr[i]; + //pthread_spin_lock(&qhp->lock); + dump_qp(qhp); + //pthread_spin_unlock(&qhp->lock); + } + } + //pthread_spin_unlock(&dev->lock); + } + fprintf(stderr, "DUMP COMPLETE:\n"); + fflush(stderr); +} +#endif /* end of STALL_DETECTION */ + +/* + * c4iw_abi_version is used to store ABI for iw_cxgb4 so the user mode library + * can know if the driver supports the kernel mode db ringing. + */ +int c4iw_abi_version = 1; + +static struct ibv_device *cxgb4_driver_init(const char *uverbs_sys_path, + int abi_version) +{ + char devstr[IBV_SYSFS_PATH_MAX], ibdev[16], value[128], *cp; + char t5nexstr[IBV_SYSFS_PATH_MAX]; + struct c4iw_dev *dev; + unsigned vendor, device, fw_maj, fw_min; + int i; + char devnum=0; + char ib_param[16]; + +#ifndef __linux__ + if (ibv_read_sysfs_file(uverbs_sys_path, "ibdev", + ibdev, sizeof ibdev) < 0) + return NULL; + /* + * Extract the non-numeric part of ibdev + * say "t5nex0" -> devname=="t5nex", devnum=0 + */ + if (strstr(ibdev,"t5nex")) { + devnum = atoi(ibdev+strlen("t5nex")); + sprintf(t5nexstr, "/dev/t5nex/%d", devnum); + } else + return NULL; + + if (ibv_read_sysfs_file(t5nexstr, "\%pnpinfo", + value, sizeof value) < 0) + return NULL; + else { + if (strstr(value,"vendor=")) { + strncpy(ib_param, strstr(value,"vendor=")+strlen("vendor="),6); + sscanf(ib_param,"%i",&vendor); + } + + if (strstr(value,"device=")) { + strncpy(ib_param, strstr(value,"device=")+strlen("device="),6); + sscanf(ib_param,"%i",&device); + } + } +#else + if (ibv_read_sysfs_file(uverbs_sys_path, "device/vendor", + value, sizeof value) < 0) + return NULL; + sscanf(value, "%i", &vendor); + + if (ibv_read_sysfs_file(uverbs_sys_path, "device/device", + value, sizeof value) < 0) + return NULL; + sscanf(value, "%i", &device); +#endif + + for (i = 0; i < sizeof hca_table / sizeof hca_table[0]; ++i) + if (vendor == hca_table[i].vendor && + device == hca_table[i].device) + goto found; + + return NULL; + +found: + c4iw_abi_version = abi_version; + + +#ifndef __linux__ + if (ibv_read_sysfs_file(t5nexstr, "firmware_version", + value, sizeof value) < 0) + return NULL; +#else + /* + * Verify that the firmware major number matches. Major number + * mismatches are fatal. Minor number mismatches are tolerated. + */ + if (ibv_read_sysfs_file(uverbs_sys_path, "ibdev", + ibdev, sizeof ibdev) < 0) + return NULL; + + memset(devstr, 0, sizeof devstr); + snprintf(devstr, sizeof devstr, "%s/class/infiniband/%s", + ibv_get_sysfs_path(), ibdev); + if (ibv_read_sysfs_file(devstr, "fw_ver", value, sizeof value) < 0) + return NULL; +#endif + + cp = strtok(value+1, "."); + sscanf(cp, "%i", &fw_maj); + cp = strtok(NULL, "."); + sscanf(cp, "%i", &fw_min); + + if (fw_maj < FW_MAJ) { + fprintf(stderr, "libcxgb4: Fatal firmware version mismatch. " + "Firmware major number is %u and libcxgb4 needs %u.\n", + fw_maj, FW_MAJ); + fflush(stderr); + return NULL; + } + + DBGLOG("libcxgb4"); + + if (fw_min < FW_MIN) { + PDBG("libcxgb4: non-fatal firmware version mismatch. " + "Firmware minor number is %u and libcxgb4 needs %u.\n", + fw_maj, FW_MAJ); + fflush(stderr); + } + + PDBG("%s found vendor %d device %d type %d\n", + __FUNCTION__, vendor, device, hca_table[i].chip_version); + + dev = calloc(1, sizeof *dev); + if (!dev) { + return NULL; + } + + pthread_spin_init(&dev->lock, PTHREAD_PROCESS_PRIVATE); + dev->ibv_dev.ops = c4iw_dev_ops; + dev->chip_version = hca_table[i].chip_version; + dev->abi_version = abi_version; + + PDBG("%s device claimed\n", __FUNCTION__); + SLIST_INSERT_HEAD(&devices, dev, list); +#ifdef STALL_DETECTION +{ + char *c = getenv("CXGB4_STALL_TIMEOUT"); + if (c) { + stall_to = strtol(c, NULL, 0); + if (errno || stall_to < 0) + stall_to = 0; + } +} +#endif +{ + char *c = getenv("CXGB4_MA_WR"); + if (c) { + ma_wr = strtol(c, NULL, 0); + if (ma_wr != 1) + ma_wr = 0; + } +} +{ + char *c = getenv("T5_ENABLE_WC"); + if (c) { + t5_en_wc = strtol(c, NULL, 0); + if (t5_en_wc != 1) + t5_en_wc = 0; + } +} + + return &dev->ibv_dev; +} + +static __attribute__((constructor)) void cxgb4_register_driver(void) +{ + c4iw_page_size = sysconf(_SC_PAGESIZE); + c4iw_page_shift = long_log2(c4iw_page_size); + c4iw_page_mask = ~(c4iw_page_size - 1); + ibv_register_driver("cxgb4", cxgb4_driver_init); +} + +#ifdef STATS +void __attribute__ ((destructor)) cs_fini(void); +void __attribute__ ((destructor)) cs_fini(void) +{ + syslog(LOG_NOTICE, "cxgb4 stats - sends %lu recv %lu read %lu " + "write %lu arm %lu cqe %lu mr %lu qp %lu cq %lu\n", + c4iw_stats.send, c4iw_stats.recv, c4iw_stats.read, + c4iw_stats.write, c4iw_stats.arm, c4iw_stats.cqe, + c4iw_stats.mr, c4iw_stats.qp, c4iw_stats.cq); +} +#endif Index: head/contrib/ofed/libcxgb4/src/libcxgb4.h =================================================================== --- head/contrib/ofed/libcxgb4/src/libcxgb4.h (nonexistent) +++ head/contrib/ofed/libcxgb4/src/libcxgb4.h (revision 273806) @@ -0,0 +1,257 @@ +/* + * Copyright (c) 2006-2014 Chelsio, Inc. All rights reserved. + * + * This software is available to you under a choice of one of two + * licenses. You may choose to be licensed under the terms of the GNU + * General Public License (GPL) Version 2, available from the file + * COPYING in the main directory of this source tree, or the + * OpenIB.org BSD license below: + * + * Redistribution and use in source and binary forms, with or + * without modification, are permitted provided that the following + * conditions are met: + * + * - Redistributions of source code must retain the above + * copyright notice, this list of conditions and the following + * disclaimer. + * + * - Redistributions in binary form must reproduce the above + * copyright notice, this list of conditions and the following + * disclaimer in the documentation and/or other materials + * provided with the distribution. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, + * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF + * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND + * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS + * BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN + * ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN + * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE + * SOFTWARE. + */ +#ifndef IWCH_H +#define IWCH_H + +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include "queue.h" +#include "t4.h" + +extern unsigned long c4iw_page_size; +extern unsigned long c4iw_page_shift; +extern unsigned long c4iw_page_mask; + +struct c4iw_mr; + +struct c4iw_dev { + struct ibv_device ibv_dev; + unsigned chip_version; + int max_mr; + struct c4iw_mr **mmid2ptr; + int max_qp; + struct c4iw_qp **qpid2ptr; + int max_cq; + struct c4iw_cq **cqid2ptr; + pthread_spinlock_t lock; + SLIST_ENTRY(c4iw_dev) list; + int abi_version; +}; + +static inline int dev_is_t5(struct c4iw_dev *dev) +{ + return dev->chip_version == CHELSIO_T5; +} + +struct c4iw_context { + struct ibv_context ibv_ctx; + struct t4_dev_status_page *status_page; + int status_page_size; +}; + +struct c4iw_pd { + struct ibv_pd ibv_pd; +}; + +struct c4iw_mr { + struct ibv_mr ibv_mr; + uint64_t va_fbo; + uint32_t len; +}; + +static inline u32 c4iw_mmid(u32 stag) +{ + return (stag >> 8); +} + +struct c4iw_cq { + struct ibv_cq ibv_cq; + struct c4iw_dev *rhp; + struct t4_cq cq; + pthread_spinlock_t lock; +#ifdef STALL_DETECTION + struct timeval time; + int dumped; +#endif +}; + +struct c4iw_qp { + struct ibv_qp ibv_qp; + struct c4iw_dev *rhp; + struct t4_wq wq; + pthread_spinlock_t lock; + int sq_sig_all; +}; + +#define to_c4iw_xxx(xxx, type) \ + ((struct c4iw_##type *) \ + ((void *) ib##xxx - offsetof(struct c4iw_##type, ibv_##xxx))) + +static inline struct c4iw_dev *to_c4iw_dev(struct ibv_device *ibdev) +{ + return to_c4iw_xxx(dev, dev); +} + +static inline struct c4iw_context *to_c4iw_context(struct ibv_context *ibctx) +{ + return to_c4iw_xxx(ctx, context); +} + +static inline struct c4iw_pd *to_c4iw_pd(struct ibv_pd *ibpd) +{ + return to_c4iw_xxx(pd, pd); +} + +static inline struct c4iw_cq *to_c4iw_cq(struct ibv_cq *ibcq) +{ + return to_c4iw_xxx(cq, cq); +} + +static inline struct c4iw_qp *to_c4iw_qp(struct ibv_qp *ibqp) +{ + return to_c4iw_xxx(qp, qp); +} + +static inline struct c4iw_mr *to_c4iw_mr(struct ibv_mr *ibmr) +{ + return to_c4iw_xxx(mr, mr); +} + +static inline struct c4iw_qp *get_qhp(struct c4iw_dev *rhp, u32 qid) +{ + return rhp->qpid2ptr[qid]; +} + +static inline struct c4iw_cq *get_chp(struct c4iw_dev *rhp, u32 qid) +{ + return rhp->cqid2ptr[qid]; +} + +static inline unsigned long_log2(unsigned long x) +{ + unsigned r = 0; + for (x >>= 1; x > 0; x >>= 1) + r++; + return r; +} + +int c4iw_query_device(struct ibv_context *context, + struct ibv_device_attr *attr); +int c4iw_query_port(struct ibv_context *context, uint8_t port, + struct ibv_port_attr *attr); + +struct ibv_pd *c4iw_alloc_pd(struct ibv_context *context); +int c4iw_free_pd(struct ibv_pd *pd); + +struct ibv_mr *c4iw_reg_mr(struct ibv_pd *pd, void *addr, + size_t length, int access); +int c4iw_dereg_mr(struct ibv_mr *mr); + +struct ibv_cq *c4iw_create_cq(struct ibv_context *context, int cqe, + struct ibv_comp_channel *channel, + int comp_vector); +int c4iw_resize_cq(struct ibv_cq *cq, int cqe); +int c4iw_destroy_cq(struct ibv_cq *cq); +int c4iw_poll_cq(struct ibv_cq *cq, int ne, struct ibv_wc *wc); +int c4iw_arm_cq(struct ibv_cq *cq, int solicited); +void c4iw_cq_event(struct ibv_cq *cq); +void c4iw_init_cq_buf(struct c4iw_cq *cq, int nent); + +struct ibv_srq *c4iw_create_srq(struct ibv_pd *pd, + struct ibv_srq_init_attr *attr); +int c4iw_modify_srq(struct ibv_srq *srq, + struct ibv_srq_attr *attr, + int mask); +int c4iw_destroy_srq(struct ibv_srq *srq); +int c4iw_post_srq_recv(struct ibv_srq *ibsrq, + struct ibv_recv_wr *wr, + struct ibv_recv_wr **bad_wr); + +struct ibv_qp *c4iw_create_qp(struct ibv_pd *pd, + struct ibv_qp_init_attr *attr); +int c4iw_modify_qp(struct ibv_qp *qp, struct ibv_qp_attr *attr, + int attr_mask); +int c4iw_destroy_qp(struct ibv_qp *qp); +int c4iw_query_qp(struct ibv_qp *qp, + struct ibv_qp_attr *attr, + int attr_mask, + struct ibv_qp_init_attr *init_attr); +void c4iw_flush_qp(struct c4iw_qp *qhp); +void c4iw_flush_qps(struct c4iw_dev *dev); +int c4iw_post_send(struct ibv_qp *ibqp, struct ibv_send_wr *wr, + struct ibv_send_wr **bad_wr); +int c4iw_post_receive(struct ibv_qp *ibqp, struct ibv_recv_wr *wr, + struct ibv_recv_wr **bad_wr); +struct ibv_ah *c4iw_create_ah(struct ibv_pd *pd, + struct ibv_ah_attr *ah_attr); +int c4iw_destroy_ah(struct ibv_ah *ah); +int c4iw_attach_mcast(struct ibv_qp *qp, const union ibv_gid *gid, + uint16_t lid); +int c4iw_detach_mcast(struct ibv_qp *qp, const union ibv_gid *gid, + uint16_t lid); +void c4iw_async_event(struct ibv_async_event *event); +void c4iw_flush_hw_cq(struct c4iw_cq *chp); +int c4iw_flush_rq(struct t4_wq *wq, struct t4_cq *cq, int count); +void c4iw_flush_sq(struct c4iw_qp *qhp); +void c4iw_count_rcqes(struct t4_cq *cq, struct t4_wq *wq, int *count); + +#define FW_MAJ 0 +#define FW_MIN 0 + +static inline unsigned long align(unsigned long val, unsigned long align) +{ + return (val + align - 1) & ~(align - 1); +} + +#ifdef STATS + +#define INC_STAT(a) { c4iw_stats.a++; } + +struct c4iw_stats { + unsigned long send; + unsigned long recv; + unsigned long read; + unsigned long write; + unsigned long arm; + unsigned long cqe; + unsigned long mr; + unsigned long qp; + unsigned long cq; +}; +extern struct c4iw_stats c4iw_stats; +#else +#define INC_STAT(a) +#endif + +#ifdef STALL_DETECTION +void dump_state(); +extern int stall_to; +#endif + +#endif /* IWCH_H */ Index: head/contrib/ofed/libcxgb4/src/qp.c =================================================================== --- head/contrib/ofed/libcxgb4/src/qp.c (nonexistent) +++ head/contrib/ofed/libcxgb4/src/qp.c (revision 273806) @@ -0,0 +1,542 @@ +/* + * Copyright (c) 2006-2014 Chelsio, Inc. All rights reserved. + * + * This software is available to you under a choice of one of two + * licenses. You may choose to be licensed under the terms of the GNU + * General Public License (GPL) Version 2, available from the file + * COPYING in the main directory of this source tree, or the + * OpenIB.org BSD license below: + * + * Redistribution and use in source and binary forms, with or + * without modification, are permitted provided that the following + * conditions are met: + * + * - Redistributions of source code must retain the above + * copyright notice, this list of conditions and the following + * disclaimer. + * + * - Redistributions in binary form must reproduce the above + * copyright notice, this list of conditions and the following + * disclaimer in the documentation and/or other materials + * provided with the distribution. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, + * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF + * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND + * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS + * BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN + * ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN + * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE + * SOFTWARE. + */ +#if HAVE_CONFIG_H +# include +#endif /* HAVE_CONFIG_H */ + +#include +#include +#include +#include +#include +#include +#include "libcxgb4.h" + +#ifdef STATS +struct c4iw_stats c4iw_stats; +#endif + +static void copy_wr_to_sq(struct t4_wq *wq, union t4_wr *wqe, u8 len16) +{ + u64 *src, *dst; + + src = (u64 *)wqe; + dst = (u64 *)((u8 *)wq->sq.queue + wq->sq.wq_pidx * T4_EQ_ENTRY_SIZE); + if (t4_sq_onchip(wq)) { + len16 = align(len16, 4); + wc_wmb(); + } + while (len16) { + *dst++ = *src++; + if (dst == (u64 *)&wq->sq.queue[wq->sq.size]) + dst = (u64 *)wq->sq.queue; + *dst++ = *src++; + if (dst == (u64 *)&wq->sq.queue[wq->sq.size]) + dst = (u64 *)wq->sq.queue; + len16--; + } +} + +static void copy_wr_to_rq(struct t4_wq *wq, union t4_recv_wr *wqe, u8 len16) +{ + u64 *src, *dst; + + src = (u64 *)wqe; + dst = (u64 *)((u8 *)wq->rq.queue + wq->rq.wq_pidx * T4_EQ_ENTRY_SIZE); + while (len16) { + *dst++ = *src++; + if (dst >= (u64 *)&wq->rq.queue[wq->rq.size]) + dst = (u64 *)wq->rq.queue; + *dst++ = *src++; + if (dst >= (u64 *)&wq->rq.queue[wq->rq.size]) + dst = (u64 *)wq->rq.queue; + len16--; + } +} + +static int build_immd(struct t4_sq *sq, struct fw_ri_immd *immdp, + struct ibv_send_wr *wr, int max, u32 *plenp) +{ + u8 *dstp, *srcp; + u32 plen = 0; + int i; + int len; + + dstp = (u8 *)immdp->data; + for (i = 0; i < wr->num_sge; i++) { + if ((plen + wr->sg_list[i].length) > max) + return -EMSGSIZE; + srcp = (u8 *)(unsigned long)wr->sg_list[i].addr; + plen += wr->sg_list[i].length; + len = wr->sg_list[i].length; + memcpy(dstp, srcp, len); + dstp += len; + srcp += len; + } + len = ROUND_UP(plen + 8, 16) - (plen + 8); + if (len) + memset(dstp, 0, len); + immdp->op = FW_RI_DATA_IMMD; + immdp->r1 = 0; + immdp->r2 = 0; + immdp->immdlen = cpu_to_be32(plen); + *plenp = plen; + return 0; +} + +static int build_isgl(struct fw_ri_isgl *isglp, struct ibv_sge *sg_list, + int num_sge, u32 *plenp) +{ + int i; + u32 plen = 0; + __be64 *flitp = (__be64 *)isglp->sge; + + for (i = 0; i < num_sge; i++) { + if ((plen + sg_list[i].length) < plen) + return -EMSGSIZE; + plen += sg_list[i].length; + *flitp++ = cpu_to_be64(((u64)sg_list[i].lkey << 32) | + sg_list[i].length); + *flitp++ = cpu_to_be64(sg_list[i].addr); + } + *flitp = 0; + isglp->op = FW_RI_DATA_ISGL; + isglp->r1 = 0; + isglp->nsge = cpu_to_be16(num_sge); + isglp->r2 = 0; + if (plenp) + *plenp = plen; + return 0; +} + +static int build_rdma_send(struct t4_sq *sq, union t4_wr *wqe, + struct ibv_send_wr *wr, u8 *len16) +{ + u32 plen; + int size; + int ret; + + if (wr->num_sge > T4_MAX_SEND_SGE) + return -EINVAL; + if (wr->send_flags & IBV_SEND_SOLICITED) + wqe->send.sendop_pkd = cpu_to_be32( + V_FW_RI_SEND_WR_SENDOP(FW_RI_SEND_WITH_SE)); + else + wqe->send.sendop_pkd = cpu_to_be32( + V_FW_RI_SEND_WR_SENDOP(FW_RI_SEND)); + wqe->send.stag_inv = 0; + wqe->send.r3 = 0; + wqe->send.r4 = 0; + + plen = 0; + if (wr->num_sge) { + if (wr->send_flags & IBV_SEND_INLINE) { + ret = build_immd(sq, wqe->send.u.immd_src, wr, + T4_MAX_SEND_INLINE, &plen); + if (ret) + return ret; + size = sizeof wqe->send + sizeof(struct fw_ri_immd) + + plen; + } else { + ret = build_isgl(wqe->send.u.isgl_src, + wr->sg_list, wr->num_sge, &plen); + if (ret) + return ret; + size = sizeof wqe->send + sizeof(struct fw_ri_isgl) + + wr->num_sge * sizeof (struct fw_ri_sge); + } + } else { + wqe->send.u.immd_src[0].op = FW_RI_DATA_IMMD; + wqe->send.u.immd_src[0].r1 = 0; + wqe->send.u.immd_src[0].r2 = 0; + wqe->send.u.immd_src[0].immdlen = 0; + size = sizeof wqe->send + sizeof(struct fw_ri_immd); + plen = 0; + } + *len16 = DIV_ROUND_UP(size, 16); + wqe->send.plen = cpu_to_be32(plen); + return 0; +} + +static int build_rdma_write(struct t4_sq *sq, union t4_wr *wqe, + struct ibv_send_wr *wr, u8 *len16) +{ + u32 plen; + int size; + int ret; + + if (wr->num_sge > T4_MAX_SEND_SGE) + return -EINVAL; + wqe->write.r2 = 0; + wqe->write.stag_sink = cpu_to_be32(wr->wr.rdma.rkey); + wqe->write.to_sink = cpu_to_be64(wr->wr.rdma.remote_addr); + if (wr->num_sge) { + if (wr->send_flags & IBV_SEND_INLINE) { + ret = build_immd(sq, wqe->write.u.immd_src, wr, + T4_MAX_WRITE_INLINE, &plen); + if (ret) + return ret; + size = sizeof wqe->write + sizeof(struct fw_ri_immd) + + plen; + } else { + ret = build_isgl(wqe->write.u.isgl_src, + wr->sg_list, wr->num_sge, &plen); + if (ret) + return ret; + size = sizeof wqe->write + sizeof(struct fw_ri_isgl) + + wr->num_sge * sizeof (struct fw_ri_sge); + } + } else { + wqe->write.u.immd_src[0].op = FW_RI_DATA_IMMD; + wqe->write.u.immd_src[0].r1 = 0; + wqe->write.u.immd_src[0].r2 = 0; + wqe->write.u.immd_src[0].immdlen = 0; + size = sizeof wqe->write + sizeof(struct fw_ri_immd); + plen = 0; + } + *len16 = DIV_ROUND_UP(size, 16); + wqe->write.plen = cpu_to_be32(plen); + return 0; +} + +static int build_rdma_read(union t4_wr *wqe, struct ibv_send_wr *wr, u8 *len16) +{ + if (wr->num_sge > 1) + return -EINVAL; + if (wr->num_sge) { + wqe->read.stag_src = cpu_to_be32(wr->wr.rdma.rkey); + wqe->read.to_src_hi = cpu_to_be32((u32)(wr->wr.rdma.remote_addr >>32)); + wqe->read.to_src_lo = cpu_to_be32((u32)wr->wr.rdma.remote_addr); + wqe->read.stag_sink = cpu_to_be32(wr->sg_list[0].lkey); + wqe->read.plen = cpu_to_be32(wr->sg_list[0].length); + wqe->read.to_sink_hi = cpu_to_be32((u32)(wr->sg_list[0].addr >> 32)); + wqe->read.to_sink_lo = cpu_to_be32((u32)(wr->sg_list[0].addr)); + } else { + wqe->read.stag_src = cpu_to_be32(2); + wqe->read.to_src_hi = 0; + wqe->read.to_src_lo = 0; + wqe->read.stag_sink = cpu_to_be32(2); + wqe->read.plen = 0; + wqe->read.to_sink_hi = 0; + wqe->read.to_sink_lo = 0; + } + wqe->read.r2 = 0; + wqe->read.r5 = 0; + *len16 = DIV_ROUND_UP(sizeof wqe->read, 16); + return 0; +} + +static int build_rdma_recv(struct c4iw_qp *qhp, union t4_recv_wr *wqe, + struct ibv_recv_wr *wr, u8 *len16) +{ + int ret; + + ret = build_isgl(&wqe->recv.isgl, wr->sg_list, wr->num_sge, NULL); + if (ret) + return ret; + *len16 = DIV_ROUND_UP(sizeof wqe->recv + + wr->num_sge * sizeof(struct fw_ri_sge), 16); + return 0; +} + +void dump_wqe(void *arg) +{ + u64 *p = arg; + int len16; + + len16 = be64_to_cpu(*p) & 0xff; + while (len16--) { + printf("%02x: %016lx ", (u8)(unsigned long)p, be64_to_cpu(*p)); + p++; + printf("%016lx\n", be64_to_cpu(*p)); + p++; + } +} + +static void ring_kernel_db(struct c4iw_qp *qhp, u32 qid, u16 idx) +{ + struct ibv_modify_qp cmd; + struct ibv_qp_attr attr; + int mask; + int ret; + + wc_wmb(); + if (qid == qhp->wq.sq.qid) { + attr.sq_psn = idx; + mask = IBV_QP_SQ_PSN; + } else { + attr.rq_psn = idx; + mask = IBV_QP_RQ_PSN; + } + ret = ibv_cmd_modify_qp(&qhp->ibv_qp, &attr, mask, &cmd, sizeof cmd); + assert(!ret); +} + +int c4iw_post_send(struct ibv_qp *ibqp, struct ibv_send_wr *wr, + struct ibv_send_wr **bad_wr) +{ + int err = 0; + u8 len16; + enum fw_wr_opcodes fw_opcode; + enum fw_ri_wr_flags fw_flags; + struct c4iw_qp *qhp; + union t4_wr *wqe, lwqe; + u32 num_wrs; + struct t4_swsqe *swsqe; + u16 idx = 0; + + qhp = to_c4iw_qp(ibqp); + pthread_spin_lock(&qhp->lock); + if (t4_wq_in_error(&qhp->wq)) { + pthread_spin_unlock(&qhp->lock); + return -EINVAL; + } + num_wrs = t4_sq_avail(&qhp->wq); + if (num_wrs == 0) { + pthread_spin_unlock(&qhp->lock); + return -ENOMEM; + } + while (wr) { + if (num_wrs == 0) { + err = -ENOMEM; + *bad_wr = wr; + break; + } + + wqe = &lwqe; + fw_flags = 0; + if (wr->send_flags & IBV_SEND_SOLICITED) + fw_flags |= FW_RI_SOLICITED_EVENT_FLAG; + if (wr->send_flags & IBV_SEND_SIGNALED || qhp->sq_sig_all) + fw_flags |= FW_RI_COMPLETION_FLAG; + swsqe = &qhp->wq.sq.sw_sq[qhp->wq.sq.pidx]; + switch (wr->opcode) { + case IBV_WR_SEND: + INC_STAT(send); + if (wr->send_flags & IBV_SEND_FENCE) + fw_flags |= FW_RI_READ_FENCE_FLAG; + fw_opcode = FW_RI_SEND_WR; + swsqe->opcode = FW_RI_SEND; + err = build_rdma_send(&qhp->wq.sq, wqe, wr, &len16); + break; + case IBV_WR_RDMA_WRITE: + INC_STAT(write); + fw_opcode = FW_RI_RDMA_WRITE_WR; + swsqe->opcode = FW_RI_RDMA_WRITE; + err = build_rdma_write(&qhp->wq.sq, wqe, wr, &len16); + break; + case IBV_WR_RDMA_READ: + INC_STAT(read); + fw_opcode = FW_RI_RDMA_READ_WR; + swsqe->opcode = FW_RI_READ_REQ; + fw_flags = 0; + err = build_rdma_read(wqe, wr, &len16); + if (err) + break; + swsqe->read_len = wr->sg_list[0].length; + if (!qhp->wq.sq.oldest_read) + qhp->wq.sq.oldest_read = swsqe; + break; + default: + PDBG("%s post of type=%d TBD!\n", __func__, + wr->opcode); + err = -EINVAL; + } + if (err) { + *bad_wr = wr; + break; + } + swsqe->idx = qhp->wq.sq.pidx; + swsqe->complete = 0; + swsqe->signaled = (wr->send_flags & IBV_SEND_SIGNALED) || + qhp->sq_sig_all; + swsqe->flushed = 0; + swsqe->wr_id = wr->wr_id; + + init_wr_hdr(wqe, qhp->wq.sq.pidx, fw_opcode, fw_flags, len16); + PDBG("%s cookie 0x%llx pidx 0x%x opcode 0x%x\n", + __func__, (unsigned long long)wr->wr_id, qhp->wq.sq.pidx, + swsqe->opcode); + wr = wr->next; + num_wrs--; + copy_wr_to_sq(&qhp->wq, wqe, len16); + t4_sq_produce(&qhp->wq, len16); + idx += DIV_ROUND_UP(len16*16, T4_EQ_ENTRY_SIZE); + } + if (t4_wq_db_enabled(&qhp->wq)) { + t4_ring_sq_db(&qhp->wq, idx, dev_is_t5(qhp->rhp), + len16, wqe); + } else + ring_kernel_db(qhp, qhp->wq.sq.qid, idx); + qhp->wq.sq.queue[qhp->wq.sq.size].status.host_wq_pidx = \ + (qhp->wq.sq.wq_pidx); + pthread_spin_unlock(&qhp->lock); + return err; +} + +int c4iw_post_receive(struct ibv_qp *ibqp, struct ibv_recv_wr *wr, + struct ibv_recv_wr **bad_wr) +{ + int err = 0; + struct c4iw_qp *qhp; + union t4_recv_wr *wqe, lwqe; + u32 num_wrs; + u8 len16 = 0; + u16 idx = 0; + + qhp = to_c4iw_qp(ibqp); + pthread_spin_lock(&qhp->lock); + if (t4_wq_in_error(&qhp->wq)) { + pthread_spin_unlock(&qhp->lock); + return -EINVAL; + } + INC_STAT(recv); + num_wrs = t4_rq_avail(&qhp->wq); + if (num_wrs == 0) { + pthread_spin_unlock(&qhp->lock); + return -ENOMEM; + } + while (wr) { + if (wr->num_sge > T4_MAX_RECV_SGE) { + err = -EINVAL; + *bad_wr = wr; + break; + } + wqe = &lwqe; + if (num_wrs) + err = build_rdma_recv(qhp, wqe, wr, &len16); + else + err = -ENOMEM; + if (err) { + *bad_wr = wr; + break; + } + + qhp->wq.rq.sw_rq[qhp->wq.rq.pidx].wr_id = wr->wr_id; + + wqe->recv.opcode = FW_RI_RECV_WR; + wqe->recv.r1 = 0; + wqe->recv.wrid = qhp->wq.rq.pidx; + wqe->recv.r2[0] = 0; + wqe->recv.r2[1] = 0; + wqe->recv.r2[2] = 0; + wqe->recv.len16 = len16; + PDBG("%s cookie 0x%llx pidx %u\n", __func__, + (unsigned long long) wr->wr_id, qhp->wq.rq.pidx); + copy_wr_to_rq(&qhp->wq, wqe, len16); + t4_rq_produce(&qhp->wq, len16); + idx += DIV_ROUND_UP(len16*16, T4_EQ_ENTRY_SIZE); + wr = wr->next; + num_wrs--; + } + if (t4_wq_db_enabled(&qhp->wq)) + t4_ring_rq_db(&qhp->wq, idx, dev_is_t5(qhp->rhp), + len16, wqe); + else + ring_kernel_db(qhp, qhp->wq.rq.qid, idx); + qhp->wq.rq.queue[qhp->wq.rq.size].status.host_wq_pidx = \ + (qhp->wq.rq.wq_pidx); + pthread_spin_unlock(&qhp->lock); + return err; +} + +static void update_qp_state(struct c4iw_qp *qhp) +{ + struct ibv_query_qp cmd; + struct ibv_qp_attr attr; + struct ibv_qp_init_attr iattr; + int ret; + + ret = ibv_cmd_query_qp(&qhp->ibv_qp, &attr, IBV_QP_STATE, &iattr, + &cmd, sizeof cmd); + assert(!ret); + if (!ret) + qhp->ibv_qp.state = attr.qp_state; +} + +/* + * Assumes qhp lock is held. + */ +void c4iw_flush_qp(struct c4iw_qp *qhp) +{ + struct c4iw_cq *rchp, *schp; + int count; + + if (qhp->wq.flushed) + return; + + update_qp_state(qhp); + + rchp = to_c4iw_cq(qhp->ibv_qp.recv_cq); + schp = to_c4iw_cq(qhp->ibv_qp.send_cq); + + PDBG("%s qhp %p rchp %p schp %p\n", __func__, qhp, rchp, schp); + qhp->wq.flushed = 1; + pthread_spin_unlock(&qhp->lock); + + /* locking heirarchy: cq lock first, then qp lock. */ + pthread_spin_lock(&rchp->lock); + pthread_spin_lock(&qhp->lock); + c4iw_flush_hw_cq(rchp); + c4iw_count_rcqes(&rchp->cq, &qhp->wq, &count); + c4iw_flush_rq(&qhp->wq, &rchp->cq, count); + pthread_spin_unlock(&qhp->lock); + pthread_spin_unlock(&rchp->lock); + + /* locking heirarchy: cq lock first, then qp lock. */ + pthread_spin_lock(&schp->lock); + pthread_spin_lock(&qhp->lock); + if (schp != rchp) + c4iw_flush_hw_cq(schp); + c4iw_flush_sq(qhp); + pthread_spin_unlock(&qhp->lock); + pthread_spin_unlock(&schp->lock); + pthread_spin_lock(&qhp->lock); +} + +void c4iw_flush_qps(struct c4iw_dev *dev) +{ + int i; + + pthread_spin_lock(&dev->lock); + for (i=0; i < dev->max_qp; i++) { + struct c4iw_qp *qhp = dev->qpid2ptr[i]; + if (qhp) { + if (!qhp->wq.flushed && t4_wq_in_error(&qhp->wq)) { + pthread_spin_lock(&qhp->lock); + c4iw_flush_qp(qhp); + pthread_spin_unlock(&qhp->lock); + } + } + } + pthread_spin_unlock(&dev->lock); +} Index: head/contrib/ofed/libcxgb4/src/queue.h =================================================================== --- head/contrib/ofed/libcxgb4/src/queue.h (nonexistent) +++ head/contrib/ofed/libcxgb4/src/queue.h (revision 273806) @@ -0,0 +1,650 @@ +/* + * Copyright (c) 2014 Chelsio, Inc. All rights reserved. + * + * This software is available to you under a choice of one of two + * licenses. You may choose to be licensed under the terms of the GNU + * General Public License (GPL) Version 2, available from the file + * COPYING in the main directory of this source tree, or the + * OpenIB.org BSD license below: + * + * Redistribution and use in source and binary forms, with or + * without modification, are permitted provided that the following + * conditions are met: + * + * - Redistributions of source code must retain the above + * copyright notice, this list of conditions and the following + * disclaimer. + * + * - Redistributions in binary form must reproduce the above + * copyright notice, this list of conditions and the following + * disclaimer in the documentation and/or other materials + * provided with the distribution. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, + * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF + * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND + * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS + * BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN + * ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN + * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE + * SOFTWARE. + */ + +/*- + * Copyright (c) 1991, 1993 + * The Regents of the University of California. All rights reserved. + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions + * are met: + * 1. Redistributions of source code must retain the above copyright + * notice, this list of conditions and the following disclaimer. + * 2. Redistributions in binary form must reproduce the above copyright + * notice, this list of conditions and the following disclaimer in the + * documentation and/or other materials provided with the distribution. + * 4. Neither the name of the University nor the names of its contributors + * may be used to endorse or promote products derived from this software + * without specific prior written permission. + * + * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND + * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE + * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE + * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE + * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL + * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS + * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) + * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT + * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY + * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF + * SUCH DAMAGE. + * + * @(#)queue.h 8.5 (Berkeley) 8/20/94 + * $FreeBSD$ + */ + +#ifndef _SYS_QUEUE_H_ +#define _SYS_QUEUE_H_ + +#include + +/* + * This file defines four types of data structures: singly-linked lists, + * singly-linked tail queues, lists and tail queues. + * + * A singly-linked list is headed by a single forward pointer. The elements + * are singly linked for minimum space and pointer manipulation overhead at + * the expense of O(n) removal for arbitrary elements. New elements can be + * added to the list after an existing element or at the head of the list. + * Elements being removed from the head of the list should use the explicit + * macro for this purpose for optimum efficiency. A singly-linked list may + * only be traversed in the forward direction. Singly-linked lists are ideal + * for applications with large datasets and few or no removals or for + * implementing a LIFO queue. + * + * A singly-linked tail queue is headed by a pair of pointers, one to the + * head of the list and the other to the tail of the list. The elements are + * singly linked for minimum space and pointer manipulation overhead at the + * expense of O(n) removal for arbitrary elements. New elements can be added + * to the list after an existing element, at the head of the list, or at the + * end of the list. Elements being removed from the head of the tail queue + * should use the explicit macro for this purpose for optimum efficiency. + * A singly-linked tail queue may only be traversed in the forward direction. + * Singly-linked tail queues are ideal for applications with large datasets + * and few or no removals or for implementing a FIFO queue. + * + * A list is headed by a single forward pointer (or an array of forward + * pointers for a hash table header). The elements are doubly linked + * so that an arbitrary element can be removed without a need to + * traverse the list. New elements can be added to the list before + * or after an existing element or at the head of the list. A list + * may only be traversed in the forward direction. + * + * A tail queue is headed by a pair of pointers, one to the head of the + * list and the other to the tail of the list. The elements are doubly + * linked so that an arbitrary element can be removed without a need to + * traverse the list. New elements can be added to the list before or + * after an existing element, at the head of the list, or at the end of + * the list. A tail queue may be traversed in either direction. + * + * For details on the use of these macros, see the queue(3) manual page. + * + * + * SLIST LIST STAILQ TAILQ + * _HEAD + + + + + * _HEAD_INITIALIZER + + + + + * _ENTRY + + + + + * _INIT + + + + + * _EMPTY + + + + + * _FIRST + + + + + * _NEXT + + + + + * _PREV - - - + + * _LAST - - + + + * _FOREACH + + + + + * _FOREACH_SAFE + + + + + * _FOREACH_REVERSE - - - + + * _FOREACH_REVERSE_SAFE - - - + + * _INSERT_HEAD + + + + + * _INSERT_BEFORE - + - + + * _INSERT_AFTER + + + + + * _INSERT_TAIL - - + + + * _CONCAT - - + + + * _REMOVE_HEAD + - + - + * _REMOVE + + + + + * + */ +#ifdef QUEUE_MACRO_DEBUG +/* Store the last 2 places the queue element or head was altered */ +struct qm_trace { + char * lastfile; + int lastline; + char * prevfile; + int prevline; +}; + +#define TRACEBUF struct qm_trace trace; +#define TRASHIT(x) do {(x) = (void *)-1;} while (0) + +#define QMD_TRACE_HEAD(head) do { \ + (head)->trace.prevline = (head)->trace.lastline; \ + (head)->trace.prevfile = (head)->trace.lastfile; \ + (head)->trace.lastline = __LINE__; \ + (head)->trace.lastfile = __FILE__; \ +} while (0) + +#define QMD_TRACE_ELEM(elem) do { \ + (elem)->trace.prevline = (elem)->trace.lastline; \ + (elem)->trace.prevfile = (elem)->trace.lastfile; \ + (elem)->trace.lastline = __LINE__; \ + (elem)->trace.lastfile = __FILE__; \ +} while (0) + +#else +#define QMD_TRACE_ELEM(elem) +#define QMD_TRACE_HEAD(head) +#define TRACEBUF +#define TRASHIT(x) +#endif /* QUEUE_MACRO_DEBUG */ + +/* + * Singly-linked List declarations. + */ +#define SLIST_HEAD(name, type) \ +struct name { \ + struct type *slh_first; /* first element */ \ +} + +#define SLIST_HEAD_INITIALIZER(head) \ + { NULL } + +#define SLIST_ENTRY(type) \ +struct { \ + struct type *sle_next; /* next element */ \ +} + +/* + * Singly-linked List functions. + */ +#define SLIST_EMPTY(head) ((head)->slh_first == NULL) + +#define SLIST_FIRST(head) ((head)->slh_first) + +#define SLIST_FOREACH(var, head, field) \ + for ((var) = SLIST_FIRST((head)); \ + (var); \ + (var) = SLIST_NEXT((var), field)) + +#define SLIST_FOREACH_SAFE(var, head, field, tvar) \ + for ((var) = SLIST_FIRST((head)); \ + (var) && ((tvar) = SLIST_NEXT((var), field), 1); \ + (var) = (tvar)) + +#define SLIST_FOREACH_PREVPTR(var, varp, head, field) \ + for ((varp) = &SLIST_FIRST((head)); \ + ((var) = *(varp)) != NULL; \ + (varp) = &SLIST_NEXT((var), field)) + +#define SLIST_INIT(head) do { \ + SLIST_FIRST((head)) = NULL; \ +} while (0) + +#define SLIST_INSERT_AFTER(slistelm, elm, field) do { \ + SLIST_NEXT((elm), field) = SLIST_NEXT((slistelm), field); \ + SLIST_NEXT((slistelm), field) = (elm); \ +} while (0) + +#define SLIST_INSERT_HEAD(head, elm, field) do { \ + SLIST_NEXT((elm), field) = SLIST_FIRST((head)); \ + SLIST_FIRST((head)) = (elm); \ +} while (0) + +#define SLIST_NEXT(elm, field) ((elm)->field.sle_next) + +#define SLIST_REMOVE(head, elm, type, field) do { \ + if (SLIST_FIRST((head)) == (elm)) { \ + SLIST_REMOVE_HEAD((head), field); \ + } \ + else { \ + struct type *curelm = SLIST_FIRST((head)); \ + while (SLIST_NEXT(curelm, field) != (elm)) \ + curelm = SLIST_NEXT(curelm, field); \ + SLIST_NEXT(curelm, field) = \ + SLIST_NEXT(SLIST_NEXT(curelm, field), field); \ + } \ + TRASHIT((elm)->field.sle_next); \ +} while (0) + +#define SLIST_REMOVE_HEAD(head, field) do { \ + SLIST_FIRST((head)) = SLIST_NEXT(SLIST_FIRST((head)), field); \ +} while (0) + +/* + * Singly-linked Tail queue declarations. + */ +#define STAILQ_HEAD(name, type) \ +struct name { \ + struct type *stqh_first;/* first element */ \ + struct type **stqh_last;/* addr of last next element */ \ +} + +#define STAILQ_HEAD_INITIALIZER(head) \ + { NULL, &(head).stqh_first } + +#define STAILQ_ENTRY(type) \ +struct { \ + struct type *stqe_next; /* next element */ \ +} + +/* + * Singly-linked Tail queue functions. + */ +#define STAILQ_CONCAT(head1, head2) do { \ + if (!STAILQ_EMPTY((head2))) { \ + *(head1)->stqh_last = (head2)->stqh_first; \ + (head1)->stqh_last = (head2)->stqh_last; \ + STAILQ_INIT((head2)); \ + } \ +} while (0) + +#define STAILQ_EMPTY(head) ((head)->stqh_first == NULL) + +#define STAILQ_FIRST(head) ((head)->stqh_first) + +#define STAILQ_FOREACH(var, head, field) \ + for((var) = STAILQ_FIRST((head)); \ + (var); \ + (var) = STAILQ_NEXT((var), field)) + + +#define STAILQ_FOREACH_SAFE(var, head, field, tvar) \ + for ((var) = STAILQ_FIRST((head)); \ + (var) && ((tvar) = STAILQ_NEXT((var), field), 1); \ + (var) = (tvar)) + +#define STAILQ_INIT(head) do { \ + STAILQ_FIRST((head)) = NULL; \ + (head)->stqh_last = &STAILQ_FIRST((head)); \ +} while (0) + +#define STAILQ_INSERT_AFTER(head, tqelm, elm, field) do { \ + if ((STAILQ_NEXT((elm), field) = STAILQ_NEXT((tqelm), field)) == NULL)\ + (head)->stqh_last = &STAILQ_NEXT((elm), field); \ + STAILQ_NEXT((tqelm), field) = (elm); \ +} while (0) + +#define STAILQ_INSERT_HEAD(head, elm, field) do { \ + if ((STAILQ_NEXT((elm), field) = STAILQ_FIRST((head))) == NULL) \ + (head)->stqh_last = &STAILQ_NEXT((elm), field); \ + STAILQ_FIRST((head)) = (elm); \ +} while (0) + +#define STAILQ_INSERT_TAIL(head, elm, field) do { \ + STAILQ_NEXT((elm), field) = NULL; \ + *(head)->stqh_last = (elm); \ + (head)->stqh_last = &STAILQ_NEXT((elm), field); \ +} while (0) + +#define STAILQ_LAST(head, type, field) \ + (STAILQ_EMPTY((head)) ? \ + NULL : \ + ((struct type *)(void *) \ + ((char *)((head)->stqh_last) - __offsetof(struct type, field)))) + +#define STAILQ_NEXT(elm, field) ((elm)->field.stqe_next) + +#define STAILQ_REMOVE(head, elm, type, field) do { \ + if (STAILQ_FIRST((head)) == (elm)) { \ + STAILQ_REMOVE_HEAD((head), field); \ + } \ + else { \ + struct type *curelm = STAILQ_FIRST((head)); \ + while (STAILQ_NEXT(curelm, field) != (elm)) \ + curelm = STAILQ_NEXT(curelm, field); \ + if ((STAILQ_NEXT(curelm, field) = \ + STAILQ_NEXT(STAILQ_NEXT(curelm, field), field)) == NULL)\ + (head)->stqh_last = &STAILQ_NEXT((curelm), field);\ + } \ + TRASHIT((elm)->field.stqe_next); \ +} while (0) + +#define STAILQ_REMOVE_HEAD(head, field) do { \ + if ((STAILQ_FIRST((head)) = \ + STAILQ_NEXT(STAILQ_FIRST((head)), field)) == NULL) \ + (head)->stqh_last = &STAILQ_FIRST((head)); \ +} while (0) + +/* + * List declarations. + */ +#define LIST_HEAD(name, type) \ +struct name { \ + struct type *lh_first; /* first element */ \ +} + +#define LIST_HEAD_INITIALIZER(head) \ + { NULL } + +#define LIST_ENTRY(type) \ +struct { \ + struct type *le_next; /* next element */ \ + struct type **le_prev; /* address of previous next element */ \ +} + +/* + * List functions. + */ + +#if (defined(_KERNEL) && defined(INVARIANTS)) +#define QMD_LIST_CHECK_HEAD(head, field) do { \ + if (LIST_FIRST((head)) != NULL && \ + LIST_FIRST((head))->field.le_prev != \ + &LIST_FIRST((head))) \ + panic("Bad list head %p first->prev != head", (head)); \ +} while (0) + +#define QMD_LIST_CHECK_NEXT(elm, field) do { \ + if (LIST_NEXT((elm), field) != NULL && \ + LIST_NEXT((elm), field)->field.le_prev != \ + &((elm)->field.le_next)) \ + panic("Bad link elm %p next->prev != elm", (elm)); \ +} while (0) + +#define QMD_LIST_CHECK_PREV(elm, field) do { \ + if (*(elm)->field.le_prev != (elm)) \ + panic("Bad link elm %p prev->next != elm", (elm)); \ +} while (0) +#else +#define QMD_LIST_CHECK_HEAD(head, field) +#define QMD_LIST_CHECK_NEXT(elm, field) +#define QMD_LIST_CHECK_PREV(elm, field) +#endif /* (_KERNEL && INVARIANTS) */ + +#define LIST_EMPTY(head) ((head)->lh_first == NULL) + +#define LIST_FIRST(head) ((head)->lh_first) + +#define LIST_FOREACH(var, head, field) \ + for ((var) = LIST_FIRST((head)); \ + (var); \ + (var) = LIST_NEXT((var), field)) + +#define LIST_FOREACH_SAFE(var, head, field, tvar) \ + for ((var) = LIST_FIRST((head)); \ + (var) && ((tvar) = LIST_NEXT((var), field), 1); \ + (var) = (tvar)) + +#define LIST_INIT(head) do { \ + LIST_FIRST((head)) = NULL; \ +} while (0) + +#define LIST_INSERT_AFTER(listelm, elm, field) do { \ + QMD_LIST_CHECK_NEXT(listelm, field); \ + if ((LIST_NEXT((elm), field) = LIST_NEXT((listelm), field)) != NULL)\ + LIST_NEXT((listelm), field)->field.le_prev = \ + &LIST_NEXT((elm), field); \ + LIST_NEXT((listelm), field) = (elm); \ + (elm)->field.le_prev = &LIST_NEXT((listelm), field); \ +} while (0) + +#define LIST_INSERT_BEFORE(listelm, elm, field) do { \ + QMD_LIST_CHECK_PREV(listelm, field); \ + (elm)->field.le_prev = (listelm)->field.le_prev; \ + LIST_NEXT((elm), field) = (listelm); \ + *(listelm)->field.le_prev = (elm); \ + (listelm)->field.le_prev = &LIST_NEXT((elm), field); \ +} while (0) + +#define LIST_INSERT_HEAD(head, elm, field) do { \ + QMD_LIST_CHECK_HEAD((head), field); \ + if ((LIST_NEXT((elm), field) = LIST_FIRST((head))) != NULL) \ + LIST_FIRST((head))->field.le_prev = &LIST_NEXT((elm), field);\ + LIST_FIRST((head)) = (elm); \ + (elm)->field.le_prev = &LIST_FIRST((head)); \ +} while (0) + +#define LIST_NEXT(elm, field) ((elm)->field.le_next) + +#define LIST_REMOVE(elm, field) do { \ + QMD_LIST_CHECK_NEXT(elm, field); \ + QMD_LIST_CHECK_PREV(elm, field); \ + if (LIST_NEXT((elm), field) != NULL) \ + LIST_NEXT((elm), field)->field.le_prev = \ + (elm)->field.le_prev; \ + *(elm)->field.le_prev = LIST_NEXT((elm), field); \ + TRASHIT((elm)->field.le_next); \ + TRASHIT((elm)->field.le_prev); \ +} while (0) + +/* + * Tail queue declarations. + */ +#define TAILQ_HEAD(name, type) \ +struct name { \ + struct type *tqh_first; /* first element */ \ + struct type **tqh_last; /* addr of last next element */ \ + TRACEBUF \ +} + +#define TAILQ_HEAD_INITIALIZER(head) \ + { NULL, &(head).tqh_first } + +#define TAILQ_ENTRY(type) \ +struct { \ + struct type *tqe_next; /* next element */ \ + struct type **tqe_prev; /* address of previous next element */ \ + TRACEBUF \ +} + +/* + * Tail queue functions. + */ +#if (defined(_KERNEL) && defined(INVARIANTS)) +#define QMD_TAILQ_CHECK_HEAD(head, field) do { \ + if (!TAILQ_EMPTY(head) && \ + TAILQ_FIRST((head))->field.tqe_prev != \ + &TAILQ_FIRST((head))) \ + panic("Bad tailq head %p first->prev != head", (head)); \ +} while (0) + +#define QMD_TAILQ_CHECK_TAIL(head, field) do { \ + if (*(head)->tqh_last != NULL) \ + panic("Bad tailq NEXT(%p->tqh_last) != NULL", (head)); \ +} while (0) + +#define QMD_TAILQ_CHECK_NEXT(elm, field) do { \ + if (TAILQ_NEXT((elm), field) != NULL && \ + TAILQ_NEXT((elm), field)->field.tqe_prev != \ + &((elm)->field.tqe_next)) \ + panic("Bad link elm %p next->prev != elm", (elm)); \ +} while (0) + +#define QMD_TAILQ_CHECK_PREV(elm, field) do { \ + if (*(elm)->field.tqe_prev != (elm)) \ + panic("Bad link elm %p prev->next != elm", (elm)); \ +} while (0) +#else +#define QMD_TAILQ_CHECK_HEAD(head, field) +#define QMD_TAILQ_CHECK_TAIL(head, headname) +#define QMD_TAILQ_CHECK_NEXT(elm, field) +#define QMD_TAILQ_CHECK_PREV(elm, field) +#endif /* (_KERNEL && INVARIANTS) */ + +#define TAILQ_CONCAT(head1, head2, field) do { \ + if (!TAILQ_EMPTY(head2)) { \ + *(head1)->tqh_last = (head2)->tqh_first; \ + (head2)->tqh_first->field.tqe_prev = (head1)->tqh_last; \ + (head1)->tqh_last = (head2)->tqh_last; \ + TAILQ_INIT((head2)); \ + QMD_TRACE_HEAD(head1); \ + QMD_TRACE_HEAD(head2); \ + } \ +} while (0) + +#define TAILQ_EMPTY(head) ((head)->tqh_first == NULL) + +#define TAILQ_FIRST(head) ((head)->tqh_first) + +#define TAILQ_FOREACH(var, head, field) \ + for ((var) = TAILQ_FIRST((head)); \ + (var); \ + (var) = TAILQ_NEXT((var), field)) + +#define TAILQ_FOREACH_SAFE(var, head, field, tvar) \ + for ((var) = TAILQ_FIRST((head)); \ + (var) && ((tvar) = TAILQ_NEXT((var), field), 1); \ + (var) = (tvar)) + +#define TAILQ_FOREACH_REVERSE(var, head, headname, field) \ + for ((var) = TAILQ_LAST((head), headname); \ + (var); \ + (var) = TAILQ_PREV((var), headname, field)) + +#define TAILQ_FOREACH_REVERSE_SAFE(var, head, headname, field, tvar) \ + for ((var) = TAILQ_LAST((head), headname); \ + (var) && ((tvar) = TAILQ_PREV((var), headname, field), 1); \ + (var) = (tvar)) + +#define TAILQ_INIT(head) do { \ + TAILQ_FIRST((head)) = NULL; \ + (head)->tqh_last = &TAILQ_FIRST((head)); \ + QMD_TRACE_HEAD(head); \ +} while (0) + +#define TAILQ_INSERT_AFTER(head, listelm, elm, field) do { \ + QMD_TAILQ_CHECK_NEXT(listelm, field); \ + if ((TAILQ_NEXT((elm), field) = TAILQ_NEXT((listelm), field)) != NULL)\ + TAILQ_NEXT((elm), field)->field.tqe_prev = \ + &TAILQ_NEXT((elm), field); \ + else { \ + (head)->tqh_last = &TAILQ_NEXT((elm), field); \ + QMD_TRACE_HEAD(head); \ + } \ + TAILQ_NEXT((listelm), field) = (elm); \ + (elm)->field.tqe_prev = &TAILQ_NEXT((listelm), field); \ + QMD_TRACE_ELEM(&(elm)->field); \ + QMD_TRACE_ELEM(&listelm->field); \ +} while (0) + +#define TAILQ_INSERT_BEFORE(listelm, elm, field) do { \ + QMD_TAILQ_CHECK_PREV(listelm, field); \ + (elm)->field.tqe_prev = (listelm)->field.tqe_prev; \ + TAILQ_NEXT((elm), field) = (listelm); \ + *(listelm)->field.tqe_prev = (elm); \ + (listelm)->field.tqe_prev = &TAILQ_NEXT((elm), field); \ + QMD_TRACE_ELEM(&(elm)->field); \ + QMD_TRACE_ELEM(&listelm->field); \ +} while (0) + +#define TAILQ_INSERT_HEAD(head, elm, field) do { \ + QMD_TAILQ_CHECK_HEAD(head, field); \ + if ((TAILQ_NEXT((elm), field) = TAILQ_FIRST((head))) != NULL) \ + TAILQ_FIRST((head))->field.tqe_prev = \ + &TAILQ_NEXT((elm), field); \ + else \ + (head)->tqh_last = &TAILQ_NEXT((elm), field); \ + TAILQ_FIRST((head)) = (elm); \ + (elm)->field.tqe_prev = &TAILQ_FIRST((head)); \ + QMD_TRACE_HEAD(head); \ + QMD_TRACE_ELEM(&(elm)->field); \ +} while (0) + +#define TAILQ_INSERT_TAIL(head, elm, field) do { \ + QMD_TAILQ_CHECK_TAIL(head, field); \ + TAILQ_NEXT((elm), field) = NULL; \ + (elm)->field.tqe_prev = (head)->tqh_last; \ + *(head)->tqh_last = (elm); \ + (head)->tqh_last = &TAILQ_NEXT((elm), field); \ + QMD_TRACE_HEAD(head); \ + QMD_TRACE_ELEM(&(elm)->field); \ +} while (0) + +#define TAILQ_LAST(head, headname) \ + (*(((struct headname *)((head)->tqh_last))->tqh_last)) + +#define TAILQ_NEXT(elm, field) ((elm)->field.tqe_next) + +#define TAILQ_PREV(elm, headname, field) \ + (*(((struct headname *)((elm)->field.tqe_prev))->tqh_last)) + +#define TAILQ_REMOVE(head, elm, field) do { \ + QMD_TAILQ_CHECK_NEXT(elm, field); \ + QMD_TAILQ_CHECK_PREV(elm, field); \ + if ((TAILQ_NEXT((elm), field)) != NULL) \ + TAILQ_NEXT((elm), field)->field.tqe_prev = \ + (elm)->field.tqe_prev; \ + else { \ + (head)->tqh_last = (elm)->field.tqe_prev; \ + QMD_TRACE_HEAD(head); \ + } \ + *(elm)->field.tqe_prev = TAILQ_NEXT((elm), field); \ + TRASHIT((elm)->field.tqe_next); \ + TRASHIT((elm)->field.tqe_prev); \ + QMD_TRACE_ELEM(&(elm)->field); \ +} while (0) + + +#ifdef _KERNEL + +/* + * XXX insque() and remque() are an old way of handling certain queues. + * They bogusly assumes that all queue heads look alike. + */ + +struct quehead { + struct quehead *qh_link; + struct quehead *qh_rlink; +}; + +#ifdef __CC_SUPPORTS___INLINE + +static __inline void +insque(void *a, void *b) +{ + struct quehead *element = (struct quehead *)a, + *head = (struct quehead *)b; + + element->qh_link = head->qh_link; + element->qh_rlink = head; + head->qh_link = element; + element->qh_link->qh_rlink = element; +} + +static __inline void +remque(void *a) +{ + struct quehead *element = (struct quehead *)a; + + element->qh_link->qh_rlink = element->qh_rlink; + element->qh_rlink->qh_link = element->qh_link; + element->qh_rlink = 0; +} + +#else /* !__CC_SUPPORTS___INLINE */ + +void insque(void *a, void *b); +void remque(void *a); + +#endif /* __CC_SUPPORTS___INLINE */ + +#endif /* _KERNEL */ + +#endif /* !_SYS_QUEUE_H_ */ Index: head/contrib/ofed/libcxgb4/src/t4.h =================================================================== --- head/contrib/ofed/libcxgb4/src/t4.h (nonexistent) +++ head/contrib/ofed/libcxgb4/src/t4.h (revision 273806) @@ -0,0 +1,715 @@ +/* + * Copyright (c) 2006-2014 Chelsio, Inc. All rights reserved. + * + * This software is available to you under a choice of one of two + * licenses. You may choose to be licensed under the terms of the GNU + * General Public License (GPL) Version 2, available from the file + * COPYING in the main directory of this source tree, or the + * OpenIB.org BSD license below: + * + * Redistribution and use in source and binary forms, with or + * without modification, are permitted provided that the following + * conditions are met: + * + * - Redistributions of source code must retain the above + * copyright notice, this list of conditions and the following + * disclaimer. + * - Redistributions in binary form must reproduce the above + * copyright notice, this list of conditions and the following + * disclaimer in the documentation and/or other materials + * provided with the distribution. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, + * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF + * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND + * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS + * BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN + * ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN + * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE + * SOFTWARE. + */ +#ifndef __T4_H__ +#define __T4_H__ + +#include +#include +#include + +#define ENODATA 95 +#undef ELAST +#define ELAST ENODATA + +/* + * Try and minimize the changes from the kernel code that is pull in + * here for kernel bypass ops. + */ +#define __u8 uint8_t +#define u8 uint8_t +#define __u16 uint16_t +#define __be16 uint16_t +#define u16 uint16_t +#define __u32 uint32_t +#define __be32 uint32_t +#define u32 uint32_t +#define __u64 uint64_t +#define __be64 uint64_t +#define u64 uint64_t +#define DECLARE_PCI_UNMAP_ADDR(a) +#define __iomem +#define cpu_to_be16 htons +#define cpu_to_be32 htonl +#define cpu_to_be64 htonll +#define be16_to_cpu ntohs +#define be32_to_cpu ntohl +#define be64_to_cpu ntohll +#define BUG_ON(c) assert(!(c)) +#define unlikely +#define ROUND_UP(x, n) (((x) + (n) - 1u) & ~((n) - 1u)) +#define DIV_ROUND_UP(n,d) (((n) + (d) - 1) / (d)) +#if __BYTE_ORDER == __LITTLE_ENDIAN +# define cpu_to_pci32(val) ((val)) +#elif __BYTE_ORDER == __BIG_ENDIAN +# define cpu_to_pci32(val) (__bswap_32((val))) +#else +# error __BYTE_ORDER not defined +#endif + +#define writel(v, a) do { *((volatile u32 *)(a)) = cpu_to_pci32(v); } while (0) + +#include /* For htonl() and friends */ +#include "t4_regs.h" +#include "t4_chip_type.h" +#include "t4fw_interface.h" + +#ifdef DEBUG +#define DBGLOG(s) +#define PDBG(fmt, args...) do {syslog(LOG_DEBUG, fmt, ##args); } while (0) +#else +#define DBGLOG(s) +#define PDBG(fmt, args...) do {} while (0) +#endif + +#define T4_MAX_READ_DEPTH 16 +#define T4_QID_BASE 1024 +#define T4_MAX_QIDS 256 +#define T4_MAX_NUM_PD 65536 +#define T4_EQ_STATUS_ENTRIES (L1_CACHE_BYTES > 64 ? 2 : 1) +#define T4_MAX_EQ_SIZE (65520 - T4_EQ_STATUS_ENTRIES) +#define T4_MAX_IQ_SIZE (65520 - 1) +#define T4_MAX_RQ_SIZE (8192 - T4_EQ_STATUS_ENTRIES) +#define T4_MAX_SQ_SIZE (T4_MAX_EQ_SIZE - 1) +#define T4_MAX_QP_DEPTH (T4_MAX_RQ_SIZE - 1) +#define T4_MAX_CQ_DEPTH (T4_MAX_IQ_SIZE - 1) +#define T4_MAX_NUM_STAG (1<<15) +#define T4_MAX_MR_SIZE (~0ULL - 1) +#define T4_PAGESIZE_MASK 0xffff000 /* 4KB-128MB */ +#define T4_STAG_UNSET 0xffffffff +#define T4_FW_MAJ 0 + +struct t4_status_page { + __be32 rsvd1; /* flit 0 - hw owns */ + __be16 rsvd2; + __be16 qid; + __be16 cidx; + __be16 pidx; + u8 qp_err; /* flit 1 - sw owns */ + u8 db_off; + u8 pad; + u16 host_wq_pidx; + u16 host_cidx; + u16 host_pidx; +}; + +#define T4_EQ_ENTRY_SIZE 64 + +#define T4_SQ_NUM_SLOTS 5 +#define T4_SQ_NUM_BYTES (T4_EQ_ENTRY_SIZE * T4_SQ_NUM_SLOTS) +#define T4_MAX_SEND_SGE ((T4_SQ_NUM_BYTES - sizeof(struct fw_ri_send_wr) - sizeof(struct fw_ri_isgl)) / sizeof (struct fw_ri_sge)) +#define T4_MAX_SEND_INLINE ((T4_SQ_NUM_BYTES - sizeof(struct fw_ri_send_wr) - sizeof(struct fw_ri_immd))) +#define T4_MAX_WRITE_INLINE ((T4_SQ_NUM_BYTES - sizeof(struct fw_ri_rdma_write_wr) - sizeof(struct fw_ri_immd))) +#define T4_MAX_WRITE_SGE ((T4_SQ_NUM_BYTES - sizeof(struct fw_ri_rdma_write_wr) - sizeof(struct fw_ri_isgl)) / sizeof (struct fw_ri_sge)) +#define T4_MAX_FR_IMMD ((T4_SQ_NUM_BYTES - sizeof(struct fw_ri_fr_nsmr_wr) - sizeof(struct fw_ri_immd))) +#define T4_MAX_FR_DEPTH 255 + +#define T4_RQ_NUM_SLOTS 2 +#define T4_RQ_NUM_BYTES (T4_EQ_ENTRY_SIZE * T4_RQ_NUM_SLOTS) +#define T4_MAX_RECV_SGE 4 + +union t4_wr { + struct fw_ri_res_wr res; + struct fw_ri_wr init; + struct fw_ri_rdma_write_wr write; + struct fw_ri_send_wr send; + struct fw_ri_rdma_read_wr read; + struct fw_ri_bind_mw_wr bind; + struct fw_ri_fr_nsmr_wr fr; + struct fw_ri_inv_lstag_wr inv; + struct t4_status_page status; + __be64 flits[T4_EQ_ENTRY_SIZE / sizeof(__be64) * T4_SQ_NUM_SLOTS]; +}; + +union t4_recv_wr { + struct fw_ri_recv_wr recv; + struct t4_status_page status; + __be64 flits[T4_EQ_ENTRY_SIZE / sizeof(__be64) * T4_RQ_NUM_SLOTS]; +}; + +static inline void init_wr_hdr(union t4_wr *wqe, u16 wrid, + enum fw_wr_opcodes opcode, u8 flags, u8 len16) +{ + wqe->send.opcode = (u8)opcode; + wqe->send.flags = flags; + wqe->send.wrid = wrid; + wqe->send.r1[0] = 0; + wqe->send.r1[1] = 0; + wqe->send.r1[2] = 0; + wqe->send.len16 = len16; +} + +/* CQE/AE status codes */ +#define T4_ERR_SUCCESS 0x0 +#define T4_ERR_STAG 0x1 /* STAG invalid: either the */ + /* STAG is offlimt, being 0, */ + /* or STAG_key mismatch */ +#define T4_ERR_PDID 0x2 /* PDID mismatch */ +#define T4_ERR_QPID 0x3 /* QPID mismatch */ +#define T4_ERR_ACCESS 0x4 /* Invalid access right */ +#define T4_ERR_WRAP 0x5 /* Wrap error */ +#define T4_ERR_BOUND 0x6 /* base and bounds voilation */ +#define T4_ERR_INVALIDATE_SHARED_MR 0x7 /* attempt to invalidate a */ + /* shared memory region */ +#define T4_ERR_INVALIDATE_MR_WITH_MW_BOUND 0x8 /* attempt to invalidate a */ + /* shared memory region */ +#define T4_ERR_ECC 0x9 /* ECC error detected */ +#define T4_ERR_ECC_PSTAG 0xA /* ECC error detected when */ + /* reading PSTAG for a MW */ + /* Invalidate */ +#define T4_ERR_PBL_ADDR_BOUND 0xB /* pbl addr out of bounds: */ + /* software error */ +#define T4_ERR_SWFLUSH 0xC /* SW FLUSHED */ +#define T4_ERR_CRC 0x10 /* CRC error */ +#define T4_ERR_MARKER 0x11 /* Marker error */ +#define T4_ERR_PDU_LEN_ERR 0x12 /* invalid PDU length */ +#define T4_ERR_OUT_OF_RQE 0x13 /* out of RQE */ +#define T4_ERR_DDP_VERSION 0x14 /* wrong DDP version */ +#define T4_ERR_RDMA_VERSION 0x15 /* wrong RDMA version */ +#define T4_ERR_OPCODE 0x16 /* invalid rdma opcode */ +#define T4_ERR_DDP_QUEUE_NUM 0x17 /* invalid ddp queue number */ +#define T4_ERR_MSN 0x18 /* MSN error */ +#define T4_ERR_TBIT 0x19 /* tag bit not set correctly */ +#define T4_ERR_MO 0x1A /* MO not 0 for TERMINATE */ + /* or READ_REQ */ +#define T4_ERR_MSN_GAP 0x1B +#define T4_ERR_MSN_RANGE 0x1C +#define T4_ERR_IRD_OVERFLOW 0x1D +#define T4_ERR_RQE_ADDR_BOUND 0x1E /* RQE addr out of bounds: */ + /* software error */ +#define T4_ERR_INTERNAL_ERR 0x1F /* internal error (opcode */ + /* mismatch) */ +/* + * CQE defs + */ +struct t4_cqe { + __be32 header; + __be32 len; + union { + struct { + __be32 stag; + __be32 msn; + } rcqe; + struct { + u32 nada1; + u16 nada2; + u16 cidx; + } scqe; + struct { + __be32 wrid_hi; + __be32 wrid_low; + } gen; + } u; + __be64 reserved; + __be64 bits_type_ts; +}; + +/* macros for flit 0 of the cqe */ + +#define S_CQE_QPID 12 +#define M_CQE_QPID 0xFFFFF +#define G_CQE_QPID(x) ((((x) >> S_CQE_QPID)) & M_CQE_QPID) +#define V_CQE_QPID(x) ((x)<> S_CQE_SWCQE)) & M_CQE_SWCQE) +#define V_CQE_SWCQE(x) ((x)<> S_CQE_STATUS)) & M_CQE_STATUS) +#define V_CQE_STATUS(x) ((x)<> S_CQE_TYPE)) & M_CQE_TYPE) +#define V_CQE_TYPE(x) ((x)<> S_CQE_OPCODE)) & M_CQE_OPCODE) +#define V_CQE_OPCODE(x) ((x)<header))) +#define CQE_QPID(x) (G_CQE_QPID(be32_to_cpu((x)->header))) +#define CQE_TYPE(x) (G_CQE_TYPE(be32_to_cpu((x)->header))) +#define SQ_TYPE(x) (CQE_TYPE((x))) +#define RQ_TYPE(x) (!CQE_TYPE((x))) +#define CQE_STATUS(x) (G_CQE_STATUS(be32_to_cpu((x)->header))) +#define CQE_OPCODE(x) (G_CQE_OPCODE(be32_to_cpu((x)->header))) + +#define CQE_SEND_OPCODE(x)( \ + (G_CQE_OPCODE(be32_to_cpu((x)->header)) == FW_RI_SEND) || \ + (G_CQE_OPCODE(be32_to_cpu((x)->header)) == FW_RI_SEND_WITH_SE) || \ + (G_CQE_OPCODE(be32_to_cpu((x)->header)) == FW_RI_SEND_WITH_INV) || \ + (G_CQE_OPCODE(be32_to_cpu((x)->header)) == FW_RI_SEND_WITH_SE_INV)) + +#define CQE_LEN(x) (be32_to_cpu((x)->len)) + +/* used for RQ completion processing */ +#define CQE_WRID_STAG(x) (be32_to_cpu((x)->u.rcqe.stag)) +#define CQE_WRID_MSN(x) (be32_to_cpu((x)->u.rcqe.msn)) + +/* used for SQ completion processing */ +#define CQE_WRID_SQ_IDX(x) (x)->u.scqe.cidx + +/* generic accessor macros */ +#define CQE_WRID_HI(x) ((x)->u.gen.wrid_hi) +#define CQE_WRID_LOW(x) ((x)->u.gen.wrid_low) + +/* macros for flit 3 of the cqe */ +#define S_CQE_GENBIT 63 +#define M_CQE_GENBIT 0x1 +#define G_CQE_GENBIT(x) (((x) >> S_CQE_GENBIT) & M_CQE_GENBIT) +#define V_CQE_GENBIT(x) ((x)<> S_CQE_OVFBIT)) & M_CQE_OVFBIT) + +#define S_CQE_IQTYPE 60 +#define M_CQE_IQTYPE 0x3 +#define G_CQE_IQTYPE(x) ((((x) >> S_CQE_IQTYPE)) & M_CQE_IQTYPE) + +#define M_CQE_TS 0x0fffffffffffffffULL +#define G_CQE_TS(x) ((x) & M_CQE_TS) + +#define CQE_OVFBIT(x) ((unsigned)G_CQE_OVFBIT(be64_to_cpu((x)->bits_type_ts))) +#define CQE_GENBIT(x) ((unsigned)G_CQE_GENBIT(be64_to_cpu((x)->bits_type_ts))) +#define CQE_TS(x) (G_CQE_TS(be64_to_cpu((x)->bits_type_ts))) + +struct t4_swsqe { + u64 wr_id; + struct t4_cqe cqe; + __be32 read_len; + int opcode; + int complete; + int signaled; + u16 idx; + int flushed; +}; + +enum { + T4_SQ_ONCHIP = (1<<0), +}; + +struct t4_sq { + union t4_wr *queue; + struct t4_swsqe *sw_sq; + struct t4_swsqe *oldest_read; + volatile u32 *udb; + size_t memsize; + u32 qid; + void *ma_sync; + u16 in_use; + u16 size; + u16 cidx; + u16 pidx; + u16 wq_pidx; + u16 flags; + short flush_cidx; +}; + +struct t4_swrqe { + u64 wr_id; +}; + +struct t4_rq { + union t4_recv_wr *queue; + struct t4_swrqe *sw_rq; + volatile u32 *udb; + size_t memsize; + u32 qid; + u32 msn; + u32 rqt_hwaddr; + u16 rqt_size; + u16 in_use; + u16 size; + u16 cidx; + u16 pidx; + u16 wq_pidx; +}; + +struct t4_wq { + struct t4_sq sq; + struct t4_rq rq; + struct c4iw_rdev *rdev; + u32 qid_mask; + int error; + int flushed; + u8 *db_offp; +}; + +static inline void t4_ma_sync(struct t4_wq *wq, int page_size) +{ + wc_wmb(); + *((volatile u32 *)wq->sq.ma_sync) = 1; +} + +static inline int t4_rqes_posted(struct t4_wq *wq) +{ + return wq->rq.in_use; +} + +static inline int t4_rq_empty(struct t4_wq *wq) +{ + return wq->rq.in_use == 0; +} + +static inline int t4_rq_full(struct t4_wq *wq) +{ + return wq->rq.in_use == (wq->rq.size - 1); +} + +static inline u32 t4_rq_avail(struct t4_wq *wq) +{ + return wq->rq.size - 1 - wq->rq.in_use; +} + +static inline void t4_rq_produce(struct t4_wq *wq, u8 len16) +{ + wq->rq.in_use++; + if (++wq->rq.pidx == wq->rq.size) + wq->rq.pidx = 0; + wq->rq.wq_pidx += DIV_ROUND_UP(len16*16, T4_EQ_ENTRY_SIZE); + if (wq->rq.wq_pidx >= wq->rq.size * T4_RQ_NUM_SLOTS) + wq->rq.wq_pidx %= wq->rq.size * T4_RQ_NUM_SLOTS; + if (!wq->error) + wq->rq.queue[wq->rq.size].status.host_pidx = wq->rq.pidx; +} + +static inline void t4_rq_consume(struct t4_wq *wq) +{ + wq->rq.in_use--; + wq->rq.msn++; + if (++wq->rq.cidx == wq->rq.size) + wq->rq.cidx = 0; + assert((wq->rq.cidx != wq->rq.pidx) || wq->rq.in_use == 0); + if (!wq->error) + wq->rq.queue[wq->rq.size].status.host_cidx = wq->rq.cidx; +} + +static inline int t4_sq_empty(struct t4_wq *wq) +{ + return wq->sq.in_use == 0; +} + +static inline int t4_sq_full(struct t4_wq *wq) +{ + return wq->sq.in_use == (wq->sq.size - 1); +} + +static inline u32 t4_sq_avail(struct t4_wq *wq) +{ + return wq->sq.size - 1 - wq->sq.in_use; +} + +static inline int t4_sq_onchip(struct t4_wq *wq) +{ + return wq->sq.flags & T4_SQ_ONCHIP; +} + +static inline void t4_sq_produce(struct t4_wq *wq, u8 len16) +{ + wq->sq.in_use++; + if (++wq->sq.pidx == wq->sq.size) + wq->sq.pidx = 0; + wq->sq.wq_pidx += DIV_ROUND_UP(len16*16, T4_EQ_ENTRY_SIZE); + if (wq->sq.wq_pidx >= wq->sq.size * T4_SQ_NUM_SLOTS) + wq->sq.wq_pidx %= wq->sq.size * T4_SQ_NUM_SLOTS; + if (!wq->error) + wq->sq.queue[wq->sq.size].status.host_pidx = (wq->sq.pidx); +} + +static inline void t4_sq_consume(struct t4_wq *wq) +{ + assert(wq->sq.in_use >= 1); + if (wq->sq.cidx == wq->sq.flush_cidx) + wq->sq.flush_cidx = -1; + wq->sq.in_use--; + if (++wq->sq.cidx == wq->sq.size) + wq->sq.cidx = 0; + assert((wq->sq.cidx != wq->sq.pidx) || wq->sq.in_use == 0); + if (!wq->error) + wq->sq.queue[wq->sq.size].status.host_cidx = wq->sq.cidx; +} + +static void copy_wqe_to_udb(volatile u32 *udb_offset, void *wqe) +{ + u64 *src, *dst; + int len16 = 4; + + src = (u64 *)wqe; + dst = (u64 *)udb_offset; + + while (len16) { + *dst++ = *src++; + *dst++ = *src++; + len16--; + } +} + +extern int ma_wr; +extern int t5_en_wc; + +static inline void t4_ring_sq_db(struct t4_wq *wq, u16 inc, u8 t5, u8 len16, + union t4_wr *wqe) +{ + wc_wmb(); + if (t5) { + if (t5_en_wc && inc == 1) { + PDBG("%s: WC wq->sq.pidx = %d; len16=%d\n", + __func__, wq->sq.pidx, len16); + copy_wqe_to_udb(wq->sq.udb + 14, wqe); + } else { + PDBG("%s: DB wq->sq.pidx = %d; len16=%d\n", + __func__, wq->sq.pidx, len16); + writel(V_PIDX_T5(inc), wq->sq.udb); + } + wc_wmb(); + return; + } + if (ma_wr) { + if (t4_sq_onchip(wq)) { + int i; + for (i = 0; i < 16; i++) + *(volatile u32 *)&wq->sq.queue[wq->sq.size].flits[2+i] = i; + } + } else { + if (t4_sq_onchip(wq)) { + int i; + for (i = 0; i < 16; i++) + *(u32 *)&wq->sq.queue[wq->sq.size].flits[2] = i; + } + } + writel(V_QID(wq->sq.qid & wq->qid_mask) | V_PIDX(inc), wq->sq.udb); +} + +static inline void t4_ring_rq_db(struct t4_wq *wq, u16 inc, u8 t5, u8 len16, + union t4_recv_wr *wqe) +{ + wc_wmb(); + if (t5) { + if (t5_en_wc && inc == 1) { + PDBG("%s: WC wq->rq.pidx = %d; len16=%d\n", + __func__, wq->rq.pidx, len16); + copy_wqe_to_udb(wq->rq.udb + 14, wqe); + } else { + PDBG("%s: DB wq->rq.pidx = %d; len16=%d\n", + __func__, wq->rq.pidx, len16); + writel(V_PIDX_T5(inc), wq->rq.udb); + } + wc_wmb(); + return; + } + writel(V_QID(wq->rq.qid & wq->qid_mask) | V_PIDX(inc), wq->rq.udb); +} + +static inline int t4_wq_in_error(struct t4_wq *wq) +{ + return wq->error || wq->rq.queue[wq->rq.size].status.qp_err; +} + +static inline void t4_set_wq_in_error(struct t4_wq *wq) +{ + wq->rq.queue[wq->rq.size].status.qp_err = 1; +} + +extern int c4iw_abi_version; + +static inline int t4_wq_db_enabled(struct t4_wq *wq) +{ + /* + * If iw_cxgb4 driver supports door bell drop recovery then its + * c4iw_abi_version would be greater than or equal to 2. In such + * case return the status of db_off flag to ring the kernel mode + * DB from user mode library. + */ + if ( c4iw_abi_version >= 2 ) + return ! *wq->db_offp; + else + return 1; +} + +struct t4_cq { + struct t4_cqe *queue; + struct t4_cqe *sw_queue; + struct c4iw_rdev *rdev; + volatile u32 *ugts; + size_t memsize; + u64 bits_type_ts; + u32 cqid; + u32 qid_mask; + u16 size; /* including status page */ + u16 cidx; + u16 sw_pidx; + u16 sw_cidx; + u16 sw_in_use; + u16 cidx_inc; + u8 gen; + u8 error; +}; + +static inline int t4_arm_cq(struct t4_cq *cq, int se) +{ + u32 val; + + while (cq->cidx_inc > M_CIDXINC) { + val = V_SEINTARM(0) | V_CIDXINC(M_CIDXINC) | V_TIMERREG(7) | + V_INGRESSQID(cq->cqid & cq->qid_mask); + writel(val, cq->ugts); + cq->cidx_inc -= M_CIDXINC; + } + val = V_SEINTARM(se) | V_CIDXINC(cq->cidx_inc) | V_TIMERREG(6) | + V_INGRESSQID(cq->cqid & cq->qid_mask); + writel(val, cq->ugts); + cq->cidx_inc = 0; + return 0; +} + +static inline void t4_swcq_produce(struct t4_cq *cq) +{ + cq->sw_in_use++; + if (cq->sw_in_use == cq->size) { + syslog(LOG_NOTICE, "cxgb4 sw cq overflow cqid %u\n", cq->cqid); + cq->error = 1; + assert(0); + } + if (++cq->sw_pidx == cq->size) + cq->sw_pidx = 0; +} + +static inline void t4_swcq_consume(struct t4_cq *cq) +{ + assert(cq->sw_in_use >= 1); + cq->sw_in_use--; + if (++cq->sw_cidx == cq->size) + cq->sw_cidx = 0; +} + +static inline void t4_hwcq_consume(struct t4_cq *cq) +{ + cq->bits_type_ts = cq->queue[cq->cidx].bits_type_ts; + if (++cq->cidx_inc == (cq->size >> 4) || cq->cidx_inc == M_CIDXINC) { + uint32_t val; + + val = V_SEINTARM(0) | V_CIDXINC(cq->cidx_inc) | V_TIMERREG(7) | + V_INGRESSQID(cq->cqid & cq->qid_mask); + writel(val, cq->ugts); + cq->cidx_inc = 0; + } + if (++cq->cidx == cq->size) { + cq->cidx = 0; + cq->gen ^= 1; + } + ((struct t4_status_page *)&cq->queue[cq->size])->host_cidx = cq->cidx; +} + +static inline int t4_valid_cqe(struct t4_cq *cq, struct t4_cqe *cqe) +{ + return (CQE_GENBIT(cqe) == cq->gen); +} + +static inline int t4_next_hw_cqe(struct t4_cq *cq, struct t4_cqe **cqe) +{ + int ret; + u16 prev_cidx; + + if (cq->cidx == 0) + prev_cidx = cq->size - 1; + else + prev_cidx = cq->cidx - 1; + + if (cq->queue[prev_cidx].bits_type_ts != cq->bits_type_ts) { + ret = -EOVERFLOW; + syslog(LOG_NOTICE, "cxgb4 cq overflow cqid %u\n", cq->cqid); + cq->error = 1; + assert(0); + } else if (t4_valid_cqe(cq, &cq->queue[cq->cidx])) { + rmb(); + *cqe = &cq->queue[cq->cidx]; + ret = 0; + } else + ret = -ENODATA; + return ret; +} + +static inline struct t4_cqe *t4_next_sw_cqe(struct t4_cq *cq) +{ + if (cq->sw_in_use == cq->size) { + syslog(LOG_NOTICE, "cxgb4 sw cq overflow cqid %u\n", cq->cqid); + cq->error = 1; + assert(0); + return NULL; + } + if (cq->sw_in_use) + return &cq->sw_queue[cq->sw_cidx]; + return NULL; +} + +static inline int t4_cq_notempty(struct t4_cq *cq) +{ + return cq->sw_in_use || t4_valid_cqe(cq, &cq->queue[cq->cidx]); +} + +static inline int t4_next_cqe(struct t4_cq *cq, struct t4_cqe **cqe) +{ + int ret = 0; + + if (cq->error) + ret = -ENODATA; + else if (cq->sw_in_use) + *cqe = &cq->sw_queue[cq->sw_cidx]; + else ret = t4_next_hw_cqe(cq, cqe); + return ret; +} + +static inline int t4_cq_in_error(struct t4_cq *cq) +{ + return ((struct t4_status_page *)&cq->queue[cq->size])->qp_err; +} + +static inline void t4_set_cq_in_error(struct t4_cq *cq) +{ + ((struct t4_status_page *)&cq->queue[cq->size])->qp_err = 1; +} + +static inline void t4_reset_cq_in_error(struct t4_cq *cq) +{ + ((struct t4_status_page *)&cq->queue[cq->size])->qp_err = 0; +} + +struct t4_dev_status_page +{ + u8 db_off; +}; + +#endif Index: head/contrib/ofed/libcxgb4/src/t4_chip_type.h =================================================================== --- head/contrib/ofed/libcxgb4/src/t4_chip_type.h (nonexistent) +++ head/contrib/ofed/libcxgb4/src/t4_chip_type.h (revision 273806) @@ -0,0 +1,96 @@ +/* + * This file is part of the Chelsio T4 Ethernet driver. + * + * Copyright (C) 2003-2014 Chelsio Communications. All rights reserved. + * + * This program 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 LICENSE file included in this + * release for licensing terms and conditions. + */ +#ifndef __T4_CHIP_TYPE_H__ +#define __T4_CHIP_TYPE_H__ + +/* + * All T4 and later chips have their PCI-E Device IDs encoded as 0xVFPP where: + * + * V = "4" for T4; "5" for T5, etc. or + * = "a" for T4 FPGA; "b" for T4 FPGA, etc. + * F = "0" for PF 0..3; "4".."7" for PF4..7; and "8" for VFs + * PP = adapter product designation + * + * We use the "version" (V) of the adpater to code the Chip Version above + * but separate out the FPGA as a separate boolean as per above. + */ +#define CHELSIO_PCI_ID_VER(__DeviceID) ((__DeviceID) >> 12) +#define CHELSIO_PCI_ID_FUNC(__DeviceID) (((__DeviceID) >> 8) & 0xf) +#define CHELSIO_PCI_ID_PROD(__DeviceID) ((__DeviceID) & 0xff) + +#define CHELSIO_T4 0x4 +#define CHELSIO_T4_FPGA 0xa +#define CHELSIO_T5 0x5 +#define CHELSIO_T5_FPGA 0xb + +/* + * Translate a PCI Device ID to a base Chelsio Chip Version -- CHELSIO_T4, + * CHELSIO_T5, etc. If it weren't for the screwed up numbering of the FPGAs + * we could do this simply as DeviceID >> 12 (because we know the real + * encoding oc CHELSIO_Tx identifiers). However, the FPGAs _do_ have weird + * Device IDs so we need to do this translation here. Note that only constant + * arithmetic and comparisons can be done here since this is being used to + * initialize static tables, etc. + * + * Finally: This will of course need to be expanded as future chips are + * developed. + */ +#define CHELSIO_PCI_ID_CHIP_VERSION(__DeviceID) \ + (CHELSIO_PCI_ID_VER(__DeviceID) == CHELSIO_T4 || \ + CHELSIO_PCI_ID_VER(__DeviceID) == CHELSIO_T4_FPGA \ + ? CHELSIO_T4 \ + : CHELSIO_T5) + +/* + * Internally we code the Chelsio T4 Family "Chip Code" as a tuple: + * + * (Is FPGA, Chip Version, Chip Revision) + * + * where: + * + * Is FPGA: is 0/1 indicating whether we're working with an FPGA + * Chip Version: is T4, T5, etc. + * Chip Revision: is the FAB "spin" of the Chip Version. + */ +#define CHELSIO_CHIP_CODE(version, revision) (((version) << 4) | (revision)) +#define CHELSIO_CHIP_FPGA 0x100 +#define CHELSIO_CHIP_VERSION(code) (((code) >> 4) & 0xf) +#define CHELSIO_CHIP_RELEASE(code) ((code) & 0xf) + +enum chip_type { + T4_A1 = CHELSIO_CHIP_CODE(CHELSIO_T4, 1), + T4_A2 = CHELSIO_CHIP_CODE(CHELSIO_T4, 2), + T4_FIRST_REV = T4_A1, + T4_LAST_REV = T4_A2, + + T5_A0 = CHELSIO_CHIP_CODE(CHELSIO_T5, 0), + T5_A1 = CHELSIO_CHIP_CODE(CHELSIO_T5, 0), + T5_FIRST_REV = T5_A0, + T5_LAST_REV = T5_A1, +}; + +static inline int is_t4(enum chip_type chip) +{ + return (CHELSIO_CHIP_VERSION(chip) == CHELSIO_T4); +} + +static inline int is_t5(enum chip_type chip) +{ + + return (CHELSIO_CHIP_VERSION(chip) == CHELSIO_T5); +} + +static inline int is_fpga(enum chip_type chip) +{ + return chip & CHELSIO_CHIP_FPGA; +} + +#endif /* __T4_CHIP_TYPE_H__ */ Index: head/contrib/ofed/libcxgb4/src/t4_pci_id_tbl.h =================================================================== --- head/contrib/ofed/libcxgb4/src/t4_pci_id_tbl.h (nonexistent) +++ head/contrib/ofed/libcxgb4/src/t4_pci_id_tbl.h (revision 273806) @@ -0,0 +1,175 @@ +/* + * This file is part of the Chelsio T4 Ethernet driver. + * + * Copyright (C) 2003-2014 Chelsio Communications. All rights reserved. + * + * This program 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 LICENSE file included in this + * release for licensing terms and conditions. + */ +#ifndef __T4_PCI_ID_TBL_H__ +#define __T4_PCI_ID_TBL_H__ + +/* + * The Os-Dependent code can defined cpp macros for creating a PCI Device ID + * Table. This is useful because it allows the PCI ID Table to be maintained + * in a single place and all supporting OSes to get new PCI Device IDs + * automatically. + * + * The macros are: + * + * CH_PCI_DEVICE_ID_TABLE_DEFINE_BEGIN + * -- Used to start the definition of the PCI ID Table. + * + * CH_PCI_DEVICE_ID_FUNCTION + * -- The PCI Function Number to use in the PCI Device ID Table. "0" + * -- for drivers attaching to PF0-3, "4" for drivers attaching to PF4, + * -- "8" for drivers attaching to SR-IOV Virtual Functions, etc. + * + * CH_PCI_DEVICE_ID_FUNCTION2 [optional] + * -- If defined, create a PCI Device ID Table with both + * -- CH_PCI_DEVICE_ID_FUNCTION and CH_PCI_DEVICE_ID_FUNCTION2 populated. + * + * CH_PCI_ID_TABLE_ENTRY(DeviceID) + * -- Used for the individual PCI Device ID entries. Note that we will + * -- be adding a trailing comma (",") after all of the entries (and + * -- between the pairs of entries if CH_PCI_DEVICE_ID_FUNCTION2 is defined). + * + * CH_PCI_DEVICE_ID_TABLE_DEFINE_END + * -- Used to finish the definition of the PCI ID Table. Note that we + * -- will be adding a trailing semi-colon (";") here. + * + * CH_PCI_DEVICE_ID_BYPASS_SUPPORTED [optional] + * -- If defined, indicates that the OS Driver has support for Bypass + * -- Adapters. + */ +#ifdef CH_PCI_DEVICE_ID_TABLE_DEFINE_BEGIN + +/* + * Some sanity checks ... + */ +#ifndef CH_PCI_DEVICE_ID_FUNCTION +#error CH_PCI_DEVICE_ID_FUNCTION not defined! +#endif +#ifndef CH_PCI_ID_TABLE_ENTRY +#error CH_PCI_ID_TABLE_ENTRY not defined! +#endif +#ifndef CH_PCI_DEVICE_ID_TABLE_DEFINE_END +#error CH_PCI_DEVICE_ID_TABLE_DEFINE_END not defined! +#endif + +/* + * T4 and later ASICs use a PCI Device ID scheme of 0xVFPP where: + * + * V = "4" for T4; "5" for T5, etc. + * F = "0" for PF 0..3; "4".."7" for PF4..7; and "8" for VFs + * PP = adapter product designation + * + * We use this consistency in order to create the proper PCI Device IDs + * for the specified CH_PCI_DEVICE_ID_FUNCTION. + */ +#ifndef CH_PCI_DEVICE_ID_FUNCTION2 +#define CH_PCI_ID_TABLE_FENTRY(__DeviceID) \ + CH_PCI_ID_TABLE_ENTRY((__DeviceID) | \ + ((CH_PCI_DEVICE_ID_FUNCTION) << 8)) +#else +#define CH_PCI_ID_TABLE_FENTRY(__DeviceID) \ + CH_PCI_ID_TABLE_ENTRY((__DeviceID) | \ + ((CH_PCI_DEVICE_ID_FUNCTION) << 8)), \ + CH_PCI_ID_TABLE_ENTRY((__DeviceID) | \ + ((CH_PCI_DEVICE_ID_FUNCTION2) << 8)) +#endif + +/* Note : The comments against each entry are used by the scripts in the vmware drivers + * to correctly generate the pciid xml file, do not change the format currently used. + */ + +CH_PCI_DEVICE_ID_TABLE_DEFINE_BEGIN + /* + * FPGAs: + * + * Unfortunately the FPGA PCI Device IDs don't follow the ASIC PCI + * Device ID numbering convetions for the Physical Functions. + */ +#if CH_PCI_DEVICE_ID_FUNCTION != 8 + CH_PCI_ID_TABLE_ENTRY(0xa000), /* PE10K FPGA */ + CH_PCI_ID_TABLE_ENTRY(0xb000), /* PF0 T5 PE10K5 FPGA */ + CH_PCI_ID_TABLE_ENTRY(0xb001), /* PF0 T5 PE10K FPGA */ +#else + CH_PCI_ID_TABLE_FENTRY(0xa000), /* PE10K FPGA */ + CH_PCI_ID_TABLE_FENTRY(0xb000), /* PF0 T5 PE10K5 FPGA */ + CH_PCI_ID_TABLE_FENTRY(0xb001), /* PF0 T5 PE10K FPGA */ +#endif + + /* + * These FPGAs seem to be used only by the csiostor driver + */ +#if ((CH_PCI_DEVICE_ID_FUNCTION == 5) || (CH_PCI_DEVICE_ID_FUNCTION == 6)) + CH_PCI_ID_TABLE_ENTRY(0xa001), /* PF1 PE10K FPGA FCOE */ + CH_PCI_ID_TABLE_ENTRY(0xa002), /* PE10K FPGA iSCSI */ +#endif + + /* + * T4 adapters: + */ + CH_PCI_ID_TABLE_FENTRY(0x4000), /* T440-dbg */ + CH_PCI_ID_TABLE_FENTRY(0x4001), /* T420-cr */ + CH_PCI_ID_TABLE_FENTRY(0x4002), /* T422-cr */ + CH_PCI_ID_TABLE_FENTRY(0x4003), /* T440-cr */ + CH_PCI_ID_TABLE_FENTRY(0x4004), /* T420-bch */ + CH_PCI_ID_TABLE_FENTRY(0x4005), /* T440-bch */ + CH_PCI_ID_TABLE_FENTRY(0x4006), /* T440-ch */ + CH_PCI_ID_TABLE_FENTRY(0x4007), /* T420-so */ + CH_PCI_ID_TABLE_FENTRY(0x4008), /* T420-cx */ + CH_PCI_ID_TABLE_FENTRY(0x4009), /* T420-bt */ + CH_PCI_ID_TABLE_FENTRY(0x400a), /* T404-bt */ +#ifdef CH_PCI_DEVICE_ID_BYPASS_SUPPORTED + CH_PCI_ID_TABLE_FENTRY(0x400b), /* B420-sr */ + CH_PCI_ID_TABLE_FENTRY(0x400c), /* B404-bt */ +#endif + CH_PCI_ID_TABLE_FENTRY(0x400d), /* T480-cr */ + CH_PCI_ID_TABLE_FENTRY(0x400e), /* T440-LP-cr */ + CH_PCI_ID_TABLE_FENTRY(0x4080), /* Custom T480-cr */ + CH_PCI_ID_TABLE_FENTRY(0x4081), /* Custom T440-cr */ + CH_PCI_ID_TABLE_FENTRY(0x4082), /* Custom T420-cr */ + CH_PCI_ID_TABLE_FENTRY(0x4083), /* Custom T420-xaui */ + CH_PCI_ID_TABLE_FENTRY(0x4084), /* Custom T440-cr */ + CH_PCI_ID_TABLE_FENTRY(0x4085), /* Custom T420-cr */ + CH_PCI_ID_TABLE_FENTRY(0x4086), /* Custom T440-bt */ + CH_PCI_ID_TABLE_FENTRY(0x4087), /* Custom T440-cr */ + CH_PCI_ID_TABLE_FENTRY(0x4088), /* Custom T440 2-xaui, 2-xfi */ + + /* + * T5 adapters: + */ + CH_PCI_ID_TABLE_FENTRY(0x5000), /* T580-dbg */ + CH_PCI_ID_TABLE_FENTRY(0x5001), /* T520-cr */ + CH_PCI_ID_TABLE_FENTRY(0x5002), /* T522-cr */ + CH_PCI_ID_TABLE_FENTRY(0x5003), /* T540-cr */ + CH_PCI_ID_TABLE_FENTRY(0x5004), /* T520-bch */ + CH_PCI_ID_TABLE_FENTRY(0x5005), /* T540-bch */ + CH_PCI_ID_TABLE_FENTRY(0x5006), /* T540-ch */ + CH_PCI_ID_TABLE_FENTRY(0x5007), /* T520-so */ + CH_PCI_ID_TABLE_FENTRY(0x5008), /* T520-cx */ + CH_PCI_ID_TABLE_FENTRY(0x5009), /* T520-bt */ + CH_PCI_ID_TABLE_FENTRY(0x500a), /* T504-bt */ +#ifdef CH_PCI_DEVICE_ID_BYPASS_SUPPORTED + CH_PCI_ID_TABLE_FENTRY(0x500b), /* B520-sr */ + CH_PCI_ID_TABLE_FENTRY(0x500c), /* B504-bt */ +#endif + CH_PCI_ID_TABLE_FENTRY(0x500d), /* T580-cr */ + CH_PCI_ID_TABLE_FENTRY(0x500e), /* T540-LP-cr */ + CH_PCI_ID_TABLE_FENTRY(0x5010), /* T580-LP-cr */ + CH_PCI_ID_TABLE_FENTRY(0x5011), /* T520-LL-cr */ + CH_PCI_ID_TABLE_FENTRY(0x5012), /* T560-cr */ + CH_PCI_ID_TABLE_FENTRY(0x5013), /* T580-chr */ + CH_PCI_ID_TABLE_FENTRY(0x5014), /* T580-so */ + CH_PCI_ID_TABLE_FENTRY(0x5015), /* T502-bt */ + CH_PCI_ID_TABLE_FENTRY(0x5080), /* Custom T540-cr */ + CH_PCI_ID_TABLE_FENTRY(0x5081), /* Custom T540-LL-cr */ +CH_PCI_DEVICE_ID_TABLE_DEFINE_END; + +#endif /* CH_PCI_DEVICE_ID_TABLE_DEFINE_BEGIN */ + +#endif /* __T4_PCI_ID_TBL_H__ */ Index: head/contrib/ofed/libcxgb4/src/t4_regs.h =================================================================== --- head/contrib/ofed/libcxgb4/src/t4_regs.h (nonexistent) +++ head/contrib/ofed/libcxgb4/src/t4_regs.h (revision 273806) @@ -0,0 +1,42349 @@ +/* This file is automatically generated --- changes will be lost */ + +#define MYPF_BASE 0x1b000 +#define MYPF_REG(reg_addr) (MYPF_BASE + (reg_addr)) + +#define PF0_BASE 0x1e000 +#define PF0_REG(reg_addr) (PF0_BASE + (reg_addr)) + +#define PF1_BASE 0x1e400 +#define PF1_REG(reg_addr) (PF1_BASE + (reg_addr)) + +#define PF2_BASE 0x1e800 +#define PF2_REG(reg_addr) (PF2_BASE + (reg_addr)) + +#define PF3_BASE 0x1ec00 +#define PF3_REG(reg_addr) (PF3_BASE + (reg_addr)) + +#define PF4_BASE 0x1f000 +#define PF4_REG(reg_addr) (PF4_BASE + (reg_addr)) + +#define PF5_BASE 0x1f400 +#define PF5_REG(reg_addr) (PF5_BASE + (reg_addr)) + +#define PF6_BASE 0x1f800 +#define PF6_REG(reg_addr) (PF6_BASE + (reg_addr)) + +#define PF7_BASE 0x1fc00 +#define PF7_REG(reg_addr) (PF7_BASE + (reg_addr)) + +#define PF_STRIDE 0x400 +#define PF_BASE(idx) (PF0_BASE + (idx) * PF_STRIDE) +#define PF_REG(idx, reg) (PF_BASE(idx) + (reg)) + +#define VF_SGE_BASE 0x0 +#define VF_SGE_REG(reg_addr) (VF_SGE_BASE + (reg_addr)) + +#define VF_MPS_BASE 0x100 +#define VF_MPS_REG(reg_addr) (VF_MPS_BASE + (reg_addr)) + +#define VF_PL_BASE 0x200 +#define VF_PL_REG(reg_addr) (VF_PL_BASE + (reg_addr)) + +#define VF_MBDATA_BASE 0x240 +#define VF_MBDATA_REG(reg_addr) (VF_MBDATA_BASE + (reg_addr)) + +#define VF_CIM_BASE 0x300 +#define VF_CIM_REG(reg_addr) (VF_CIM_BASE + (reg_addr)) + +#define MYPORT_BASE 0x1c000 +#define MYPORT_REG(reg_addr) (MYPORT_BASE + (reg_addr)) + +#define PORT0_BASE 0x20000 +#define PORT0_REG(reg_addr) (PORT0_BASE + (reg_addr)) + +#define PORT1_BASE 0x22000 +#define PORT1_REG(reg_addr) (PORT1_BASE + (reg_addr)) + +#define PORT2_BASE 0x24000 +#define PORT2_REG(reg_addr) (PORT2_BASE + (reg_addr)) + +#define PORT3_BASE 0x26000 +#define PORT3_REG(reg_addr) (PORT3_BASE + (reg_addr)) + +#define PORT_STRIDE 0x2000 +#define PORT_BASE(idx) (PORT0_BASE + (idx) * PORT_STRIDE) +#define PORT_REG(idx, reg) (PORT_BASE(idx) + (reg)) + +#define SGE_QUEUE_BASE_MAP_HIGH(idx) (A_SGE_QUEUE_BASE_MAP_HIGH + (idx) * 8) +#define NUM_SGE_QUEUE_BASE_MAP_HIGH_INSTANCES 136 + +#define SGE_QUEUE_BASE_MAP_LOW(idx) (A_SGE_QUEUE_BASE_MAP_LOW + (idx) * 8) +#define NUM_SGE_QUEUE_BASE_MAP_LOW_INSTANCES 136 + +#define PCIE_DMA_REG(reg_addr, idx) ((reg_addr) + (idx) * 8) +#define NUM_PCIE_DMA_INSTANCES 4 + +#define PCIE_CMD_REG(reg_addr, idx) ((reg_addr) + (idx) * 8) +#define NUM_PCIE_CMD_INSTANCES 2 + +#define PCIE_HMA_REG(reg_addr, idx) ((reg_addr) + (idx) * 8) +#define NUM_PCIE_HMA_INSTANCES 1 + +#define PCIE_MEM_ACCESS_REG(reg_addr, idx) ((reg_addr) + (idx) * 8) +#define NUM_PCIE_MEM_ACCESS_INSTANCES 8 + +#define PCIE_MAILBOX_REG(reg_addr, idx) ((reg_addr) + (idx) * 8) +#define NUM_PCIE_MAILBOX_INSTANCES 1 + +#define PCIE_FW_REG(reg_addr, idx) ((reg_addr) + (idx) * 4) +#define NUM_PCIE_FW_INSTANCES 8 + +#define PCIE_FUNC_REG(reg_addr, idx) ((reg_addr) + (idx) * 8) +#define NUM_PCIE_FUNC_INSTANCES 256 + +#define PCIE_FID(idx) (A_PCIE_FID + (idx) * 4) +#define NUM_PCIE_FID_INSTANCES 2048 + +#define PCIE_DMA_BUF_REG(reg_addr, idx) ((reg_addr) + (idx) * 8) +#define NUM_PCIE_DMA_BUF_INSTANCES 4 + +#define MC_DDR3PHYDATX8_REG(reg_addr, idx) ((reg_addr) + (idx) * 256) +#define NUM_MC_DDR3PHYDATX8_INSTANCES 9 + +#define MC_BIST_STATUS_REG(reg_addr, idx) ((reg_addr) + (idx) * 4) +#define NUM_MC_BIST_STATUS_INSTANCES 18 + +#define EDC_BIST_STATUS_REG(reg_addr, idx) ((reg_addr) + (idx) * 4) +#define NUM_EDC_BIST_STATUS_INSTANCES 18 + +#define CIM_PF_MAILBOX_DATA(idx) (A_CIM_PF_MAILBOX_DATA + (idx) * 4) +#define NUM_CIM_PF_MAILBOX_DATA_INSTANCES 16 + +#define MPS_TRC_FILTER_MATCH_CTL_A(idx) (A_MPS_TRC_FILTER_MATCH_CTL_A + (idx) * 4) +#define NUM_MPS_TRC_FILTER_MATCH_CTL_A_INSTANCES 4 + +#define MPS_TRC_FILTER_MATCH_CTL_B(idx) (A_MPS_TRC_FILTER_MATCH_CTL_B + (idx) * 4) +#define NUM_MPS_TRC_FILTER_MATCH_CTL_B_INSTANCES 4 + +#define MPS_TRC_FILTER_RUNT_CTL(idx) (A_MPS_TRC_FILTER_RUNT_CTL + (idx) * 4) +#define NUM_MPS_TRC_FILTER_RUNT_CTL_INSTANCES 4 + +#define MPS_TRC_FILTER_DROP(idx) (A_MPS_TRC_FILTER_DROP + (idx) * 4) +#define NUM_MPS_TRC_FILTER_DROP_INSTANCES 4 + +#define MPS_TRC_FILTER0_MATCH(idx) (A_MPS_TRC_FILTER0_MATCH + (idx) * 4) +#define NUM_MPS_TRC_FILTER0_MATCH_INSTANCES 28 + +#define MPS_TRC_FILTER0_DONT_CARE(idx) (A_MPS_TRC_FILTER0_DONT_CARE + (idx) * 4) +#define NUM_MPS_TRC_FILTER0_DONT_CARE_INSTANCES 28 + +#define MPS_TRC_FILTER1_MATCH(idx) (A_MPS_TRC_FILTER1_MATCH + (idx) * 4) +#define NUM_MPS_TRC_FILTER1_MATCH_INSTANCES 28 + +#define MPS_TRC_FILTER1_DONT_CARE(idx) (A_MPS_TRC_FILTER1_DONT_CARE + (idx) * 4) +#define NUM_MPS_TRC_FILTER1_DONT_CARE_INSTANCES 28 + +#define MPS_TRC_FILTER2_MATCH(idx) (A_MPS_TRC_FILTER2_MATCH + (idx) * 4) +#define NUM_MPS_TRC_FILTER2_MATCH_INSTANCES 28 + +#define MPS_TRC_FILTER2_DONT_CARE(idx) (A_MPS_TRC_FILTER2_DONT_CARE + (idx) * 4) +#define NUM_MPS_TRC_FILTER2_DONT_CARE_INSTANCES 28 + +#define MPS_TRC_FILTER3_MATCH(idx) (A_MPS_TRC_FILTER3_MATCH + (idx) * 4) +#define NUM_MPS_TRC_FILTER3_MATCH_INSTANCES 28 + +#define MPS_TRC_FILTER3_DONT_CARE(idx) (A_MPS_TRC_FILTER3_DONT_CARE + (idx) * 4) +#define NUM_MPS_TRC_FILTER3_DONT_CARE_INSTANCES 28 + +#define MPS_PORT_CLS_HASH_SRAM(idx) (A_MPS_PORT_CLS_HASH_SRAM + (idx) * 4) +#define NUM_MPS_PORT_CLS_HASH_SRAM_INSTANCES 65 + +#define MPS_CLS_VLAN_TABLE(idx) (A_MPS_CLS_VLAN_TABLE + (idx) * 4) +#define NUM_MPS_CLS_VLAN_TABLE_INSTANCES 9 + +#define MPS_CLS_SRAM_L(idx) (A_MPS_CLS_SRAM_L + (idx) * 8) +#define NUM_MPS_CLS_SRAM_L_INSTANCES 336 + +#define MPS_CLS_SRAM_H(idx) (A_MPS_CLS_SRAM_H + (idx) * 8) +#define NUM_MPS_CLS_SRAM_H_INSTANCES 336 + +#define MPS_CLS_TCAM_Y_L(idx) (A_MPS_CLS_TCAM_Y_L + (idx) * 16) +#define NUM_MPS_CLS_TCAM_Y_L_INSTANCES 512 + +#define MPS_CLS_TCAM_Y_H(idx) (A_MPS_CLS_TCAM_Y_H + (idx) * 16) +#define NUM_MPS_CLS_TCAM_Y_H_INSTANCES 512 + +#define MPS_CLS_TCAM_X_L(idx) (A_MPS_CLS_TCAM_X_L + (idx) * 16) +#define NUM_MPS_CLS_TCAM_X_L_INSTANCES 512 + +#define MPS_CLS_TCAM_X_H(idx) (A_MPS_CLS_TCAM_X_H + (idx) * 16) +#define NUM_MPS_CLS_TCAM_X_H_INSTANCES 512 + +#define PL_SEMAPHORE_LOCK(idx) (A_PL_SEMAPHORE_LOCK + (idx) * 4) +#define NUM_PL_SEMAPHORE_LOCK_INSTANCES 8 + +#define PL_VF_SLICE_L(idx) (A_PL_VF_SLICE_L + (idx) * 8) +#define NUM_PL_VF_SLICE_L_INSTANCES 8 + +#define PL_VF_SLICE_H(idx) (A_PL_VF_SLICE_H + (idx) * 8) +#define NUM_PL_VF_SLICE_H_INSTANCES 8 + +#define PL_FLR_VF_STATUS(idx) (A_PL_FLR_VF_STATUS + (idx) * 4) +#define NUM_PL_FLR_VF_STATUS_INSTANCES 4 + +#define PL_VFID_MAP(idx) (A_PL_VFID_MAP + (idx) * 4) +#define NUM_PL_VFID_MAP_INSTANCES 256 + +#define LE_DB_MASK_IPV4(idx) (A_LE_DB_MASK_IPV4 + (idx) * 4) +#define NUM_LE_DB_MASK_IPV4_INSTANCES 17 + +#define LE_DB_MASK_IPV6(idx) (A_LE_DB_MASK_IPV6 + (idx) * 4) +#define NUM_LE_DB_MASK_IPV6_INSTANCES 17 + +#define LE_DB_DBGI_REQ_DATA(idx) (A_LE_DB_DBGI_REQ_DATA + (idx) * 4) +#define NUM_LE_DB_DBGI_REQ_DATA_INSTANCES 17 + +#define LE_DB_DBGI_REQ_MASK(idx) (A_LE_DB_DBGI_REQ_MASK + (idx) * 4) +#define NUM_LE_DB_DBGI_REQ_MASK_INSTANCES 17 + +#define LE_DB_DBGI_RSP_DATA(idx) (A_LE_DB_DBGI_RSP_DATA + (idx) * 4) +#define NUM_LE_DB_DBGI_RSP_DATA_INSTANCES 17 + +#define LE_DB_ACTIVE_MASK_IPV4(idx) (A_LE_DB_ACTIVE_MASK_IPV4 + (idx) * 4) +#define NUM_LE_DB_ACTIVE_MASK_IPV4_INSTANCES 17 + +#define LE_DB_ACTIVE_MASK_IPV6(idx) (A_LE_DB_ACTIVE_MASK_IPV6 + (idx) * 4) +#define NUM_LE_DB_ACTIVE_MASK_IPV6_INSTANCES 17 + +#define LE_HASH_MASK_GEN_IPV4(idx) (A_LE_HASH_MASK_GEN_IPV4 + (idx) * 4) +#define NUM_LE_HASH_MASK_GEN_IPV4_INSTANCES 4 + +#define LE_HASH_MASK_GEN_IPV6(idx) (A_LE_HASH_MASK_GEN_IPV6 + (idx) * 4) +#define NUM_LE_HASH_MASK_GEN_IPV6_INSTANCES 12 + +#define LE_HASH_MASK_CMP_IPV4(idx) (A_LE_HASH_MASK_CMP_IPV4 + (idx) * 4) +#define NUM_LE_HASH_MASK_CMP_IPV4_INSTANCES 4 + +#define LE_HASH_MASK_CMP_IPV6(idx) (A_LE_HASH_MASK_CMP_IPV6 + (idx) * 4) +#define NUM_LE_HASH_MASK_CMP_IPV6_INSTANCES 12 + +#define UP_TSCH_CHANNEL_REG(reg_addr, idx) ((reg_addr) + (idx) * 16) +#define NUM_UP_TSCH_CHANNEL_INSTANCES 4 + +#define CIM_CTL_MAILBOX_VF_STATUS(idx) (A_CIM_CTL_MAILBOX_VF_STATUS + (idx) * 4) +#define NUM_CIM_CTL_MAILBOX_VF_STATUS_INSTANCES 4 + +#define CIM_CTL_MAILBOX_VFN_CTL(idx) (A_CIM_CTL_MAILBOX_VFN_CTL + (idx) * 16) +#define NUM_CIM_CTL_MAILBOX_VFN_CTL_INSTANCES 128 + +#define CIM_CTL_TSCH_CHANNEL_REG(reg_addr, idx) ((reg_addr) + (idx) * 288) +#define NUM_CIM_CTL_TSCH_CHANNEL_INSTANCES 4 + +#define CIM_CTL_TSCH_CHANNEL_TSCH_CLASS_REG(reg_addr, idx) ((reg_addr) + (idx) * 16) +#define NUM_CIM_CTL_TSCH_CHANNEL_TSCH_CLASS_INSTANCES 16 + +#define T5_MYPORT_BASE 0x2c000 +#define T5_MYPORT_REG(reg_addr) (T5_MYPORT_BASE + (reg_addr)) + +#define T5_PORT0_BASE 0x30000 +#define T5_PORT0_REG(reg_addr) (T5_PORT0_BASE + (reg_addr)) + +#define T5_PORT1_BASE 0x34000 +#define T5_PORT1_REG(reg_addr) (T5_PORT1_BASE + (reg_addr)) + +#define T5_PORT2_BASE 0x38000 +#define T5_PORT2_REG(reg_addr) (T5_PORT2_BASE + (reg_addr)) + +#define T5_PORT3_BASE 0x3c000 +#define T5_PORT3_REG(reg_addr) (T5_PORT3_BASE + (reg_addr)) + +#define T5_PORT_STRIDE 0x4000 +#define T5_PORT_BASE(idx) (T5_PORT0_BASE + (idx) * T5_PORT_STRIDE) +#define T5_PORT_REG(idx, reg) (T5_PORT_BASE(idx) + (reg)) + +#define MC_STRIDE (MC_1_BASE_ADDR - MC_0_BASE_ADDR) +#define MC_REG(reg, idx) (reg + MC_STRIDE * idx) + +#define PCIE_PF_INT_REG(reg_addr, idx) ((reg_addr) + (idx) * 8) +#define NUM_PCIE_PF_INT_INSTANCES 8 + +#define PCIE_VF_INT_REG(reg_addr, idx) ((reg_addr) + (idx) * 8) +#define NUM_PCIE_VF_INT_INSTANCES 128 + +#define PCIE_FID_VFID(idx) (A_PCIE_FID_VFID + (idx) * 4) +#define NUM_PCIE_FID_VFID_INSTANCES 2048 + +#define PCIE_COOKIE_REG(reg_addr, idx) ((reg_addr) + (idx) * 4) +#define NUM_PCIE_COOKIE_INSTANCES 8 + +#define PCIE_T5_DMA_REG(reg_addr, idx) ((reg_addr) + (idx) * 16) +#define NUM_PCIE_T5_DMA_INSTANCES 4 + +#define PCIE_T5_CMD_REG(reg_addr, idx) ((reg_addr) + (idx) * 16) +#define NUM_PCIE_T5_CMD_INSTANCES 3 + +#define PCIE_T5_HMA_REG(reg_addr, idx) ((reg_addr) + (idx) * 16) +#define NUM_PCIE_T5_HMA_INSTANCES 1 + +#define PCIE_PHY_PRESET_REG(reg_addr, idx) ((reg_addr) + (idx) * 4) +#define NUM_PCIE_PHY_PRESET_INSTANCES 11 + +#define MPS_T5_CLS_SRAM_L(idx) (A_MPS_T5_CLS_SRAM_L + (idx) * 8) +#define NUM_MPS_T5_CLS_SRAM_L_INSTANCES 512 + +#define MPS_T5_CLS_SRAM_H(idx) (A_MPS_T5_CLS_SRAM_H + (idx) * 8) +#define NUM_MPS_T5_CLS_SRAM_H_INSTANCES 512 + +#define LE_T5_DB_MASK_IPV4(idx) (A_LE_T5_DB_MASK_IPV4 + (idx) * 4) +#define NUM_LE_T5_DB_MASK_IPV4_INSTANCES 5 + +#define LE_T5_DB_ACTIVE_MASK_IPV4(idx) (A_LE_T5_DB_ACTIVE_MASK_IPV4 + (idx) * 4) +#define NUM_LE_T5_DB_ACTIVE_MASK_IPV4_INSTANCES 5 + +#define LE_HASH_MASK_GEN_IPV4T5(idx) (A_LE_HASH_MASK_GEN_IPV4T5 + (idx) * 4) +#define NUM_LE_HASH_MASK_GEN_IPV4T5_INSTANCES 5 + +#define LE_HASH_MASK_GEN_IPV6T5(idx) (A_LE_HASH_MASK_GEN_IPV6T5 + (idx) * 4) +#define NUM_LE_HASH_MASK_GEN_IPV6T5_INSTANCES 12 + +#define LE_HASH_MASK_CMP_IPV4T5(idx) (A_LE_HASH_MASK_CMP_IPV4T5 + (idx) * 4) +#define NUM_LE_HASH_MASK_CMP_IPV4T5_INSTANCES 5 + +#define LE_HASH_MASK_CMP_IPV6T5(idx) (A_LE_HASH_MASK_CMP_IPV6T5 + (idx) * 4) +#define NUM_LE_HASH_MASK_CMP_IPV6T5_INSTANCES 12 + +#define LE_DB_SECOND_ACTIVE_MASK_IPV4(idx) (A_LE_DB_SECOND_ACTIVE_MASK_IPV4 + (idx) * 4) +#define NUM_LE_DB_SECOND_ACTIVE_MASK_IPV4_INSTANCES 5 + +#define LE_DB_SECOND_GEN_HASH_MASK_IPV4(idx) (A_LE_DB_SECOND_GEN_HASH_MASK_IPV4 + (idx) * 4) +#define NUM_LE_DB_SECOND_GEN_HASH_MASK_IPV4_INSTANCES 5 + +#define LE_DB_SECOND_CMP_HASH_MASK_IPV4(idx) (A_LE_DB_SECOND_CMP_HASH_MASK_IPV4 + (idx) * 4) +#define NUM_LE_DB_SECOND_CMP_HASH_MASK_IPV4_INSTANCES 5 + +#define MC_ADR_REG(reg_addr, idx) ((reg_addr) + (idx) * 512) +#define NUM_MC_ADR_INSTANCES 2 + +#define MC_DDRPHY_DP18_REG(reg_addr, idx) ((reg_addr) + (idx) * 512) +#define NUM_MC_DDRPHY_DP18_INSTANCES 5 + +#define MC_CE_ERR_DATA_REG(reg_addr, idx) ((reg_addr) + (idx) * 4) +#define NUM_MC_CE_ERR_DATA_INSTANCES 8 + +#define MC_CE_COR_DATA_REG(reg_addr, idx) ((reg_addr) + (idx) * 4) +#define NUM_MC_CE_COR_DATA_INSTANCES 8 + +#define MC_UE_ERR_DATA_REG(reg_addr, idx) ((reg_addr) + (idx) * 4) +#define NUM_MC_UE_ERR_DATA_INSTANCES 8 + +#define MC_UE_COR_DATA_REG(reg_addr, idx) ((reg_addr) + (idx) * 4) +#define NUM_MC_UE_COR_DATA_INSTANCES 8 + +#define MC_P_BIST_STATUS_REG(reg_addr, idx) ((reg_addr) + (idx) * 4) +#define NUM_MC_P_BIST_STATUS_INSTANCES 18 + +#define EDC_H_BIST_STATUS_REG(reg_addr, idx) ((reg_addr) + (idx) * 4) +#define NUM_EDC_H_BIST_STATUS_INSTANCES 18 + +#define EDC_H_ECC_ERR_DATA_REG(reg_addr, idx) ((reg_addr) + (idx) * 4) +#define NUM_EDC_H_ECC_ERR_DATA_INSTANCES 16 + +#define EDC_STRIDE (EDC_1_BASE_ADDR - EDC_0_BASE_ADDR) +#define EDC_REG(reg, idx) (reg + EDC_STRIDE * idx) + +/* registers for module SGE */ +#define SGE_BASE_ADDR 0x1000 + +#define A_SGE_PF_KDOORBELL 0x0 + +#define S_QID 15 +#define M_QID 0x1ffffU +#define V_QID(x) ((x) << S_QID) +#define G_QID(x) (((x) >> S_QID) & M_QID) + +#define S_DBPRIO 14 +#define V_DBPRIO(x) ((x) << S_DBPRIO) +#define F_DBPRIO V_DBPRIO(1U) + +#define S_PIDX 0 +#define M_PIDX 0x3fffU +#define V_PIDX(x) ((x) << S_PIDX) +#define G_PIDX(x) (((x) >> S_PIDX) & M_PIDX) + +#define A_SGE_VF_KDOORBELL 0x0 + +#define S_DBTYPE 13 +#define V_DBTYPE(x) ((x) << S_DBTYPE) +#define F_DBTYPE V_DBTYPE(1U) + +#define S_PIDX_T5 0 +#define M_PIDX_T5 0x1fffU +#define V_PIDX_T5(x) ((x) << S_PIDX_T5) +#define G_PIDX_T5(x) (((x) >> S_PIDX_T5) & M_PIDX_T5) + +#define A_SGE_PF_GTS 0x4 + +#define S_INGRESSQID 16 +#define M_INGRESSQID 0xffffU +#define V_INGRESSQID(x) ((x) << S_INGRESSQID) +#define G_INGRESSQID(x) (((x) >> S_INGRESSQID) & M_INGRESSQID) + +#define S_TIMERREG 13 +#define M_TIMERREG 0x7U +#define V_TIMERREG(x) ((x) << S_TIMERREG) +#define G_TIMERREG(x) (((x) >> S_TIMERREG) & M_TIMERREG) + +#define S_SEINTARM 12 +#define V_SEINTARM(x) ((x) << S_SEINTARM) +#define F_SEINTARM V_SEINTARM(1U) + +#define S_CIDXINC 0 +#define M_CIDXINC 0xfffU +#define V_CIDXINC(x) ((x) << S_CIDXINC) +#define G_CIDXINC(x) (((x) >> S_CIDXINC) & M_CIDXINC) + +#define A_SGE_VF_GTS 0x4 +#define A_SGE_PF_KTIMESTAMP_LO 0x8 +#define A_SGE_VF_KTIMESTAMP_LO 0x8 +#define A_SGE_PF_KTIMESTAMP_HI 0xc + +#define S_TSTAMPVAL 0 +#define M_TSTAMPVAL 0xfffffffU +#define V_TSTAMPVAL(x) ((x) << S_TSTAMPVAL) +#define G_TSTAMPVAL(x) (((x) >> S_TSTAMPVAL) & M_TSTAMPVAL) + +#define A_SGE_VF_KTIMESTAMP_HI 0xc +#define A_SGE_CONTROL 0x1008 + +#define S_IGRALLCPLTOFL 31 +#define V_IGRALLCPLTOFL(x) ((x) << S_IGRALLCPLTOFL) +#define F_IGRALLCPLTOFL V_IGRALLCPLTOFL(1U) + +#define S_FLSPLITMIN 22 +#define M_FLSPLITMIN 0x1ffU +#define V_FLSPLITMIN(x) ((x) << S_FLSPLITMIN) +#define G_FLSPLITMIN(x) (((x) >> S_FLSPLITMIN) & M_FLSPLITMIN) + +#define S_FLSPLITMODE 20 +#define M_FLSPLITMODE 0x3U +#define V_FLSPLITMODE(x) ((x) << S_FLSPLITMODE) +#define G_FLSPLITMODE(x) (((x) >> S_FLSPLITMODE) & M_FLSPLITMODE) + +#define S_DCASYSTYPE 19 +#define V_DCASYSTYPE(x) ((x) << S_DCASYSTYPE) +#define F_DCASYSTYPE V_DCASYSTYPE(1U) + +#define S_RXPKTCPLMODE 18 +#define V_RXPKTCPLMODE(x) ((x) << S_RXPKTCPLMODE) +#define F_RXPKTCPLMODE V_RXPKTCPLMODE(1U) + +#define S_EGRSTATUSPAGESIZE 17 +#define V_EGRSTATUSPAGESIZE(x) ((x) << S_EGRSTATUSPAGESIZE) +#define F_EGRSTATUSPAGESIZE V_EGRSTATUSPAGESIZE(1U) + +#define S_INGHINTENABLE1 15 +#define V_INGHINTENABLE1(x) ((x) << S_INGHINTENABLE1) +#define F_INGHINTENABLE1 V_INGHINTENABLE1(1U) + +#define S_INGHINTENABLE0 14 +#define V_INGHINTENABLE0(x) ((x) << S_INGHINTENABLE0) +#define F_INGHINTENABLE0 V_INGHINTENABLE0(1U) + +#define S_INGINTCOMPAREIDX 13 +#define V_INGINTCOMPAREIDX(x) ((x) << S_INGINTCOMPAREIDX) +#define F_INGINTCOMPAREIDX V_INGINTCOMPAREIDX(1U) + +#define S_PKTSHIFT 10 +#define M_PKTSHIFT 0x7U +#define V_PKTSHIFT(x) ((x) << S_PKTSHIFT) +#define G_PKTSHIFT(x) (((x) >> S_PKTSHIFT) & M_PKTSHIFT) + +#define S_INGPCIEBOUNDARY 7 +#define M_INGPCIEBOUNDARY 0x7U +#define V_INGPCIEBOUNDARY(x) ((x) << S_INGPCIEBOUNDARY) +#define G_INGPCIEBOUNDARY(x) (((x) >> S_INGPCIEBOUNDARY) & M_INGPCIEBOUNDARY) + +#define S_INGPADBOUNDARY 4 +#define M_INGPADBOUNDARY 0x7U +#define V_INGPADBOUNDARY(x) ((x) << S_INGPADBOUNDARY) +#define G_INGPADBOUNDARY(x) (((x) >> S_INGPADBOUNDARY) & M_INGPADBOUNDARY) + +#define S_EGRPCIEBOUNDARY 1 +#define M_EGRPCIEBOUNDARY 0x7U +#define V_EGRPCIEBOUNDARY(x) ((x) << S_EGRPCIEBOUNDARY) +#define G_EGRPCIEBOUNDARY(x) (((x) >> S_EGRPCIEBOUNDARY) & M_EGRPCIEBOUNDARY) + +#define S_GLOBALENABLE 0 +#define V_GLOBALENABLE(x) ((x) << S_GLOBALENABLE) +#define F_GLOBALENABLE V_GLOBALENABLE(1U) + +#define A_SGE_HOST_PAGE_SIZE 0x100c + +#define S_HOSTPAGESIZEPF7 28 +#define M_HOSTPAGESIZEPF7 0xfU +#define V_HOSTPAGESIZEPF7(x) ((x) << S_HOSTPAGESIZEPF7) +#define G_HOSTPAGESIZEPF7(x) (((x) >> S_HOSTPAGESIZEPF7) & M_HOSTPAGESIZEPF7) + +#define S_HOSTPAGESIZEPF6 24 +#define M_HOSTPAGESIZEPF6 0xfU +#define V_HOSTPAGESIZEPF6(x) ((x) << S_HOSTPAGESIZEPF6) +#define G_HOSTPAGESIZEPF6(x) (((x) >> S_HOSTPAGESIZEPF6) & M_HOSTPAGESIZEPF6) + +#define S_HOSTPAGESIZEPF5 20 +#define M_HOSTPAGESIZEPF5 0xfU +#define V_HOSTPAGESIZEPF5(x) ((x) << S_HOSTPAGESIZEPF5) +#define G_HOSTPAGESIZEPF5(x) (((x) >> S_HOSTPAGESIZEPF5) & M_HOSTPAGESIZEPF5) + +#define S_HOSTPAGESIZEPF4 16 +#define M_HOSTPAGESIZEPF4 0xfU +#define V_HOSTPAGESIZEPF4(x) ((x) << S_HOSTPAGESIZEPF4) +#define G_HOSTPAGESIZEPF4(x) (((x) >> S_HOSTPAGESIZEPF4) & M_HOSTPAGESIZEPF4) + +#define S_HOSTPAGESIZEPF3 12 +#define M_HOSTPAGESIZEPF3 0xfU +#define V_HOSTPAGESIZEPF3(x) ((x) << S_HOSTPAGESIZEPF3) +#define G_HOSTPAGESIZEPF3(x) (((x) >> S_HOSTPAGESIZEPF3) & M_HOSTPAGESIZEPF3) + +#define S_HOSTPAGESIZEPF2 8 +#define M_HOSTPAGESIZEPF2 0xfU +#define V_HOSTPAGESIZEPF2(x) ((x) << S_HOSTPAGESIZEPF2) +#define G_HOSTPAGESIZEPF2(x) (((x) >> S_HOSTPAGESIZEPF2) & M_HOSTPAGESIZEPF2) + +#define S_HOSTPAGESIZEPF1 4 +#define M_HOSTPAGESIZEPF1 0xfU +#define V_HOSTPAGESIZEPF1(x) ((x) << S_HOSTPAGESIZEPF1) +#define G_HOSTPAGESIZEPF1(x) (((x) >> S_HOSTPAGESIZEPF1) & M_HOSTPAGESIZEPF1) + +#define S_HOSTPAGESIZEPF0 0 +#define M_HOSTPAGESIZEPF0 0xfU +#define V_HOSTPAGESIZEPF0(x) ((x) << S_HOSTPAGESIZEPF0) +#define G_HOSTPAGESIZEPF0(x) (((x) >> S_HOSTPAGESIZEPF0) & M_HOSTPAGESIZEPF0) + +#define A_SGE_EGRESS_QUEUES_PER_PAGE_PF 0x1010 + +#define S_QUEUESPERPAGEPF7 28 +#define M_QUEUESPERPAGEPF7 0xfU +#define V_QUEUESPERPAGEPF7(x) ((x) << S_QUEUESPERPAGEPF7) +#define G_QUEUESPERPAGEPF7(x) (((x) >> S_QUEUESPERPAGEPF7) & M_QUEUESPERPAGEPF7) + +#define S_QUEUESPERPAGEPF6 24 +#define M_QUEUESPERPAGEPF6 0xfU +#define V_QUEUESPERPAGEPF6(x) ((x) << S_QUEUESPERPAGEPF6) +#define G_QUEUESPERPAGEPF6(x) (((x) >> S_QUEUESPERPAGEPF6) & M_QUEUESPERPAGEPF6) + +#define S_QUEUESPERPAGEPF5 20 +#define M_QUEUESPERPAGEPF5 0xfU +#define V_QUEUESPERPAGEPF5(x) ((x) << S_QUEUESPERPAGEPF5) +#define G_QUEUESPERPAGEPF5(x) (((x) >> S_QUEUESPERPAGEPF5) & M_QUEUESPERPAGEPF5) + +#define S_QUEUESPERPAGEPF4 16 +#define M_QUEUESPERPAGEPF4 0xfU +#define V_QUEUESPERPAGEPF4(x) ((x) << S_QUEUESPERPAGEPF4) +#define G_QUEUESPERPAGEPF4(x) (((x) >> S_QUEUESPERPAGEPF4) & M_QUEUESPERPAGEPF4) + +#define S_QUEUESPERPAGEPF3 12 +#define M_QUEUESPERPAGEPF3 0xfU +#define V_QUEUESPERPAGEPF3(x) ((x) << S_QUEUESPERPAGEPF3) +#define G_QUEUESPERPAGEPF3(x) (((x) >> S_QUEUESPERPAGEPF3) & M_QUEUESPERPAGEPF3) + +#define S_QUEUESPERPAGEPF2 8 +#define M_QUEUESPERPAGEPF2 0xfU +#define V_QUEUESPERPAGEPF2(x) ((x) << S_QUEUESPERPAGEPF2) +#define G_QUEUESPERPAGEPF2(x) (((x) >> S_QUEUESPERPAGEPF2) & M_QUEUESPERPAGEPF2) + +#define S_QUEUESPERPAGEPF1 4 +#define M_QUEUESPERPAGEPF1 0xfU +#define V_QUEUESPERPAGEPF1(x) ((x) << S_QUEUESPERPAGEPF1) +#define G_QUEUESPERPAGEPF1(x) (((x) >> S_QUEUESPERPAGEPF1) & M_QUEUESPERPAGEPF1) + +#define S_QUEUESPERPAGEPF0 0 +#define M_QUEUESPERPAGEPF0 0xfU +#define V_QUEUESPERPAGEPF0(x) ((x) << S_QUEUESPERPAGEPF0) +#define G_QUEUESPERPAGEPF0(x) (((x) >> S_QUEUESPERPAGEPF0) & M_QUEUESPERPAGEPF0) + +#define A_SGE_EGRESS_QUEUES_PER_PAGE_VF 0x1014 + +#define S_QUEUESPERPAGEVFPF7 28 +#define M_QUEUESPERPAGEVFPF7 0xfU +#define V_QUEUESPERPAGEVFPF7(x) ((x) << S_QUEUESPERPAGEVFPF7) +#define G_QUEUESPERPAGEVFPF7(x) (((x) >> S_QUEUESPERPAGEVFPF7) & M_QUEUESPERPAGEVFPF7) + +#define S_QUEUESPERPAGEVFPF6 24 +#define M_QUEUESPERPAGEVFPF6 0xfU +#define V_QUEUESPERPAGEVFPF6(x) ((x) << S_QUEUESPERPAGEVFPF6) +#define G_QUEUESPERPAGEVFPF6(x) (((x) >> S_QUEUESPERPAGEVFPF6) & M_QUEUESPERPAGEVFPF6) + +#define S_QUEUESPERPAGEVFPF5 20 +#define M_QUEUESPERPAGEVFPF5 0xfU +#define V_QUEUESPERPAGEVFPF5(x) ((x) << S_QUEUESPERPAGEVFPF5) +#define G_QUEUESPERPAGEVFPF5(x) (((x) >> S_QUEUESPERPAGEVFPF5) & M_QUEUESPERPAGEVFPF5) + +#define S_QUEUESPERPAGEVFPF4 16 +#define M_QUEUESPERPAGEVFPF4 0xfU +#define V_QUEUESPERPAGEVFPF4(x) ((x) << S_QUEUESPERPAGEVFPF4) +#define G_QUEUESPERPAGEVFPF4(x) (((x) >> S_QUEUESPERPAGEVFPF4) & M_QUEUESPERPAGEVFPF4) + +#define S_QUEUESPERPAGEVFPF3 12 +#define M_QUEUESPERPAGEVFPF3 0xfU +#define V_QUEUESPERPAGEVFPF3(x) ((x) << S_QUEUESPERPAGEVFPF3) +#define G_QUEUESPERPAGEVFPF3(x) (((x) >> S_QUEUESPERPAGEVFPF3) & M_QUEUESPERPAGEVFPF3) + +#define S_QUEUESPERPAGEVFPF2 8 +#define M_QUEUESPERPAGEVFPF2 0xfU +#define V_QUEUESPERPAGEVFPF2(x) ((x) << S_QUEUESPERPAGEVFPF2) +#define G_QUEUESPERPAGEVFPF2(x) (((x) >> S_QUEUESPERPAGEVFPF2) & M_QUEUESPERPAGEVFPF2) + +#define S_QUEUESPERPAGEVFPF1 4 +#define M_QUEUESPERPAGEVFPF1 0xfU +#define V_QUEUESPERPAGEVFPF1(x) ((x) << S_QUEUESPERPAGEVFPF1) +#define G_QUEUESPERPAGEVFPF1(x) (((x) >> S_QUEUESPERPAGEVFPF1) & M_QUEUESPERPAGEVFPF1) + +#define S_QUEUESPERPAGEVFPF0 0 +#define M_QUEUESPERPAGEVFPF0 0xfU +#define V_QUEUESPERPAGEVFPF0(x) ((x) << S_QUEUESPERPAGEVFPF0) +#define G_QUEUESPERPAGEVFPF0(x) (((x) >> S_QUEUESPERPAGEVFPF0) & M_QUEUESPERPAGEVFPF0) + +#define A_SGE_USER_MODE_LIMITS 0x1018 + +#define S_OPCODE_MIN 24 +#define M_OPCODE_MIN 0xffU +#define V_OPCODE_MIN(x) ((x) << S_OPCODE_MIN) +#define G_OPCODE_MIN(x) (((x) >> S_OPCODE_MIN) & M_OPCODE_MIN) + +#define S_OPCODE_MAX 16 +#define M_OPCODE_MAX 0xffU +#define V_OPCODE_MAX(x) ((x) << S_OPCODE_MAX) +#define G_OPCODE_MAX(x) (((x) >> S_OPCODE_MAX) & M_OPCODE_MAX) + +#define S_LENGTH_MIN 8 +#define M_LENGTH_MIN 0xffU +#define V_LENGTH_MIN(x) ((x) << S_LENGTH_MIN) +#define G_LENGTH_MIN(x) (((x) >> S_LENGTH_MIN) & M_LENGTH_MIN) + +#define S_LENGTH_MAX 0 +#define M_LENGTH_MAX 0xffU +#define V_LENGTH_MAX(x) ((x) << S_LENGTH_MAX) +#define G_LENGTH_MAX(x) (((x) >> S_LENGTH_MAX) & M_LENGTH_MAX) + +#define A_SGE_WR_ERROR 0x101c + +#define S_WR_ERROR_OPCODE 0 +#define M_WR_ERROR_OPCODE 0xffU +#define V_WR_ERROR_OPCODE(x) ((x) << S_WR_ERROR_OPCODE) +#define G_WR_ERROR_OPCODE(x) (((x) >> S_WR_ERROR_OPCODE) & M_WR_ERROR_OPCODE) + +#define A_SGE_PERR_INJECT 0x1020 + +#define S_MEMSEL 1 +#define M_MEMSEL 0x1fU +#define V_MEMSEL(x) ((x) << S_MEMSEL) +#define G_MEMSEL(x) (((x) >> S_MEMSEL) & M_MEMSEL) + +#define S_INJECTDATAERR 0 +#define V_INJECTDATAERR(x) ((x) << S_INJECTDATAERR) +#define F_INJECTDATAERR V_INJECTDATAERR(1U) + +#define A_SGE_INT_CAUSE1 0x1024 + +#define S_PERR_FLM_CREDITFIFO 30 +#define V_PERR_FLM_CREDITFIFO(x) ((x) << S_PERR_FLM_CREDITFIFO) +#define F_PERR_FLM_CREDITFIFO V_PERR_FLM_CREDITFIFO(1U) + +#define S_PERR_IMSG_HINT_FIFO 29 +#define V_PERR_IMSG_HINT_FIFO(x) ((x) << S_PERR_IMSG_HINT_FIFO) +#define F_PERR_IMSG_HINT_FIFO V_PERR_IMSG_HINT_FIFO(1U) + +#define S_PERR_MC_PC 28 +#define V_PERR_MC_PC(x) ((x) << S_PERR_MC_PC) +#define F_PERR_MC_PC V_PERR_MC_PC(1U) + +#define S_PERR_MC_IGR_CTXT 27 +#define V_PERR_MC_IGR_CTXT(x) ((x) << S_PERR_MC_IGR_CTXT) +#define F_PERR_MC_IGR_CTXT V_PERR_MC_IGR_CTXT(1U) + +#define S_PERR_MC_EGR_CTXT 26 +#define V_PERR_MC_EGR_CTXT(x) ((x) << S_PERR_MC_EGR_CTXT) +#define F_PERR_MC_EGR_CTXT V_PERR_MC_EGR_CTXT(1U) + +#define S_PERR_MC_FLM 25 +#define V_PERR_MC_FLM(x) ((x) << S_PERR_MC_FLM) +#define F_PERR_MC_FLM V_PERR_MC_FLM(1U) + +#define S_PERR_PC_MCTAG 24 +#define V_PERR_PC_MCTAG(x) ((x) << S_PERR_PC_MCTAG) +#define F_PERR_PC_MCTAG V_PERR_PC_MCTAG(1U) + +#define S_PERR_PC_CHPI_RSP1 23 +#define V_PERR_PC_CHPI_RSP1(x) ((x) << S_PERR_PC_CHPI_RSP1) +#define F_PERR_PC_CHPI_RSP1 V_PERR_PC_CHPI_RSP1(1U) + +#define S_PERR_PC_CHPI_RSP0 22 +#define V_PERR_PC_CHPI_RSP0(x) ((x) << S_PERR_PC_CHPI_RSP0) +#define F_PERR_PC_CHPI_RSP0 V_PERR_PC_CHPI_RSP0(1U) + +#define S_PERR_DBP_PC_RSP_FIFO3 21 +#define V_PERR_DBP_PC_RSP_FIFO3(x) ((x) << S_PERR_DBP_PC_RSP_FIFO3) +#define F_PERR_DBP_PC_RSP_FIFO3 V_PERR_DBP_PC_RSP_FIFO3(1U) + +#define S_PERR_DBP_PC_RSP_FIFO2 20 +#define V_PERR_DBP_PC_RSP_FIFO2(x) ((x) << S_PERR_DBP_PC_RSP_FIFO2) +#define F_PERR_DBP_PC_RSP_FIFO2 V_PERR_DBP_PC_RSP_FIFO2(1U) + +#define S_PERR_DBP_PC_RSP_FIFO1 19 +#define V_PERR_DBP_PC_RSP_FIFO1(x) ((x) << S_PERR_DBP_PC_RSP_FIFO1) +#define F_PERR_DBP_PC_RSP_FIFO1 V_PERR_DBP_PC_RSP_FIFO1(1U) + +#define S_PERR_DBP_PC_RSP_FIFO0 18 +#define V_PERR_DBP_PC_RSP_FIFO0(x) ((x) << S_PERR_DBP_PC_RSP_FIFO0) +#define F_PERR_DBP_PC_RSP_FIFO0 V_PERR_DBP_PC_RSP_FIFO0(1U) + +#define S_PERR_DMARBT 17 +#define V_PERR_DMARBT(x) ((x) << S_PERR_DMARBT) +#define F_PERR_DMARBT V_PERR_DMARBT(1U) + +#define S_PERR_FLM_DBPFIFO 16 +#define V_PERR_FLM_DBPFIFO(x) ((x) << S_PERR_FLM_DBPFIFO) +#define F_PERR_FLM_DBPFIFO V_PERR_FLM_DBPFIFO(1U) + +#define S_PERR_FLM_MCREQ_FIFO 15 +#define V_PERR_FLM_MCREQ_FIFO(x) ((x) << S_PERR_FLM_MCREQ_FIFO) +#define F_PERR_FLM_MCREQ_FIFO V_PERR_FLM_MCREQ_FIFO(1U) + +#define S_PERR_FLM_HINTFIFO 14 +#define V_PERR_FLM_HINTFIFO(x) ((x) << S_PERR_FLM_HINTFIFO) +#define F_PERR_FLM_HINTFIFO V_PERR_FLM_HINTFIFO(1U) + +#define S_PERR_ALIGN_CTL_FIFO3 13 +#define V_PERR_ALIGN_CTL_FIFO3(x) ((x) << S_PERR_ALIGN_CTL_FIFO3) +#define F_PERR_ALIGN_CTL_FIFO3 V_PERR_ALIGN_CTL_FIFO3(1U) + +#define S_PERR_ALIGN_CTL_FIFO2 12 +#define V_PERR_ALIGN_CTL_FIFO2(x) ((x) << S_PERR_ALIGN_CTL_FIFO2) +#define F_PERR_ALIGN_CTL_FIFO2 V_PERR_ALIGN_CTL_FIFO2(1U) + +#define S_PERR_ALIGN_CTL_FIFO1 11 +#define V_PERR_ALIGN_CTL_FIFO1(x) ((x) << S_PERR_ALIGN_CTL_FIFO1) +#define F_PERR_ALIGN_CTL_FIFO1 V_PERR_ALIGN_CTL_FIFO1(1U) + +#define S_PERR_ALIGN_CTL_FIFO0 10 +#define V_PERR_ALIGN_CTL_FIFO0(x) ((x) << S_PERR_ALIGN_CTL_FIFO0) +#define F_PERR_ALIGN_CTL_FIFO0 V_PERR_ALIGN_CTL_FIFO0(1U) + +#define S_PERR_EDMA_FIFO3 9 +#define V_PERR_EDMA_FIFO3(x) ((x) << S_PERR_EDMA_FIFO3) +#define F_PERR_EDMA_FIFO3 V_PERR_EDMA_FIFO3(1U) + +#define S_PERR_EDMA_FIFO2 8 +#define V_PERR_EDMA_FIFO2(x) ((x) << S_PERR_EDMA_FIFO2) +#define F_PERR_EDMA_FIFO2 V_PERR_EDMA_FIFO2(1U) + +#define S_PERR_EDMA_FIFO1 7 +#define V_PERR_EDMA_FIFO1(x) ((x) << S_PERR_EDMA_FIFO1) +#define F_PERR_EDMA_FIFO1 V_PERR_EDMA_FIFO1(1U) + +#define S_PERR_EDMA_FIFO0 6 +#define V_PERR_EDMA_FIFO0(x) ((x) << S_PERR_EDMA_FIFO0) +#define F_PERR_EDMA_FIFO0 V_PERR_EDMA_FIFO0(1U) + +#define S_PERR_PD_FIFO3 5 +#define V_PERR_PD_FIFO3(x) ((x) << S_PERR_PD_FIFO3) +#define F_PERR_PD_FIFO3 V_PERR_PD_FIFO3(1U) + +#define S_PERR_PD_FIFO2 4 +#define V_PERR_PD_FIFO2(x) ((x) << S_PERR_PD_FIFO2) +#define F_PERR_PD_FIFO2 V_PERR_PD_FIFO2(1U) + +#define S_PERR_PD_FIFO1 3 +#define V_PERR_PD_FIFO1(x) ((x) << S_PERR_PD_FIFO1) +#define F_PERR_PD_FIFO1 V_PERR_PD_FIFO1(1U) + +#define S_PERR_PD_FIFO0 2 +#define V_PERR_PD_FIFO0(x) ((x) << S_PERR_PD_FIFO0) +#define F_PERR_PD_FIFO0 V_PERR_PD_FIFO0(1U) + +#define S_PERR_ING_CTXT_MIFRSP 1 +#define V_PERR_ING_CTXT_MIFRSP(x) ((x) << S_PERR_ING_CTXT_MIFRSP) +#define F_PERR_ING_CTXT_MIFRSP V_PERR_ING_CTXT_MIFRSP(1U) + +#define S_PERR_EGR_CTXT_MIFRSP 0 +#define V_PERR_EGR_CTXT_MIFRSP(x) ((x) << S_PERR_EGR_CTXT_MIFRSP) +#define F_PERR_EGR_CTXT_MIFRSP V_PERR_EGR_CTXT_MIFRSP(1U) + +#define S_PERR_PC_CHPI_RSP2 31 +#define V_PERR_PC_CHPI_RSP2(x) ((x) << S_PERR_PC_CHPI_RSP2) +#define F_PERR_PC_CHPI_RSP2 V_PERR_PC_CHPI_RSP2(1U) + +#define A_SGE_INT_ENABLE1 0x1028 +#define A_SGE_PERR_ENABLE1 0x102c +#define A_SGE_INT_CAUSE2 0x1030 + +#define S_PERR_HINT_DELAY_FIFO1 30 +#define V_PERR_HINT_DELAY_FIFO1(x) ((x) << S_PERR_HINT_DELAY_FIFO1) +#define F_PERR_HINT_DELAY_FIFO1 V_PERR_HINT_DELAY_FIFO1(1U) + +#define S_PERR_HINT_DELAY_FIFO0 29 +#define V_PERR_HINT_DELAY_FIFO0(x) ((x) << S_PERR_HINT_DELAY_FIFO0) +#define F_PERR_HINT_DELAY_FIFO0 V_PERR_HINT_DELAY_FIFO0(1U) + +#define S_PERR_IMSG_PD_FIFO 28 +#define V_PERR_IMSG_PD_FIFO(x) ((x) << S_PERR_IMSG_PD_FIFO) +#define F_PERR_IMSG_PD_FIFO V_PERR_IMSG_PD_FIFO(1U) + +#define S_PERR_ULPTX_FIFO1 27 +#define V_PERR_ULPTX_FIFO1(x) ((x) << S_PERR_ULPTX_FIFO1) +#define F_PERR_ULPTX_FIFO1 V_PERR_ULPTX_FIFO1(1U) + +#define S_PERR_ULPTX_FIFO0 26 +#define V_PERR_ULPTX_FIFO0(x) ((x) << S_PERR_ULPTX_FIFO0) +#define F_PERR_ULPTX_FIFO0 V_PERR_ULPTX_FIFO0(1U) + +#define S_PERR_IDMA2IMSG_FIFO1 25 +#define V_PERR_IDMA2IMSG_FIFO1(x) ((x) << S_PERR_IDMA2IMSG_FIFO1) +#define F_PERR_IDMA2IMSG_FIFO1 V_PERR_IDMA2IMSG_FIFO1(1U) + +#define S_PERR_IDMA2IMSG_FIFO0 24 +#define V_PERR_IDMA2IMSG_FIFO0(x) ((x) << S_PERR_IDMA2IMSG_FIFO0) +#define F_PERR_IDMA2IMSG_FIFO0 V_PERR_IDMA2IMSG_FIFO0(1U) + +#define S_PERR_HEADERSPLIT_FIFO1 23 +#define V_PERR_HEADERSPLIT_FIFO1(x) ((x) << S_PERR_HEADERSPLIT_FIFO1) +#define F_PERR_HEADERSPLIT_FIFO1 V_PERR_HEADERSPLIT_FIFO1(1U) + +#define S_PERR_HEADERSPLIT_FIFO0 22 +#define V_PERR_HEADERSPLIT_FIFO0(x) ((x) << S_PERR_HEADERSPLIT_FIFO0) +#define F_PERR_HEADERSPLIT_FIFO0 V_PERR_HEADERSPLIT_FIFO0(1U) + +#define S_PERR_ESWITCH_FIFO3 21 +#define V_PERR_ESWITCH_FIFO3(x) ((x) << S_PERR_ESWITCH_FIFO3) +#define F_PERR_ESWITCH_FIFO3 V_PERR_ESWITCH_FIFO3(1U) + +#define S_PERR_ESWITCH_FIFO2 20 +#define V_PERR_ESWITCH_FIFO2(x) ((x) << S_PERR_ESWITCH_FIFO2) +#define F_PERR_ESWITCH_FIFO2 V_PERR_ESWITCH_FIFO2(1U) + +#define S_PERR_ESWITCH_FIFO1 19 +#define V_PERR_ESWITCH_FIFO1(x) ((x) << S_PERR_ESWITCH_FIFO1) +#define F_PERR_ESWITCH_FIFO1 V_PERR_ESWITCH_FIFO1(1U) + +#define S_PERR_ESWITCH_FIFO0 18 +#define V_PERR_ESWITCH_FIFO0(x) ((x) << S_PERR_ESWITCH_FIFO0) +#define F_PERR_ESWITCH_FIFO0 V_PERR_ESWITCH_FIFO0(1U) + +#define S_PERR_PC_DBP1 17 +#define V_PERR_PC_DBP1(x) ((x) << S_PERR_PC_DBP1) +#define F_PERR_PC_DBP1 V_PERR_PC_DBP1(1U) + +#define S_PERR_PC_DBP0 16 +#define V_PERR_PC_DBP0(x) ((x) << S_PERR_PC_DBP0) +#define F_PERR_PC_DBP0 V_PERR_PC_DBP0(1U) + +#define S_PERR_IMSG_OB_FIFO 15 +#define V_PERR_IMSG_OB_FIFO(x) ((x) << S_PERR_IMSG_OB_FIFO) +#define F_PERR_IMSG_OB_FIFO V_PERR_IMSG_OB_FIFO(1U) + +#define S_PERR_CONM_SRAM 14 +#define V_PERR_CONM_SRAM(x) ((x) << S_PERR_CONM_SRAM) +#define F_PERR_CONM_SRAM V_PERR_CONM_SRAM(1U) + +#define S_PERR_PC_MC_RSP 13 +#define V_PERR_PC_MC_RSP(x) ((x) << S_PERR_PC_MC_RSP) +#define F_PERR_PC_MC_RSP V_PERR_PC_MC_RSP(1U) + +#define S_PERR_ISW_IDMA0_FIFO 12 +#define V_PERR_ISW_IDMA0_FIFO(x) ((x) << S_PERR_ISW_IDMA0_FIFO) +#define F_PERR_ISW_IDMA0_FIFO V_PERR_ISW_IDMA0_FIFO(1U) + +#define S_PERR_ISW_IDMA1_FIFO 11 +#define V_PERR_ISW_IDMA1_FIFO(x) ((x) << S_PERR_ISW_IDMA1_FIFO) +#define F_PERR_ISW_IDMA1_FIFO V_PERR_ISW_IDMA1_FIFO(1U) + +#define S_PERR_ISW_DBP_FIFO 10 +#define V_PERR_ISW_DBP_FIFO(x) ((x) << S_PERR_ISW_DBP_FIFO) +#define F_PERR_ISW_DBP_FIFO V_PERR_ISW_DBP_FIFO(1U) + +#define S_PERR_ISW_GTS_FIFO 9 +#define V_PERR_ISW_GTS_FIFO(x) ((x) << S_PERR_ISW_GTS_FIFO) +#define F_PERR_ISW_GTS_FIFO V_PERR_ISW_GTS_FIFO(1U) + +#define S_PERR_ITP_EVR 8 +#define V_PERR_ITP_EVR(x) ((x) << S_PERR_ITP_EVR) +#define F_PERR_ITP_EVR V_PERR_ITP_EVR(1U) + +#define S_PERR_FLM_CNTXMEM 7 +#define V_PERR_FLM_CNTXMEM(x) ((x) << S_PERR_FLM_CNTXMEM) +#define F_PERR_FLM_CNTXMEM V_PERR_FLM_CNTXMEM(1U) + +#define S_PERR_FLM_L1CACHE 6 +#define V_PERR_FLM_L1CACHE(x) ((x) << S_PERR_FLM_L1CACHE) +#define F_PERR_FLM_L1CACHE V_PERR_FLM_L1CACHE(1U) + +#define S_PERR_DBP_HINT_FIFO 5 +#define V_PERR_DBP_HINT_FIFO(x) ((x) << S_PERR_DBP_HINT_FIFO) +#define F_PERR_DBP_HINT_FIFO V_PERR_DBP_HINT_FIFO(1U) + +#define S_PERR_DBP_HP_FIFO 4 +#define V_PERR_DBP_HP_FIFO(x) ((x) << S_PERR_DBP_HP_FIFO) +#define F_PERR_DBP_HP_FIFO V_PERR_DBP_HP_FIFO(1U) + +#define S_PERR_DBP_LP_FIFO 3 +#define V_PERR_DBP_LP_FIFO(x) ((x) << S_PERR_DBP_LP_FIFO) +#define F_PERR_DBP_LP_FIFO V_PERR_DBP_LP_FIFO(1U) + +#define S_PERR_ING_CTXT_CACHE 2 +#define V_PERR_ING_CTXT_CACHE(x) ((x) << S_PERR_ING_CTXT_CACHE) +#define F_PERR_ING_CTXT_CACHE V_PERR_ING_CTXT_CACHE(1U) + +#define S_PERR_EGR_CTXT_CACHE 1 +#define V_PERR_EGR_CTXT_CACHE(x) ((x) << S_PERR_EGR_CTXT_CACHE) +#define F_PERR_EGR_CTXT_CACHE V_PERR_EGR_CTXT_CACHE(1U) + +#define S_PERR_BASE_SIZE 0 +#define V_PERR_BASE_SIZE(x) ((x) << S_PERR_BASE_SIZE) +#define F_PERR_BASE_SIZE V_PERR_BASE_SIZE(1U) + +#define S_PERR_DBP_HINT_FL_FIFO 24 +#define V_PERR_DBP_HINT_FL_FIFO(x) ((x) << S_PERR_DBP_HINT_FL_FIFO) +#define F_PERR_DBP_HINT_FL_FIFO V_PERR_DBP_HINT_FL_FIFO(1U) + +#define S_PERR_EGR_DBP_TX_COAL 23 +#define V_PERR_EGR_DBP_TX_COAL(x) ((x) << S_PERR_EGR_DBP_TX_COAL) +#define F_PERR_EGR_DBP_TX_COAL V_PERR_EGR_DBP_TX_COAL(1U) + +#define S_PERR_DBP_FL_FIFO 22 +#define V_PERR_DBP_FL_FIFO(x) ((x) << S_PERR_DBP_FL_FIFO) +#define F_PERR_DBP_FL_FIFO V_PERR_DBP_FL_FIFO(1U) + +#define S_PERR_PC_DBP2 15 +#define V_PERR_PC_DBP2(x) ((x) << S_PERR_PC_DBP2) +#define F_PERR_PC_DBP2 V_PERR_PC_DBP2(1U) + +#define A_SGE_INT_ENABLE2 0x1034 +#define A_SGE_PERR_ENABLE2 0x1038 +#define A_SGE_INT_CAUSE3 0x103c + +#define S_ERR_FLM_DBP 31 +#define V_ERR_FLM_DBP(x) ((x) << S_ERR_FLM_DBP) +#define F_ERR_FLM_DBP V_ERR_FLM_DBP(1U) + +#define S_ERR_FLM_IDMA1 30 +#define V_ERR_FLM_IDMA1(x) ((x) << S_ERR_FLM_IDMA1) +#define F_ERR_FLM_IDMA1 V_ERR_FLM_IDMA1(1U) + +#define S_ERR_FLM_IDMA0 29 +#define V_ERR_FLM_IDMA0(x) ((x) << S_ERR_FLM_IDMA0) +#define F_ERR_FLM_IDMA0 V_ERR_FLM_IDMA0(1U) + +#define S_ERR_FLM_HINT 28 +#define V_ERR_FLM_HINT(x) ((x) << S_ERR_FLM_HINT) +#define F_ERR_FLM_HINT V_ERR_FLM_HINT(1U) + +#define S_ERR_PCIE_ERROR3 27 +#define V_ERR_PCIE_ERROR3(x) ((x) << S_ERR_PCIE_ERROR3) +#define F_ERR_PCIE_ERROR3 V_ERR_PCIE_ERROR3(1U) + +#define S_ERR_PCIE_ERROR2 26 +#define V_ERR_PCIE_ERROR2(x) ((x) << S_ERR_PCIE_ERROR2) +#define F_ERR_PCIE_ERROR2 V_ERR_PCIE_ERROR2(1U) + +#define S_ERR_PCIE_ERROR1 25 +#define V_ERR_PCIE_ERROR1(x) ((x) << S_ERR_PCIE_ERROR1) +#define F_ERR_PCIE_ERROR1 V_ERR_PCIE_ERROR1(1U) + +#define S_ERR_PCIE_ERROR0 24 +#define V_ERR_PCIE_ERROR0(x) ((x) << S_ERR_PCIE_ERROR0) +#define F_ERR_PCIE_ERROR0 V_ERR_PCIE_ERROR0(1U) + +#define S_ERR_TIMER_ABOVE_MAX_QID 23 +#define V_ERR_TIMER_ABOVE_MAX_QID(x) ((x) << S_ERR_TIMER_ABOVE_MAX_QID) +#define F_ERR_TIMER_ABOVE_MAX_QID V_ERR_TIMER_ABOVE_MAX_QID(1U) + +#define S_ERR_CPL_EXCEED_IQE_SIZE 22 +#define V_ERR_CPL_EXCEED_IQE_SIZE(x) ((x) << S_ERR_CPL_EXCEED_IQE_SIZE) +#define F_ERR_CPL_EXCEED_IQE_SIZE V_ERR_CPL_EXCEED_IQE_SIZE(1U) + +#define S_ERR_INVALID_CIDX_INC 21 +#define V_ERR_INVALID_CIDX_INC(x) ((x) << S_ERR_INVALID_CIDX_INC) +#define F_ERR_INVALID_CIDX_INC V_ERR_INVALID_CIDX_INC(1U) + +#define S_ERR_ITP_TIME_PAUSED 20 +#define V_ERR_ITP_TIME_PAUSED(x) ((x) << S_ERR_ITP_TIME_PAUSED) +#define F_ERR_ITP_TIME_PAUSED V_ERR_ITP_TIME_PAUSED(1U) + +#define S_ERR_CPL_OPCODE_0 19 +#define V_ERR_CPL_OPCODE_0(x) ((x) << S_ERR_CPL_OPCODE_0) +#define F_ERR_CPL_OPCODE_0 V_ERR_CPL_OPCODE_0(1U) + +#define S_ERR_DROPPED_DB 18 +#define V_ERR_DROPPED_DB(x) ((x) << S_ERR_DROPPED_DB) +#define F_ERR_DROPPED_DB V_ERR_DROPPED_DB(1U) + +#define S_ERR_DATA_CPL_ON_HIGH_QID1 17 +#define V_ERR_DATA_CPL_ON_HIGH_QID1(x) ((x) << S_ERR_DATA_CPL_ON_HIGH_QID1) +#define F_ERR_DATA_CPL_ON_HIGH_QID1 V_ERR_DATA_CPL_ON_HIGH_QID1(1U) + +#define S_ERR_DATA_CPL_ON_HIGH_QID0 16 +#define V_ERR_DATA_CPL_ON_HIGH_QID0(x) ((x) << S_ERR_DATA_CPL_ON_HIGH_QID0) +#define F_ERR_DATA_CPL_ON_HIGH_QID0 V_ERR_DATA_CPL_ON_HIGH_QID0(1U) + +#define S_ERR_BAD_DB_PIDX3 15 +#define V_ERR_BAD_DB_PIDX3(x) ((x) << S_ERR_BAD_DB_PIDX3) +#define F_ERR_BAD_DB_PIDX3 V_ERR_BAD_DB_PIDX3(1U) + +#define S_ERR_BAD_DB_PIDX2 14 +#define V_ERR_BAD_DB_PIDX2(x) ((x) << S_ERR_BAD_DB_PIDX2) +#define F_ERR_BAD_DB_PIDX2 V_ERR_BAD_DB_PIDX2(1U) + +#define S_ERR_BAD_DB_PIDX1 13 +#define V_ERR_BAD_DB_PIDX1(x) ((x) << S_ERR_BAD_DB_PIDX1) +#define F_ERR_BAD_DB_PIDX1 V_ERR_BAD_DB_PIDX1(1U) + +#define S_ERR_BAD_DB_PIDX0 12 +#define V_ERR_BAD_DB_PIDX0(x) ((x) << S_ERR_BAD_DB_PIDX0) +#define F_ERR_BAD_DB_PIDX0 V_ERR_BAD_DB_PIDX0(1U) + +#define S_ERR_ING_PCIE_CHAN 11 +#define V_ERR_ING_PCIE_CHAN(x) ((x) << S_ERR_ING_PCIE_CHAN) +#define F_ERR_ING_PCIE_CHAN V_ERR_ING_PCIE_CHAN(1U) + +#define S_ERR_ING_CTXT_PRIO 10 +#define V_ERR_ING_CTXT_PRIO(x) ((x) << S_ERR_ING_CTXT_PRIO) +#define F_ERR_ING_CTXT_PRIO V_ERR_ING_CTXT_PRIO(1U) + +#define S_ERR_EGR_CTXT_PRIO 9 +#define V_ERR_EGR_CTXT_PRIO(x) ((x) << S_ERR_EGR_CTXT_PRIO) +#define F_ERR_EGR_CTXT_PRIO V_ERR_EGR_CTXT_PRIO(1U) + +#define S_DBFIFO_HP_INT 8 +#define V_DBFIFO_HP_INT(x) ((x) << S_DBFIFO_HP_INT) +#define F_DBFIFO_HP_INT V_DBFIFO_HP_INT(1U) + +#define S_DBFIFO_LP_INT 7 +#define V_DBFIFO_LP_INT(x) ((x) << S_DBFIFO_LP_INT) +#define F_DBFIFO_LP_INT V_DBFIFO_LP_INT(1U) + +#define S_REG_ADDRESS_ERR 6 +#define V_REG_ADDRESS_ERR(x) ((x) << S_REG_ADDRESS_ERR) +#define F_REG_ADDRESS_ERR V_REG_ADDRESS_ERR(1U) + +#define S_INGRESS_SIZE_ERR 5 +#define V_INGRESS_SIZE_ERR(x) ((x) << S_INGRESS_SIZE_ERR) +#define F_INGRESS_SIZE_ERR V_INGRESS_SIZE_ERR(1U) + +#define S_EGRESS_SIZE_ERR 4 +#define V_EGRESS_SIZE_ERR(x) ((x) << S_EGRESS_SIZE_ERR) +#define F_EGRESS_SIZE_ERR V_EGRESS_SIZE_ERR(1U) + +#define S_ERR_INV_CTXT3 3 +#define V_ERR_INV_CTXT3(x) ((x) << S_ERR_INV_CTXT3) +#define F_ERR_INV_CTXT3 V_ERR_INV_CTXT3(1U) + +#define S_ERR_INV_CTXT2 2 +#define V_ERR_INV_CTXT2(x) ((x) << S_ERR_INV_CTXT2) +#define F_ERR_INV_CTXT2 V_ERR_INV_CTXT2(1U) + +#define S_ERR_INV_CTXT1 1 +#define V_ERR_INV_CTXT1(x) ((x) << S_ERR_INV_CTXT1) +#define F_ERR_INV_CTXT1 V_ERR_INV_CTXT1(1U) + +#define S_ERR_INV_CTXT0 0 +#define V_ERR_INV_CTXT0(x) ((x) << S_ERR_INV_CTXT0) +#define F_ERR_INV_CTXT0 V_ERR_INV_CTXT0(1U) + +#define A_SGE_INT_ENABLE3 0x1040 +#define A_SGE_FL_BUFFER_SIZE0 0x1044 + +#define S_SIZE 4 +#define M_SIZE 0xfffffffU +#define V_SIZE(x) ((x) << S_SIZE) +#define G_SIZE(x) (((x) >> S_SIZE) & M_SIZE) + +#define A_SGE_FL_BUFFER_SIZE1 0x1048 +#define A_SGE_FL_BUFFER_SIZE2 0x104c +#define A_SGE_FL_BUFFER_SIZE3 0x1050 +#define A_SGE_FL_BUFFER_SIZE4 0x1054 +#define A_SGE_FL_BUFFER_SIZE5 0x1058 +#define A_SGE_FL_BUFFER_SIZE6 0x105c +#define A_SGE_FL_BUFFER_SIZE7 0x1060 +#define A_SGE_FL_BUFFER_SIZE8 0x1064 +#define A_SGE_FL_BUFFER_SIZE9 0x1068 +#define A_SGE_FL_BUFFER_SIZE10 0x106c +#define A_SGE_FL_BUFFER_SIZE11 0x1070 +#define A_SGE_FL_BUFFER_SIZE12 0x1074 +#define A_SGE_FL_BUFFER_SIZE13 0x1078 +#define A_SGE_FL_BUFFER_SIZE14 0x107c +#define A_SGE_FL_BUFFER_SIZE15 0x1080 +#define A_SGE_DBQ_CTXT_BADDR 0x1084 + +#define S_BASEADDR 3 +#define M_BASEADDR 0x1fffffffU +#define V_BASEADDR(x) ((x) << S_BASEADDR) +#define G_BASEADDR(x) (((x) >> S_BASEADDR) & M_BASEADDR) + +#define A_SGE_IMSG_CTXT_BADDR 0x1088 +#define A_SGE_FLM_CACHE_BADDR 0x108c +#define A_SGE_FLM_CFG 0x1090 + +#define S_OPMODE 26 +#define M_OPMODE 0x3fU +#define V_OPMODE(x) ((x) << S_OPMODE) +#define G_OPMODE(x) (((x) >> S_OPMODE) & M_OPMODE) + +#define S_NOHDR 18 +#define V_NOHDR(x) ((x) << S_NOHDR) +#define F_NOHDR V_NOHDR(1U) + +#define S_CACHEPTRCNT 16 +#define M_CACHEPTRCNT 0x3U +#define V_CACHEPTRCNT(x) ((x) << S_CACHEPTRCNT) +#define G_CACHEPTRCNT(x) (((x) >> S_CACHEPTRCNT) & M_CACHEPTRCNT) + +#define S_EDRAMPTRCNT 14 +#define M_EDRAMPTRCNT 0x3U +#define V_EDRAMPTRCNT(x) ((x) << S_EDRAMPTRCNT) +#define G_EDRAMPTRCNT(x) (((x) >> S_EDRAMPTRCNT) & M_EDRAMPTRCNT) + +#define S_HDRSTARTFLQ 11 +#define M_HDRSTARTFLQ 0x7U +#define V_HDRSTARTFLQ(x) ((x) << S_HDRSTARTFLQ) +#define G_HDRSTARTFLQ(x) (((x) >> S_HDRSTARTFLQ) & M_HDRSTARTFLQ) + +#define S_FETCHTHRESH 6 +#define M_FETCHTHRESH 0x1fU +#define V_FETCHTHRESH(x) ((x) << S_FETCHTHRESH) +#define G_FETCHTHRESH(x) (((x) >> S_FETCHTHRESH) & M_FETCHTHRESH) + +#define S_CREDITCNT 4 +#define M_CREDITCNT 0x3U +#define V_CREDITCNT(x) ((x) << S_CREDITCNT) +#define G_CREDITCNT(x) (((x) >> S_CREDITCNT) & M_CREDITCNT) + +#define S_NOEDRAM 0 +#define V_NOEDRAM(x) ((x) << S_NOEDRAM) +#define F_NOEDRAM V_NOEDRAM(1U) + +#define S_CREDITCNTPACKING 2 +#define M_CREDITCNTPACKING 0x3U +#define V_CREDITCNTPACKING(x) ((x) << S_CREDITCNTPACKING) +#define G_CREDITCNTPACKING(x) (((x) >> S_CREDITCNTPACKING) & M_CREDITCNTPACKING) + +#define A_SGE_CONM_CTRL 0x1094 + +#define S_EGRTHRESHOLD 8 +#define M_EGRTHRESHOLD 0x3fU +#define V_EGRTHRESHOLD(x) ((x) << S_EGRTHRESHOLD) +#define G_EGRTHRESHOLD(x) (((x) >> S_EGRTHRESHOLD) & M_EGRTHRESHOLD) + +#define S_INGTHRESHOLD 2 +#define M_INGTHRESHOLD 0x3fU +#define V_INGTHRESHOLD(x) ((x) << S_INGTHRESHOLD) +#define G_INGTHRESHOLD(x) (((x) >> S_INGTHRESHOLD) & M_INGTHRESHOLD) + +#define S_MPS_ENABLE 1 +#define V_MPS_ENABLE(x) ((x) << S_MPS_ENABLE) +#define F_MPS_ENABLE V_MPS_ENABLE(1U) + +#define S_TP_ENABLE 0 +#define V_TP_ENABLE(x) ((x) << S_TP_ENABLE) +#define F_TP_ENABLE V_TP_ENABLE(1U) + +#define S_EGRTHRESHOLDPACKING 14 +#define M_EGRTHRESHOLDPACKING 0x3fU +#define V_EGRTHRESHOLDPACKING(x) ((x) << S_EGRTHRESHOLDPACKING) +#define G_EGRTHRESHOLDPACKING(x) (((x) >> S_EGRTHRESHOLDPACKING) & M_EGRTHRESHOLDPACKING) + +#define A_SGE_TIMESTAMP_LO 0x1098 +#define A_SGE_TIMESTAMP_HI 0x109c + +#define S_TSOP 28 +#define M_TSOP 0x3U +#define V_TSOP(x) ((x) << S_TSOP) +#define G_TSOP(x) (((x) >> S_TSOP) & M_TSOP) + +#define S_TSVAL 0 +#define M_TSVAL 0xfffffffU +#define V_TSVAL(x) ((x) << S_TSVAL) +#define G_TSVAL(x) (((x) >> S_TSVAL) & M_TSVAL) + +#define A_SGE_INGRESS_RX_THRESHOLD 0x10a0 + +#define S_THRESHOLD_0 24 +#define M_THRESHOLD_0 0x3fU +#define V_THRESHOLD_0(x) ((x) << S_THRESHOLD_0) +#define G_THRESHOLD_0(x) (((x) >> S_THRESHOLD_0) & M_THRESHOLD_0) + +#define S_THRESHOLD_1 16 +#define M_THRESHOLD_1 0x3fU +#define V_THRESHOLD_1(x) ((x) << S_THRESHOLD_1) +#define G_THRESHOLD_1(x) (((x) >> S_THRESHOLD_1) & M_THRESHOLD_1) + +#define S_THRESHOLD_2 8 +#define M_THRESHOLD_2 0x3fU +#define V_THRESHOLD_2(x) ((x) << S_THRESHOLD_2) +#define G_THRESHOLD_2(x) (((x) >> S_THRESHOLD_2) & M_THRESHOLD_2) + +#define S_THRESHOLD_3 0 +#define M_THRESHOLD_3 0x3fU +#define V_THRESHOLD_3(x) ((x) << S_THRESHOLD_3) +#define G_THRESHOLD_3(x) (((x) >> S_THRESHOLD_3) & M_THRESHOLD_3) + +#define A_SGE_DBFIFO_STATUS 0x10a4 + +#define S_HP_INT_THRESH 28 +#define M_HP_INT_THRESH 0xfU +#define V_HP_INT_THRESH(x) ((x) << S_HP_INT_THRESH) +#define G_HP_INT_THRESH(x) (((x) >> S_HP_INT_THRESH) & M_HP_INT_THRESH) + +#define S_HP_COUNT 16 +#define M_HP_COUNT 0x7ffU +#define V_HP_COUNT(x) ((x) << S_HP_COUNT) +#define G_HP_COUNT(x) (((x) >> S_HP_COUNT) & M_HP_COUNT) + +#define S_LP_INT_THRESH 12 +#define M_LP_INT_THRESH 0xfU +#define V_LP_INT_THRESH(x) ((x) << S_LP_INT_THRESH) +#define G_LP_INT_THRESH(x) (((x) >> S_LP_INT_THRESH) & M_LP_INT_THRESH) + +#define S_LP_COUNT 0 +#define M_LP_COUNT 0x7ffU +#define V_LP_COUNT(x) ((x) << S_LP_COUNT) +#define G_LP_COUNT(x) (((x) >> S_LP_COUNT) & M_LP_COUNT) + +#define S_BAR2VALID 31 +#define V_BAR2VALID(x) ((x) << S_BAR2VALID) +#define F_BAR2VALID V_BAR2VALID(1U) + +#define S_BAR2FULL 30 +#define V_BAR2FULL(x) ((x) << S_BAR2FULL) +#define F_BAR2FULL V_BAR2FULL(1U) + +#define S_LP_INT_THRESH_T5 18 +#define M_LP_INT_THRESH_T5 0xfffU +#define V_LP_INT_THRESH_T5(x) ((x) << S_LP_INT_THRESH_T5) +#define G_LP_INT_THRESH_T5(x) (((x) >> S_LP_INT_THRESH_T5) & M_LP_INT_THRESH_T5) + +#define S_LP_COUNT_T5 0 +#define M_LP_COUNT_T5 0x3ffffU +#define V_LP_COUNT_T5(x) ((x) << S_LP_COUNT_T5) +#define G_LP_COUNT_T5(x) (((x) >> S_LP_COUNT_T5) & M_LP_COUNT_T5) + +#define A_SGE_DOORBELL_CONTROL 0x10a8 + +#define S_HINTDEPTHCTL 27 +#define M_HINTDEPTHCTL 0x1fU +#define V_HINTDEPTHCTL(x) ((x) << S_HINTDEPTHCTL) +#define G_HINTDEPTHCTL(x) (((x) >> S_HINTDEPTHCTL) & M_HINTDEPTHCTL) + +#define S_NOCOALESCE 26 +#define V_NOCOALESCE(x) ((x) << S_NOCOALESCE) +#define F_NOCOALESCE V_NOCOALESCE(1U) + +#define S_HP_WEIGHT 24 +#define M_HP_WEIGHT 0x3U +#define V_HP_WEIGHT(x) ((x) << S_HP_WEIGHT) +#define G_HP_WEIGHT(x) (((x) >> S_HP_WEIGHT) & M_HP_WEIGHT) + +#define S_HP_DISABLE 23 +#define V_HP_DISABLE(x) ((x) << S_HP_DISABLE) +#define F_HP_DISABLE V_HP_DISABLE(1U) + +#define S_FORCEUSERDBTOLP 22 +#define V_FORCEUSERDBTOLP(x) ((x) << S_FORCEUSERDBTOLP) +#define F_FORCEUSERDBTOLP V_FORCEUSERDBTOLP(1U) + +#define S_FORCEVFPF0DBTOLP 21 +#define V_FORCEVFPF0DBTOLP(x) ((x) << S_FORCEVFPF0DBTOLP) +#define F_FORCEVFPF0DBTOLP V_FORCEVFPF0DBTOLP(1U) + +#define S_FORCEVFPF1DBTOLP 20 +#define V_FORCEVFPF1DBTOLP(x) ((x) << S_FORCEVFPF1DBTOLP) +#define F_FORCEVFPF1DBTOLP V_FORCEVFPF1DBTOLP(1U) + +#define S_FORCEVFPF2DBTOLP 19 +#define V_FORCEVFPF2DBTOLP(x) ((x) << S_FORCEVFPF2DBTOLP) +#define F_FORCEVFPF2DBTOLP V_FORCEVFPF2DBTOLP(1U) + +#define S_FORCEVFPF3DBTOLP 18 +#define V_FORCEVFPF3DBTOLP(x) ((x) << S_FORCEVFPF3DBTOLP) +#define F_FORCEVFPF3DBTOLP V_FORCEVFPF3DBTOLP(1U) + +#define S_FORCEVFPF4DBTOLP 17 +#define V_FORCEVFPF4DBTOLP(x) ((x) << S_FORCEVFPF4DBTOLP) +#define F_FORCEVFPF4DBTOLP V_FORCEVFPF4DBTOLP(1U) + +#define S_FORCEVFPF5DBTOLP 16 +#define V_FORCEVFPF5DBTOLP(x) ((x) << S_FORCEVFPF5DBTOLP) +#define F_FORCEVFPF5DBTOLP V_FORCEVFPF5DBTOLP(1U) + +#define S_FORCEVFPF6DBTOLP 15 +#define V_FORCEVFPF6DBTOLP(x) ((x) << S_FORCEVFPF6DBTOLP) +#define F_FORCEVFPF6DBTOLP V_FORCEVFPF6DBTOLP(1U) + +#define S_FORCEVFPF7DBTOLP 14 +#define V_FORCEVFPF7DBTOLP(x) ((x) << S_FORCEVFPF7DBTOLP) +#define F_FORCEVFPF7DBTOLP V_FORCEVFPF7DBTOLP(1U) + +#define S_ENABLE_DROP 13 +#define V_ENABLE_DROP(x) ((x) << S_ENABLE_DROP) +#define F_ENABLE_DROP V_ENABLE_DROP(1U) + +#define S_DROP_TIMEOUT 1 +#define M_DROP_TIMEOUT 0xfffU +#define V_DROP_TIMEOUT(x) ((x) << S_DROP_TIMEOUT) +#define G_DROP_TIMEOUT(x) (((x) >> S_DROP_TIMEOUT) & M_DROP_TIMEOUT) + +#define S_DROPPED_DB 0 +#define V_DROPPED_DB(x) ((x) << S_DROPPED_DB) +#define F_DROPPED_DB V_DROPPED_DB(1U) + +#define A_SGE_DROPPED_DOORBELL 0x10ac +#define A_SGE_DOORBELL_THROTTLE_CONTROL 0x10b0 + +#define S_THROTTLE_COUNT 1 +#define M_THROTTLE_COUNT 0xfffU +#define V_THROTTLE_COUNT(x) ((x) << S_THROTTLE_COUNT) +#define G_THROTTLE_COUNT(x) (((x) >> S_THROTTLE_COUNT) & M_THROTTLE_COUNT) + +#define S_THROTTLE_ENABLE 0 +#define V_THROTTLE_ENABLE(x) ((x) << S_THROTTLE_ENABLE) +#define F_THROTTLE_ENABLE V_THROTTLE_ENABLE(1U) + +#define S_BAR2THROTTLECOUNT 16 +#define M_BAR2THROTTLECOUNT 0xffU +#define V_BAR2THROTTLECOUNT(x) ((x) << S_BAR2THROTTLECOUNT) +#define G_BAR2THROTTLECOUNT(x) (((x) >> S_BAR2THROTTLECOUNT) & M_BAR2THROTTLECOUNT) + +#define S_CLRCOALESCEDISABLE 15 +#define V_CLRCOALESCEDISABLE(x) ((x) << S_CLRCOALESCEDISABLE) +#define F_CLRCOALESCEDISABLE V_CLRCOALESCEDISABLE(1U) + +#define S_OPENBAR2GATEONCE 14 +#define V_OPENBAR2GATEONCE(x) ((x) << S_OPENBAR2GATEONCE) +#define F_OPENBAR2GATEONCE V_OPENBAR2GATEONCE(1U) + +#define S_FORCEOPENBAR2GATE 13 +#define V_FORCEOPENBAR2GATE(x) ((x) << S_FORCEOPENBAR2GATE) +#define F_FORCEOPENBAR2GATE V_FORCEOPENBAR2GATE(1U) + +#define A_SGE_ITP_CONTROL 0x10b4 + +#define S_CRITICAL_TIME 10 +#define M_CRITICAL_TIME 0x7fffU +#define V_CRITICAL_TIME(x) ((x) << S_CRITICAL_TIME) +#define G_CRITICAL_TIME(x) (((x) >> S_CRITICAL_TIME) & M_CRITICAL_TIME) + +#define S_LL_EMPTY 4 +#define M_LL_EMPTY 0x3fU +#define V_LL_EMPTY(x) ((x) << S_LL_EMPTY) +#define G_LL_EMPTY(x) (((x) >> S_LL_EMPTY) & M_LL_EMPTY) + +#define S_LL_READ_WAIT_DISABLE 0 +#define V_LL_READ_WAIT_DISABLE(x) ((x) << S_LL_READ_WAIT_DISABLE) +#define F_LL_READ_WAIT_DISABLE V_LL_READ_WAIT_DISABLE(1U) + +#define A_SGE_TIMER_VALUE_0_AND_1 0x10b8 + +#define S_TIMERVALUE0 16 +#define M_TIMERVALUE0 0xffffU +#define V_TIMERVALUE0(x) ((x) << S_TIMERVALUE0) +#define G_TIMERVALUE0(x) (((x) >> S_TIMERVALUE0) & M_TIMERVALUE0) + +#define S_TIMERVALUE1 0 +#define M_TIMERVALUE1 0xffffU +#define V_TIMERVALUE1(x) ((x) << S_TIMERVALUE1) +#define G_TIMERVALUE1(x) (((x) >> S_TIMERVALUE1) & M_TIMERVALUE1) + +#define A_SGE_TIMER_VALUE_2_AND_3 0x10bc + +#define S_TIMERVALUE2 16 +#define M_TIMERVALUE2 0xffffU +#define V_TIMERVALUE2(x) ((x) << S_TIMERVALUE2) +#define G_TIMERVALUE2(x) (((x) >> S_TIMERVALUE2) & M_TIMERVALUE2) + +#define S_TIMERVALUE3 0 +#define M_TIMERVALUE3 0xffffU +#define V_TIMERVALUE3(x) ((x) << S_TIMERVALUE3) +#define G_TIMERVALUE3(x) (((x) >> S_TIMERVALUE3) & M_TIMERVALUE3) + +#define A_SGE_TIMER_VALUE_4_AND_5 0x10c0 + +#define S_TIMERVALUE4 16 +#define M_TIMERVALUE4 0xffffU +#define V_TIMERVALUE4(x) ((x) << S_TIMERVALUE4) +#define G_TIMERVALUE4(x) (((x) >> S_TIMERVALUE4) & M_TIMERVALUE4) + +#define S_TIMERVALUE5 0 +#define M_TIMERVALUE5 0xffffU +#define V_TIMERVALUE5(x) ((x) << S_TIMERVALUE5) +#define G_TIMERVALUE5(x) (((x) >> S_TIMERVALUE5) & M_TIMERVALUE5) + +#define A_SGE_PD_RSP_CREDIT01 0x10c4 + +#define S_RSPCREDITEN0 31 +#define V_RSPCREDITEN0(x) ((x) << S_RSPCREDITEN0) +#define F_RSPCREDITEN0 V_RSPCREDITEN0(1U) + +#define S_MAXTAG0 24 +#define M_MAXTAG0 0x7fU +#define V_MAXTAG0(x) ((x) << S_MAXTAG0) +#define G_MAXTAG0(x) (((x) >> S_MAXTAG0) & M_MAXTAG0) + +#define S_MAXRSPCNT0 16 +#define M_MAXRSPCNT0 0xffU +#define V_MAXRSPCNT0(x) ((x) << S_MAXRSPCNT0) +#define G_MAXRSPCNT0(x) (((x) >> S_MAXRSPCNT0) & M_MAXRSPCNT0) + +#define S_RSPCREDITEN1 15 +#define V_RSPCREDITEN1(x) ((x) << S_RSPCREDITEN1) +#define F_RSPCREDITEN1 V_RSPCREDITEN1(1U) + +#define S_MAXTAG1 8 +#define M_MAXTAG1 0x7fU +#define V_MAXTAG1(x) ((x) << S_MAXTAG1) +#define G_MAXTAG1(x) (((x) >> S_MAXTAG1) & M_MAXTAG1) + +#define S_MAXRSPCNT1 0 +#define M_MAXRSPCNT1 0xffU +#define V_MAXRSPCNT1(x) ((x) << S_MAXRSPCNT1) +#define G_MAXRSPCNT1(x) (((x) >> S_MAXRSPCNT1) & M_MAXRSPCNT1) + +#define A_SGE_PD_RSP_CREDIT23 0x10c8 + +#define S_RSPCREDITEN2 31 +#define V_RSPCREDITEN2(x) ((x) << S_RSPCREDITEN2) +#define F_RSPCREDITEN2 V_RSPCREDITEN2(1U) + +#define S_MAXTAG2 24 +#define M_MAXTAG2 0x7fU +#define V_MAXTAG2(x) ((x) << S_MAXTAG2) +#define G_MAXTAG2(x) (((x) >> S_MAXTAG2) & M_MAXTAG2) + +#define S_MAXRSPCNT2 16 +#define M_MAXRSPCNT2 0xffU +#define V_MAXRSPCNT2(x) ((x) << S_MAXRSPCNT2) +#define G_MAXRSPCNT2(x) (((x) >> S_MAXRSPCNT2) & M_MAXRSPCNT2) + +#define S_RSPCREDITEN3 15 +#define V_RSPCREDITEN3(x) ((x) << S_RSPCREDITEN3) +#define F_RSPCREDITEN3 V_RSPCREDITEN3(1U) + +#define S_MAXTAG3 8 +#define M_MAXTAG3 0x7fU +#define V_MAXTAG3(x) ((x) << S_MAXTAG3) +#define G_MAXTAG3(x) (((x) >> S_MAXTAG3) & M_MAXTAG3) + +#define S_MAXRSPCNT3 0 +#define M_MAXRSPCNT3 0xffU +#define V_MAXRSPCNT3(x) ((x) << S_MAXRSPCNT3) +#define G_MAXRSPCNT3(x) (((x) >> S_MAXRSPCNT3) & M_MAXRSPCNT3) + +#define A_SGE_DEBUG_INDEX 0x10cc +#define A_SGE_DEBUG_DATA_HIGH 0x10d0 +#define A_SGE_DEBUG_DATA_LOW 0x10d4 +#define A_SGE_REVISION 0x10d8 +#define A_SGE_INT_CAUSE4 0x10dc + +#define S_ERR_BAD_UPFL_INC_CREDIT3 8 +#define V_ERR_BAD_UPFL_INC_CREDIT3(x) ((x) << S_ERR_BAD_UPFL_INC_CREDIT3) +#define F_ERR_BAD_UPFL_INC_CREDIT3 V_ERR_BAD_UPFL_INC_CREDIT3(1U) + +#define S_ERR_BAD_UPFL_INC_CREDIT2 7 +#define V_ERR_BAD_UPFL_INC_CREDIT2(x) ((x) << S_ERR_BAD_UPFL_INC_CREDIT2) +#define F_ERR_BAD_UPFL_INC_CREDIT2 V_ERR_BAD_UPFL_INC_CREDIT2(1U) + +#define S_ERR_BAD_UPFL_INC_CREDIT1 6 +#define V_ERR_BAD_UPFL_INC_CREDIT1(x) ((x) << S_ERR_BAD_UPFL_INC_CREDIT1) +#define F_ERR_BAD_UPFL_INC_CREDIT1 V_ERR_BAD_UPFL_INC_CREDIT1(1U) + +#define S_ERR_BAD_UPFL_INC_CREDIT0 5 +#define V_ERR_BAD_UPFL_INC_CREDIT0(x) ((x) << S_ERR_BAD_UPFL_INC_CREDIT0) +#define F_ERR_BAD_UPFL_INC_CREDIT0 V_ERR_BAD_UPFL_INC_CREDIT0(1U) + +#define S_ERR_PHYSADDR_LEN0_IDMA1 4 +#define V_ERR_PHYSADDR_LEN0_IDMA1(x) ((x) << S_ERR_PHYSADDR_LEN0_IDMA1) +#define F_ERR_PHYSADDR_LEN0_IDMA1 V_ERR_PHYSADDR_LEN0_IDMA1(1U) + +#define S_ERR_PHYSADDR_LEN0_IDMA0 3 +#define V_ERR_PHYSADDR_LEN0_IDMA0(x) ((x) << S_ERR_PHYSADDR_LEN0_IDMA0) +#define F_ERR_PHYSADDR_LEN0_IDMA0 V_ERR_PHYSADDR_LEN0_IDMA0(1U) + +#define S_ERR_FLM_INVALID_PKT_DROP1 2 +#define V_ERR_FLM_INVALID_PKT_DROP1(x) ((x) << S_ERR_FLM_INVALID_PKT_DROP1) +#define F_ERR_FLM_INVALID_PKT_DROP1 V_ERR_FLM_INVALID_PKT_DROP1(1U) + +#define S_ERR_FLM_INVALID_PKT_DROP0 1 +#define V_ERR_FLM_INVALID_PKT_DROP0(x) ((x) << S_ERR_FLM_INVALID_PKT_DROP0) +#define F_ERR_FLM_INVALID_PKT_DROP0 V_ERR_FLM_INVALID_PKT_DROP0(1U) + +#define S_ERR_UNEXPECTED_TIMER 0 +#define V_ERR_UNEXPECTED_TIMER(x) ((x) << S_ERR_UNEXPECTED_TIMER) +#define F_ERR_UNEXPECTED_TIMER V_ERR_UNEXPECTED_TIMER(1U) + +#define S_BAR2_EGRESS_LEN_OR_ADDR_ERR 29 +#define V_BAR2_EGRESS_LEN_OR_ADDR_ERR(x) ((x) << S_BAR2_EGRESS_LEN_OR_ADDR_ERR) +#define F_BAR2_EGRESS_LEN_OR_ADDR_ERR V_BAR2_EGRESS_LEN_OR_ADDR_ERR(1U) + +#define S_ERR_CPL_EXCEED_MAX_IQE_SIZE1 28 +#define V_ERR_CPL_EXCEED_MAX_IQE_SIZE1(x) ((x) << S_ERR_CPL_EXCEED_MAX_IQE_SIZE1) +#define F_ERR_CPL_EXCEED_MAX_IQE_SIZE1 V_ERR_CPL_EXCEED_MAX_IQE_SIZE1(1U) + +#define S_ERR_CPL_EXCEED_MAX_IQE_SIZE0 27 +#define V_ERR_CPL_EXCEED_MAX_IQE_SIZE0(x) ((x) << S_ERR_CPL_EXCEED_MAX_IQE_SIZE0) +#define F_ERR_CPL_EXCEED_MAX_IQE_SIZE0 V_ERR_CPL_EXCEED_MAX_IQE_SIZE0(1U) + +#define S_ERR_WR_LEN_TOO_LARGE3 26 +#define V_ERR_WR_LEN_TOO_LARGE3(x) ((x) << S_ERR_WR_LEN_TOO_LARGE3) +#define F_ERR_WR_LEN_TOO_LARGE3 V_ERR_WR_LEN_TOO_LARGE3(1U) + +#define S_ERR_WR_LEN_TOO_LARGE2 25 +#define V_ERR_WR_LEN_TOO_LARGE2(x) ((x) << S_ERR_WR_LEN_TOO_LARGE2) +#define F_ERR_WR_LEN_TOO_LARGE2 V_ERR_WR_LEN_TOO_LARGE2(1U) + +#define S_ERR_WR_LEN_TOO_LARGE1 24 +#define V_ERR_WR_LEN_TOO_LARGE1(x) ((x) << S_ERR_WR_LEN_TOO_LARGE1) +#define F_ERR_WR_LEN_TOO_LARGE1 V_ERR_WR_LEN_TOO_LARGE1(1U) + +#define S_ERR_WR_LEN_TOO_LARGE0 23 +#define V_ERR_WR_LEN_TOO_LARGE0(x) ((x) << S_ERR_WR_LEN_TOO_LARGE0) +#define F_ERR_WR_LEN_TOO_LARGE0 V_ERR_WR_LEN_TOO_LARGE0(1U) + +#define S_ERR_LARGE_MINFETCH_WITH_TXCOAL3 22 +#define V_ERR_LARGE_MINFETCH_WITH_TXCOAL3(x) ((x) << S_ERR_LARGE_MINFETCH_WITH_TXCOAL3) +#define F_ERR_LARGE_MINFETCH_WITH_TXCOAL3 V_ERR_LARGE_MINFETCH_WITH_TXCOAL3(1U) + +#define S_ERR_LARGE_MINFETCH_WITH_TXCOAL2 21 +#define V_ERR_LARGE_MINFETCH_WITH_TXCOAL2(x) ((x) << S_ERR_LARGE_MINFETCH_WITH_TXCOAL2) +#define F_ERR_LARGE_MINFETCH_WITH_TXCOAL2 V_ERR_LARGE_MINFETCH_WITH_TXCOAL2(1U) + +#define S_ERR_LARGE_MINFETCH_WITH_TXCOAL1 20 +#define V_ERR_LARGE_MINFETCH_WITH_TXCOAL1(x) ((x) << S_ERR_LARGE_MINFETCH_WITH_TXCOAL1) +#define F_ERR_LARGE_MINFETCH_WITH_TXCOAL1 V_ERR_LARGE_MINFETCH_WITH_TXCOAL1(1U) + +#define S_ERR_LARGE_MINFETCH_WITH_TXCOAL0 19 +#define V_ERR_LARGE_MINFETCH_WITH_TXCOAL0(x) ((x) << S_ERR_LARGE_MINFETCH_WITH_TXCOAL0) +#define F_ERR_LARGE_MINFETCH_WITH_TXCOAL0 V_ERR_LARGE_MINFETCH_WITH_TXCOAL0(1U) + +#define S_COAL_WITH_HP_DISABLE_ERR 18 +#define V_COAL_WITH_HP_DISABLE_ERR(x) ((x) << S_COAL_WITH_HP_DISABLE_ERR) +#define F_COAL_WITH_HP_DISABLE_ERR V_COAL_WITH_HP_DISABLE_ERR(1U) + +#define S_BAR2_EGRESS_COAL0_ERR 17 +#define V_BAR2_EGRESS_COAL0_ERR(x) ((x) << S_BAR2_EGRESS_COAL0_ERR) +#define F_BAR2_EGRESS_COAL0_ERR V_BAR2_EGRESS_COAL0_ERR(1U) + +#define S_BAR2_EGRESS_SIZE_ERR 16 +#define V_BAR2_EGRESS_SIZE_ERR(x) ((x) << S_BAR2_EGRESS_SIZE_ERR) +#define F_BAR2_EGRESS_SIZE_ERR V_BAR2_EGRESS_SIZE_ERR(1U) + +#define S_FLM_PC_RSP_ERR 15 +#define V_FLM_PC_RSP_ERR(x) ((x) << S_FLM_PC_RSP_ERR) +#define F_FLM_PC_RSP_ERR V_FLM_PC_RSP_ERR(1U) + +#define S_DBFIFO_HP_INT_LOW 14 +#define V_DBFIFO_HP_INT_LOW(x) ((x) << S_DBFIFO_HP_INT_LOW) +#define F_DBFIFO_HP_INT_LOW V_DBFIFO_HP_INT_LOW(1U) + +#define S_DBFIFO_LP_INT_LOW 13 +#define V_DBFIFO_LP_INT_LOW(x) ((x) << S_DBFIFO_LP_INT_LOW) +#define F_DBFIFO_LP_INT_LOW V_DBFIFO_LP_INT_LOW(1U) + +#define S_DBFIFO_FL_INT_LOW 12 +#define V_DBFIFO_FL_INT_LOW(x) ((x) << S_DBFIFO_FL_INT_LOW) +#define F_DBFIFO_FL_INT_LOW V_DBFIFO_FL_INT_LOW(1U) + +#define S_DBFIFO_FL_INT 11 +#define V_DBFIFO_FL_INT(x) ((x) << S_DBFIFO_FL_INT) +#define F_DBFIFO_FL_INT V_DBFIFO_FL_INT(1U) + +#define S_ERR_RX_CPL_PACKET_SIZE1 10 +#define V_ERR_RX_CPL_PACKET_SIZE1(x) ((x) << S_ERR_RX_CPL_PACKET_SIZE1) +#define F_ERR_RX_CPL_PACKET_SIZE1 V_ERR_RX_CPL_PACKET_SIZE1(1U) + +#define S_ERR_RX_CPL_PACKET_SIZE0 9 +#define V_ERR_RX_CPL_PACKET_SIZE0(x) ((x) << S_ERR_RX_CPL_PACKET_SIZE0) +#define F_ERR_RX_CPL_PACKET_SIZE0 V_ERR_RX_CPL_PACKET_SIZE0(1U) + +#define A_SGE_INT_ENABLE4 0x10e0 +#define A_SGE_STAT_TOTAL 0x10e4 +#define A_SGE_STAT_MATCH 0x10e8 +#define A_SGE_STAT_CFG 0x10ec + +#define S_ITPOPMODE 8 +#define V_ITPOPMODE(x) ((x) << S_ITPOPMODE) +#define F_ITPOPMODE V_ITPOPMODE(1U) + +#define S_EGRCTXTOPMODE 6 +#define M_EGRCTXTOPMODE 0x3U +#define V_EGRCTXTOPMODE(x) ((x) << S_EGRCTXTOPMODE) +#define G_EGRCTXTOPMODE(x) (((x) >> S_EGRCTXTOPMODE) & M_EGRCTXTOPMODE) + +#define S_INGCTXTOPMODE 4 +#define M_INGCTXTOPMODE 0x3U +#define V_INGCTXTOPMODE(x) ((x) << S_INGCTXTOPMODE) +#define G_INGCTXTOPMODE(x) (((x) >> S_INGCTXTOPMODE) & M_INGCTXTOPMODE) + +#define S_STATMODE 2 +#define M_STATMODE 0x3U +#define V_STATMODE(x) ((x) << S_STATMODE) +#define G_STATMODE(x) (((x) >> S_STATMODE) & M_STATMODE) + +#define S_STATSOURCE 0 +#define M_STATSOURCE 0x3U +#define V_STATSOURCE(x) ((x) << S_STATSOURCE) +#define G_STATSOURCE(x) (((x) >> S_STATSOURCE) & M_STATSOURCE) + +#define S_STATSOURCE_T5 9 +#define M_STATSOURCE_T5 0xfU +#define V_STATSOURCE_T5(x) ((x) << S_STATSOURCE_T5) +#define G_STATSOURCE_T5(x) (((x) >> S_STATSOURCE_T5) & M_STATSOURCE_T5) + +#define A_SGE_HINT_CFG 0x10f0 + +#define S_HINTSALLOWEDNOHDR 6 +#define M_HINTSALLOWEDNOHDR 0x3fU +#define V_HINTSALLOWEDNOHDR(x) ((x) << S_HINTSALLOWEDNOHDR) +#define G_HINTSALLOWEDNOHDR(x) (((x) >> S_HINTSALLOWEDNOHDR) & M_HINTSALLOWEDNOHDR) + +#define S_HINTSALLOWEDHDR 0 +#define M_HINTSALLOWEDHDR 0x3fU +#define V_HINTSALLOWEDHDR(x) ((x) << S_HINTSALLOWEDHDR) +#define G_HINTSALLOWEDHDR(x) (((x) >> S_HINTSALLOWEDHDR) & M_HINTSALLOWEDHDR) + +#define S_UPCUTOFFTHRESHLP 12 +#define M_UPCUTOFFTHRESHLP 0x7ffU +#define V_UPCUTOFFTHRESHLP(x) ((x) << S_UPCUTOFFTHRESHLP) +#define G_UPCUTOFFTHRESHLP(x) (((x) >> S_UPCUTOFFTHRESHLP) & M_UPCUTOFFTHRESHLP) + +#define A_SGE_INGRESS_QUEUES_PER_PAGE_PF 0x10f4 +#define A_SGE_INGRESS_QUEUES_PER_PAGE_VF 0x10f8 +#define A_SGE_PD_WRR_CONFIG 0x10fc + +#define S_EDMA_WEIGHT 0 +#define M_EDMA_WEIGHT 0x3fU +#define V_EDMA_WEIGHT(x) ((x) << S_EDMA_WEIGHT) +#define G_EDMA_WEIGHT(x) (((x) >> S_EDMA_WEIGHT) & M_EDMA_WEIGHT) + +#define A_SGE_ERROR_STATS 0x1100 + +#define S_UNCAPTURED_ERROR 18 +#define V_UNCAPTURED_ERROR(x) ((x) << S_UNCAPTURED_ERROR) +#define F_UNCAPTURED_ERROR V_UNCAPTURED_ERROR(1U) + +#define S_ERROR_QID_VALID 17 +#define V_ERROR_QID_VALID(x) ((x) << S_ERROR_QID_VALID) +#define F_ERROR_QID_VALID V_ERROR_QID_VALID(1U) + +#define S_ERROR_QID 0 +#define M_ERROR_QID 0x1ffffU +#define V_ERROR_QID(x) ((x) << S_ERROR_QID) +#define G_ERROR_QID(x) (((x) >> S_ERROR_QID) & M_ERROR_QID) + +#define S_CAUSE_REGISTER 24 +#define M_CAUSE_REGISTER 0x7U +#define V_CAUSE_REGISTER(x) ((x) << S_CAUSE_REGISTER) +#define G_CAUSE_REGISTER(x) (((x) >> S_CAUSE_REGISTER) & M_CAUSE_REGISTER) + +#define S_CAUSE_BIT 19 +#define M_CAUSE_BIT 0x1fU +#define V_CAUSE_BIT(x) ((x) << S_CAUSE_BIT) +#define G_CAUSE_BIT(x) (((x) >> S_CAUSE_BIT) & M_CAUSE_BIT) + +#define A_SGE_SHARED_TAG_CHAN_CFG 0x1104 + +#define S_MINTAG3 24 +#define M_MINTAG3 0xffU +#define V_MINTAG3(x) ((x) << S_MINTAG3) +#define G_MINTAG3(x) (((x) >> S_MINTAG3) & M_MINTAG3) + +#define S_MINTAG2 16 +#define M_MINTAG2 0xffU +#define V_MINTAG2(x) ((x) << S_MINTAG2) +#define G_MINTAG2(x) (((x) >> S_MINTAG2) & M_MINTAG2) + +#define S_MINTAG1 8 +#define M_MINTAG1 0xffU +#define V_MINTAG1(x) ((x) << S_MINTAG1) +#define G_MINTAG1(x) (((x) >> S_MINTAG1) & M_MINTAG1) + +#define S_MINTAG0 0 +#define M_MINTAG0 0xffU +#define V_MINTAG0(x) ((x) << S_MINTAG0) +#define G_MINTAG0(x) (((x) >> S_MINTAG0) & M_MINTAG0) + +#define A_SGE_SHARED_TAG_POOL_CFG 0x1108 + +#define S_TAGPOOLTOTAL 0 +#define M_TAGPOOLTOTAL 0xffU +#define V_TAGPOOLTOTAL(x) ((x) << S_TAGPOOLTOTAL) +#define G_TAGPOOLTOTAL(x) (((x) >> S_TAGPOOLTOTAL) & M_TAGPOOLTOTAL) + +#define A_SGE_INT_CAUSE5 0x110c + +#define S_ERR_T_RXCRC 31 +#define V_ERR_T_RXCRC(x) ((x) << S_ERR_T_RXCRC) +#define F_ERR_T_RXCRC V_ERR_T_RXCRC(1U) + +#define S_PERR_MC_RSPDATA 30 +#define V_PERR_MC_RSPDATA(x) ((x) << S_PERR_MC_RSPDATA) +#define F_PERR_MC_RSPDATA V_PERR_MC_RSPDATA(1U) + +#define S_PERR_PC_RSPDATA 29 +#define V_PERR_PC_RSPDATA(x) ((x) << S_PERR_PC_RSPDATA) +#define F_PERR_PC_RSPDATA V_PERR_PC_RSPDATA(1U) + +#define S_PERR_PD_RDRSPDATA 28 +#define V_PERR_PD_RDRSPDATA(x) ((x) << S_PERR_PD_RDRSPDATA) +#define F_PERR_PD_RDRSPDATA V_PERR_PD_RDRSPDATA(1U) + +#define S_PERR_U_RXDATA 27 +#define V_PERR_U_RXDATA(x) ((x) << S_PERR_U_RXDATA) +#define F_PERR_U_RXDATA V_PERR_U_RXDATA(1U) + +#define S_PERR_UD_RXDATA 26 +#define V_PERR_UD_RXDATA(x) ((x) << S_PERR_UD_RXDATA) +#define F_PERR_UD_RXDATA V_PERR_UD_RXDATA(1U) + +#define S_PERR_UP_DATA 25 +#define V_PERR_UP_DATA(x) ((x) << S_PERR_UP_DATA) +#define F_PERR_UP_DATA V_PERR_UP_DATA(1U) + +#define S_PERR_CIM2SGE_RXDATA 24 +#define V_PERR_CIM2SGE_RXDATA(x) ((x) << S_PERR_CIM2SGE_RXDATA) +#define F_PERR_CIM2SGE_RXDATA V_PERR_CIM2SGE_RXDATA(1U) + +#define S_PERR_HINT_DELAY_FIFO1_T5 23 +#define V_PERR_HINT_DELAY_FIFO1_T5(x) ((x) << S_PERR_HINT_DELAY_FIFO1_T5) +#define F_PERR_HINT_DELAY_FIFO1_T5 V_PERR_HINT_DELAY_FIFO1_T5(1U) + +#define S_PERR_HINT_DELAY_FIFO0_T5 22 +#define V_PERR_HINT_DELAY_FIFO0_T5(x) ((x) << S_PERR_HINT_DELAY_FIFO0_T5) +#define F_PERR_HINT_DELAY_FIFO0_T5 V_PERR_HINT_DELAY_FIFO0_T5(1U) + +#define S_PERR_IMSG_PD_FIFO_T5 21 +#define V_PERR_IMSG_PD_FIFO_T5(x) ((x) << S_PERR_IMSG_PD_FIFO_T5) +#define F_PERR_IMSG_PD_FIFO_T5 V_PERR_IMSG_PD_FIFO_T5(1U) + +#define S_PERR_ULPTX_FIFO1_T5 20 +#define V_PERR_ULPTX_FIFO1_T5(x) ((x) << S_PERR_ULPTX_FIFO1_T5) +#define F_PERR_ULPTX_FIFO1_T5 V_PERR_ULPTX_FIFO1_T5(1U) + +#define S_PERR_ULPTX_FIFO0_T5 19 +#define V_PERR_ULPTX_FIFO0_T5(x) ((x) << S_PERR_ULPTX_FIFO0_T5) +#define F_PERR_ULPTX_FIFO0_T5 V_PERR_ULPTX_FIFO0_T5(1U) + +#define S_PERR_IDMA2IMSG_FIFO1_T5 18 +#define V_PERR_IDMA2IMSG_FIFO1_T5(x) ((x) << S_PERR_IDMA2IMSG_FIFO1_T5) +#define F_PERR_IDMA2IMSG_FIFO1_T5 V_PERR_IDMA2IMSG_FIFO1_T5(1U) + +#define S_PERR_IDMA2IMSG_FIFO0_T5 17 +#define V_PERR_IDMA2IMSG_FIFO0_T5(x) ((x) << S_PERR_IDMA2IMSG_FIFO0_T5) +#define F_PERR_IDMA2IMSG_FIFO0_T5 V_PERR_IDMA2IMSG_FIFO0_T5(1U) + +#define S_PERR_POINTER_DATA_FIFO0 16 +#define V_PERR_POINTER_DATA_FIFO0(x) ((x) << S_PERR_POINTER_DATA_FIFO0) +#define F_PERR_POINTER_DATA_FIFO0 V_PERR_POINTER_DATA_FIFO0(1U) + +#define S_PERR_POINTER_DATA_FIFO1 15 +#define V_PERR_POINTER_DATA_FIFO1(x) ((x) << S_PERR_POINTER_DATA_FIFO1) +#define F_PERR_POINTER_DATA_FIFO1 V_PERR_POINTER_DATA_FIFO1(1U) + +#define S_PERR_POINTER_HDR_FIFO0 14 +#define V_PERR_POINTER_HDR_FIFO0(x) ((x) << S_PERR_POINTER_HDR_FIFO0) +#define F_PERR_POINTER_HDR_FIFO0 V_PERR_POINTER_HDR_FIFO0(1U) + +#define S_PERR_POINTER_HDR_FIFO1 13 +#define V_PERR_POINTER_HDR_FIFO1(x) ((x) << S_PERR_POINTER_HDR_FIFO1) +#define F_PERR_POINTER_HDR_FIFO1 V_PERR_POINTER_HDR_FIFO1(1U) + +#define S_PERR_PAYLOAD_FIFO0 12 +#define V_PERR_PAYLOAD_FIFO0(x) ((x) << S_PERR_PAYLOAD_FIFO0) +#define F_PERR_PAYLOAD_FIFO0 V_PERR_PAYLOAD_FIFO0(1U) + +#define S_PERR_PAYLOAD_FIFO1 11 +#define V_PERR_PAYLOAD_FIFO1(x) ((x) << S_PERR_PAYLOAD_FIFO1) +#define F_PERR_PAYLOAD_FIFO1 V_PERR_PAYLOAD_FIFO1(1U) + +#define S_PERR_EDMA_INPUT_FIFO3 10 +#define V_PERR_EDMA_INPUT_FIFO3(x) ((x) << S_PERR_EDMA_INPUT_FIFO3) +#define F_PERR_EDMA_INPUT_FIFO3 V_PERR_EDMA_INPUT_FIFO3(1U) + +#define S_PERR_EDMA_INPUT_FIFO2 9 +#define V_PERR_EDMA_INPUT_FIFO2(x) ((x) << S_PERR_EDMA_INPUT_FIFO2) +#define F_PERR_EDMA_INPUT_FIFO2 V_PERR_EDMA_INPUT_FIFO2(1U) + +#define S_PERR_EDMA_INPUT_FIFO1 8 +#define V_PERR_EDMA_INPUT_FIFO1(x) ((x) << S_PERR_EDMA_INPUT_FIFO1) +#define F_PERR_EDMA_INPUT_FIFO1 V_PERR_EDMA_INPUT_FIFO1(1U) + +#define S_PERR_EDMA_INPUT_FIFO0 7 +#define V_PERR_EDMA_INPUT_FIFO0(x) ((x) << S_PERR_EDMA_INPUT_FIFO0) +#define F_PERR_EDMA_INPUT_FIFO0 V_PERR_EDMA_INPUT_FIFO0(1U) + +#define S_PERR_MGT_BAR2_FIFO 6 +#define V_PERR_MGT_BAR2_FIFO(x) ((x) << S_PERR_MGT_BAR2_FIFO) +#define F_PERR_MGT_BAR2_FIFO V_PERR_MGT_BAR2_FIFO(1U) + +#define S_PERR_HEADERSPLIT_FIFO1_T5 5 +#define V_PERR_HEADERSPLIT_FIFO1_T5(x) ((x) << S_PERR_HEADERSPLIT_FIFO1_T5) +#define F_PERR_HEADERSPLIT_FIFO1_T5 V_PERR_HEADERSPLIT_FIFO1_T5(1U) + +#define S_PERR_HEADERSPLIT_FIFO0_T5 4 +#define V_PERR_HEADERSPLIT_FIFO0_T5(x) ((x) << S_PERR_HEADERSPLIT_FIFO0_T5) +#define F_PERR_HEADERSPLIT_FIFO0_T5 V_PERR_HEADERSPLIT_FIFO0_T5(1U) + +#define S_PERR_CIM_FIFO1 3 +#define V_PERR_CIM_FIFO1(x) ((x) << S_PERR_CIM_FIFO1) +#define F_PERR_CIM_FIFO1 V_PERR_CIM_FIFO1(1U) + +#define S_PERR_CIM_FIFO0 2 +#define V_PERR_CIM_FIFO0(x) ((x) << S_PERR_CIM_FIFO0) +#define F_PERR_CIM_FIFO0 V_PERR_CIM_FIFO0(1U) + +#define S_PERR_IDMA_SWITCH_OUTPUT_FIFO1 1 +#define V_PERR_IDMA_SWITCH_OUTPUT_FIFO1(x) ((x) << S_PERR_IDMA_SWITCH_OUTPUT_FIFO1) +#define F_PERR_IDMA_SWITCH_OUTPUT_FIFO1 V_PERR_IDMA_SWITCH_OUTPUT_FIFO1(1U) + +#define S_PERR_IDMA_SWITCH_OUTPUT_FIFO0 0 +#define V_PERR_IDMA_SWITCH_OUTPUT_FIFO0(x) ((x) << S_PERR_IDMA_SWITCH_OUTPUT_FIFO0) +#define F_PERR_IDMA_SWITCH_OUTPUT_FIFO0 V_PERR_IDMA_SWITCH_OUTPUT_FIFO0(1U) + +#define A_SGE_INT_ENABLE5 0x1110 +#define A_SGE_PERR_ENABLE5 0x1114 +#define A_SGE_DBFIFO_STATUS2 0x1118 + +#define S_FL_INT_THRESH 24 +#define M_FL_INT_THRESH 0xfU +#define V_FL_INT_THRESH(x) ((x) << S_FL_INT_THRESH) +#define G_FL_INT_THRESH(x) (((x) >> S_FL_INT_THRESH) & M_FL_INT_THRESH) + +#define S_FL_COUNT 14 +#define M_FL_COUNT 0x3ffU +#define V_FL_COUNT(x) ((x) << S_FL_COUNT) +#define G_FL_COUNT(x) (((x) >> S_FL_COUNT) & M_FL_COUNT) + +#define S_HP_INT_THRESH_T5 10 +#define M_HP_INT_THRESH_T5 0xfU +#define V_HP_INT_THRESH_T5(x) ((x) << S_HP_INT_THRESH_T5) +#define G_HP_INT_THRESH_T5(x) (((x) >> S_HP_INT_THRESH_T5) & M_HP_INT_THRESH_T5) + +#define S_HP_COUNT_T5 0 +#define M_HP_COUNT_T5 0x3ffU +#define V_HP_COUNT_T5(x) ((x) << S_HP_COUNT_T5) +#define G_HP_COUNT_T5(x) (((x) >> S_HP_COUNT_T5) & M_HP_COUNT_T5) + +#define A_SGE_FETCH_BURST_MAX_0_AND_1 0x111c + +#define S_FETCHBURSTMAX0 16 +#define M_FETCHBURSTMAX0 0x3ffU +#define V_FETCHBURSTMAX0(x) ((x) << S_FETCHBURSTMAX0) +#define G_FETCHBURSTMAX0(x) (((x) >> S_FETCHBURSTMAX0) & M_FETCHBURSTMAX0) + +#define S_FETCHBURSTMAX1 0 +#define M_FETCHBURSTMAX1 0x3ffU +#define V_FETCHBURSTMAX1(x) ((x) << S_FETCHBURSTMAX1) +#define G_FETCHBURSTMAX1(x) (((x) >> S_FETCHBURSTMAX1) & M_FETCHBURSTMAX1) + +#define A_SGE_FETCH_BURST_MAX_2_AND_3 0x1120 + +#define S_FETCHBURSTMAX2 16 +#define M_FETCHBURSTMAX2 0x3ffU +#define V_FETCHBURSTMAX2(x) ((x) << S_FETCHBURSTMAX2) +#define G_FETCHBURSTMAX2(x) (((x) >> S_FETCHBURSTMAX2) & M_FETCHBURSTMAX2) + +#define S_FETCHBURSTMAX3 0 +#define M_FETCHBURSTMAX3 0x3ffU +#define V_FETCHBURSTMAX3(x) ((x) << S_FETCHBURSTMAX3) +#define G_FETCHBURSTMAX3(x) (((x) >> S_FETCHBURSTMAX3) & M_FETCHBURSTMAX3) + +#define A_SGE_CONTROL2 0x1124 + +#define S_UPFLCUTOFFDIS 21 +#define V_UPFLCUTOFFDIS(x) ((x) << S_UPFLCUTOFFDIS) +#define F_UPFLCUTOFFDIS V_UPFLCUTOFFDIS(1U) + +#define S_RXCPLSIZEAUTOCORRECT 20 +#define V_RXCPLSIZEAUTOCORRECT(x) ((x) << S_RXCPLSIZEAUTOCORRECT) +#define F_RXCPLSIZEAUTOCORRECT V_RXCPLSIZEAUTOCORRECT(1U) + +#define S_IDMAARBROUNDROBIN 19 +#define V_IDMAARBROUNDROBIN(x) ((x) << S_IDMAARBROUNDROBIN) +#define F_IDMAARBROUNDROBIN V_IDMAARBROUNDROBIN(1U) + +#define S_INGPACKBOUNDARY 16 +#define M_INGPACKBOUNDARY 0x7U +#define V_INGPACKBOUNDARY(x) ((x) << S_INGPACKBOUNDARY) +#define G_INGPACKBOUNDARY(x) (((x) >> S_INGPACKBOUNDARY) & M_INGPACKBOUNDARY) + +#define S_CGEN_EGRESS_CONTEXT 15 +#define V_CGEN_EGRESS_CONTEXT(x) ((x) << S_CGEN_EGRESS_CONTEXT) +#define F_CGEN_EGRESS_CONTEXT V_CGEN_EGRESS_CONTEXT(1U) + +#define S_CGEN_INGRESS_CONTEXT 14 +#define V_CGEN_INGRESS_CONTEXT(x) ((x) << S_CGEN_INGRESS_CONTEXT) +#define F_CGEN_INGRESS_CONTEXT V_CGEN_INGRESS_CONTEXT(1U) + +#define S_CGEN_IDMA 13 +#define V_CGEN_IDMA(x) ((x) << S_CGEN_IDMA) +#define F_CGEN_IDMA V_CGEN_IDMA(1U) + +#define S_CGEN_DBP 12 +#define V_CGEN_DBP(x) ((x) << S_CGEN_DBP) +#define F_CGEN_DBP V_CGEN_DBP(1U) + +#define S_CGEN_EDMA 11 +#define V_CGEN_EDMA(x) ((x) << S_CGEN_EDMA) +#define F_CGEN_EDMA V_CGEN_EDMA(1U) + +#define S_VFIFO_ENABLE 10 +#define V_VFIFO_ENABLE(x) ((x) << S_VFIFO_ENABLE) +#define F_VFIFO_ENABLE V_VFIFO_ENABLE(1U) + +#define S_FLM_RESCHEDULE_MODE 9 +#define V_FLM_RESCHEDULE_MODE(x) ((x) << S_FLM_RESCHEDULE_MODE) +#define F_FLM_RESCHEDULE_MODE V_FLM_RESCHEDULE_MODE(1U) + +#define S_HINTDEPTHCTLFL 4 +#define M_HINTDEPTHCTLFL 0x1fU +#define V_HINTDEPTHCTLFL(x) ((x) << S_HINTDEPTHCTLFL) +#define G_HINTDEPTHCTLFL(x) (((x) >> S_HINTDEPTHCTLFL) & M_HINTDEPTHCTLFL) + +#define S_FORCE_ORDERING 3 +#define V_FORCE_ORDERING(x) ((x) << S_FORCE_ORDERING) +#define F_FORCE_ORDERING V_FORCE_ORDERING(1U) + +#define S_TX_COALESCE_SIZE 2 +#define V_TX_COALESCE_SIZE(x) ((x) << S_TX_COALESCE_SIZE) +#define F_TX_COALESCE_SIZE V_TX_COALESCE_SIZE(1U) + +#define S_COAL_STRICT_CIM_PRI 1 +#define V_COAL_STRICT_CIM_PRI(x) ((x) << S_COAL_STRICT_CIM_PRI) +#define F_COAL_STRICT_CIM_PRI V_COAL_STRICT_CIM_PRI(1U) + +#define S_TX_COALESCE_PRI 0 +#define V_TX_COALESCE_PRI(x) ((x) << S_TX_COALESCE_PRI) +#define F_TX_COALESCE_PRI V_TX_COALESCE_PRI(1U) + +#define A_SGE_DEEP_SLEEP 0x1128 + +#define S_IDMA1_SLEEP_STATUS 11 +#define V_IDMA1_SLEEP_STATUS(x) ((x) << S_IDMA1_SLEEP_STATUS) +#define F_IDMA1_SLEEP_STATUS V_IDMA1_SLEEP_STATUS(1U) + +#define S_IDMA0_SLEEP_STATUS 10 +#define V_IDMA0_SLEEP_STATUS(x) ((x) << S_IDMA0_SLEEP_STATUS) +#define F_IDMA0_SLEEP_STATUS V_IDMA0_SLEEP_STATUS(1U) + +#define S_IDMA1_SLEEP_REQ 9 +#define V_IDMA1_SLEEP_REQ(x) ((x) << S_IDMA1_SLEEP_REQ) +#define F_IDMA1_SLEEP_REQ V_IDMA1_SLEEP_REQ(1U) + +#define S_IDMA0_SLEEP_REQ 8 +#define V_IDMA0_SLEEP_REQ(x) ((x) << S_IDMA0_SLEEP_REQ) +#define F_IDMA0_SLEEP_REQ V_IDMA0_SLEEP_REQ(1U) + +#define S_EDMA3_SLEEP_STATUS 7 +#define V_EDMA3_SLEEP_STATUS(x) ((x) << S_EDMA3_SLEEP_STATUS) +#define F_EDMA3_SLEEP_STATUS V_EDMA3_SLEEP_STATUS(1U) + +#define S_EDMA2_SLEEP_STATUS 6 +#define V_EDMA2_SLEEP_STATUS(x) ((x) << S_EDMA2_SLEEP_STATUS) +#define F_EDMA2_SLEEP_STATUS V_EDMA2_SLEEP_STATUS(1U) + +#define S_EDMA1_SLEEP_STATUS 5 +#define V_EDMA1_SLEEP_STATUS(x) ((x) << S_EDMA1_SLEEP_STATUS) +#define F_EDMA1_SLEEP_STATUS V_EDMA1_SLEEP_STATUS(1U) + +#define S_EDMA0_SLEEP_STATUS 4 +#define V_EDMA0_SLEEP_STATUS(x) ((x) << S_EDMA0_SLEEP_STATUS) +#define F_EDMA0_SLEEP_STATUS V_EDMA0_SLEEP_STATUS(1U) + +#define S_EDMA3_SLEEP_REQ 3 +#define V_EDMA3_SLEEP_REQ(x) ((x) << S_EDMA3_SLEEP_REQ) +#define F_EDMA3_SLEEP_REQ V_EDMA3_SLEEP_REQ(1U) + +#define S_EDMA2_SLEEP_REQ 2 +#define V_EDMA2_SLEEP_REQ(x) ((x) << S_EDMA2_SLEEP_REQ) +#define F_EDMA2_SLEEP_REQ V_EDMA2_SLEEP_REQ(1U) + +#define S_EDMA1_SLEEP_REQ 1 +#define V_EDMA1_SLEEP_REQ(x) ((x) << S_EDMA1_SLEEP_REQ) +#define F_EDMA1_SLEEP_REQ V_EDMA1_SLEEP_REQ(1U) + +#define S_EDMA0_SLEEP_REQ 0 +#define V_EDMA0_SLEEP_REQ(x) ((x) << S_EDMA0_SLEEP_REQ) +#define F_EDMA0_SLEEP_REQ V_EDMA0_SLEEP_REQ(1U) + +#define A_SGE_DOORBELL_THROTTLE_THRESHOLD 0x112c + +#define S_THROTTLE_THRESHOLD_FL 16 +#define M_THROTTLE_THRESHOLD_FL 0xfU +#define V_THROTTLE_THRESHOLD_FL(x) ((x) << S_THROTTLE_THRESHOLD_FL) +#define G_THROTTLE_THRESHOLD_FL(x) (((x) >> S_THROTTLE_THRESHOLD_FL) & M_THROTTLE_THRESHOLD_FL) + +#define S_THROTTLE_THRESHOLD_HP 12 +#define M_THROTTLE_THRESHOLD_HP 0xfU +#define V_THROTTLE_THRESHOLD_HP(x) ((x) << S_THROTTLE_THRESHOLD_HP) +#define G_THROTTLE_THRESHOLD_HP(x) (((x) >> S_THROTTLE_THRESHOLD_HP) & M_THROTTLE_THRESHOLD_HP) + +#define S_THROTTLE_THRESHOLD_LP 0 +#define M_THROTTLE_THRESHOLD_LP 0xfffU +#define V_THROTTLE_THRESHOLD_LP(x) ((x) << S_THROTTLE_THRESHOLD_LP) +#define G_THROTTLE_THRESHOLD_LP(x) (((x) >> S_THROTTLE_THRESHOLD_LP) & M_THROTTLE_THRESHOLD_LP) + +#define A_SGE_DBP_FETCH_THRESHOLD 0x1130 + +#define S_DBP_FETCH_THRESHOLD_FL 21 +#define M_DBP_FETCH_THRESHOLD_FL 0xfU +#define V_DBP_FETCH_THRESHOLD_FL(x) ((x) << S_DBP_FETCH_THRESHOLD_FL) +#define G_DBP_FETCH_THRESHOLD_FL(x) (((x) >> S_DBP_FETCH_THRESHOLD_FL) & M_DBP_FETCH_THRESHOLD_FL) + +#define S_DBP_FETCH_THRESHOLD_HP 17 +#define M_DBP_FETCH_THRESHOLD_HP 0xfU +#define V_DBP_FETCH_THRESHOLD_HP(x) ((x) << S_DBP_FETCH_THRESHOLD_HP) +#define G_DBP_FETCH_THRESHOLD_HP(x) (((x) >> S_DBP_FETCH_THRESHOLD_HP) & M_DBP_FETCH_THRESHOLD_HP) + +#define S_DBP_FETCH_THRESHOLD_LP 5 +#define M_DBP_FETCH_THRESHOLD_LP 0xfffU +#define V_DBP_FETCH_THRESHOLD_LP(x) ((x) << S_DBP_FETCH_THRESHOLD_LP) +#define G_DBP_FETCH_THRESHOLD_LP(x) (((x) >> S_DBP_FETCH_THRESHOLD_LP) & M_DBP_FETCH_THRESHOLD_LP) + +#define S_DBP_FETCH_THRESHOLD_MODE 4 +#define V_DBP_FETCH_THRESHOLD_MODE(x) ((x) << S_DBP_FETCH_THRESHOLD_MODE) +#define F_DBP_FETCH_THRESHOLD_MODE V_DBP_FETCH_THRESHOLD_MODE(1U) + +#define S_DBP_FETCH_THRESHOLD_EN3 3 +#define V_DBP_FETCH_THRESHOLD_EN3(x) ((x) << S_DBP_FETCH_THRESHOLD_EN3) +#define F_DBP_FETCH_THRESHOLD_EN3 V_DBP_FETCH_THRESHOLD_EN3(1U) + +#define S_DBP_FETCH_THRESHOLD_EN2 2 +#define V_DBP_FETCH_THRESHOLD_EN2(x) ((x) << S_DBP_FETCH_THRESHOLD_EN2) +#define F_DBP_FETCH_THRESHOLD_EN2 V_DBP_FETCH_THRESHOLD_EN2(1U) + +#define S_DBP_FETCH_THRESHOLD_EN1 1 +#define V_DBP_FETCH_THRESHOLD_EN1(x) ((x) << S_DBP_FETCH_THRESHOLD_EN1) +#define F_DBP_FETCH_THRESHOLD_EN1 V_DBP_FETCH_THRESHOLD_EN1(1U) + +#define S_DBP_FETCH_THRESHOLD_EN0 0 +#define V_DBP_FETCH_THRESHOLD_EN0(x) ((x) << S_DBP_FETCH_THRESHOLD_EN0) +#define F_DBP_FETCH_THRESHOLD_EN0 V_DBP_FETCH_THRESHOLD_EN0(1U) + +#define A_SGE_DBP_FETCH_THRESHOLD_QUEUE 0x1134 + +#define S_DBP_FETCH_THRESHOLD_IQ1 16 +#define M_DBP_FETCH_THRESHOLD_IQ1 0xffffU +#define V_DBP_FETCH_THRESHOLD_IQ1(x) ((x) << S_DBP_FETCH_THRESHOLD_IQ1) +#define G_DBP_FETCH_THRESHOLD_IQ1(x) (((x) >> S_DBP_FETCH_THRESHOLD_IQ1) & M_DBP_FETCH_THRESHOLD_IQ1) + +#define S_DBP_FETCH_THRESHOLD_IQ0 0 +#define M_DBP_FETCH_THRESHOLD_IQ0 0xffffU +#define V_DBP_FETCH_THRESHOLD_IQ0(x) ((x) << S_DBP_FETCH_THRESHOLD_IQ0) +#define G_DBP_FETCH_THRESHOLD_IQ0(x) (((x) >> S_DBP_FETCH_THRESHOLD_IQ0) & M_DBP_FETCH_THRESHOLD_IQ0) + +#define A_SGE_DBVFIFO_BADDR 0x1138 +#define A_SGE_DBVFIFO_SIZE 0x113c + +#define S_DBVFIFO_SIZE 6 +#define M_DBVFIFO_SIZE 0xfffU +#define V_DBVFIFO_SIZE(x) ((x) << S_DBVFIFO_SIZE) +#define G_DBVFIFO_SIZE(x) (((x) >> S_DBVFIFO_SIZE) & M_DBVFIFO_SIZE) + +#define A_SGE_DBFIFO_STATUS3 0x1140 + +#define S_LP_PTRS_EQUAL 21 +#define V_LP_PTRS_EQUAL(x) ((x) << S_LP_PTRS_EQUAL) +#define F_LP_PTRS_EQUAL V_LP_PTRS_EQUAL(1U) + +#define S_LP_SNAPHOT 20 +#define V_LP_SNAPHOT(x) ((x) << S_LP_SNAPHOT) +#define F_LP_SNAPHOT V_LP_SNAPHOT(1U) + +#define S_FL_INT_THRESH_LOW 16 +#define M_FL_INT_THRESH_LOW 0xfU +#define V_FL_INT_THRESH_LOW(x) ((x) << S_FL_INT_THRESH_LOW) +#define G_FL_INT_THRESH_LOW(x) (((x) >> S_FL_INT_THRESH_LOW) & M_FL_INT_THRESH_LOW) + +#define S_HP_INT_THRESH_LOW 12 +#define M_HP_INT_THRESH_LOW 0xfU +#define V_HP_INT_THRESH_LOW(x) ((x) << S_HP_INT_THRESH_LOW) +#define G_HP_INT_THRESH_LOW(x) (((x) >> S_HP_INT_THRESH_LOW) & M_HP_INT_THRESH_LOW) + +#define S_LP_INT_THRESH_LOW 0 +#define M_LP_INT_THRESH_LOW 0xfffU +#define V_LP_INT_THRESH_LOW(x) ((x) << S_LP_INT_THRESH_LOW) +#define G_LP_INT_THRESH_LOW(x) (((x) >> S_LP_INT_THRESH_LOW) & M_LP_INT_THRESH_LOW) + +#define A_SGE_CHANGESET 0x1144 +#define A_SGE_PC_RSP_ERROR 0x1148 +#define A_SGE_PC0_REQ_BIST_CMD 0x1180 +#define A_SGE_PC0_REQ_BIST_ERROR_CNT 0x1184 +#define A_SGE_PC1_REQ_BIST_CMD 0x1190 +#define A_SGE_PC1_REQ_BIST_ERROR_CNT 0x1194 +#define A_SGE_PC0_RSP_BIST_CMD 0x11a0 +#define A_SGE_PC0_RSP_BIST_ERROR_CNT 0x11a4 +#define A_SGE_PC1_RSP_BIST_CMD 0x11b0 +#define A_SGE_PC1_RSP_BIST_ERROR_CNT 0x11b4 +#define A_SGE_CTXT_CMD 0x11fc + +#define S_BUSY 31 +#define V_BUSY(x) ((x) << S_BUSY) +#define F_BUSY V_BUSY(1U) + +#define S_CTXTOP 28 +#define M_CTXTOP 0x3U +#define V_CTXTOP(x) ((x) << S_CTXTOP) +#define G_CTXTOP(x) (((x) >> S_CTXTOP) & M_CTXTOP) + +#define S_CTXTTYPE 24 +#define M_CTXTTYPE 0x3U +#define V_CTXTTYPE(x) ((x) << S_CTXTTYPE) +#define G_CTXTTYPE(x) (((x) >> S_CTXTTYPE) & M_CTXTTYPE) + +#define S_CTXTQID 0 +#define M_CTXTQID 0x1ffffU +#define V_CTXTQID(x) ((x) << S_CTXTQID) +#define G_CTXTQID(x) (((x) >> S_CTXTQID) & M_CTXTQID) + +#define A_SGE_CTXT_DATA0 0x1200 +#define A_SGE_CTXT_DATA1 0x1204 +#define A_SGE_CTXT_DATA2 0x1208 +#define A_SGE_CTXT_DATA3 0x120c +#define A_SGE_CTXT_DATA4 0x1210 +#define A_SGE_CTXT_DATA5 0x1214 +#define A_SGE_CTXT_DATA6 0x1218 +#define A_SGE_CTXT_DATA7 0x121c +#define A_SGE_CTXT_MASK0 0x1220 +#define A_SGE_CTXT_MASK1 0x1224 +#define A_SGE_CTXT_MASK2 0x1228 +#define A_SGE_CTXT_MASK3 0x122c +#define A_SGE_CTXT_MASK4 0x1230 +#define A_SGE_CTXT_MASK5 0x1234 +#define A_SGE_CTXT_MASK6 0x1238 +#define A_SGE_CTXT_MASK7 0x123c +#define A_SGE_DEBUG_DATA_HIGH_INDEX_0 0x1280 + +#define S_CIM_WM 24 +#define M_CIM_WM 0x3U +#define V_CIM_WM(x) ((x) << S_CIM_WM) +#define G_CIM_WM(x) (((x) >> S_CIM_WM) & M_CIM_WM) + +#define S_DEBUG_UP_SOP_CNT 20 +#define M_DEBUG_UP_SOP_CNT 0xfU +#define V_DEBUG_UP_SOP_CNT(x) ((x) << S_DEBUG_UP_SOP_CNT) +#define G_DEBUG_UP_SOP_CNT(x) (((x) >> S_DEBUG_UP_SOP_CNT) & M_DEBUG_UP_SOP_CNT) + +#define S_DEBUG_UP_EOP_CNT 16 +#define M_DEBUG_UP_EOP_CNT 0xfU +#define V_DEBUG_UP_EOP_CNT(x) ((x) << S_DEBUG_UP_EOP_CNT) +#define G_DEBUG_UP_EOP_CNT(x) (((x) >> S_DEBUG_UP_EOP_CNT) & M_DEBUG_UP_EOP_CNT) + +#define S_DEBUG_CIM_SOP1_CNT 12 +#define M_DEBUG_CIM_SOP1_CNT 0xfU +#define V_DEBUG_CIM_SOP1_CNT(x) ((x) << S_DEBUG_CIM_SOP1_CNT) +#define G_DEBUG_CIM_SOP1_CNT(x) (((x) >> S_DEBUG_CIM_SOP1_CNT) & M_DEBUG_CIM_SOP1_CNT) + +#define S_DEBUG_CIM_EOP1_CNT 8 +#define M_DEBUG_CIM_EOP1_CNT 0xfU +#define V_DEBUG_CIM_EOP1_CNT(x) ((x) << S_DEBUG_CIM_EOP1_CNT) +#define G_DEBUG_CIM_EOP1_CNT(x) (((x) >> S_DEBUG_CIM_EOP1_CNT) & M_DEBUG_CIM_EOP1_CNT) + +#define S_DEBUG_CIM_SOP0_CNT 4 +#define M_DEBUG_CIM_SOP0_CNT 0xfU +#define V_DEBUG_CIM_SOP0_CNT(x) ((x) << S_DEBUG_CIM_SOP0_CNT) +#define G_DEBUG_CIM_SOP0_CNT(x) (((x) >> S_DEBUG_CIM_SOP0_CNT) & M_DEBUG_CIM_SOP0_CNT) + +#define S_DEBUG_CIM_EOP0_CNT 0 +#define M_DEBUG_CIM_EOP0_CNT 0xfU +#define V_DEBUG_CIM_EOP0_CNT(x) ((x) << S_DEBUG_CIM_EOP0_CNT) +#define G_DEBUG_CIM_EOP0_CNT(x) (((x) >> S_DEBUG_CIM_EOP0_CNT) & M_DEBUG_CIM_EOP0_CNT) + +#define A_SGE_DEBUG_DATA_HIGH_INDEX_1 0x1284 + +#define S_DEBUG_T_RX_SOP1_CNT 28 +#define M_DEBUG_T_RX_SOP1_CNT 0xfU +#define V_DEBUG_T_RX_SOP1_CNT(x) ((x) << S_DEBUG_T_RX_SOP1_CNT) +#define G_DEBUG_T_RX_SOP1_CNT(x) (((x) >> S_DEBUG_T_RX_SOP1_CNT) & M_DEBUG_T_RX_SOP1_CNT) + +#define S_DEBUG_T_RX_EOP1_CNT 24 +#define M_DEBUG_T_RX_EOP1_CNT 0xfU +#define V_DEBUG_T_RX_EOP1_CNT(x) ((x) << S_DEBUG_T_RX_EOP1_CNT) +#define G_DEBUG_T_RX_EOP1_CNT(x) (((x) >> S_DEBUG_T_RX_EOP1_CNT) & M_DEBUG_T_RX_EOP1_CNT) + +#define S_DEBUG_T_RX_SOP0_CNT 20 +#define M_DEBUG_T_RX_SOP0_CNT 0xfU +#define V_DEBUG_T_RX_SOP0_CNT(x) ((x) << S_DEBUG_T_RX_SOP0_CNT) +#define G_DEBUG_T_RX_SOP0_CNT(x) (((x) >> S_DEBUG_T_RX_SOP0_CNT) & M_DEBUG_T_RX_SOP0_CNT) + +#define S_DEBUG_T_RX_EOP0_CNT 16 +#define M_DEBUG_T_RX_EOP0_CNT 0xfU +#define V_DEBUG_T_RX_EOP0_CNT(x) ((x) << S_DEBUG_T_RX_EOP0_CNT) +#define G_DEBUG_T_RX_EOP0_CNT(x) (((x) >> S_DEBUG_T_RX_EOP0_CNT) & M_DEBUG_T_RX_EOP0_CNT) + +#define S_DEBUG_U_RX_SOP1_CNT 12 +#define M_DEBUG_U_RX_SOP1_CNT 0xfU +#define V_DEBUG_U_RX_SOP1_CNT(x) ((x) << S_DEBUG_U_RX_SOP1_CNT) +#define G_DEBUG_U_RX_SOP1_CNT(x) (((x) >> S_DEBUG_U_RX_SOP1_CNT) & M_DEBUG_U_RX_SOP1_CNT) + +#define S_DEBUG_U_RX_EOP1_CNT 8 +#define M_DEBUG_U_RX_EOP1_CNT 0xfU +#define V_DEBUG_U_RX_EOP1_CNT(x) ((x) << S_DEBUG_U_RX_EOP1_CNT) +#define G_DEBUG_U_RX_EOP1_CNT(x) (((x) >> S_DEBUG_U_RX_EOP1_CNT) & M_DEBUG_U_RX_EOP1_CNT) + +#define S_DEBUG_U_RX_SOP0_CNT 4 +#define M_DEBUG_U_RX_SOP0_CNT 0xfU +#define V_DEBUG_U_RX_SOP0_CNT(x) ((x) << S_DEBUG_U_RX_SOP0_CNT) +#define G_DEBUG_U_RX_SOP0_CNT(x) (((x) >> S_DEBUG_U_RX_SOP0_CNT) & M_DEBUG_U_RX_SOP0_CNT) + +#define S_DEBUG_U_RX_EOP0_CNT 0 +#define M_DEBUG_U_RX_EOP0_CNT 0xfU +#define V_DEBUG_U_RX_EOP0_CNT(x) ((x) << S_DEBUG_U_RX_EOP0_CNT) +#define G_DEBUG_U_RX_EOP0_CNT(x) (((x) >> S_DEBUG_U_RX_EOP0_CNT) & M_DEBUG_U_RX_EOP0_CNT) + +#define A_SGE_DEBUG_DATA_HIGH_INDEX_2 0x1288 + +#define S_DEBUG_UD_RX_SOP3_CNT 28 +#define M_DEBUG_UD_RX_SOP3_CNT 0xfU +#define V_DEBUG_UD_RX_SOP3_CNT(x) ((x) << S_DEBUG_UD_RX_SOP3_CNT) +#define G_DEBUG_UD_RX_SOP3_CNT(x) (((x) >> S_DEBUG_UD_RX_SOP3_CNT) & M_DEBUG_UD_RX_SOP3_CNT) + +#define S_DEBUG_UD_RX_EOP3_CNT 24 +#define M_DEBUG_UD_RX_EOP3_CNT 0xfU +#define V_DEBUG_UD_RX_EOP3_CNT(x) ((x) << S_DEBUG_UD_RX_EOP3_CNT) +#define G_DEBUG_UD_RX_EOP3_CNT(x) (((x) >> S_DEBUG_UD_RX_EOP3_CNT) & M_DEBUG_UD_RX_EOP3_CNT) + +#define S_DEBUG_UD_RX_SOP2_CNT 20 +#define M_DEBUG_UD_RX_SOP2_CNT 0xfU +#define V_DEBUG_UD_RX_SOP2_CNT(x) ((x) << S_DEBUG_UD_RX_SOP2_CNT) +#define G_DEBUG_UD_RX_SOP2_CNT(x) (((x) >> S_DEBUG_UD_RX_SOP2_CNT) & M_DEBUG_UD_RX_SOP2_CNT) + +#define S_DEBUG_UD_RX_EOP2_CNT 16 +#define M_DEBUG_UD_RX_EOP2_CNT 0xfU +#define V_DEBUG_UD_RX_EOP2_CNT(x) ((x) << S_DEBUG_UD_RX_EOP2_CNT) +#define G_DEBUG_UD_RX_EOP2_CNT(x) (((x) >> S_DEBUG_UD_RX_EOP2_CNT) & M_DEBUG_UD_RX_EOP2_CNT) + +#define S_DEBUG_UD_RX_SOP1_CNT 12 +#define M_DEBUG_UD_RX_SOP1_CNT 0xfU +#define V_DEBUG_UD_RX_SOP1_CNT(x) ((x) << S_DEBUG_UD_RX_SOP1_CNT) +#define G_DEBUG_UD_RX_SOP1_CNT(x) (((x) >> S_DEBUG_UD_RX_SOP1_CNT) & M_DEBUG_UD_RX_SOP1_CNT) + +#define S_DEBUG_UD_RX_EOP1_CNT 8 +#define M_DEBUG_UD_RX_EOP1_CNT 0xfU +#define V_DEBUG_UD_RX_EOP1_CNT(x) ((x) << S_DEBUG_UD_RX_EOP1_CNT) +#define G_DEBUG_UD_RX_EOP1_CNT(x) (((x) >> S_DEBUG_UD_RX_EOP1_CNT) & M_DEBUG_UD_RX_EOP1_CNT) + +#define S_DEBUG_UD_RX_SOP0_CNT 4 +#define M_DEBUG_UD_RX_SOP0_CNT 0xfU +#define V_DEBUG_UD_RX_SOP0_CNT(x) ((x) << S_DEBUG_UD_RX_SOP0_CNT) +#define G_DEBUG_UD_RX_SOP0_CNT(x) (((x) >> S_DEBUG_UD_RX_SOP0_CNT) & M_DEBUG_UD_RX_SOP0_CNT) + +#define S_DEBUG_UD_RX_EOP0_CNT 0 +#define M_DEBUG_UD_RX_EOP0_CNT 0xfU +#define V_DEBUG_UD_RX_EOP0_CNT(x) ((x) << S_DEBUG_UD_RX_EOP0_CNT) +#define G_DEBUG_UD_RX_EOP0_CNT(x) (((x) >> S_DEBUG_UD_RX_EOP0_CNT) & M_DEBUG_UD_RX_EOP0_CNT) + +#define A_SGE_DEBUG_DATA_HIGH_INDEX_3 0x128c + +#define S_DEBUG_U_TX_SOP3_CNT 28 +#define M_DEBUG_U_TX_SOP3_CNT 0xfU +#define V_DEBUG_U_TX_SOP3_CNT(x) ((x) << S_DEBUG_U_TX_SOP3_CNT) +#define G_DEBUG_U_TX_SOP3_CNT(x) (((x) >> S_DEBUG_U_TX_SOP3_CNT) & M_DEBUG_U_TX_SOP3_CNT) + +#define S_DEBUG_U_TX_EOP3_CNT 24 +#define M_DEBUG_U_TX_EOP3_CNT 0xfU +#define V_DEBUG_U_TX_EOP3_CNT(x) ((x) << S_DEBUG_U_TX_EOP3_CNT) +#define G_DEBUG_U_TX_EOP3_CNT(x) (((x) >> S_DEBUG_U_TX_EOP3_CNT) & M_DEBUG_U_TX_EOP3_CNT) + +#define S_DEBUG_U_TX_SOP2_CNT 20 +#define M_DEBUG_U_TX_SOP2_CNT 0xfU +#define V_DEBUG_U_TX_SOP2_CNT(x) ((x) << S_DEBUG_U_TX_SOP2_CNT) +#define G_DEBUG_U_TX_SOP2_CNT(x) (((x) >> S_DEBUG_U_TX_SOP2_CNT) & M_DEBUG_U_TX_SOP2_CNT) + +#define S_DEBUG_U_TX_EOP2_CNT 16 +#define M_DEBUG_U_TX_EOP2_CNT 0xfU +#define V_DEBUG_U_TX_EOP2_CNT(x) ((x) << S_DEBUG_U_TX_EOP2_CNT) +#define G_DEBUG_U_TX_EOP2_CNT(x) (((x) >> S_DEBUG_U_TX_EOP2_CNT) & M_DEBUG_U_TX_EOP2_CNT) + +#define S_DEBUG_U_TX_SOP1_CNT 12 +#define M_DEBUG_U_TX_SOP1_CNT 0xfU +#define V_DEBUG_U_TX_SOP1_CNT(x) ((x) << S_DEBUG_U_TX_SOP1_CNT) +#define G_DEBUG_U_TX_SOP1_CNT(x) (((x) >> S_DEBUG_U_TX_SOP1_CNT) & M_DEBUG_U_TX_SOP1_CNT) + +#define S_DEBUG_U_TX_EOP1_CNT 8 +#define M_DEBUG_U_TX_EOP1_CNT 0xfU +#define V_DEBUG_U_TX_EOP1_CNT(x) ((x) << S_DEBUG_U_TX_EOP1_CNT) +#define G_DEBUG_U_TX_EOP1_CNT(x) (((x) >> S_DEBUG_U_TX_EOP1_CNT) & M_DEBUG_U_TX_EOP1_CNT) + +#define S_DEBUG_U_TX_SOP0_CNT 4 +#define M_DEBUG_U_TX_SOP0_CNT 0xfU +#define V_DEBUG_U_TX_SOP0_CNT(x) ((x) << S_DEBUG_U_TX_SOP0_CNT) +#define G_DEBUG_U_TX_SOP0_CNT(x) (((x) >> S_DEBUG_U_TX_SOP0_CNT) & M_DEBUG_U_TX_SOP0_CNT) + +#define S_DEBUG_U_TX_EOP0_CNT 0 +#define M_DEBUG_U_TX_EOP0_CNT 0xfU +#define V_DEBUG_U_TX_EOP0_CNT(x) ((x) << S_DEBUG_U_TX_EOP0_CNT) +#define G_DEBUG_U_TX_EOP0_CNT(x) (((x) >> S_DEBUG_U_TX_EOP0_CNT) & M_DEBUG_U_TX_EOP0_CNT) + +#define A_SGE_DEBUG_DATA_HIGH_INDEX_4 0x1290 + +#define S_DEBUG_PC_RSP_SOP1_CNT 28 +#define M_DEBUG_PC_RSP_SOP1_CNT 0xfU +#define V_DEBUG_PC_RSP_SOP1_CNT(x) ((x) << S_DEBUG_PC_RSP_SOP1_CNT) +#define G_DEBUG_PC_RSP_SOP1_CNT(x) (((x) >> S_DEBUG_PC_RSP_SOP1_CNT) & M_DEBUG_PC_RSP_SOP1_CNT) + +#define S_DEBUG_PC_RSP_EOP1_CNT 24 +#define M_DEBUG_PC_RSP_EOP1_CNT 0xfU +#define V_DEBUG_PC_RSP_EOP1_CNT(x) ((x) << S_DEBUG_PC_RSP_EOP1_CNT) +#define G_DEBUG_PC_RSP_EOP1_CNT(x) (((x) >> S_DEBUG_PC_RSP_EOP1_CNT) & M_DEBUG_PC_RSP_EOP1_CNT) + +#define S_DEBUG_PC_RSP_SOP0_CNT 20 +#define M_DEBUG_PC_RSP_SOP0_CNT 0xfU +#define V_DEBUG_PC_RSP_SOP0_CNT(x) ((x) << S_DEBUG_PC_RSP_SOP0_CNT) +#define G_DEBUG_PC_RSP_SOP0_CNT(x) (((x) >> S_DEBUG_PC_RSP_SOP0_CNT) & M_DEBUG_PC_RSP_SOP0_CNT) + +#define S_DEBUG_PC_RSP_EOP0_CNT 16 +#define M_DEBUG_PC_RSP_EOP0_CNT 0xfU +#define V_DEBUG_PC_RSP_EOP0_CNT(x) ((x) << S_DEBUG_PC_RSP_EOP0_CNT) +#define G_DEBUG_PC_RSP_EOP0_CNT(x) (((x) >> S_DEBUG_PC_RSP_EOP0_CNT) & M_DEBUG_PC_RSP_EOP0_CNT) + +#define S_DEBUG_PC_REQ_SOP1_CNT 12 +#define M_DEBUG_PC_REQ_SOP1_CNT 0xfU +#define V_DEBUG_PC_REQ_SOP1_CNT(x) ((x) << S_DEBUG_PC_REQ_SOP1_CNT) +#define G_DEBUG_PC_REQ_SOP1_CNT(x) (((x) >> S_DEBUG_PC_REQ_SOP1_CNT) & M_DEBUG_PC_REQ_SOP1_CNT) + +#define S_DEBUG_PC_REQ_EOP1_CNT 8 +#define M_DEBUG_PC_REQ_EOP1_CNT 0xfU +#define V_DEBUG_PC_REQ_EOP1_CNT(x) ((x) << S_DEBUG_PC_REQ_EOP1_CNT) +#define G_DEBUG_PC_REQ_EOP1_CNT(x) (((x) >> S_DEBUG_PC_REQ_EOP1_CNT) & M_DEBUG_PC_REQ_EOP1_CNT) + +#define S_DEBUG_PC_REQ_SOP0_CNT 4 +#define M_DEBUG_PC_REQ_SOP0_CNT 0xfU +#define V_DEBUG_PC_REQ_SOP0_CNT(x) ((x) << S_DEBUG_PC_REQ_SOP0_CNT) +#define G_DEBUG_PC_REQ_SOP0_CNT(x) (((x) >> S_DEBUG_PC_REQ_SOP0_CNT) & M_DEBUG_PC_REQ_SOP0_CNT) + +#define S_DEBUG_PC_REQ_EOP0_CNT 0 +#define M_DEBUG_PC_REQ_EOP0_CNT 0xfU +#define V_DEBUG_PC_REQ_EOP0_CNT(x) ((x) << S_DEBUG_PC_REQ_EOP0_CNT) +#define G_DEBUG_PC_REQ_EOP0_CNT(x) (((x) >> S_DEBUG_PC_REQ_EOP0_CNT) & M_DEBUG_PC_REQ_EOP0_CNT) + +#define A_SGE_DEBUG_DATA_HIGH_INDEX_5 0x1294 + +#define S_DEBUG_PD_RDREQ_SOP3_CNT 28 +#define M_DEBUG_PD_RDREQ_SOP3_CNT 0xfU +#define V_DEBUG_PD_RDREQ_SOP3_CNT(x) ((x) << S_DEBUG_PD_RDREQ_SOP3_CNT) +#define G_DEBUG_PD_RDREQ_SOP3_CNT(x) (((x) >> S_DEBUG_PD_RDREQ_SOP3_CNT) & M_DEBUG_PD_RDREQ_SOP3_CNT) + +#define S_DEBUG_PD_RDREQ_EOP3_CNT 24 +#define M_DEBUG_PD_RDREQ_EOP3_CNT 0xfU +#define V_DEBUG_PD_RDREQ_EOP3_CNT(x) ((x) << S_DEBUG_PD_RDREQ_EOP3_CNT) +#define G_DEBUG_PD_RDREQ_EOP3_CNT(x) (((x) >> S_DEBUG_PD_RDREQ_EOP3_CNT) & M_DEBUG_PD_RDREQ_EOP3_CNT) + +#define S_DEBUG_PD_RDREQ_SOP2_CNT 20 +#define M_DEBUG_PD_RDREQ_SOP2_CNT 0xfU +#define V_DEBUG_PD_RDREQ_SOP2_CNT(x) ((x) << S_DEBUG_PD_RDREQ_SOP2_CNT) +#define G_DEBUG_PD_RDREQ_SOP2_CNT(x) (((x) >> S_DEBUG_PD_RDREQ_SOP2_CNT) & M_DEBUG_PD_RDREQ_SOP2_CNT) + +#define S_DEBUG_PD_RDREQ_EOP2_CNT 16 +#define M_DEBUG_PD_RDREQ_EOP2_CNT 0xfU +#define V_DEBUG_PD_RDREQ_EOP2_CNT(x) ((x) << S_DEBUG_PD_RDREQ_EOP2_CNT) +#define G_DEBUG_PD_RDREQ_EOP2_CNT(x) (((x) >> S_DEBUG_PD_RDREQ_EOP2_CNT) & M_DEBUG_PD_RDREQ_EOP2_CNT) + +#define S_DEBUG_PD_RDREQ_SOP1_CNT 12 +#define M_DEBUG_PD_RDREQ_SOP1_CNT 0xfU +#define V_DEBUG_PD_RDREQ_SOP1_CNT(x) ((x) << S_DEBUG_PD_RDREQ_SOP1_CNT) +#define G_DEBUG_PD_RDREQ_SOP1_CNT(x) (((x) >> S_DEBUG_PD_RDREQ_SOP1_CNT) & M_DEBUG_PD_RDREQ_SOP1_CNT) + +#define S_DEBUG_PD_RDREQ_EOP1_CNT 8 +#define M_DEBUG_PD_RDREQ_EOP1_CNT 0xfU +#define V_DEBUG_PD_RDREQ_EOP1_CNT(x) ((x) << S_DEBUG_PD_RDREQ_EOP1_CNT) +#define G_DEBUG_PD_RDREQ_EOP1_CNT(x) (((x) >> S_DEBUG_PD_RDREQ_EOP1_CNT) & M_DEBUG_PD_RDREQ_EOP1_CNT) + +#define S_DEBUG_PD_RDREQ_SOP0_CNT 4 +#define M_DEBUG_PD_RDREQ_SOP0_CNT 0xfU +#define V_DEBUG_PD_RDREQ_SOP0_CNT(x) ((x) << S_DEBUG_PD_RDREQ_SOP0_CNT) +#define G_DEBUG_PD_RDREQ_SOP0_CNT(x) (((x) >> S_DEBUG_PD_RDREQ_SOP0_CNT) & M_DEBUG_PD_RDREQ_SOP0_CNT) + +#define S_DEBUG_PD_RDREQ_EOP0_CNT 0 +#define M_DEBUG_PD_RDREQ_EOP0_CNT 0xfU +#define V_DEBUG_PD_RDREQ_EOP0_CNT(x) ((x) << S_DEBUG_PD_RDREQ_EOP0_CNT) +#define G_DEBUG_PD_RDREQ_EOP0_CNT(x) (((x) >> S_DEBUG_PD_RDREQ_EOP0_CNT) & M_DEBUG_PD_RDREQ_EOP0_CNT) + +#define A_SGE_DEBUG_DATA_HIGH_INDEX_6 0x1298 + +#define S_DEBUG_PD_RDRSP_SOP3_CNT 28 +#define M_DEBUG_PD_RDRSP_SOP3_CNT 0xfU +#define V_DEBUG_PD_RDRSP_SOP3_CNT(x) ((x) << S_DEBUG_PD_RDRSP_SOP3_CNT) +#define G_DEBUG_PD_RDRSP_SOP3_CNT(x) (((x) >> S_DEBUG_PD_RDRSP_SOP3_CNT) & M_DEBUG_PD_RDRSP_SOP3_CNT) + +#define S_DEBUG_PD_RDRSP_EOP3_CNT 24 +#define M_DEBUG_PD_RDRSP_EOP3_CNT 0xfU +#define V_DEBUG_PD_RDRSP_EOP3_CNT(x) ((x) << S_DEBUG_PD_RDRSP_EOP3_CNT) +#define G_DEBUG_PD_RDRSP_EOP3_CNT(x) (((x) >> S_DEBUG_PD_RDRSP_EOP3_CNT) & M_DEBUG_PD_RDRSP_EOP3_CNT) + +#define S_DEBUG_PD_RDRSP_SOP2_CNT 20 +#define M_DEBUG_PD_RDRSP_SOP2_CNT 0xfU +#define V_DEBUG_PD_RDRSP_SOP2_CNT(x) ((x) << S_DEBUG_PD_RDRSP_SOP2_CNT) +#define G_DEBUG_PD_RDRSP_SOP2_CNT(x) (((x) >> S_DEBUG_PD_RDRSP_SOP2_CNT) & M_DEBUG_PD_RDRSP_SOP2_CNT) + +#define S_DEBUG_PD_RDRSP_EOP2_CNT 16 +#define M_DEBUG_PD_RDRSP_EOP2_CNT 0xfU +#define V_DEBUG_PD_RDRSP_EOP2_CNT(x) ((x) << S_DEBUG_PD_RDRSP_EOP2_CNT) +#define G_DEBUG_PD_RDRSP_EOP2_CNT(x) (((x) >> S_DEBUG_PD_RDRSP_EOP2_CNT) & M_DEBUG_PD_RDRSP_EOP2_CNT) + +#define S_DEBUG_PD_RDRSP_SOP1_CNT 12 +#define M_DEBUG_PD_RDRSP_SOP1_CNT 0xfU +#define V_DEBUG_PD_RDRSP_SOP1_CNT(x) ((x) << S_DEBUG_PD_RDRSP_SOP1_CNT) +#define G_DEBUG_PD_RDRSP_SOP1_CNT(x) (((x) >> S_DEBUG_PD_RDRSP_SOP1_CNT) & M_DEBUG_PD_RDRSP_SOP1_CNT) + +#define S_DEBUG_PD_RDRSP_EOP1_CNT 8 +#define M_DEBUG_PD_RDRSP_EOP1_CNT 0xfU +#define V_DEBUG_PD_RDRSP_EOP1_CNT(x) ((x) << S_DEBUG_PD_RDRSP_EOP1_CNT) +#define G_DEBUG_PD_RDRSP_EOP1_CNT(x) (((x) >> S_DEBUG_PD_RDRSP_EOP1_CNT) & M_DEBUG_PD_RDRSP_EOP1_CNT) + +#define S_DEBUG_PD_RDRSP_SOP0_CNT 4 +#define M_DEBUG_PD_RDRSP_SOP0_CNT 0xfU +#define V_DEBUG_PD_RDRSP_SOP0_CNT(x) ((x) << S_DEBUG_PD_RDRSP_SOP0_CNT) +#define G_DEBUG_PD_RDRSP_SOP0_CNT(x) (((x) >> S_DEBUG_PD_RDRSP_SOP0_CNT) & M_DEBUG_PD_RDRSP_SOP0_CNT) + +#define S_DEBUG_PD_RDRSP_EOP0_CNT 0 +#define M_DEBUG_PD_RDRSP_EOP0_CNT 0xfU +#define V_DEBUG_PD_RDRSP_EOP0_CNT(x) ((x) << S_DEBUG_PD_RDRSP_EOP0_CNT) +#define G_DEBUG_PD_RDRSP_EOP0_CNT(x) (((x) >> S_DEBUG_PD_RDRSP_EOP0_CNT) & M_DEBUG_PD_RDRSP_EOP0_CNT) + +#define A_SGE_DEBUG_DATA_HIGH_INDEX_7 0x129c + +#define S_DEBUG_PD_WRREQ_SOP3_CNT 28 +#define M_DEBUG_PD_WRREQ_SOP3_CNT 0xfU +#define V_DEBUG_PD_WRREQ_SOP3_CNT(x) ((x) << S_DEBUG_PD_WRREQ_SOP3_CNT) +#define G_DEBUG_PD_WRREQ_SOP3_CNT(x) (((x) >> S_DEBUG_PD_WRREQ_SOP3_CNT) & M_DEBUG_PD_WRREQ_SOP3_CNT) + +#define S_DEBUG_PD_WRREQ_EOP3_CNT 24 +#define M_DEBUG_PD_WRREQ_EOP3_CNT 0xfU +#define V_DEBUG_PD_WRREQ_EOP3_CNT(x) ((x) << S_DEBUG_PD_WRREQ_EOP3_CNT) +#define G_DEBUG_PD_WRREQ_EOP3_CNT(x) (((x) >> S_DEBUG_PD_WRREQ_EOP3_CNT) & M_DEBUG_PD_WRREQ_EOP3_CNT) + +#define S_DEBUG_PD_WRREQ_SOP2_CNT 20 +#define M_DEBUG_PD_WRREQ_SOP2_CNT 0xfU +#define V_DEBUG_PD_WRREQ_SOP2_CNT(x) ((x) << S_DEBUG_PD_WRREQ_SOP2_CNT) +#define G_DEBUG_PD_WRREQ_SOP2_CNT(x) (((x) >> S_DEBUG_PD_WRREQ_SOP2_CNT) & M_DEBUG_PD_WRREQ_SOP2_CNT) + +#define S_DEBUG_PD_WRREQ_EOP2_CNT 16 +#define M_DEBUG_PD_WRREQ_EOP2_CNT 0xfU +#define V_DEBUG_PD_WRREQ_EOP2_CNT(x) ((x) << S_DEBUG_PD_WRREQ_EOP2_CNT) +#define G_DEBUG_PD_WRREQ_EOP2_CNT(x) (((x) >> S_DEBUG_PD_WRREQ_EOP2_CNT) & M_DEBUG_PD_WRREQ_EOP2_CNT) + +#define S_DEBUG_PD_WRREQ_SOP1_CNT 12 +#define M_DEBUG_PD_WRREQ_SOP1_CNT 0xfU +#define V_DEBUG_PD_WRREQ_SOP1_CNT(x) ((x) << S_DEBUG_PD_WRREQ_SOP1_CNT) +#define G_DEBUG_PD_WRREQ_SOP1_CNT(x) (((x) >> S_DEBUG_PD_WRREQ_SOP1_CNT) & M_DEBUG_PD_WRREQ_SOP1_CNT) + +#define S_DEBUG_PD_WRREQ_EOP1_CNT 8 +#define M_DEBUG_PD_WRREQ_EOP1_CNT 0xfU +#define V_DEBUG_PD_WRREQ_EOP1_CNT(x) ((x) << S_DEBUG_PD_WRREQ_EOP1_CNT) +#define G_DEBUG_PD_WRREQ_EOP1_CNT(x) (((x) >> S_DEBUG_PD_WRREQ_EOP1_CNT) & M_DEBUG_PD_WRREQ_EOP1_CNT) + +#define S_DEBUG_PD_WRREQ_SOP0_CNT 4 +#define M_DEBUG_PD_WRREQ_SOP0_CNT 0xfU +#define V_DEBUG_PD_WRREQ_SOP0_CNT(x) ((x) << S_DEBUG_PD_WRREQ_SOP0_CNT) +#define G_DEBUG_PD_WRREQ_SOP0_CNT(x) (((x) >> S_DEBUG_PD_WRREQ_SOP0_CNT) & M_DEBUG_PD_WRREQ_SOP0_CNT) + +#define S_DEBUG_PD_WRREQ_EOP0_CNT 0 +#define M_DEBUG_PD_WRREQ_EOP0_CNT 0xfU +#define V_DEBUG_PD_WRREQ_EOP0_CNT(x) ((x) << S_DEBUG_PD_WRREQ_EOP0_CNT) +#define G_DEBUG_PD_WRREQ_EOP0_CNT(x) (((x) >> S_DEBUG_PD_WRREQ_EOP0_CNT) & M_DEBUG_PD_WRREQ_EOP0_CNT) + +#define A_SGE_DEBUG_DATA_HIGH_INDEX_8 0x12a0 + +#define S_GLOBALENABLE_OFF 29 +#define V_GLOBALENABLE_OFF(x) ((x) << S_GLOBALENABLE_OFF) +#define F_GLOBALENABLE_OFF V_GLOBALENABLE_OFF(1U) + +#define S_DEBUG_CIM2SGE_RXAFULL_D 27 +#define M_DEBUG_CIM2SGE_RXAFULL_D 0x3U +#define V_DEBUG_CIM2SGE_RXAFULL_D(x) ((x) << S_DEBUG_CIM2SGE_RXAFULL_D) +#define G_DEBUG_CIM2SGE_RXAFULL_D(x) (((x) >> S_DEBUG_CIM2SGE_RXAFULL_D) & M_DEBUG_CIM2SGE_RXAFULL_D) + +#define S_DEBUG_CPLSW_CIM_TXAFULL_D 25 +#define M_DEBUG_CPLSW_CIM_TXAFULL_D 0x3U +#define V_DEBUG_CPLSW_CIM_TXAFULL_D(x) ((x) << S_DEBUG_CPLSW_CIM_TXAFULL_D) +#define G_DEBUG_CPLSW_CIM_TXAFULL_D(x) (((x) >> S_DEBUG_CPLSW_CIM_TXAFULL_D) & M_DEBUG_CPLSW_CIM_TXAFULL_D) + +#define S_DEBUG_UP_FULL 24 +#define V_DEBUG_UP_FULL(x) ((x) << S_DEBUG_UP_FULL) +#define F_DEBUG_UP_FULL V_DEBUG_UP_FULL(1U) + +#define S_DEBUG_M_RD_REQ_OUTSTANDING_PC 23 +#define V_DEBUG_M_RD_REQ_OUTSTANDING_PC(x) ((x) << S_DEBUG_M_RD_REQ_OUTSTANDING_PC) +#define F_DEBUG_M_RD_REQ_OUTSTANDING_PC V_DEBUG_M_RD_REQ_OUTSTANDING_PC(1U) + +#define S_DEBUG_M_RD_REQ_OUTSTANDING_VFIFO 22 +#define V_DEBUG_M_RD_REQ_OUTSTANDING_VFIFO(x) ((x) << S_DEBUG_M_RD_REQ_OUTSTANDING_VFIFO) +#define F_DEBUG_M_RD_REQ_OUTSTANDING_VFIFO V_DEBUG_M_RD_REQ_OUTSTANDING_VFIFO(1U) + +#define S_DEBUG_M_RD_REQ_OUTSTANDING_IMSG 21 +#define V_DEBUG_M_RD_REQ_OUTSTANDING_IMSG(x) ((x) << S_DEBUG_M_RD_REQ_OUTSTANDING_IMSG) +#define F_DEBUG_M_RD_REQ_OUTSTANDING_IMSG V_DEBUG_M_RD_REQ_OUTSTANDING_IMSG(1U) + +#define S_DEBUG_M_RD_REQ_OUTSTANDING_CMARB 20 +#define V_DEBUG_M_RD_REQ_OUTSTANDING_CMARB(x) ((x) << S_DEBUG_M_RD_REQ_OUTSTANDING_CMARB) +#define F_DEBUG_M_RD_REQ_OUTSTANDING_CMARB V_DEBUG_M_RD_REQ_OUTSTANDING_CMARB(1U) + +#define S_DEBUG_M_RD_REQ_OUTSTANDING_FLM 19 +#define V_DEBUG_M_RD_REQ_OUTSTANDING_FLM(x) ((x) << S_DEBUG_M_RD_REQ_OUTSTANDING_FLM) +#define F_DEBUG_M_RD_REQ_OUTSTANDING_FLM V_DEBUG_M_RD_REQ_OUTSTANDING_FLM(1U) + +#define S_DEBUG_M_REQVLD 18 +#define V_DEBUG_M_REQVLD(x) ((x) << S_DEBUG_M_REQVLD) +#define F_DEBUG_M_REQVLD V_DEBUG_M_REQVLD(1U) + +#define S_DEBUG_M_REQRDY 17 +#define V_DEBUG_M_REQRDY(x) ((x) << S_DEBUG_M_REQRDY) +#define F_DEBUG_M_REQRDY V_DEBUG_M_REQRDY(1U) + +#define S_DEBUG_M_RSPVLD 16 +#define V_DEBUG_M_RSPVLD(x) ((x) << S_DEBUG_M_RSPVLD) +#define F_DEBUG_M_RSPVLD V_DEBUG_M_RSPVLD(1U) + +#define S_DEBUG_PD_WRREQ_INT3_CNT 12 +#define M_DEBUG_PD_WRREQ_INT3_CNT 0xfU +#define V_DEBUG_PD_WRREQ_INT3_CNT(x) ((x) << S_DEBUG_PD_WRREQ_INT3_CNT) +#define G_DEBUG_PD_WRREQ_INT3_CNT(x) (((x) >> S_DEBUG_PD_WRREQ_INT3_CNT) & M_DEBUG_PD_WRREQ_INT3_CNT) + +#define S_DEBUG_PD_WRREQ_INT2_CNT 8 +#define M_DEBUG_PD_WRREQ_INT2_CNT 0xfU +#define V_DEBUG_PD_WRREQ_INT2_CNT(x) ((x) << S_DEBUG_PD_WRREQ_INT2_CNT) +#define G_DEBUG_PD_WRREQ_INT2_CNT(x) (((x) >> S_DEBUG_PD_WRREQ_INT2_CNT) & M_DEBUG_PD_WRREQ_INT2_CNT) + +#define S_DEBUG_PD_WRREQ_INT1_CNT 4 +#define M_DEBUG_PD_WRREQ_INT1_CNT 0xfU +#define V_DEBUG_PD_WRREQ_INT1_CNT(x) ((x) << S_DEBUG_PD_WRREQ_INT1_CNT) +#define G_DEBUG_PD_WRREQ_INT1_CNT(x) (((x) >> S_DEBUG_PD_WRREQ_INT1_CNT) & M_DEBUG_PD_WRREQ_INT1_CNT) + +#define S_DEBUG_PD_WRREQ_INT0_CNT 0 +#define M_DEBUG_PD_WRREQ_INT0_CNT 0xfU +#define V_DEBUG_PD_WRREQ_INT0_CNT(x) ((x) << S_DEBUG_PD_WRREQ_INT0_CNT) +#define G_DEBUG_PD_WRREQ_INT0_CNT(x) (((x) >> S_DEBUG_PD_WRREQ_INT0_CNT) & M_DEBUG_PD_WRREQ_INT0_CNT) + +#define A_SGE_DEBUG_DATA_HIGH_INDEX_9 0x12a4 + +#define S_DEBUG_CPLSW_TP_RX_SOP1_CNT 28 +#define M_DEBUG_CPLSW_TP_RX_SOP1_CNT 0xfU +#define V_DEBUG_CPLSW_TP_RX_SOP1_CNT(x) ((x) << S_DEBUG_CPLSW_TP_RX_SOP1_CNT) +#define G_DEBUG_CPLSW_TP_RX_SOP1_CNT(x) (((x) >> S_DEBUG_CPLSW_TP_RX_SOP1_CNT) & M_DEBUG_CPLSW_TP_RX_SOP1_CNT) + +#define S_DEBUG_CPLSW_TP_RX_EOP1_CNT 24 +#define M_DEBUG_CPLSW_TP_RX_EOP1_CNT 0xfU +#define V_DEBUG_CPLSW_TP_RX_EOP1_CNT(x) ((x) << S_DEBUG_CPLSW_TP_RX_EOP1_CNT) +#define G_DEBUG_CPLSW_TP_RX_EOP1_CNT(x) (((x) >> S_DEBUG_CPLSW_TP_RX_EOP1_CNT) & M_DEBUG_CPLSW_TP_RX_EOP1_CNT) + +#define S_DEBUG_CPLSW_TP_RX_SOP0_CNT 20 +#define M_DEBUG_CPLSW_TP_RX_SOP0_CNT 0xfU +#define V_DEBUG_CPLSW_TP_RX_SOP0_CNT(x) ((x) << S_DEBUG_CPLSW_TP_RX_SOP0_CNT) +#define G_DEBUG_CPLSW_TP_RX_SOP0_CNT(x) (((x) >> S_DEBUG_CPLSW_TP_RX_SOP0_CNT) & M_DEBUG_CPLSW_TP_RX_SOP0_CNT) + +#define S_DEBUG_CPLSW_TP_RX_EOP0_CNT 16 +#define M_DEBUG_CPLSW_TP_RX_EOP0_CNT 0xfU +#define V_DEBUG_CPLSW_TP_RX_EOP0_CNT(x) ((x) << S_DEBUG_CPLSW_TP_RX_EOP0_CNT) +#define G_DEBUG_CPLSW_TP_RX_EOP0_CNT(x) (((x) >> S_DEBUG_CPLSW_TP_RX_EOP0_CNT) & M_DEBUG_CPLSW_TP_RX_EOP0_CNT) + +#define S_DEBUG_CPLSW_CIM_SOP1_CNT 12 +#define M_DEBUG_CPLSW_CIM_SOP1_CNT 0xfU +#define V_DEBUG_CPLSW_CIM_SOP1_CNT(x) ((x) << S_DEBUG_CPLSW_CIM_SOP1_CNT) +#define G_DEBUG_CPLSW_CIM_SOP1_CNT(x) (((x) >> S_DEBUG_CPLSW_CIM_SOP1_CNT) & M_DEBUG_CPLSW_CIM_SOP1_CNT) + +#define S_DEBUG_CPLSW_CIM_EOP1_CNT 8 +#define M_DEBUG_CPLSW_CIM_EOP1_CNT 0xfU +#define V_DEBUG_CPLSW_CIM_EOP1_CNT(x) ((x) << S_DEBUG_CPLSW_CIM_EOP1_CNT) +#define G_DEBUG_CPLSW_CIM_EOP1_CNT(x) (((x) >> S_DEBUG_CPLSW_CIM_EOP1_CNT) & M_DEBUG_CPLSW_CIM_EOP1_CNT) + +#define S_DEBUG_CPLSW_CIM_SOP0_CNT 4 +#define M_DEBUG_CPLSW_CIM_SOP0_CNT 0xfU +#define V_DEBUG_CPLSW_CIM_SOP0_CNT(x) ((x) << S_DEBUG_CPLSW_CIM_SOP0_CNT) +#define G_DEBUG_CPLSW_CIM_SOP0_CNT(x) (((x) >> S_DEBUG_CPLSW_CIM_SOP0_CNT) & M_DEBUG_CPLSW_CIM_SOP0_CNT) + +#define S_DEBUG_CPLSW_CIM_EOP0_CNT 0 +#define M_DEBUG_CPLSW_CIM_EOP0_CNT 0xfU +#define V_DEBUG_CPLSW_CIM_EOP0_CNT(x) ((x) << S_DEBUG_CPLSW_CIM_EOP0_CNT) +#define G_DEBUG_CPLSW_CIM_EOP0_CNT(x) (((x) >> S_DEBUG_CPLSW_CIM_EOP0_CNT) & M_DEBUG_CPLSW_CIM_EOP0_CNT) + +#define A_SGE_DEBUG_DATA_HIGH_INDEX_10 0x12a8 + +#define S_DEBUG_T_RXAFULL_D 30 +#define M_DEBUG_T_RXAFULL_D 0x3U +#define V_DEBUG_T_RXAFULL_D(x) ((x) << S_DEBUG_T_RXAFULL_D) +#define G_DEBUG_T_RXAFULL_D(x) (((x) >> S_DEBUG_T_RXAFULL_D) & M_DEBUG_T_RXAFULL_D) + +#define S_DEBUG_PD_RDRSPAFULL_D 26 +#define M_DEBUG_PD_RDRSPAFULL_D 0xfU +#define V_DEBUG_PD_RDRSPAFULL_D(x) ((x) << S_DEBUG_PD_RDRSPAFULL_D) +#define G_DEBUG_PD_RDRSPAFULL_D(x) (((x) >> S_DEBUG_PD_RDRSPAFULL_D) & M_DEBUG_PD_RDRSPAFULL_D) + +#define S_DEBUG_PD_RDREQAFULL_D 22 +#define M_DEBUG_PD_RDREQAFULL_D 0xfU +#define V_DEBUG_PD_RDREQAFULL_D(x) ((x) << S_DEBUG_PD_RDREQAFULL_D) +#define G_DEBUG_PD_RDREQAFULL_D(x) (((x) >> S_DEBUG_PD_RDREQAFULL_D) & M_DEBUG_PD_RDREQAFULL_D) + +#define S_DEBUG_PD_WRREQAFULL_D 18 +#define M_DEBUG_PD_WRREQAFULL_D 0xfU +#define V_DEBUG_PD_WRREQAFULL_D(x) ((x) << S_DEBUG_PD_WRREQAFULL_D) +#define G_DEBUG_PD_WRREQAFULL_D(x) (((x) >> S_DEBUG_PD_WRREQAFULL_D) & M_DEBUG_PD_WRREQAFULL_D) + +#define S_DEBUG_PC_RSPAFULL_D 15 +#define M_DEBUG_PC_RSPAFULL_D 0x7U +#define V_DEBUG_PC_RSPAFULL_D(x) ((x) << S_DEBUG_PC_RSPAFULL_D) +#define G_DEBUG_PC_RSPAFULL_D(x) (((x) >> S_DEBUG_PC_RSPAFULL_D) & M_DEBUG_PC_RSPAFULL_D) + +#define S_DEBUG_PC_REQAFULL_D 12 +#define M_DEBUG_PC_REQAFULL_D 0x7U +#define V_DEBUG_PC_REQAFULL_D(x) ((x) << S_DEBUG_PC_REQAFULL_D) +#define G_DEBUG_PC_REQAFULL_D(x) (((x) >> S_DEBUG_PC_REQAFULL_D) & M_DEBUG_PC_REQAFULL_D) + +#define S_DEBUG_U_TXAFULL_D 8 +#define M_DEBUG_U_TXAFULL_D 0xfU +#define V_DEBUG_U_TXAFULL_D(x) ((x) << S_DEBUG_U_TXAFULL_D) +#define G_DEBUG_U_TXAFULL_D(x) (((x) >> S_DEBUG_U_TXAFULL_D) & M_DEBUG_U_TXAFULL_D) + +#define S_DEBUG_UD_RXAFULL_D 4 +#define M_DEBUG_UD_RXAFULL_D 0xfU +#define V_DEBUG_UD_RXAFULL_D(x) ((x) << S_DEBUG_UD_RXAFULL_D) +#define G_DEBUG_UD_RXAFULL_D(x) (((x) >> S_DEBUG_UD_RXAFULL_D) & M_DEBUG_UD_RXAFULL_D) + +#define S_DEBUG_U_RXAFULL_D 2 +#define M_DEBUG_U_RXAFULL_D 0x3U +#define V_DEBUG_U_RXAFULL_D(x) ((x) << S_DEBUG_U_RXAFULL_D) +#define G_DEBUG_U_RXAFULL_D(x) (((x) >> S_DEBUG_U_RXAFULL_D) & M_DEBUG_U_RXAFULL_D) + +#define S_DEBUG_CIM_AFULL_D 0 +#define M_DEBUG_CIM_AFULL_D 0x3U +#define V_DEBUG_CIM_AFULL_D(x) ((x) << S_DEBUG_CIM_AFULL_D) +#define G_DEBUG_CIM_AFULL_D(x) (((x) >> S_DEBUG_CIM_AFULL_D) & M_DEBUG_CIM_AFULL_D) + +#define A_SGE_DEBUG_DATA_HIGH_INDEX_11 0x12ac + +#define S_DEBUG_FLM_IDMA1_CACHE_DATA_ACTIVE 24 +#define V_DEBUG_FLM_IDMA1_CACHE_DATA_ACTIVE(x) ((x) << S_DEBUG_FLM_IDMA1_CACHE_DATA_ACTIVE) +#define F_DEBUG_FLM_IDMA1_CACHE_DATA_ACTIVE V_DEBUG_FLM_IDMA1_CACHE_DATA_ACTIVE(1U) + +#define S_DEBUG_FLM_IDMA1_CACHE_HDR_ACTIVE 23 +#define V_DEBUG_FLM_IDMA1_CACHE_HDR_ACTIVE(x) ((x) << S_DEBUG_FLM_IDMA1_CACHE_HDR_ACTIVE) +#define F_DEBUG_FLM_IDMA1_CACHE_HDR_ACTIVE V_DEBUG_FLM_IDMA1_CACHE_HDR_ACTIVE(1U) + +#define S_DEBUG_FLM_IDMA1_CTXT_DATA_ACTIVE 22 +#define V_DEBUG_FLM_IDMA1_CTXT_DATA_ACTIVE(x) ((x) << S_DEBUG_FLM_IDMA1_CTXT_DATA_ACTIVE) +#define F_DEBUG_FLM_IDMA1_CTXT_DATA_ACTIVE V_DEBUG_FLM_IDMA1_CTXT_DATA_ACTIVE(1U) + +#define S_DEBUG_FLM_IDMA1_CTXT_HDR_ACTIVE 21 +#define V_DEBUG_FLM_IDMA1_CTXT_HDR_ACTIVE(x) ((x) << S_DEBUG_FLM_IDMA1_CTXT_HDR_ACTIVE) +#define F_DEBUG_FLM_IDMA1_CTXT_HDR_ACTIVE V_DEBUG_FLM_IDMA1_CTXT_HDR_ACTIVE(1U) + +#define S_DEBUG_ST_FLM_IDMA1_CACHE 19 +#define M_DEBUG_ST_FLM_IDMA1_CACHE 0x3U +#define V_DEBUG_ST_FLM_IDMA1_CACHE(x) ((x) << S_DEBUG_ST_FLM_IDMA1_CACHE) +#define G_DEBUG_ST_FLM_IDMA1_CACHE(x) (((x) >> S_DEBUG_ST_FLM_IDMA1_CACHE) & M_DEBUG_ST_FLM_IDMA1_CACHE) + +#define S_DEBUG_ST_FLM_IDMA1_CTXT 16 +#define M_DEBUG_ST_FLM_IDMA1_CTXT 0x7U +#define V_DEBUG_ST_FLM_IDMA1_CTXT(x) ((x) << S_DEBUG_ST_FLM_IDMA1_CTXT) +#define G_DEBUG_ST_FLM_IDMA1_CTXT(x) (((x) >> S_DEBUG_ST_FLM_IDMA1_CTXT) & M_DEBUG_ST_FLM_IDMA1_CTXT) + +#define S_DEBUG_FLM_IDMA0_CACHE_DATA_ACTIVE 8 +#define V_DEBUG_FLM_IDMA0_CACHE_DATA_ACTIVE(x) ((x) << S_DEBUG_FLM_IDMA0_CACHE_DATA_ACTIVE) +#define F_DEBUG_FLM_IDMA0_CACHE_DATA_ACTIVE V_DEBUG_FLM_IDMA0_CACHE_DATA_ACTIVE(1U) + +#define S_DEBUG_FLM_IDMA0_CACHE_HDR_ACTIVE 7 +#define V_DEBUG_FLM_IDMA0_CACHE_HDR_ACTIVE(x) ((x) << S_DEBUG_FLM_IDMA0_CACHE_HDR_ACTIVE) +#define F_DEBUG_FLM_IDMA0_CACHE_HDR_ACTIVE V_DEBUG_FLM_IDMA0_CACHE_HDR_ACTIVE(1U) + +#define S_DEBUG_FLM_IDMA0_CTXT_DATA_ACTIVE 6 +#define V_DEBUG_FLM_IDMA0_CTXT_DATA_ACTIVE(x) ((x) << S_DEBUG_FLM_IDMA0_CTXT_DATA_ACTIVE) +#define F_DEBUG_FLM_IDMA0_CTXT_DATA_ACTIVE V_DEBUG_FLM_IDMA0_CTXT_DATA_ACTIVE(1U) + +#define S_DEBUG_FLM_IDMA0_CTXT_HDR_ACTIVE 5 +#define V_DEBUG_FLM_IDMA0_CTXT_HDR_ACTIVE(x) ((x) << S_DEBUG_FLM_IDMA0_CTXT_HDR_ACTIVE) +#define F_DEBUG_FLM_IDMA0_CTXT_HDR_ACTIVE V_DEBUG_FLM_IDMA0_CTXT_HDR_ACTIVE(1U) + +#define S_DEBUG_ST_FLM_IDMA0_CACHE 3 +#define M_DEBUG_ST_FLM_IDMA0_CACHE 0x3U +#define V_DEBUG_ST_FLM_IDMA0_CACHE(x) ((x) << S_DEBUG_ST_FLM_IDMA0_CACHE) +#define G_DEBUG_ST_FLM_IDMA0_CACHE(x) (((x) >> S_DEBUG_ST_FLM_IDMA0_CACHE) & M_DEBUG_ST_FLM_IDMA0_CACHE) + +#define S_DEBUG_ST_FLM_IDMA0_CTXT 0 +#define M_DEBUG_ST_FLM_IDMA0_CTXT 0x7U +#define V_DEBUG_ST_FLM_IDMA0_CTXT(x) ((x) << S_DEBUG_ST_FLM_IDMA0_CTXT) +#define G_DEBUG_ST_FLM_IDMA0_CTXT(x) (((x) >> S_DEBUG_ST_FLM_IDMA0_CTXT) & M_DEBUG_ST_FLM_IDMA0_CTXT) + +#define A_SGE_DEBUG_DATA_HIGH_INDEX_12 0x12b0 + +#define S_DEBUG_CPLSW_SOP1_CNT 28 +#define M_DEBUG_CPLSW_SOP1_CNT 0xfU +#define V_DEBUG_CPLSW_SOP1_CNT(x) ((x) << S_DEBUG_CPLSW_SOP1_CNT) +#define G_DEBUG_CPLSW_SOP1_CNT(x) (((x) >> S_DEBUG_CPLSW_SOP1_CNT) & M_DEBUG_CPLSW_SOP1_CNT) + +#define S_DEBUG_CPLSW_EOP1_CNT 24 +#define M_DEBUG_CPLSW_EOP1_CNT 0xfU +#define V_DEBUG_CPLSW_EOP1_CNT(x) ((x) << S_DEBUG_CPLSW_EOP1_CNT) +#define G_DEBUG_CPLSW_EOP1_CNT(x) (((x) >> S_DEBUG_CPLSW_EOP1_CNT) & M_DEBUG_CPLSW_EOP1_CNT) + +#define S_DEBUG_CPLSW_SOP0_CNT 20 +#define M_DEBUG_CPLSW_SOP0_CNT 0xfU +#define V_DEBUG_CPLSW_SOP0_CNT(x) ((x) << S_DEBUG_CPLSW_SOP0_CNT) +#define G_DEBUG_CPLSW_SOP0_CNT(x) (((x) >> S_DEBUG_CPLSW_SOP0_CNT) & M_DEBUG_CPLSW_SOP0_CNT) + +#define S_DEBUG_CPLSW_EOP0_CNT 16 +#define M_DEBUG_CPLSW_EOP0_CNT 0xfU +#define V_DEBUG_CPLSW_EOP0_CNT(x) ((x) << S_DEBUG_CPLSW_EOP0_CNT) +#define G_DEBUG_CPLSW_EOP0_CNT(x) (((x) >> S_DEBUG_CPLSW_EOP0_CNT) & M_DEBUG_CPLSW_EOP0_CNT) + +#define S_DEBUG_PC_RSP_SOP2_CNT 12 +#define M_DEBUG_PC_RSP_SOP2_CNT 0xfU +#define V_DEBUG_PC_RSP_SOP2_CNT(x) ((x) << S_DEBUG_PC_RSP_SOP2_CNT) +#define G_DEBUG_PC_RSP_SOP2_CNT(x) (((x) >> S_DEBUG_PC_RSP_SOP2_CNT) & M_DEBUG_PC_RSP_SOP2_CNT) + +#define S_DEBUG_PC_RSP_EOP2_CNT 8 +#define M_DEBUG_PC_RSP_EOP2_CNT 0xfU +#define V_DEBUG_PC_RSP_EOP2_CNT(x) ((x) << S_DEBUG_PC_RSP_EOP2_CNT) +#define G_DEBUG_PC_RSP_EOP2_CNT(x) (((x) >> S_DEBUG_PC_RSP_EOP2_CNT) & M_DEBUG_PC_RSP_EOP2_CNT) + +#define S_DEBUG_PC_REQ_SOP2_CNT 4 +#define M_DEBUG_PC_REQ_SOP2_CNT 0xfU +#define V_DEBUG_PC_REQ_SOP2_CNT(x) ((x) << S_DEBUG_PC_REQ_SOP2_CNT) +#define G_DEBUG_PC_REQ_SOP2_CNT(x) (((x) >> S_DEBUG_PC_REQ_SOP2_CNT) & M_DEBUG_PC_REQ_SOP2_CNT) + +#define S_DEBUG_PC_REQ_EOP2_CNT 0 +#define M_DEBUG_PC_REQ_EOP2_CNT 0xfU +#define V_DEBUG_PC_REQ_EOP2_CNT(x) ((x) << S_DEBUG_PC_REQ_EOP2_CNT) +#define G_DEBUG_PC_REQ_EOP2_CNT(x) (((x) >> S_DEBUG_PC_REQ_EOP2_CNT) & M_DEBUG_PC_REQ_EOP2_CNT) + +#define A_SGE_DEBUG_DATA_HIGH_INDEX_13 0x12b4 +#define A_SGE_DEBUG_DATA_HIGH_INDEX_14 0x12b8 +#define A_SGE_DEBUG_DATA_HIGH_INDEX_15 0x12bc +#define A_SGE_DEBUG_DATA_LOW_INDEX_0 0x12c0 + +#define S_DEBUG_ST_IDMA1_FLM_REQ 29 +#define M_DEBUG_ST_IDMA1_FLM_REQ 0x7U +#define V_DEBUG_ST_IDMA1_FLM_REQ(x) ((x) << S_DEBUG_ST_IDMA1_FLM_REQ) +#define G_DEBUG_ST_IDMA1_FLM_REQ(x) (((x) >> S_DEBUG_ST_IDMA1_FLM_REQ) & M_DEBUG_ST_IDMA1_FLM_REQ) + +#define S_DEBUG_ST_IDMA0_FLM_REQ 26 +#define M_DEBUG_ST_IDMA0_FLM_REQ 0x7U +#define V_DEBUG_ST_IDMA0_FLM_REQ(x) ((x) << S_DEBUG_ST_IDMA0_FLM_REQ) +#define G_DEBUG_ST_IDMA0_FLM_REQ(x) (((x) >> S_DEBUG_ST_IDMA0_FLM_REQ) & M_DEBUG_ST_IDMA0_FLM_REQ) + +#define S_DEBUG_ST_IMSG_CTXT 23 +#define M_DEBUG_ST_IMSG_CTXT 0x7U +#define V_DEBUG_ST_IMSG_CTXT(x) ((x) << S_DEBUG_ST_IMSG_CTXT) +#define G_DEBUG_ST_IMSG_CTXT(x) (((x) >> S_DEBUG_ST_IMSG_CTXT) & M_DEBUG_ST_IMSG_CTXT) + +#define S_DEBUG_ST_IMSG 18 +#define M_DEBUG_ST_IMSG 0x1fU +#define V_DEBUG_ST_IMSG(x) ((x) << S_DEBUG_ST_IMSG) +#define G_DEBUG_ST_IMSG(x) (((x) >> S_DEBUG_ST_IMSG) & M_DEBUG_ST_IMSG) + +#define S_DEBUG_ST_IDMA1_IALN 16 +#define M_DEBUG_ST_IDMA1_IALN 0x3U +#define V_DEBUG_ST_IDMA1_IALN(x) ((x) << S_DEBUG_ST_IDMA1_IALN) +#define G_DEBUG_ST_IDMA1_IALN(x) (((x) >> S_DEBUG_ST_IDMA1_IALN) & M_DEBUG_ST_IDMA1_IALN) + +#define S_DEBUG_ST_IDMA1_IDMA_SM 9 +#define M_DEBUG_ST_IDMA1_IDMA_SM 0x3fU +#define V_DEBUG_ST_IDMA1_IDMA_SM(x) ((x) << S_DEBUG_ST_IDMA1_IDMA_SM) +#define G_DEBUG_ST_IDMA1_IDMA_SM(x) (((x) >> S_DEBUG_ST_IDMA1_IDMA_SM) & M_DEBUG_ST_IDMA1_IDMA_SM) + +#define S_DEBUG_ST_IDMA0_IALN 7 +#define M_DEBUG_ST_IDMA0_IALN 0x3U +#define V_DEBUG_ST_IDMA0_IALN(x) ((x) << S_DEBUG_ST_IDMA0_IALN) +#define G_DEBUG_ST_IDMA0_IALN(x) (((x) >> S_DEBUG_ST_IDMA0_IALN) & M_DEBUG_ST_IDMA0_IALN) + +#define S_DEBUG_ST_IDMA0_IDMA_SM 0 +#define M_DEBUG_ST_IDMA0_IDMA_SM 0x3fU +#define V_DEBUG_ST_IDMA0_IDMA_SM(x) ((x) << S_DEBUG_ST_IDMA0_IDMA_SM) +#define G_DEBUG_ST_IDMA0_IDMA_SM(x) (((x) >> S_DEBUG_ST_IDMA0_IDMA_SM) & M_DEBUG_ST_IDMA0_IDMA_SM) + +#define A_SGE_DEBUG_DATA_LOW_INDEX_1 0x12c4 + +#define S_DEBUG_ITP_EMPTY 12 +#define M_DEBUG_ITP_EMPTY 0x3fU +#define V_DEBUG_ITP_EMPTY(x) ((x) << S_DEBUG_ITP_EMPTY) +#define G_DEBUG_ITP_EMPTY(x) (((x) >> S_DEBUG_ITP_EMPTY) & M_DEBUG_ITP_EMPTY) + +#define S_DEBUG_ITP_EXPIRED 6 +#define M_DEBUG_ITP_EXPIRED 0x3fU +#define V_DEBUG_ITP_EXPIRED(x) ((x) << S_DEBUG_ITP_EXPIRED) +#define G_DEBUG_ITP_EXPIRED(x) (((x) >> S_DEBUG_ITP_EXPIRED) & M_DEBUG_ITP_EXPIRED) + +#define S_DEBUG_ITP_PAUSE 5 +#define V_DEBUG_ITP_PAUSE(x) ((x) << S_DEBUG_ITP_PAUSE) +#define F_DEBUG_ITP_PAUSE V_DEBUG_ITP_PAUSE(1U) + +#define S_DEBUG_ITP_DEL_DONE 4 +#define V_DEBUG_ITP_DEL_DONE(x) ((x) << S_DEBUG_ITP_DEL_DONE) +#define F_DEBUG_ITP_DEL_DONE V_DEBUG_ITP_DEL_DONE(1U) + +#define S_DEBUG_ITP_ADD_DONE 3 +#define V_DEBUG_ITP_ADD_DONE(x) ((x) << S_DEBUG_ITP_ADD_DONE) +#define F_DEBUG_ITP_ADD_DONE V_DEBUG_ITP_ADD_DONE(1U) + +#define S_DEBUG_ITP_EVR_STATE 0 +#define M_DEBUG_ITP_EVR_STATE 0x7U +#define V_DEBUG_ITP_EVR_STATE(x) ((x) << S_DEBUG_ITP_EVR_STATE) +#define G_DEBUG_ITP_EVR_STATE(x) (((x) >> S_DEBUG_ITP_EVR_STATE) & M_DEBUG_ITP_EVR_STATE) + +#define A_SGE_DEBUG_DATA_LOW_INDEX_2 0x12c8 + +#define S_DEBUG_ST_DBP_THREAD2_CIMFL 25 +#define M_DEBUG_ST_DBP_THREAD2_CIMFL 0x1fU +#define V_DEBUG_ST_DBP_THREAD2_CIMFL(x) ((x) << S_DEBUG_ST_DBP_THREAD2_CIMFL) +#define G_DEBUG_ST_DBP_THREAD2_CIMFL(x) (((x) >> S_DEBUG_ST_DBP_THREAD2_CIMFL) & M_DEBUG_ST_DBP_THREAD2_CIMFL) + +#define S_DEBUG_ST_DBP_THREAD2_MAIN 20 +#define M_DEBUG_ST_DBP_THREAD2_MAIN 0x1fU +#define V_DEBUG_ST_DBP_THREAD2_MAIN(x) ((x) << S_DEBUG_ST_DBP_THREAD2_MAIN) +#define G_DEBUG_ST_DBP_THREAD2_MAIN(x) (((x) >> S_DEBUG_ST_DBP_THREAD2_MAIN) & M_DEBUG_ST_DBP_THREAD2_MAIN) + +#define S_DEBUG_ST_DBP_THREAD1_CIMFL 15 +#define M_DEBUG_ST_DBP_THREAD1_CIMFL 0x1fU +#define V_DEBUG_ST_DBP_THREAD1_CIMFL(x) ((x) << S_DEBUG_ST_DBP_THREAD1_CIMFL) +#define G_DEBUG_ST_DBP_THREAD1_CIMFL(x) (((x) >> S_DEBUG_ST_DBP_THREAD1_CIMFL) & M_DEBUG_ST_DBP_THREAD1_CIMFL) + +#define S_DEBUG_ST_DBP_THREAD1_MAIN 10 +#define M_DEBUG_ST_DBP_THREAD1_MAIN 0x1fU +#define V_DEBUG_ST_DBP_THREAD1_MAIN(x) ((x) << S_DEBUG_ST_DBP_THREAD1_MAIN) +#define G_DEBUG_ST_DBP_THREAD1_MAIN(x) (((x) >> S_DEBUG_ST_DBP_THREAD1_MAIN) & M_DEBUG_ST_DBP_THREAD1_MAIN) + +#define S_DEBUG_ST_DBP_THREAD0_CIMFL 5 +#define M_DEBUG_ST_DBP_THREAD0_CIMFL 0x1fU +#define V_DEBUG_ST_DBP_THREAD0_CIMFL(x) ((x) << S_DEBUG_ST_DBP_THREAD0_CIMFL) +#define G_DEBUG_ST_DBP_THREAD0_CIMFL(x) (((x) >> S_DEBUG_ST_DBP_THREAD0_CIMFL) & M_DEBUG_ST_DBP_THREAD0_CIMFL) + +#define S_DEBUG_ST_DBP_THREAD0_MAIN 0 +#define M_DEBUG_ST_DBP_THREAD0_MAIN 0x1fU +#define V_DEBUG_ST_DBP_THREAD0_MAIN(x) ((x) << S_DEBUG_ST_DBP_THREAD0_MAIN) +#define G_DEBUG_ST_DBP_THREAD0_MAIN(x) (((x) >> S_DEBUG_ST_DBP_THREAD0_MAIN) & M_DEBUG_ST_DBP_THREAD0_MAIN) + +#define A_SGE_DEBUG_DATA_LOW_INDEX_3 0x12cc + +#define S_DEBUG_ST_DBP_UPCP_MAIN 14 +#define M_DEBUG_ST_DBP_UPCP_MAIN 0x1fU +#define V_DEBUG_ST_DBP_UPCP_MAIN(x) ((x) << S_DEBUG_ST_DBP_UPCP_MAIN) +#define G_DEBUG_ST_DBP_UPCP_MAIN(x) (((x) >> S_DEBUG_ST_DBP_UPCP_MAIN) & M_DEBUG_ST_DBP_UPCP_MAIN) + +#define S_DEBUG_ST_DBP_DBFIFO_MAIN 13 +#define V_DEBUG_ST_DBP_DBFIFO_MAIN(x) ((x) << S_DEBUG_ST_DBP_DBFIFO_MAIN) +#define F_DEBUG_ST_DBP_DBFIFO_MAIN V_DEBUG_ST_DBP_DBFIFO_MAIN(1U) + +#define S_DEBUG_ST_DBP_CTXT 10 +#define M_DEBUG_ST_DBP_CTXT 0x7U +#define V_DEBUG_ST_DBP_CTXT(x) ((x) << S_DEBUG_ST_DBP_CTXT) +#define G_DEBUG_ST_DBP_CTXT(x) (((x) >> S_DEBUG_ST_DBP_CTXT) & M_DEBUG_ST_DBP_CTXT) + +#define S_DEBUG_ST_DBP_THREAD3_CIMFL 5 +#define M_DEBUG_ST_DBP_THREAD3_CIMFL 0x1fU +#define V_DEBUG_ST_DBP_THREAD3_CIMFL(x) ((x) << S_DEBUG_ST_DBP_THREAD3_CIMFL) +#define G_DEBUG_ST_DBP_THREAD3_CIMFL(x) (((x) >> S_DEBUG_ST_DBP_THREAD3_CIMFL) & M_DEBUG_ST_DBP_THREAD3_CIMFL) + +#define S_DEBUG_ST_DBP_THREAD3_MAIN 0 +#define M_DEBUG_ST_DBP_THREAD3_MAIN 0x1fU +#define V_DEBUG_ST_DBP_THREAD3_MAIN(x) ((x) << S_DEBUG_ST_DBP_THREAD3_MAIN) +#define G_DEBUG_ST_DBP_THREAD3_MAIN(x) (((x) >> S_DEBUG_ST_DBP_THREAD3_MAIN) & M_DEBUG_ST_DBP_THREAD3_MAIN) + +#define A_SGE_DEBUG_DATA_LOW_INDEX_4 0x12d0 + +#define S_DEBUG_ST_EDMA3_ALIGN_SUB 29 +#define M_DEBUG_ST_EDMA3_ALIGN_SUB 0x7U +#define V_DEBUG_ST_EDMA3_ALIGN_SUB(x) ((x) << S_DEBUG_ST_EDMA3_ALIGN_SUB) +#define G_DEBUG_ST_EDMA3_ALIGN_SUB(x) (((x) >> S_DEBUG_ST_EDMA3_ALIGN_SUB) & M_DEBUG_ST_EDMA3_ALIGN_SUB) + +#define S_DEBUG_ST_EDMA3_ALIGN 27 +#define M_DEBUG_ST_EDMA3_ALIGN 0x3U +#define V_DEBUG_ST_EDMA3_ALIGN(x) ((x) << S_DEBUG_ST_EDMA3_ALIGN) +#define G_DEBUG_ST_EDMA3_ALIGN(x) (((x) >> S_DEBUG_ST_EDMA3_ALIGN) & M_DEBUG_ST_EDMA3_ALIGN) + +#define S_DEBUG_ST_EDMA3_REQ 24 +#define M_DEBUG_ST_EDMA3_REQ 0x7U +#define V_DEBUG_ST_EDMA3_REQ(x) ((x) << S_DEBUG_ST_EDMA3_REQ) +#define G_DEBUG_ST_EDMA3_REQ(x) (((x) >> S_DEBUG_ST_EDMA3_REQ) & M_DEBUG_ST_EDMA3_REQ) + +#define S_DEBUG_ST_EDMA2_ALIGN_SUB 21 +#define M_DEBUG_ST_EDMA2_ALIGN_SUB 0x7U +#define V_DEBUG_ST_EDMA2_ALIGN_SUB(x) ((x) << S_DEBUG_ST_EDMA2_ALIGN_SUB) +#define G_DEBUG_ST_EDMA2_ALIGN_SUB(x) (((x) >> S_DEBUG_ST_EDMA2_ALIGN_SUB) & M_DEBUG_ST_EDMA2_ALIGN_SUB) + +#define S_DEBUG_ST_EDMA2_ALIGN 19 +#define M_DEBUG_ST_EDMA2_ALIGN 0x3U +#define V_DEBUG_ST_EDMA2_ALIGN(x) ((x) << S_DEBUG_ST_EDMA2_ALIGN) +#define G_DEBUG_ST_EDMA2_ALIGN(x) (((x) >> S_DEBUG_ST_EDMA2_ALIGN) & M_DEBUG_ST_EDMA2_ALIGN) + +#define S_DEBUG_ST_EDMA2_REQ 16 +#define M_DEBUG_ST_EDMA2_REQ 0x7U +#define V_DEBUG_ST_EDMA2_REQ(x) ((x) << S_DEBUG_ST_EDMA2_REQ) +#define G_DEBUG_ST_EDMA2_REQ(x) (((x) >> S_DEBUG_ST_EDMA2_REQ) & M_DEBUG_ST_EDMA2_REQ) + +#define S_DEBUG_ST_EDMA1_ALIGN_SUB 13 +#define M_DEBUG_ST_EDMA1_ALIGN_SUB 0x7U +#define V_DEBUG_ST_EDMA1_ALIGN_SUB(x) ((x) << S_DEBUG_ST_EDMA1_ALIGN_SUB) +#define G_DEBUG_ST_EDMA1_ALIGN_SUB(x) (((x) >> S_DEBUG_ST_EDMA1_ALIGN_SUB) & M_DEBUG_ST_EDMA1_ALIGN_SUB) + +#define S_DEBUG_ST_EDMA1_ALIGN 11 +#define M_DEBUG_ST_EDMA1_ALIGN 0x3U +#define V_DEBUG_ST_EDMA1_ALIGN(x) ((x) << S_DEBUG_ST_EDMA1_ALIGN) +#define G_DEBUG_ST_EDMA1_ALIGN(x) (((x) >> S_DEBUG_ST_EDMA1_ALIGN) & M_DEBUG_ST_EDMA1_ALIGN) + +#define S_DEBUG_ST_EDMA1_REQ 8 +#define M_DEBUG_ST_EDMA1_REQ 0x7U +#define V_DEBUG_ST_EDMA1_REQ(x) ((x) << S_DEBUG_ST_EDMA1_REQ) +#define G_DEBUG_ST_EDMA1_REQ(x) (((x) >> S_DEBUG_ST_EDMA1_REQ) & M_DEBUG_ST_EDMA1_REQ) + +#define S_DEBUG_ST_EDMA0_ALIGN_SUB 5 +#define M_DEBUG_ST_EDMA0_ALIGN_SUB 0x7U +#define V_DEBUG_ST_EDMA0_ALIGN_SUB(x) ((x) << S_DEBUG_ST_EDMA0_ALIGN_SUB) +#define G_DEBUG_ST_EDMA0_ALIGN_SUB(x) (((x) >> S_DEBUG_ST_EDMA0_ALIGN_SUB) & M_DEBUG_ST_EDMA0_ALIGN_SUB) + +#define S_DEBUG_ST_EDMA0_ALIGN 3 +#define M_DEBUG_ST_EDMA0_ALIGN 0x3U +#define V_DEBUG_ST_EDMA0_ALIGN(x) ((x) << S_DEBUG_ST_EDMA0_ALIGN) +#define G_DEBUG_ST_EDMA0_ALIGN(x) (((x) >> S_DEBUG_ST_EDMA0_ALIGN) & M_DEBUG_ST_EDMA0_ALIGN) + +#define S_DEBUG_ST_EDMA0_REQ 0 +#define M_DEBUG_ST_EDMA0_REQ 0x7U +#define V_DEBUG_ST_EDMA0_REQ(x) ((x) << S_DEBUG_ST_EDMA0_REQ) +#define G_DEBUG_ST_EDMA0_REQ(x) (((x) >> S_DEBUG_ST_EDMA0_REQ) & M_DEBUG_ST_EDMA0_REQ) + +#define A_SGE_DEBUG_DATA_LOW_INDEX_5 0x12d4 + +#define S_DEBUG_ST_FLM_DBPTR 30 +#define M_DEBUG_ST_FLM_DBPTR 0x3U +#define V_DEBUG_ST_FLM_DBPTR(x) ((x) << S_DEBUG_ST_FLM_DBPTR) +#define G_DEBUG_ST_FLM_DBPTR(x) (((x) >> S_DEBUG_ST_FLM_DBPTR) & M_DEBUG_ST_FLM_DBPTR) + +#define S_DEBUG_FLM_CACHE_LOCKED_COUNT 23 +#define M_DEBUG_FLM_CACHE_LOCKED_COUNT 0x7fU +#define V_DEBUG_FLM_CACHE_LOCKED_COUNT(x) ((x) << S_DEBUG_FLM_CACHE_LOCKED_COUNT) +#define G_DEBUG_FLM_CACHE_LOCKED_COUNT(x) (((x) >> S_DEBUG_FLM_CACHE_LOCKED_COUNT) & M_DEBUG_FLM_CACHE_LOCKED_COUNT) + +#define S_DEBUG_FLM_CACHE_AGENT 20 +#define M_DEBUG_FLM_CACHE_AGENT 0x7U +#define V_DEBUG_FLM_CACHE_AGENT(x) ((x) << S_DEBUG_FLM_CACHE_AGENT) +#define G_DEBUG_FLM_CACHE_AGENT(x) (((x) >> S_DEBUG_FLM_CACHE_AGENT) & M_DEBUG_FLM_CACHE_AGENT) + +#define S_DEBUG_ST_FLM_CACHE 16 +#define M_DEBUG_ST_FLM_CACHE 0xfU +#define V_DEBUG_ST_FLM_CACHE(x) ((x) << S_DEBUG_ST_FLM_CACHE) +#define G_DEBUG_ST_FLM_CACHE(x) (((x) >> S_DEBUG_ST_FLM_CACHE) & M_DEBUG_ST_FLM_CACHE) + +#define S_DEBUG_FLM_DBPTR_CIDX_STALL 12 +#define V_DEBUG_FLM_DBPTR_CIDX_STALL(x) ((x) << S_DEBUG_FLM_DBPTR_CIDX_STALL) +#define F_DEBUG_FLM_DBPTR_CIDX_STALL V_DEBUG_FLM_DBPTR_CIDX_STALL(1U) + +#define S_DEBUG_FLM_DBPTR_QID 0 +#define M_DEBUG_FLM_DBPTR_QID 0xfffU +#define V_DEBUG_FLM_DBPTR_QID(x) ((x) << S_DEBUG_FLM_DBPTR_QID) +#define G_DEBUG_FLM_DBPTR_QID(x) (((x) >> S_DEBUG_FLM_DBPTR_QID) & M_DEBUG_FLM_DBPTR_QID) + +#define A_SGE_DEBUG_DATA_LOW_INDEX_6 0x12d8 + +#define S_DEBUG_DBP_THREAD0_QID 0 +#define M_DEBUG_DBP_THREAD0_QID 0x1ffffU +#define V_DEBUG_DBP_THREAD0_QID(x) ((x) << S_DEBUG_DBP_THREAD0_QID) +#define G_DEBUG_DBP_THREAD0_QID(x) (((x) >> S_DEBUG_DBP_THREAD0_QID) & M_DEBUG_DBP_THREAD0_QID) + +#define A_SGE_DEBUG_DATA_LOW_INDEX_7 0x12dc + +#define S_DEBUG_DBP_THREAD1_QID 0 +#define M_DEBUG_DBP_THREAD1_QID 0x1ffffU +#define V_DEBUG_DBP_THREAD1_QID(x) ((x) << S_DEBUG_DBP_THREAD1_QID) +#define G_DEBUG_DBP_THREAD1_QID(x) (((x) >> S_DEBUG_DBP_THREAD1_QID) & M_DEBUG_DBP_THREAD1_QID) + +#define A_SGE_DEBUG_DATA_LOW_INDEX_8 0x12e0 + +#define S_DEBUG_DBP_THREAD2_QID 0 +#define M_DEBUG_DBP_THREAD2_QID 0x1ffffU +#define V_DEBUG_DBP_THREAD2_QID(x) ((x) << S_DEBUG_DBP_THREAD2_QID) +#define G_DEBUG_DBP_THREAD2_QID(x) (((x) >> S_DEBUG_DBP_THREAD2_QID) & M_DEBUG_DBP_THREAD2_QID) + +#define A_SGE_DEBUG_DATA_LOW_INDEX_9 0x12e4 + +#define S_DEBUG_DBP_THREAD3_QID 0 +#define M_DEBUG_DBP_THREAD3_QID 0x1ffffU +#define V_DEBUG_DBP_THREAD3_QID(x) ((x) << S_DEBUG_DBP_THREAD3_QID) +#define G_DEBUG_DBP_THREAD3_QID(x) (((x) >> S_DEBUG_DBP_THREAD3_QID) & M_DEBUG_DBP_THREAD3_QID) + +#define A_SGE_DEBUG_DATA_LOW_INDEX_10 0x12e8 + +#define S_DEBUG_IMSG_CPL 16 +#define M_DEBUG_IMSG_CPL 0xffU +#define V_DEBUG_IMSG_CPL(x) ((x) << S_DEBUG_IMSG_CPL) +#define G_DEBUG_IMSG_CPL(x) (((x) >> S_DEBUG_IMSG_CPL) & M_DEBUG_IMSG_CPL) + +#define S_DEBUG_IMSG_QID 0 +#define M_DEBUG_IMSG_QID 0xffffU +#define V_DEBUG_IMSG_QID(x) ((x) << S_DEBUG_IMSG_QID) +#define G_DEBUG_IMSG_QID(x) (((x) >> S_DEBUG_IMSG_QID) & M_DEBUG_IMSG_QID) + +#define A_SGE_DEBUG_DATA_LOW_INDEX_11 0x12ec + +#define S_DEBUG_IDMA1_QID 16 +#define M_DEBUG_IDMA1_QID 0xffffU +#define V_DEBUG_IDMA1_QID(x) ((x) << S_DEBUG_IDMA1_QID) +#define G_DEBUG_IDMA1_QID(x) (((x) >> S_DEBUG_IDMA1_QID) & M_DEBUG_IDMA1_QID) + +#define S_DEBUG_IDMA0_QID 0 +#define M_DEBUG_IDMA0_QID 0xffffU +#define V_DEBUG_IDMA0_QID(x) ((x) << S_DEBUG_IDMA0_QID) +#define G_DEBUG_IDMA0_QID(x) (((x) >> S_DEBUG_IDMA0_QID) & M_DEBUG_IDMA0_QID) + +#define A_SGE_DEBUG_DATA_LOW_INDEX_12 0x12f0 + +#define S_DEBUG_IDMA1_FLM_REQ_QID 16 +#define M_DEBUG_IDMA1_FLM_REQ_QID 0xffffU +#define V_DEBUG_IDMA1_FLM_REQ_QID(x) ((x) << S_DEBUG_IDMA1_FLM_REQ_QID) +#define G_DEBUG_IDMA1_FLM_REQ_QID(x) (((x) >> S_DEBUG_IDMA1_FLM_REQ_QID) & M_DEBUG_IDMA1_FLM_REQ_QID) + +#define S_DEBUG_IDMA0_FLM_REQ_QID 0 +#define M_DEBUG_IDMA0_FLM_REQ_QID 0xffffU +#define V_DEBUG_IDMA0_FLM_REQ_QID(x) ((x) << S_DEBUG_IDMA0_FLM_REQ_QID) +#define G_DEBUG_IDMA0_FLM_REQ_QID(x) (((x) >> S_DEBUG_IDMA0_FLM_REQ_QID) & M_DEBUG_IDMA0_FLM_REQ_QID) + +#define A_SGE_DEBUG_DATA_LOW_INDEX_13 0x12f4 +#define A_SGE_DEBUG_DATA_LOW_INDEX_14 0x12f8 +#define A_SGE_DEBUG_DATA_LOW_INDEX_15 0x12fc +#define A_SGE_QUEUE_BASE_MAP_HIGH 0x1300 + +#define S_EGRESS_LOG2SIZE 27 +#define M_EGRESS_LOG2SIZE 0x1fU +#define V_EGRESS_LOG2SIZE(x) ((x) << S_EGRESS_LOG2SIZE) +#define G_EGRESS_LOG2SIZE(x) (((x) >> S_EGRESS_LOG2SIZE) & M_EGRESS_LOG2SIZE) + +#define S_EGRESS_BASE 10 +#define M_EGRESS_BASE 0x1ffffU +#define V_EGRESS_BASE(x) ((x) << S_EGRESS_BASE) +#define G_EGRESS_BASE(x) (((x) >> S_EGRESS_BASE) & M_EGRESS_BASE) + +#define S_INGRESS2_LOG2SIZE 5 +#define M_INGRESS2_LOG2SIZE 0x1fU +#define V_INGRESS2_LOG2SIZE(x) ((x) << S_INGRESS2_LOG2SIZE) +#define G_INGRESS2_LOG2SIZE(x) (((x) >> S_INGRESS2_LOG2SIZE) & M_INGRESS2_LOG2SIZE) + +#define S_INGRESS1_LOG2SIZE 0 +#define M_INGRESS1_LOG2SIZE 0x1fU +#define V_INGRESS1_LOG2SIZE(x) ((x) << S_INGRESS1_LOG2SIZE) +#define G_INGRESS1_LOG2SIZE(x) (((x) >> S_INGRESS1_LOG2SIZE) & M_INGRESS1_LOG2SIZE) + +#define S_EGRESS_SIZE 27 +#define M_EGRESS_SIZE 0x1fU +#define V_EGRESS_SIZE(x) ((x) << S_EGRESS_SIZE) +#define G_EGRESS_SIZE(x) (((x) >> S_EGRESS_SIZE) & M_EGRESS_SIZE) + +#define S_INGRESS2_SIZE 5 +#define M_INGRESS2_SIZE 0x1fU +#define V_INGRESS2_SIZE(x) ((x) << S_INGRESS2_SIZE) +#define G_INGRESS2_SIZE(x) (((x) >> S_INGRESS2_SIZE) & M_INGRESS2_SIZE) + +#define S_INGRESS1_SIZE 0 +#define M_INGRESS1_SIZE 0x1fU +#define V_INGRESS1_SIZE(x) ((x) << S_INGRESS1_SIZE) +#define G_INGRESS1_SIZE(x) (((x) >> S_INGRESS1_SIZE) & M_INGRESS1_SIZE) + +#define A_SGE_QUEUE_BASE_MAP_LOW 0x1304 + +#define S_INGRESS2_BASE 16 +#define M_INGRESS2_BASE 0xffffU +#define V_INGRESS2_BASE(x) ((x) << S_INGRESS2_BASE) +#define G_INGRESS2_BASE(x) (((x) >> S_INGRESS2_BASE) & M_INGRESS2_BASE) + +#define S_INGRESS1_BASE 0 +#define M_INGRESS1_BASE 0xffffU +#define V_INGRESS1_BASE(x) ((x) << S_INGRESS1_BASE) +#define G_INGRESS1_BASE(x) (((x) >> S_INGRESS1_BASE) & M_INGRESS1_BASE) + +#define A_SGE_LA_RDPTR_0 0x1800 +#define A_SGE_LA_RDDATA_0 0x1804 +#define A_SGE_LA_WRPTR_0 0x1808 +#define A_SGE_LA_RESERVED_0 0x180c +#define A_SGE_LA_RDPTR_1 0x1810 +#define A_SGE_LA_RDDATA_1 0x1814 +#define A_SGE_LA_WRPTR_1 0x1818 +#define A_SGE_LA_RESERVED_1 0x181c +#define A_SGE_LA_RDPTR_2 0x1820 +#define A_SGE_LA_RDDATA_2 0x1824 +#define A_SGE_LA_WRPTR_2 0x1828 +#define A_SGE_LA_RESERVED_2 0x182c +#define A_SGE_LA_RDPTR_3 0x1830 +#define A_SGE_LA_RDDATA_3 0x1834 +#define A_SGE_LA_WRPTR_3 0x1838 +#define A_SGE_LA_RESERVED_3 0x183c +#define A_SGE_LA_RDPTR_4 0x1840 +#define A_SGE_LA_RDDATA_4 0x1844 +#define A_SGE_LA_WRPTR_4 0x1848 +#define A_SGE_LA_RESERVED_4 0x184c +#define A_SGE_LA_RDPTR_5 0x1850 +#define A_SGE_LA_RDDATA_5 0x1854 +#define A_SGE_LA_WRPTR_5 0x1858 +#define A_SGE_LA_RESERVED_5 0x185c +#define A_SGE_LA_RDPTR_6 0x1860 +#define A_SGE_LA_RDDATA_6 0x1864 +#define A_SGE_LA_WRPTR_6 0x1868 +#define A_SGE_LA_RESERVED_6 0x186c +#define A_SGE_LA_RDPTR_7 0x1870 +#define A_SGE_LA_RDDATA_7 0x1874 +#define A_SGE_LA_WRPTR_7 0x1878 +#define A_SGE_LA_RESERVED_7 0x187c +#define A_SGE_LA_RDPTR_8 0x1880 +#define A_SGE_LA_RDDATA_8 0x1884 +#define A_SGE_LA_WRPTR_8 0x1888 +#define A_SGE_LA_RESERVED_8 0x188c +#define A_SGE_LA_RDPTR_9 0x1890 +#define A_SGE_LA_RDDATA_9 0x1894 +#define A_SGE_LA_WRPTR_9 0x1898 +#define A_SGE_LA_RESERVED_9 0x189c +#define A_SGE_LA_RDPTR_10 0x18a0 +#define A_SGE_LA_RDDATA_10 0x18a4 +#define A_SGE_LA_WRPTR_10 0x18a8 +#define A_SGE_LA_RESERVED_10 0x18ac +#define A_SGE_LA_RDPTR_11 0x18b0 +#define A_SGE_LA_RDDATA_11 0x18b4 +#define A_SGE_LA_WRPTR_11 0x18b8 +#define A_SGE_LA_RESERVED_11 0x18bc +#define A_SGE_LA_RDPTR_12 0x18c0 +#define A_SGE_LA_RDDATA_12 0x18c4 +#define A_SGE_LA_WRPTR_12 0x18c8 +#define A_SGE_LA_RESERVED_12 0x18cc +#define A_SGE_LA_RDPTR_13 0x18d0 +#define A_SGE_LA_RDDATA_13 0x18d4 +#define A_SGE_LA_WRPTR_13 0x18d8 +#define A_SGE_LA_RESERVED_13 0x18dc +#define A_SGE_LA_RDPTR_14 0x18e0 +#define A_SGE_LA_RDDATA_14 0x18e4 +#define A_SGE_LA_WRPTR_14 0x18e8 +#define A_SGE_LA_RESERVED_14 0x18ec +#define A_SGE_LA_RDPTR_15 0x18f0 +#define A_SGE_LA_RDDATA_15 0x18f4 +#define A_SGE_LA_WRPTR_15 0x18f8 +#define A_SGE_LA_RESERVED_15 0x18fc + +/* registers for module PCIE */ +#define PCIE_BASE_ADDR 0x3000 + +#define A_PCIE_PF_CFG 0x40 + +#define S_INTXSTAT 16 +#define V_INTXSTAT(x) ((x) << S_INTXSTAT) +#define F_INTXSTAT V_INTXSTAT(1U) + +#define S_AUXPWRPMEN 15 +#define V_AUXPWRPMEN(x) ((x) << S_AUXPWRPMEN) +#define F_AUXPWRPMEN V_AUXPWRPMEN(1U) + +#define S_NOSOFTRESET 14 +#define V_NOSOFTRESET(x) ((x) << S_NOSOFTRESET) +#define F_NOSOFTRESET V_NOSOFTRESET(1U) + +#define S_AIVEC 4 +#define M_AIVEC 0x3ffU +#define V_AIVEC(x) ((x) << S_AIVEC) +#define G_AIVEC(x) (((x) >> S_AIVEC) & M_AIVEC) + +#define S_INTXTYPE 2 +#define M_INTXTYPE 0x3U +#define V_INTXTYPE(x) ((x) << S_INTXTYPE) +#define G_INTXTYPE(x) (((x) >> S_INTXTYPE) & M_INTXTYPE) + +#define S_D3HOTEN 1 +#define V_D3HOTEN(x) ((x) << S_D3HOTEN) +#define F_D3HOTEN V_D3HOTEN(1U) + +#define S_CLIDECEN 0 +#define V_CLIDECEN(x) ((x) << S_CLIDECEN) +#define F_CLIDECEN V_CLIDECEN(1U) + +#define A_PCIE_PF_CLI 0x44 +#define A_PCIE_PF_GEN_MSG 0x48 + +#define S_MSGTYPE 0 +#define M_MSGTYPE 0xffU +#define V_MSGTYPE(x) ((x) << S_MSGTYPE) +#define G_MSGTYPE(x) (((x) >> S_MSGTYPE) & M_MSGTYPE) + +#define A_PCIE_PF_EXPROM_OFST 0x4c + +#define S_OFFSET 10 +#define M_OFFSET 0x3fffU +#define V_OFFSET(x) ((x) << S_OFFSET) +#define G_OFFSET(x) (((x) >> S_OFFSET) & M_OFFSET) + +#define A_PCIE_INT_ENABLE 0x3000 + +#define S_NONFATALERR 30 +#define V_NONFATALERR(x) ((x) << S_NONFATALERR) +#define F_NONFATALERR V_NONFATALERR(1U) + +#define S_UNXSPLCPLERR 29 +#define V_UNXSPLCPLERR(x) ((x) << S_UNXSPLCPLERR) +#define F_UNXSPLCPLERR V_UNXSPLCPLERR(1U) + +#define S_PCIEPINT 28 +#define V_PCIEPINT(x) ((x) << S_PCIEPINT) +#define F_PCIEPINT V_PCIEPINT(1U) + +#define S_PCIESINT 27 +#define V_PCIESINT(x) ((x) << S_PCIESINT) +#define F_PCIESINT V_PCIESINT(1U) + +#define S_RPLPERR 26 +#define V_RPLPERR(x) ((x) << S_RPLPERR) +#define F_RPLPERR V_RPLPERR(1U) + +#define S_RXWRPERR 25 +#define V_RXWRPERR(x) ((x) << S_RXWRPERR) +#define F_RXWRPERR V_RXWRPERR(1U) + +#define S_RXCPLPERR 24 +#define V_RXCPLPERR(x) ((x) << S_RXCPLPERR) +#define F_RXCPLPERR V_RXCPLPERR(1U) + +#define S_PIOTAGPERR 23 +#define V_PIOTAGPERR(x) ((x) << S_PIOTAGPERR) +#define F_PIOTAGPERR V_PIOTAGPERR(1U) + +#define S_MATAGPERR 22 +#define V_MATAGPERR(x) ((x) << S_MATAGPERR) +#define F_MATAGPERR V_MATAGPERR(1U) + +#define S_INTXCLRPERR 21 +#define V_INTXCLRPERR(x) ((x) << S_INTXCLRPERR) +#define F_INTXCLRPERR V_INTXCLRPERR(1U) + +#define S_FIDPERR 20 +#define V_FIDPERR(x) ((x) << S_FIDPERR) +#define F_FIDPERR V_FIDPERR(1U) + +#define S_CFGSNPPERR 19 +#define V_CFGSNPPERR(x) ((x) << S_CFGSNPPERR) +#define F_CFGSNPPERR V_CFGSNPPERR(1U) + +#define S_HRSPPERR 18 +#define V_HRSPPERR(x) ((x) << S_HRSPPERR) +#define F_HRSPPERR V_HRSPPERR(1U) + +#define S_HREQPERR 17 +#define V_HREQPERR(x) ((x) << S_HREQPERR) +#define F_HREQPERR V_HREQPERR(1U) + +#define S_HCNTPERR 16 +#define V_HCNTPERR(x) ((x) << S_HCNTPERR) +#define F_HCNTPERR V_HCNTPERR(1U) + +#define S_DRSPPERR 15 +#define V_DRSPPERR(x) ((x) << S_DRSPPERR) +#define F_DRSPPERR V_DRSPPERR(1U) + +#define S_DREQPERR 14 +#define V_DREQPERR(x) ((x) << S_DREQPERR) +#define F_DREQPERR V_DREQPERR(1U) + +#define S_DCNTPERR 13 +#define V_DCNTPERR(x) ((x) << S_DCNTPERR) +#define F_DCNTPERR V_DCNTPERR(1U) + +#define S_CRSPPERR 12 +#define V_CRSPPERR(x) ((x) << S_CRSPPERR) +#define F_CRSPPERR V_CRSPPERR(1U) + +#define S_CREQPERR 11 +#define V_CREQPERR(x) ((x) << S_CREQPERR) +#define F_CREQPERR V_CREQPERR(1U) + +#define S_CCNTPERR 10 +#define V_CCNTPERR(x) ((x) << S_CCNTPERR) +#define F_CCNTPERR V_CCNTPERR(1U) + +#define S_TARTAGPERR 9 +#define V_TARTAGPERR(x) ((x) << S_TARTAGPERR) +#define F_TARTAGPERR V_TARTAGPERR(1U) + +#define S_PIOREQPERR 8 +#define V_PIOREQPERR(x) ((x) << S_PIOREQPERR) +#define F_PIOREQPERR V_PIOREQPERR(1U) + +#define S_PIOCPLPERR 7 +#define V_PIOCPLPERR(x) ((x) << S_PIOCPLPERR) +#define F_PIOCPLPERR V_PIOCPLPERR(1U) + +#define S_MSIXDIPERR 6 +#define V_MSIXDIPERR(x) ((x) << S_MSIXDIPERR) +#define F_MSIXDIPERR V_MSIXDIPERR(1U) + +#define S_MSIXDATAPERR 5 +#define V_MSIXDATAPERR(x) ((x) << S_MSIXDATAPERR) +#define F_MSIXDATAPERR V_MSIXDATAPERR(1U) + +#define S_MSIXADDRHPERR 4 +#define V_MSIXADDRHPERR(x) ((x) << S_MSIXADDRHPERR) +#define F_MSIXADDRHPERR V_MSIXADDRHPERR(1U) + +#define S_MSIXADDRLPERR 3 +#define V_MSIXADDRLPERR(x) ((x) << S_MSIXADDRLPERR) +#define F_MSIXADDRLPERR V_MSIXADDRLPERR(1U) + +#define S_MSIDATAPERR 2 +#define V_MSIDATAPERR(x) ((x) << S_MSIDATAPERR) +#define F_MSIDATAPERR V_MSIDATAPERR(1U) + +#define S_MSIADDRHPERR 1 +#define V_MSIADDRHPERR(x) ((x) << S_MSIADDRHPERR) +#define F_MSIADDRHPERR V_MSIADDRHPERR(1U) + +#define S_MSIADDRLPERR 0 +#define V_MSIADDRLPERR(x) ((x) << S_MSIADDRLPERR) +#define F_MSIADDRLPERR V_MSIADDRLPERR(1U) + +#define S_IPGRPPERR 31 +#define V_IPGRPPERR(x) ((x) << S_IPGRPPERR) +#define F_IPGRPPERR V_IPGRPPERR(1U) + +#define S_READRSPERR 29 +#define V_READRSPERR(x) ((x) << S_READRSPERR) +#define F_READRSPERR V_READRSPERR(1U) + +#define S_TRGT1GRPPERR 28 +#define V_TRGT1GRPPERR(x) ((x) << S_TRGT1GRPPERR) +#define F_TRGT1GRPPERR V_TRGT1GRPPERR(1U) + +#define S_IPSOTPERR 27 +#define V_IPSOTPERR(x) ((x) << S_IPSOTPERR) +#define F_IPSOTPERR V_IPSOTPERR(1U) + +#define S_IPRETRYPERR 26 +#define V_IPRETRYPERR(x) ((x) << S_IPRETRYPERR) +#define F_IPRETRYPERR V_IPRETRYPERR(1U) + +#define S_IPRXDATAGRPPERR 25 +#define V_IPRXDATAGRPPERR(x) ((x) << S_IPRXDATAGRPPERR) +#define F_IPRXDATAGRPPERR V_IPRXDATAGRPPERR(1U) + +#define S_IPRXHDRGRPPERR 24 +#define V_IPRXHDRGRPPERR(x) ((x) << S_IPRXHDRGRPPERR) +#define F_IPRXHDRGRPPERR V_IPRXHDRGRPPERR(1U) + +#define S_PIOTAGQPERR 23 +#define V_PIOTAGQPERR(x) ((x) << S_PIOTAGQPERR) +#define F_PIOTAGQPERR V_PIOTAGQPERR(1U) + +#define S_MAGRPPERR 22 +#define V_MAGRPPERR(x) ((x) << S_MAGRPPERR) +#define F_MAGRPPERR V_MAGRPPERR(1U) + +#define S_VFIDPERR 21 +#define V_VFIDPERR(x) ((x) << S_VFIDPERR) +#define F_VFIDPERR V_VFIDPERR(1U) + +#define S_HREQRDPERR 17 +#define V_HREQRDPERR(x) ((x) << S_HREQRDPERR) +#define F_HREQRDPERR V_HREQRDPERR(1U) + +#define S_HREQWRPERR 16 +#define V_HREQWRPERR(x) ((x) << S_HREQWRPERR) +#define F_HREQWRPERR V_HREQWRPERR(1U) + +#define S_DREQRDPERR 14 +#define V_DREQRDPERR(x) ((x) << S_DREQRDPERR) +#define F_DREQRDPERR V_DREQRDPERR(1U) + +#define S_DREQWRPERR 13 +#define V_DREQWRPERR(x) ((x) << S_DREQWRPERR) +#define F_DREQWRPERR V_DREQWRPERR(1U) + +#define S_CREQRDPERR 11 +#define V_CREQRDPERR(x) ((x) << S_CREQRDPERR) +#define F_CREQRDPERR V_CREQRDPERR(1U) + +#define S_MSTTAGQPERR 10 +#define V_MSTTAGQPERR(x) ((x) << S_MSTTAGQPERR) +#define F_MSTTAGQPERR V_MSTTAGQPERR(1U) + +#define S_TGTTAGQPERR 9 +#define V_TGTTAGQPERR(x) ((x) << S_TGTTAGQPERR) +#define F_TGTTAGQPERR V_TGTTAGQPERR(1U) + +#define S_PIOREQGRPPERR 8 +#define V_PIOREQGRPPERR(x) ((x) << S_PIOREQGRPPERR) +#define F_PIOREQGRPPERR V_PIOREQGRPPERR(1U) + +#define S_PIOCPLGRPPERR 7 +#define V_PIOCPLGRPPERR(x) ((x) << S_PIOCPLGRPPERR) +#define F_PIOCPLGRPPERR V_PIOCPLGRPPERR(1U) + +#define S_MSIXSTIPERR 2 +#define V_MSIXSTIPERR(x) ((x) << S_MSIXSTIPERR) +#define F_MSIXSTIPERR V_MSIXSTIPERR(1U) + +#define S_MSTTIMEOUTPERR 1 +#define V_MSTTIMEOUTPERR(x) ((x) << S_MSTTIMEOUTPERR) +#define F_MSTTIMEOUTPERR V_MSTTIMEOUTPERR(1U) + +#define S_MSTGRPPERR 0 +#define V_MSTGRPPERR(x) ((x) << S_MSTGRPPERR) +#define F_MSTGRPPERR V_MSTGRPPERR(1U) + +#define A_PCIE_INT_CAUSE 0x3004 +#define A_PCIE_PERR_ENABLE 0x3008 +#define A_PCIE_PERR_INJECT 0x300c + +#define S_IDE 0 +#define V_IDE(x) ((x) << S_IDE) +#define F_IDE V_IDE(1U) + +#define A_PCIE_NONFAT_ERR 0x3010 + +#define S_RDRSPERR 9 +#define V_RDRSPERR(x) ((x) << S_RDRSPERR) +#define F_RDRSPERR V_RDRSPERR(1U) + +#define S_VPDRSPERR 8 +#define V_VPDRSPERR(x) ((x) << S_VPDRSPERR) +#define F_VPDRSPERR V_VPDRSPERR(1U) + +#define S_POPD 7 +#define V_POPD(x) ((x) << S_POPD) +#define F_POPD V_POPD(1U) + +#define S_POPH 6 +#define V_POPH(x) ((x) << S_POPH) +#define F_POPH V_POPH(1U) + +#define S_POPC 5 +#define V_POPC(x) ((x) << S_POPC) +#define F_POPC V_POPC(1U) + +#define S_MEMREQ 4 +#define V_MEMREQ(x) ((x) << S_MEMREQ) +#define F_MEMREQ V_MEMREQ(1U) + +#define S_PIOREQ 3 +#define V_PIOREQ(x) ((x) << S_PIOREQ) +#define F_PIOREQ V_PIOREQ(1U) + +#define S_TAGDROP 2 +#define V_TAGDROP(x) ((x) << S_TAGDROP) +#define F_TAGDROP V_TAGDROP(1U) + +#define S_TAGCPL 1 +#define V_TAGCPL(x) ((x) << S_TAGCPL) +#define F_TAGCPL V_TAGCPL(1U) + +#define S_CFGSNP 0 +#define V_CFGSNP(x) ((x) << S_CFGSNP) +#define F_CFGSNP V_CFGSNP(1U) + +#define S_MAREQTIMEOUT 29 +#define V_MAREQTIMEOUT(x) ((x) << S_MAREQTIMEOUT) +#define F_MAREQTIMEOUT V_MAREQTIMEOUT(1U) + +#define S_TRGT1BARTYPEERR 28 +#define V_TRGT1BARTYPEERR(x) ((x) << S_TRGT1BARTYPEERR) +#define F_TRGT1BARTYPEERR V_TRGT1BARTYPEERR(1U) + +#define S_MAEXTRARSPERR 27 +#define V_MAEXTRARSPERR(x) ((x) << S_MAEXTRARSPERR) +#define F_MAEXTRARSPERR V_MAEXTRARSPERR(1U) + +#define S_MARSPTIMEOUT 26 +#define V_MARSPTIMEOUT(x) ((x) << S_MARSPTIMEOUT) +#define F_MARSPTIMEOUT V_MARSPTIMEOUT(1U) + +#define S_INTVFALLMSIDISERR 25 +#define V_INTVFALLMSIDISERR(x) ((x) << S_INTVFALLMSIDISERR) +#define F_INTVFALLMSIDISERR V_INTVFALLMSIDISERR(1U) + +#define S_INTVFRANGEERR 24 +#define V_INTVFRANGEERR(x) ((x) << S_INTVFRANGEERR) +#define F_INTVFRANGEERR V_INTVFRANGEERR(1U) + +#define S_INTPLIRSPERR 23 +#define V_INTPLIRSPERR(x) ((x) << S_INTPLIRSPERR) +#define F_INTPLIRSPERR V_INTPLIRSPERR(1U) + +#define S_MEMREQRDTAGERR 22 +#define V_MEMREQRDTAGERR(x) ((x) << S_MEMREQRDTAGERR) +#define F_MEMREQRDTAGERR V_MEMREQRDTAGERR(1U) + +#define S_CFGINITDONEERR 21 +#define V_CFGINITDONEERR(x) ((x) << S_CFGINITDONEERR) +#define F_CFGINITDONEERR V_CFGINITDONEERR(1U) + +#define S_BAR2TIMEOUT 20 +#define V_BAR2TIMEOUT(x) ((x) << S_BAR2TIMEOUT) +#define F_BAR2TIMEOUT V_BAR2TIMEOUT(1U) + +#define S_VPDTIMEOUT 19 +#define V_VPDTIMEOUT(x) ((x) << S_VPDTIMEOUT) +#define F_VPDTIMEOUT V_VPDTIMEOUT(1U) + +#define S_MEMRSPRDTAGERR 18 +#define V_MEMRSPRDTAGERR(x) ((x) << S_MEMRSPRDTAGERR) +#define F_MEMRSPRDTAGERR V_MEMRSPRDTAGERR(1U) + +#define S_MEMRSPWRTAGERR 17 +#define V_MEMRSPWRTAGERR(x) ((x) << S_MEMRSPWRTAGERR) +#define F_MEMRSPWRTAGERR V_MEMRSPWRTAGERR(1U) + +#define S_PIORSPRDTAGERR 16 +#define V_PIORSPRDTAGERR(x) ((x) << S_PIORSPRDTAGERR) +#define F_PIORSPRDTAGERR V_PIORSPRDTAGERR(1U) + +#define S_PIORSPWRTAGERR 15 +#define V_PIORSPWRTAGERR(x) ((x) << S_PIORSPWRTAGERR) +#define F_PIORSPWRTAGERR V_PIORSPWRTAGERR(1U) + +#define S_DBITIMEOUT 14 +#define V_DBITIMEOUT(x) ((x) << S_DBITIMEOUT) +#define F_DBITIMEOUT V_DBITIMEOUT(1U) + +#define S_PIOUNALINDWR 13 +#define V_PIOUNALINDWR(x) ((x) << S_PIOUNALINDWR) +#define F_PIOUNALINDWR V_PIOUNALINDWR(1U) + +#define S_BAR2RDERR 12 +#define V_BAR2RDERR(x) ((x) << S_BAR2RDERR) +#define F_BAR2RDERR V_BAR2RDERR(1U) + +#define S_MAWREOPERR 11 +#define V_MAWREOPERR(x) ((x) << S_MAWREOPERR) +#define F_MAWREOPERR V_MAWREOPERR(1U) + +#define S_MARDEOPERR 10 +#define V_MARDEOPERR(x) ((x) << S_MARDEOPERR) +#define F_MARDEOPERR V_MARDEOPERR(1U) + +#define S_BAR2REQ 2 +#define V_BAR2REQ(x) ((x) << S_BAR2REQ) +#define F_BAR2REQ V_BAR2REQ(1U) + +#define A_PCIE_CFG 0x3014 + +#define S_CFGDMAXPYLDSZRX 26 +#define M_CFGDMAXPYLDSZRX 0x7U +#define V_CFGDMAXPYLDSZRX(x) ((x) << S_CFGDMAXPYLDSZRX) +#define G_CFGDMAXPYLDSZRX(x) (((x) >> S_CFGDMAXPYLDSZRX) & M_CFGDMAXPYLDSZRX) + +#define S_CFGDMAXPYLDSZTX 23 +#define M_CFGDMAXPYLDSZTX 0x7U +#define V_CFGDMAXPYLDSZTX(x) ((x) << S_CFGDMAXPYLDSZTX) +#define G_CFGDMAXPYLDSZTX(x) (((x) >> S_CFGDMAXPYLDSZTX) & M_CFGDMAXPYLDSZTX) + +#define S_CFGDMAXRDREQSZ 20 +#define M_CFGDMAXRDREQSZ 0x7U +#define V_CFGDMAXRDREQSZ(x) ((x) << S_CFGDMAXRDREQSZ) +#define G_CFGDMAXRDREQSZ(x) (((x) >> S_CFGDMAXRDREQSZ) & M_CFGDMAXRDREQSZ) + +#define S_MASYNCEN 19 +#define V_MASYNCEN(x) ((x) << S_MASYNCEN) +#define F_MASYNCEN V_MASYNCEN(1U) + +#define S_DCAENDMA 18 +#define V_DCAENDMA(x) ((x) << S_DCAENDMA) +#define F_DCAENDMA V_DCAENDMA(1U) + +#define S_DCAENCMD 17 +#define V_DCAENCMD(x) ((x) << S_DCAENCMD) +#define F_DCAENCMD V_DCAENCMD(1U) + +#define S_VFMSIPNDEN 16 +#define V_VFMSIPNDEN(x) ((x) << S_VFMSIPNDEN) +#define F_VFMSIPNDEN V_VFMSIPNDEN(1U) + +#define S_FORCETXERROR 15 +#define V_FORCETXERROR(x) ((x) << S_FORCETXERROR) +#define F_FORCETXERROR V_FORCETXERROR(1U) + +#define S_VPDREQPROTECT 14 +#define V_VPDREQPROTECT(x) ((x) << S_VPDREQPROTECT) +#define F_VPDREQPROTECT V_VPDREQPROTECT(1U) + +#define S_FIDTABLEINVALID 13 +#define V_FIDTABLEINVALID(x) ((x) << S_FIDTABLEINVALID) +#define F_FIDTABLEINVALID V_FIDTABLEINVALID(1U) + +#define S_BYPASSMSIXCACHE 12 +#define V_BYPASSMSIXCACHE(x) ((x) << S_BYPASSMSIXCACHE) +#define F_BYPASSMSIXCACHE V_BYPASSMSIXCACHE(1U) + +#define S_BYPASSMSICACHE 11 +#define V_BYPASSMSICACHE(x) ((x) << S_BYPASSMSICACHE) +#define F_BYPASSMSICACHE V_BYPASSMSICACHE(1U) + +#define S_SIMSPEED 10 +#define V_SIMSPEED(x) ((x) << S_SIMSPEED) +#define F_SIMSPEED V_SIMSPEED(1U) + +#define S_TC0_STAMP 9 +#define V_TC0_STAMP(x) ((x) << S_TC0_STAMP) +#define F_TC0_STAMP V_TC0_STAMP(1U) + +#define S_AI_TCVAL 6 +#define M_AI_TCVAL 0x7U +#define V_AI_TCVAL(x) ((x) << S_AI_TCVAL) +#define G_AI_TCVAL(x) (((x) >> S_AI_TCVAL) & M_AI_TCVAL) + +#define S_DMASTOPEN 5 +#define V_DMASTOPEN(x) ((x) << S_DMASTOPEN) +#define F_DMASTOPEN V_DMASTOPEN(1U) + +#define S_DEVSTATERSTMODE 4 +#define V_DEVSTATERSTMODE(x) ((x) << S_DEVSTATERSTMODE) +#define F_DEVSTATERSTMODE V_DEVSTATERSTMODE(1U) + +#define S_HOTRSTPCIECRSTMODE 3 +#define V_HOTRSTPCIECRSTMODE(x) ((x) << S_HOTRSTPCIECRSTMODE) +#define F_HOTRSTPCIECRSTMODE V_HOTRSTPCIECRSTMODE(1U) + +#define S_DLDNPCIECRSTMODE 2 +#define V_DLDNPCIECRSTMODE(x) ((x) << S_DLDNPCIECRSTMODE) +#define F_DLDNPCIECRSTMODE V_DLDNPCIECRSTMODE(1U) + +#define S_DLDNPCIEPRECRSTMODE 1 +#define V_DLDNPCIEPRECRSTMODE(x) ((x) << S_DLDNPCIEPRECRSTMODE) +#define F_DLDNPCIEPRECRSTMODE V_DLDNPCIEPRECRSTMODE(1U) + +#define S_LINKDNRSTEN 0 +#define V_LINKDNRSTEN(x) ((x) << S_LINKDNRSTEN) +#define F_LINKDNRSTEN V_LINKDNRSTEN(1U) + +#define S_DIAGCTRLBUS 28 +#define M_DIAGCTRLBUS 0x7U +#define V_DIAGCTRLBUS(x) ((x) << S_DIAGCTRLBUS) +#define G_DIAGCTRLBUS(x) (((x) >> S_DIAGCTRLBUS) & M_DIAGCTRLBUS) + +#define S_IPPERREN 27 +#define V_IPPERREN(x) ((x) << S_IPPERREN) +#define F_IPPERREN V_IPPERREN(1U) + +#define S_CFGDEXTTAGEN 26 +#define V_CFGDEXTTAGEN(x) ((x) << S_CFGDEXTTAGEN) +#define F_CFGDEXTTAGEN V_CFGDEXTTAGEN(1U) + +#define S_CFGDMAXPYLDSZ 23 +#define M_CFGDMAXPYLDSZ 0x7U +#define V_CFGDMAXPYLDSZ(x) ((x) << S_CFGDMAXPYLDSZ) +#define G_CFGDMAXPYLDSZ(x) (((x) >> S_CFGDMAXPYLDSZ) & M_CFGDMAXPYLDSZ) + +#define S_DCAEN 17 +#define V_DCAEN(x) ((x) << S_DCAEN) +#define F_DCAEN V_DCAEN(1U) + +#define S_T5CMDREQPRIORITY 16 +#define V_T5CMDREQPRIORITY(x) ((x) << S_T5CMDREQPRIORITY) +#define F_T5CMDREQPRIORITY V_T5CMDREQPRIORITY(1U) + +#define S_T5VPDREQPROTECT 14 +#define M_T5VPDREQPROTECT 0x3U +#define V_T5VPDREQPROTECT(x) ((x) << S_T5VPDREQPROTECT) +#define G_T5VPDREQPROTECT(x) (((x) >> S_T5VPDREQPROTECT) & M_T5VPDREQPROTECT) + +#define S_DROPPEDRDRSPDATA 12 +#define V_DROPPEDRDRSPDATA(x) ((x) << S_DROPPEDRDRSPDATA) +#define F_DROPPEDRDRSPDATA V_DROPPEDRDRSPDATA(1U) + +#define S_AI_INTX_REASSERTEN 11 +#define V_AI_INTX_REASSERTEN(x) ((x) << S_AI_INTX_REASSERTEN) +#define F_AI_INTX_REASSERTEN V_AI_INTX_REASSERTEN(1U) + +#define S_AUTOTXNDISABLE 10 +#define V_AUTOTXNDISABLE(x) ((x) << S_AUTOTXNDISABLE) +#define F_AUTOTXNDISABLE V_AUTOTXNDISABLE(1U) + +#define S_LINKREQRSTPCIECRSTMODE 3 +#define V_LINKREQRSTPCIECRSTMODE(x) ((x) << S_LINKREQRSTPCIECRSTMODE) +#define F_LINKREQRSTPCIECRSTMODE V_LINKREQRSTPCIECRSTMODE(1U) + +#define A_PCIE_DMA_CTRL 0x3018 + +#define S_LITTLEENDIAN 7 +#define V_LITTLEENDIAN(x) ((x) << S_LITTLEENDIAN) +#define F_LITTLEENDIAN V_LITTLEENDIAN(1U) + +#define A_PCIE_CFG2 0x3018 + +#define S_VPDTIMER 16 +#define M_VPDTIMER 0xffffU +#define V_VPDTIMER(x) ((x) << S_VPDTIMER) +#define G_VPDTIMER(x) (((x) >> S_VPDTIMER) & M_VPDTIMER) + +#define S_BAR2TIMER 4 +#define M_BAR2TIMER 0xfffU +#define V_BAR2TIMER(x) ((x) << S_BAR2TIMER) +#define G_BAR2TIMER(x) (((x) >> S_BAR2TIMER) & M_BAR2TIMER) + +#define S_MSTREQRDRRASIMPLE 3 +#define V_MSTREQRDRRASIMPLE(x) ((x) << S_MSTREQRDRRASIMPLE) +#define F_MSTREQRDRRASIMPLE V_MSTREQRDRRASIMPLE(1U) + +#define S_TOTMAXTAG 0 +#define M_TOTMAXTAG 0x3U +#define V_TOTMAXTAG(x) ((x) << S_TOTMAXTAG) +#define G_TOTMAXTAG(x) (((x) >> S_TOTMAXTAG) & M_TOTMAXTAG) + +#define A_PCIE_DMA_CFG 0x301c + +#define S_MAXPYLDSIZE 28 +#define M_MAXPYLDSIZE 0x7U +#define V_MAXPYLDSIZE(x) ((x) << S_MAXPYLDSIZE) +#define G_MAXPYLDSIZE(x) (((x) >> S_MAXPYLDSIZE) & M_MAXPYLDSIZE) + +#define S_MAXRDREQSIZE 25 +#define M_MAXRDREQSIZE 0x7U +#define V_MAXRDREQSIZE(x) ((x) << S_MAXRDREQSIZE) +#define G_MAXRDREQSIZE(x) (((x) >> S_MAXRDREQSIZE) & M_MAXRDREQSIZE) + +#define S_DMA_MAXRSPCNT 16 +#define M_DMA_MAXRSPCNT 0x1ffU +#define V_DMA_MAXRSPCNT(x) ((x) << S_DMA_MAXRSPCNT) +#define G_DMA_MAXRSPCNT(x) (((x) >> S_DMA_MAXRSPCNT) & M_DMA_MAXRSPCNT) + +#define S_DMA_MAXREQCNT 8 +#define M_DMA_MAXREQCNT 0xffU +#define V_DMA_MAXREQCNT(x) ((x) << S_DMA_MAXREQCNT) +#define G_DMA_MAXREQCNT(x) (((x) >> S_DMA_MAXREQCNT) & M_DMA_MAXREQCNT) + +#define S_MAXTAG 0 +#define M_MAXTAG 0x7fU +#define V_MAXTAG(x) ((x) << S_MAXTAG) +#define G_MAXTAG(x) (((x) >> S_MAXTAG) & M_MAXTAG) + +#define A_PCIE_CFG3 0x301c + +#define S_AUTOPIOCOOKIEMATCH 6 +#define V_AUTOPIOCOOKIEMATCH(x) ((x) << S_AUTOPIOCOOKIEMATCH) +#define F_AUTOPIOCOOKIEMATCH V_AUTOPIOCOOKIEMATCH(1U) + +#define S_FLRPNDCPLMODE 4 +#define M_FLRPNDCPLMODE 0x3U +#define V_FLRPNDCPLMODE(x) ((x) << S_FLRPNDCPLMODE) +#define G_FLRPNDCPLMODE(x) (((x) >> S_FLRPNDCPLMODE) & M_FLRPNDCPLMODE) + +#define S_HMADCASTFIRSTONLY 2 +#define V_HMADCASTFIRSTONLY(x) ((x) << S_HMADCASTFIRSTONLY) +#define F_HMADCASTFIRSTONLY V_HMADCASTFIRSTONLY(1U) + +#define S_CMDDCASTFIRSTONLY 1 +#define V_CMDDCASTFIRSTONLY(x) ((x) << S_CMDDCASTFIRSTONLY) +#define F_CMDDCASTFIRSTONLY V_CMDDCASTFIRSTONLY(1U) + +#define S_DMADCASTFIRSTONLY 0 +#define V_DMADCASTFIRSTONLY(x) ((x) << S_DMADCASTFIRSTONLY) +#define F_DMADCASTFIRSTONLY V_DMADCASTFIRSTONLY(1U) + +#define A_PCIE_DMA_STAT 0x3020 + +#define S_STATEREQ 28 +#define M_STATEREQ 0xfU +#define V_STATEREQ(x) ((x) << S_STATEREQ) +#define G_STATEREQ(x) (((x) >> S_STATEREQ) & M_STATEREQ) + +#define S_DMA_RSPCNT 16 +#define M_DMA_RSPCNT 0xfffU +#define V_DMA_RSPCNT(x) ((x) << S_DMA_RSPCNT) +#define G_DMA_RSPCNT(x) (((x) >> S_DMA_RSPCNT) & M_DMA_RSPCNT) + +#define S_STATEAREQ 13 +#define M_STATEAREQ 0x7U +#define V_STATEAREQ(x) ((x) << S_STATEAREQ) +#define G_STATEAREQ(x) (((x) >> S_STATEAREQ) & M_STATEAREQ) + +#define S_TAGFREE 12 +#define V_TAGFREE(x) ((x) << S_TAGFREE) +#define F_TAGFREE V_TAGFREE(1U) + +#define S_DMA_REQCNT 0 +#define M_DMA_REQCNT 0x7ffU +#define V_DMA_REQCNT(x) ((x) << S_DMA_REQCNT) +#define G_DMA_REQCNT(x) (((x) >> S_DMA_REQCNT) & M_DMA_REQCNT) + +#define A_PCIE_CFG4 0x3020 + +#define S_L1CLKREMOVALEN 17 +#define V_L1CLKREMOVALEN(x) ((x) << S_L1CLKREMOVALEN) +#define F_L1CLKREMOVALEN V_L1CLKREMOVALEN(1U) + +#define S_READYENTERL23 16 +#define V_READYENTERL23(x) ((x) << S_READYENTERL23) +#define F_READYENTERL23 V_READYENTERL23(1U) + +#define S_EXITL1 12 +#define V_EXITL1(x) ((x) << S_EXITL1) +#define F_EXITL1 V_EXITL1(1U) + +#define S_ENTERL1 8 +#define V_ENTERL1(x) ((x) << S_ENTERL1) +#define F_ENTERL1 V_ENTERL1(1U) + +#define S_GENPME 0 +#define M_GENPME 0xffU +#define V_GENPME(x) ((x) << S_GENPME) +#define G_GENPME(x) (((x) >> S_GENPME) & M_GENPME) + +#define A_PCIE_CFG5 0x3024 + +#define S_ENABLESKPPARITYFIX 2 +#define V_ENABLESKPPARITYFIX(x) ((x) << S_ENABLESKPPARITYFIX) +#define F_ENABLESKPPARITYFIX V_ENABLESKPPARITYFIX(1U) + +#define S_ENABLEL2ENTRYINL1 1 +#define V_ENABLEL2ENTRYINL1(x) ((x) << S_ENABLEL2ENTRYINL1) +#define F_ENABLEL2ENTRYINL1 V_ENABLEL2ENTRYINL1(1U) + +#define S_HOLDCPLENTERINGL1 0 +#define V_HOLDCPLENTERINGL1(x) ((x) << S_HOLDCPLENTERINGL1) +#define F_HOLDCPLENTERINGL1 V_HOLDCPLENTERINGL1(1U) + +#define A_PCIE_CFG6 0x3028 + +#define S_PERSTTIMERCOUNT 12 +#define M_PERSTTIMERCOUNT 0x3fffU +#define V_PERSTTIMERCOUNT(x) ((x) << S_PERSTTIMERCOUNT) +#define G_PERSTTIMERCOUNT(x) (((x) >> S_PERSTTIMERCOUNT) & M_PERSTTIMERCOUNT) + +#define S_PERSTTIMEOUT 8 +#define V_PERSTTIMEOUT(x) ((x) << S_PERSTTIMEOUT) +#define F_PERSTTIMEOUT V_PERSTTIMEOUT(1U) + +#define S_PERSTTIMER 0 +#define M_PERSTTIMER 0xfU +#define V_PERSTTIMER(x) ((x) << S_PERSTTIMER) +#define G_PERSTTIMER(x) (((x) >> S_PERSTTIMER) & M_PERSTTIMER) + +#define A_PCIE_CMD_CTRL 0x303c +#define A_PCIE_CMD_CFG 0x3040 + +#define S_MAXRSPCNT 16 +#define M_MAXRSPCNT 0xfU +#define V_MAXRSPCNT(x) ((x) << S_MAXRSPCNT) +#define G_MAXRSPCNT(x) (((x) >> S_MAXRSPCNT) & M_MAXRSPCNT) + +#define S_MAXREQCNT 8 +#define M_MAXREQCNT 0x1fU +#define V_MAXREQCNT(x) ((x) << S_MAXREQCNT) +#define G_MAXREQCNT(x) (((x) >> S_MAXREQCNT) & M_MAXREQCNT) + +#define A_PCIE_CMD_STAT 0x3044 + +#define S_RSPCNT 16 +#define M_RSPCNT 0x7fU +#define V_RSPCNT(x) ((x) << S_RSPCNT) +#define G_RSPCNT(x) (((x) >> S_RSPCNT) & M_RSPCNT) + +#define S_REQCNT 0 +#define M_REQCNT 0xffU +#define V_REQCNT(x) ((x) << S_REQCNT) +#define G_REQCNT(x) (((x) >> S_REQCNT) & M_REQCNT) + +#define A_PCIE_HMA_CTRL 0x3050 + +#define S_IPLTSSM 12 +#define M_IPLTSSM 0xfU +#define V_IPLTSSM(x) ((x) << S_IPLTSSM) +#define G_IPLTSSM(x) (((x) >> S_IPLTSSM) & M_IPLTSSM) + +#define S_IPCONFIGDOWN 8 +#define M_IPCONFIGDOWN 0x7U +#define V_IPCONFIGDOWN(x) ((x) << S_IPCONFIGDOWN) +#define G_IPCONFIGDOWN(x) (((x) >> S_IPCONFIGDOWN) & M_IPCONFIGDOWN) + +#define A_PCIE_HMA_CFG 0x3054 + +#define S_HMA_MAXRSPCNT 16 +#define M_HMA_MAXRSPCNT 0x1fU +#define V_HMA_MAXRSPCNT(x) ((x) << S_HMA_MAXRSPCNT) +#define G_HMA_MAXRSPCNT(x) (((x) >> S_HMA_MAXRSPCNT) & M_HMA_MAXRSPCNT) + +#define A_PCIE_HMA_STAT 0x3058 + +#define S_HMA_RSPCNT 16 +#define M_HMA_RSPCNT 0xffU +#define V_HMA_RSPCNT(x) ((x) << S_HMA_RSPCNT) +#define G_HMA_RSPCNT(x) (((x) >> S_HMA_RSPCNT) & M_HMA_RSPCNT) + +#define A_PCIE_PIO_FIFO_CFG 0x305c + +#define S_CPLCONFIG 16 +#define M_CPLCONFIG 0xffffU +#define V_CPLCONFIG(x) ((x) << S_CPLCONFIG) +#define G_CPLCONFIG(x) (((x) >> S_CPLCONFIG) & M_CPLCONFIG) + +#define S_PIOSTOPEN 12 +#define V_PIOSTOPEN(x) ((x) << S_PIOSTOPEN) +#define F_PIOSTOPEN V_PIOSTOPEN(1U) + +#define S_IPLANESWAP 11 +#define V_IPLANESWAP(x) ((x) << S_IPLANESWAP) +#define F_IPLANESWAP V_IPLANESWAP(1U) + +#define S_FORCESTRICTTS1 10 +#define V_FORCESTRICTTS1(x) ((x) << S_FORCESTRICTTS1) +#define F_FORCESTRICTTS1 V_FORCESTRICTTS1(1U) + +#define S_FORCEPROGRESSCNT 0 +#define M_FORCEPROGRESSCNT 0x3ffU +#define V_FORCEPROGRESSCNT(x) ((x) << S_FORCEPROGRESSCNT) +#define G_FORCEPROGRESSCNT(x) (((x) >> S_FORCEPROGRESSCNT) & M_FORCEPROGRESSCNT) + +#define A_PCIE_CFG_SPACE_REQ 0x3060 + +#define S_ENABLE 30 +#define V_ENABLE(x) ((x) << S_ENABLE) +#define F_ENABLE V_ENABLE(1U) + +#define S_AI 29 +#define V_AI(x) ((x) << S_AI) +#define F_AI V_AI(1U) + +#define S_LOCALCFG 28 +#define V_LOCALCFG(x) ((x) << S_LOCALCFG) +#define F_LOCALCFG V_LOCALCFG(1U) + +#define S_BUS 20 +#define M_BUS 0xffU +#define V_BUS(x) ((x) << S_BUS) +#define G_BUS(x) (((x) >> S_BUS) & M_BUS) + +#define S_DEVICE 15 +#define M_DEVICE 0x1fU +#define V_DEVICE(x) ((x) << S_DEVICE) +#define G_DEVICE(x) (((x) >> S_DEVICE) & M_DEVICE) + +#define S_FUNCTION 12 +#define M_FUNCTION 0x7U +#define V_FUNCTION(x) ((x) << S_FUNCTION) +#define G_FUNCTION(x) (((x) >> S_FUNCTION) & M_FUNCTION) + +#define S_EXTREGISTER 8 +#define M_EXTREGISTER 0xfU +#define V_EXTREGISTER(x) ((x) << S_EXTREGISTER) +#define G_EXTREGISTER(x) (((x) >> S_EXTREGISTER) & M_EXTREGISTER) + +#define S_REGISTER 0 +#define M_REGISTER 0xffU +#define V_REGISTER(x) ((x) << S_REGISTER) +#define G_REGISTER(x) (((x) >> S_REGISTER) & M_REGISTER) + +#define S_CS2 28 +#define V_CS2(x) ((x) << S_CS2) +#define F_CS2 V_CS2(1U) + +#define S_WRBE 24 +#define M_WRBE 0xfU +#define V_WRBE(x) ((x) << S_WRBE) +#define G_WRBE(x) (((x) >> S_WRBE) & M_WRBE) + +#define S_CFG_SPACE_VFVLD 23 +#define V_CFG_SPACE_VFVLD(x) ((x) << S_CFG_SPACE_VFVLD) +#define F_CFG_SPACE_VFVLD V_CFG_SPACE_VFVLD(1U) + +#define S_CFG_SPACE_RVF 16 +#define M_CFG_SPACE_RVF 0x7fU +#define V_CFG_SPACE_RVF(x) ((x) << S_CFG_SPACE_RVF) +#define G_CFG_SPACE_RVF(x) (((x) >> S_CFG_SPACE_RVF) & M_CFG_SPACE_RVF) + +#define S_CFG_SPACE_PF 12 +#define M_CFG_SPACE_PF 0x7U +#define V_CFG_SPACE_PF(x) ((x) << S_CFG_SPACE_PF) +#define G_CFG_SPACE_PF(x) (((x) >> S_CFG_SPACE_PF) & M_CFG_SPACE_PF) + +#define A_PCIE_CFG_SPACE_DATA 0x3064 +#define A_PCIE_MEM_ACCESS_BASE_WIN 0x3068 + +#define S_PCIEOFST 10 +#define M_PCIEOFST 0x3fffffU +#define V_PCIEOFST(x) ((x) << S_PCIEOFST) +#define G_PCIEOFST(x) (((x) >> S_PCIEOFST) & M_PCIEOFST) + +#define S_BIR 8 +#define M_BIR 0x3U +#define V_BIR(x) ((x) << S_BIR) +#define G_BIR(x) (((x) >> S_BIR) & M_BIR) + +#define S_WINDOW 0 +#define M_WINDOW 0xffU +#define V_WINDOW(x) ((x) << S_WINDOW) +#define G_WINDOW(x) (((x) >> S_WINDOW) & M_WINDOW) + +#define A_PCIE_MEM_ACCESS_OFFSET 0x306c + +#define S_MEMOFST 7 +#define M_MEMOFST 0x1ffffffU +#define V_MEMOFST(x) ((x) << S_MEMOFST) +#define G_MEMOFST(x) (((x) >> S_MEMOFST) & M_MEMOFST) + +#define A_PCIE_MAILBOX_BASE_WIN 0x30a8 + +#define S_MBOXPCIEOFST 6 +#define M_MBOXPCIEOFST 0x3ffffffU +#define V_MBOXPCIEOFST(x) ((x) << S_MBOXPCIEOFST) +#define G_MBOXPCIEOFST(x) (((x) >> S_MBOXPCIEOFST) & M_MBOXPCIEOFST) + +#define S_MBOXBIR 4 +#define M_MBOXBIR 0x3U +#define V_MBOXBIR(x) ((x) << S_MBOXBIR) +#define G_MBOXBIR(x) (((x) >> S_MBOXBIR) & M_MBOXBIR) + +#define S_MBOXWIN 0 +#define M_MBOXWIN 0x3U +#define V_MBOXWIN(x) ((x) << S_MBOXWIN) +#define G_MBOXWIN(x) (((x) >> S_MBOXWIN) & M_MBOXWIN) + +#define A_PCIE_MAILBOX_OFFSET 0x30ac +#define A_PCIE_MA_CTRL 0x30b0 + +#define S_MA_TAGFREE 29 +#define V_MA_TAGFREE(x) ((x) << S_MA_TAGFREE) +#define F_MA_TAGFREE V_MA_TAGFREE(1U) + +#define S_MA_MAXRSPCNT 24 +#define M_MA_MAXRSPCNT 0x1fU +#define V_MA_MAXRSPCNT(x) ((x) << S_MA_MAXRSPCNT) +#define G_MA_MAXRSPCNT(x) (((x) >> S_MA_MAXRSPCNT) & M_MA_MAXRSPCNT) + +#define S_MA_MAXREQCNT 16 +#define M_MA_MAXREQCNT 0x1fU +#define V_MA_MAXREQCNT(x) ((x) << S_MA_MAXREQCNT) +#define G_MA_MAXREQCNT(x) (((x) >> S_MA_MAXREQCNT) & M_MA_MAXREQCNT) + +#define S_MA_LE 15 +#define V_MA_LE(x) ((x) << S_MA_LE) +#define F_MA_LE V_MA_LE(1U) + +#define S_MA_MAXPYLDSIZE 12 +#define M_MA_MAXPYLDSIZE 0x7U +#define V_MA_MAXPYLDSIZE(x) ((x) << S_MA_MAXPYLDSIZE) +#define G_MA_MAXPYLDSIZE(x) (((x) >> S_MA_MAXPYLDSIZE) & M_MA_MAXPYLDSIZE) + +#define S_MA_MAXRDREQSIZE 8 +#define M_MA_MAXRDREQSIZE 0x7U +#define V_MA_MAXRDREQSIZE(x) ((x) << S_MA_MAXRDREQSIZE) +#define G_MA_MAXRDREQSIZE(x) (((x) >> S_MA_MAXRDREQSIZE) & M_MA_MAXRDREQSIZE) + +#define S_MA_MAXTAG 0 +#define M_MA_MAXTAG 0x1fU +#define V_MA_MAXTAG(x) ((x) << S_MA_MAXTAG) +#define G_MA_MAXTAG(x) (((x) >> S_MA_MAXTAG) & M_MA_MAXTAG) + +#define S_T5_MA_MAXREQCNT 16 +#define M_T5_MA_MAXREQCNT 0x7fU +#define V_T5_MA_MAXREQCNT(x) ((x) << S_T5_MA_MAXREQCNT) +#define G_T5_MA_MAXREQCNT(x) (((x) >> S_T5_MA_MAXREQCNT) & M_T5_MA_MAXREQCNT) + +#define S_MA_MAXREQSIZE 8 +#define M_MA_MAXREQSIZE 0x7U +#define V_MA_MAXREQSIZE(x) ((x) << S_MA_MAXREQSIZE) +#define G_MA_MAXREQSIZE(x) (((x) >> S_MA_MAXREQSIZE) & M_MA_MAXREQSIZE) + +#define A_PCIE_MA_SYNC 0x30b4 +#define A_PCIE_FW 0x30b8 +#define A_PCIE_FW_PF 0x30bc +#define A_PCIE_PIO_PAUSE 0x30dc + +#define S_PIOPAUSEDONE 31 +#define V_PIOPAUSEDONE(x) ((x) << S_PIOPAUSEDONE) +#define F_PIOPAUSEDONE V_PIOPAUSEDONE(1U) + +#define S_PIOPAUSETIME 4 +#define M_PIOPAUSETIME 0xffffffU +#define V_PIOPAUSETIME(x) ((x) << S_PIOPAUSETIME) +#define G_PIOPAUSETIME(x) (((x) >> S_PIOPAUSETIME) & M_PIOPAUSETIME) + +#define S_PIOPAUSE 0 +#define V_PIOPAUSE(x) ((x) << S_PIOPAUSE) +#define F_PIOPAUSE V_PIOPAUSE(1U) + +#define S_MSTPAUSEDONE 30 +#define V_MSTPAUSEDONE(x) ((x) << S_MSTPAUSEDONE) +#define F_MSTPAUSEDONE V_MSTPAUSEDONE(1U) + +#define S_MSTPAUSE 1 +#define V_MSTPAUSE(x) ((x) << S_MSTPAUSE) +#define F_MSTPAUSE V_MSTPAUSE(1U) + +#define A_PCIE_SYS_CFG_READY 0x30e0 +#define A_PCIE_MA_STAT 0x30e0 +#define A_PCIE_STATIC_CFG1 0x30e4 + +#define S_LINKDOWN_RESET_EN 26 +#define V_LINKDOWN_RESET_EN(x) ((x) << S_LINKDOWN_RESET_EN) +#define F_LINKDOWN_RESET_EN V_LINKDOWN_RESET_EN(1U) + +#define S_IN_WR_DISCONTIG 25 +#define V_IN_WR_DISCONTIG(x) ((x) << S_IN_WR_DISCONTIG) +#define F_IN_WR_DISCONTIG V_IN_WR_DISCONTIG(1U) + +#define S_IN_RD_CPLSIZE 22 +#define M_IN_RD_CPLSIZE 0x7U +#define V_IN_RD_CPLSIZE(x) ((x) << S_IN_RD_CPLSIZE) +#define G_IN_RD_CPLSIZE(x) (((x) >> S_IN_RD_CPLSIZE) & M_IN_RD_CPLSIZE) + +#define S_IN_RD_BUFMODE 20 +#define M_IN_RD_BUFMODE 0x3U +#define V_IN_RD_BUFMODE(x) ((x) << S_IN_RD_BUFMODE) +#define G_IN_RD_BUFMODE(x) (((x) >> S_IN_RD_BUFMODE) & M_IN_RD_BUFMODE) + +#define S_GBIF_NPTRANS_TOT 18 +#define M_GBIF_NPTRANS_TOT 0x3U +#define V_GBIF_NPTRANS_TOT(x) ((x) << S_GBIF_NPTRANS_TOT) +#define G_GBIF_NPTRANS_TOT(x) (((x) >> S_GBIF_NPTRANS_TOT) & M_GBIF_NPTRANS_TOT) + +#define S_IN_PDAT_TOT 15 +#define M_IN_PDAT_TOT 0x7U +#define V_IN_PDAT_TOT(x) ((x) << S_IN_PDAT_TOT) +#define G_IN_PDAT_TOT(x) (((x) >> S_IN_PDAT_TOT) & M_IN_PDAT_TOT) + +#define S_PCIE_NPTRANS_TOT 12 +#define M_PCIE_NPTRANS_TOT 0x7U +#define V_PCIE_NPTRANS_TOT(x) ((x) << S_PCIE_NPTRANS_TOT) +#define G_PCIE_NPTRANS_TOT(x) (((x) >> S_PCIE_NPTRANS_TOT) & M_PCIE_NPTRANS_TOT) + +#define S_OUT_PDAT_TOT 9 +#define M_OUT_PDAT_TOT 0x7U +#define V_OUT_PDAT_TOT(x) ((x) << S_OUT_PDAT_TOT) +#define G_OUT_PDAT_TOT(x) (((x) >> S_OUT_PDAT_TOT) & M_OUT_PDAT_TOT) + +#define S_GBIF_MAX_WRSIZE 6 +#define M_GBIF_MAX_WRSIZE 0x7U +#define V_GBIF_MAX_WRSIZE(x) ((x) << S_GBIF_MAX_WRSIZE) +#define G_GBIF_MAX_WRSIZE(x) (((x) >> S_GBIF_MAX_WRSIZE) & M_GBIF_MAX_WRSIZE) + +#define S_GBIF_MAX_RDSIZE 3 +#define M_GBIF_MAX_RDSIZE 0x7U +#define V_GBIF_MAX_RDSIZE(x) ((x) << S_GBIF_MAX_RDSIZE) +#define G_GBIF_MAX_RDSIZE(x) (((x) >> S_GBIF_MAX_RDSIZE) & M_GBIF_MAX_RDSIZE) + +#define S_PCIE_MAX_RDSIZE 0 +#define M_PCIE_MAX_RDSIZE 0x7U +#define V_PCIE_MAX_RDSIZE(x) ((x) << S_PCIE_MAX_RDSIZE) +#define G_PCIE_MAX_RDSIZE(x) (((x) >> S_PCIE_MAX_RDSIZE) & M_PCIE_MAX_RDSIZE) + +#define S_AUXPOWER_DETECTED 27 +#define V_AUXPOWER_DETECTED(x) ((x) << S_AUXPOWER_DETECTED) +#define F_AUXPOWER_DETECTED V_AUXPOWER_DETECTED(1U) + +#define A_PCIE_STATIC_CFG2 0x30e8 + +#define S_PL_CONTROL 16 +#define M_PL_CONTROL 0xffffU +#define V_PL_CONTROL(x) ((x) << S_PL_CONTROL) +#define G_PL_CONTROL(x) (((x) >> S_PL_CONTROL) & M_PL_CONTROL) + +#define S_STATIC_SPARE3 0 +#define M_STATIC_SPARE3 0x3fffU +#define V_STATIC_SPARE3(x) ((x) << S_STATIC_SPARE3) +#define G_STATIC_SPARE3(x) (((x) >> S_STATIC_SPARE3) & M_STATIC_SPARE3) + +#define A_PCIE_DBG_INDIR_REQ 0x30ec + +#define S_DBGENABLE 31 +#define V_DBGENABLE(x) ((x) << S_DBGENABLE) +#define F_DBGENABLE V_DBGENABLE(1U) + +#define S_DBGAUTOINC 30 +#define V_DBGAUTOINC(x) ((x) << S_DBGAUTOINC) +#define F_DBGAUTOINC V_DBGAUTOINC(1U) + +#define S_POINTER 8 +#define M_POINTER 0xffffU +#define V_POINTER(x) ((x) << S_POINTER) +#define G_POINTER(x) (((x) >> S_POINTER) & M_POINTER) + +#define S_SELECT 0 +#define M_SELECT 0xfU +#define V_SELECT(x) ((x) << S_SELECT) +#define G_SELECT(x) (((x) >> S_SELECT) & M_SELECT) + +#define A_PCIE_DBG_INDIR_DATA_0 0x30f0 +#define A_PCIE_DBG_INDIR_DATA_1 0x30f4 +#define A_PCIE_DBG_INDIR_DATA_2 0x30f8 +#define A_PCIE_DBG_INDIR_DATA_3 0x30fc +#define A_PCIE_FUNC_INT_CFG 0x3100 + +#define S_PBAOFST 28 +#define M_PBAOFST 0xfU +#define V_PBAOFST(x) ((x) << S_PBAOFST) +#define G_PBAOFST(x) (((x) >> S_PBAOFST) & M_PBAOFST) + +#define S_TABOFST 24 +#define M_TABOFST 0xfU +#define V_TABOFST(x) ((x) << S_TABOFST) +#define G_TABOFST(x) (((x) >> S_TABOFST) & M_TABOFST) + +#define S_VECNUM 12 +#define M_VECNUM 0x3ffU +#define V_VECNUM(x) ((x) << S_VECNUM) +#define G_VECNUM(x) (((x) >> S_VECNUM) & M_VECNUM) + +#define S_VECBASE 0 +#define M_VECBASE 0x7ffU +#define V_VECBASE(x) ((x) << S_VECBASE) +#define G_VECBASE(x) (((x) >> S_VECBASE) & M_VECBASE) + +#define A_PCIE_FUNC_CTL_STAT 0x3104 + +#define S_SENDFLRRSP 31 +#define V_SENDFLRRSP(x) ((x) << S_SENDFLRRSP) +#define F_SENDFLRRSP V_SENDFLRRSP(1U) + +#define S_IMMFLRRSP 24 +#define V_IMMFLRRSP(x) ((x) << S_IMMFLRRSP) +#define F_IMMFLRRSP V_IMMFLRRSP(1U) + +#define S_TXNDISABLE 20 +#define V_TXNDISABLE(x) ((x) << S_TXNDISABLE) +#define F_TXNDISABLE V_TXNDISABLE(1U) + +#define S_PNDTXNS 8 +#define M_PNDTXNS 0x3ffU +#define V_PNDTXNS(x) ((x) << S_PNDTXNS) +#define G_PNDTXNS(x) (((x) >> S_PNDTXNS) & M_PNDTXNS) + +#define S_VFVLD 3 +#define V_VFVLD(x) ((x) << S_VFVLD) +#define F_VFVLD V_VFVLD(1U) + +#define S_PFNUM 0 +#define M_PFNUM 0x7U +#define V_PFNUM(x) ((x) << S_PFNUM) +#define G_PFNUM(x) (((x) >> S_PFNUM) & M_PFNUM) + +#define A_PCIE_PF_INT_CFG 0x3140 +#define A_PCIE_PF_INT_CFG2 0x3144 +#define A_PCIE_VF_INT_CFG 0x3180 +#define A_PCIE_VF_INT_CFG2 0x3184 +#define A_PCIE_PF_MSI_EN 0x35a8 + +#define S_PFMSIEN_7_0 0 +#define M_PFMSIEN_7_0 0xffU +#define V_PFMSIEN_7_0(x) ((x) << S_PFMSIEN_7_0) +#define G_PFMSIEN_7_0(x) (((x) >> S_PFMSIEN_7_0) & M_PFMSIEN_7_0) + +#define A_PCIE_VF_MSI_EN_0 0x35ac +#define A_PCIE_VF_MSI_EN_1 0x35b0 +#define A_PCIE_VF_MSI_EN_2 0x35b4 +#define A_PCIE_VF_MSI_EN_3 0x35b8 +#define A_PCIE_PF_MSIX_EN 0x35bc + +#define S_PFMSIXEN_7_0 0 +#define M_PFMSIXEN_7_0 0xffU +#define V_PFMSIXEN_7_0(x) ((x) << S_PFMSIXEN_7_0) +#define G_PFMSIXEN_7_0(x) (((x) >> S_PFMSIXEN_7_0) & M_PFMSIXEN_7_0) + +#define A_PCIE_VF_MSIX_EN_0 0x35c0 +#define A_PCIE_VF_MSIX_EN_1 0x35c4 +#define A_PCIE_VF_MSIX_EN_2 0x35c8 +#define A_PCIE_VF_MSIX_EN_3 0x35cc +#define A_PCIE_FID_VFID_SEL 0x35ec + +#define S_FID_VFID_SEL_SELECT 0 +#define M_FID_VFID_SEL_SELECT 0x3U +#define V_FID_VFID_SEL_SELECT(x) ((x) << S_FID_VFID_SEL_SELECT) +#define G_FID_VFID_SEL_SELECT(x) (((x) >> S_FID_VFID_SEL_SELECT) & M_FID_VFID_SEL_SELECT) + +#define A_PCIE_FID_VFID 0x3600 + +#define S_FID_VFID_SELECT 30 +#define M_FID_VFID_SELECT 0x3U +#define V_FID_VFID_SELECT(x) ((x) << S_FID_VFID_SELECT) +#define G_FID_VFID_SELECT(x) (((x) >> S_FID_VFID_SELECT) & M_FID_VFID_SELECT) + +#define S_IDO 24 +#define V_IDO(x) ((x) << S_IDO) +#define F_IDO V_IDO(1U) + +#define S_FID_VFID_VFID 16 +#define M_FID_VFID_VFID 0xffU +#define V_FID_VFID_VFID(x) ((x) << S_FID_VFID_VFID) +#define G_FID_VFID_VFID(x) (((x) >> S_FID_VFID_VFID) & M_FID_VFID_VFID) + +#define S_FID_VFID_TC 11 +#define M_FID_VFID_TC 0x7U +#define V_FID_VFID_TC(x) ((x) << S_FID_VFID_TC) +#define G_FID_VFID_TC(x) (((x) >> S_FID_VFID_TC) & M_FID_VFID_TC) + +#define S_FID_VFID_VFVLD 10 +#define V_FID_VFID_VFVLD(x) ((x) << S_FID_VFID_VFVLD) +#define F_FID_VFID_VFVLD V_FID_VFID_VFVLD(1U) + +#define S_FID_VFID_PF 7 +#define M_FID_VFID_PF 0x7U +#define V_FID_VFID_PF(x) ((x) << S_FID_VFID_PF) +#define G_FID_VFID_PF(x) (((x) >> S_FID_VFID_PF) & M_FID_VFID_PF) + +#define S_FID_VFID_RVF 0 +#define M_FID_VFID_RVF 0x7fU +#define V_FID_VFID_RVF(x) ((x) << S_FID_VFID_RVF) +#define G_FID_VFID_RVF(x) (((x) >> S_FID_VFID_RVF) & M_FID_VFID_RVF) + +#define A_PCIE_FID 0x3900 + +#define S_PAD 11 +#define V_PAD(x) ((x) << S_PAD) +#define F_PAD V_PAD(1U) + +#define S_TC 8 +#define M_TC 0x7U +#define V_TC(x) ((x) << S_TC) +#define G_TC(x) (((x) >> S_TC) & M_TC) + +#define S_FUNC 0 +#define M_FUNC 0xffU +#define V_FUNC(x) ((x) << S_FUNC) +#define G_FUNC(x) (((x) >> S_FUNC) & M_FUNC) + +#define A_PCIE_COOKIE_STAT 0x5600 + +#define S_COOKIEB 16 +#define M_COOKIEB 0x3ffU +#define V_COOKIEB(x) ((x) << S_COOKIEB) +#define G_COOKIEB(x) (((x) >> S_COOKIEB) & M_COOKIEB) + +#define S_COOKIEA 0 +#define M_COOKIEA 0x3ffU +#define V_COOKIEA(x) ((x) << S_COOKIEA) +#define G_COOKIEA(x) (((x) >> S_COOKIEA) & M_COOKIEA) + +#define A_PCIE_FLR_PIO 0x5620 + +#define S_RCVDBAR2COOKIE 24 +#define M_RCVDBAR2COOKIE 0xffU +#define V_RCVDBAR2COOKIE(x) ((x) << S_RCVDBAR2COOKIE) +#define G_RCVDBAR2COOKIE(x) (((x) >> S_RCVDBAR2COOKIE) & M_RCVDBAR2COOKIE) + +#define S_RCVDMARSPCOOKIE 16 +#define M_RCVDMARSPCOOKIE 0xffU +#define V_RCVDMARSPCOOKIE(x) ((x) << S_RCVDMARSPCOOKIE) +#define G_RCVDMARSPCOOKIE(x) (((x) >> S_RCVDMARSPCOOKIE) & M_RCVDMARSPCOOKIE) + +#define S_RCVDPIORSPCOOKIE 8 +#define M_RCVDPIORSPCOOKIE 0xffU +#define V_RCVDPIORSPCOOKIE(x) ((x) << S_RCVDPIORSPCOOKIE) +#define G_RCVDPIORSPCOOKIE(x) (((x) >> S_RCVDPIORSPCOOKIE) & M_RCVDPIORSPCOOKIE) + +#define S_EXPDCOOKIE 0 +#define M_EXPDCOOKIE 0xffU +#define V_EXPDCOOKIE(x) ((x) << S_EXPDCOOKIE) +#define G_EXPDCOOKIE(x) (((x) >> S_EXPDCOOKIE) & M_EXPDCOOKIE) + +#define A_PCIE_FLR_PIO2 0x5624 + +#define S_RCVDMAREQCOOKIE 16 +#define M_RCVDMAREQCOOKIE 0xffU +#define V_RCVDMAREQCOOKIE(x) ((x) << S_RCVDMAREQCOOKIE) +#define G_RCVDMAREQCOOKIE(x) (((x) >> S_RCVDMAREQCOOKIE) & M_RCVDMAREQCOOKIE) + +#define S_RCVDPIOREQCOOKIE 8 +#define M_RCVDPIOREQCOOKIE 0xffU +#define V_RCVDPIOREQCOOKIE(x) ((x) << S_RCVDPIOREQCOOKIE) +#define G_RCVDPIOREQCOOKIE(x) (((x) >> S_RCVDPIOREQCOOKIE) & M_RCVDPIOREQCOOKIE) + +#define A_PCIE_VC0_CDTS0 0x56cc + +#define S_CPLD0 20 +#define M_CPLD0 0xfffU +#define V_CPLD0(x) ((x) << S_CPLD0) +#define G_CPLD0(x) (((x) >> S_CPLD0) & M_CPLD0) + +#define S_PH0 12 +#define M_PH0 0xffU +#define V_PH0(x) ((x) << S_PH0) +#define G_PH0(x) (((x) >> S_PH0) & M_PH0) + +#define S_PD0 0 +#define M_PD0 0xfffU +#define V_PD0(x) ((x) << S_PD0) +#define G_PD0(x) (((x) >> S_PD0) & M_PD0) + +#define A_PCIE_VC0_CDTS1 0x56d0 + +#define S_CPLH0 20 +#define M_CPLH0 0xffU +#define V_CPLH0(x) ((x) << S_CPLH0) +#define G_CPLH0(x) (((x) >> S_CPLH0) & M_CPLH0) + +#define S_NPH0 12 +#define M_NPH0 0xffU +#define V_NPH0(x) ((x) << S_NPH0) +#define G_NPH0(x) (((x) >> S_NPH0) & M_NPH0) + +#define S_NPD0 0 +#define M_NPD0 0xfffU +#define V_NPD0(x) ((x) << S_NPD0) +#define G_NPD0(x) (((x) >> S_NPD0) & M_NPD0) + +#define A_PCIE_VC1_CDTS0 0x56d4 + +#define S_CPLD1 20 +#define M_CPLD1 0xfffU +#define V_CPLD1(x) ((x) << S_CPLD1) +#define G_CPLD1(x) (((x) >> S_CPLD1) & M_CPLD1) + +#define S_PH1 12 +#define M_PH1 0xffU +#define V_PH1(x) ((x) << S_PH1) +#define G_PH1(x) (((x) >> S_PH1) & M_PH1) + +#define S_PD1 0 +#define M_PD1 0xfffU +#define V_PD1(x) ((x) << S_PD1) +#define G_PD1(x) (((x) >> S_PD1) & M_PD1) + +#define A_PCIE_VC1_CDTS1 0x56d8 + +#define S_CPLH1 20 +#define M_CPLH1 0xffU +#define V_CPLH1(x) ((x) << S_CPLH1) +#define G_CPLH1(x) (((x) >> S_CPLH1) & M_CPLH1) + +#define S_NPH1 12 +#define M_NPH1 0xffU +#define V_NPH1(x) ((x) << S_NPH1) +#define G_NPH1(x) (((x) >> S_NPH1) & M_NPH1) + +#define S_NPD1 0 +#define M_NPD1 0xfffU +#define V_NPD1(x) ((x) << S_NPD1) +#define G_NPD1(x) (((x) >> S_NPD1) & M_NPD1) + +#define A_PCIE_FLR_PF_STATUS 0x56dc +#define A_PCIE_FLR_VF0_STATUS 0x56e0 +#define A_PCIE_FLR_VF1_STATUS 0x56e4 +#define A_PCIE_FLR_VF2_STATUS 0x56e8 +#define A_PCIE_FLR_VF3_STATUS 0x56ec +#define A_PCIE_STAT 0x56f4 + +#define S_PM_STATUS 24 +#define M_PM_STATUS 0xffU +#define V_PM_STATUS(x) ((x) << S_PM_STATUS) +#define G_PM_STATUS(x) (((x) >> S_PM_STATUS) & M_PM_STATUS) + +#define S_PM_CURRENTSTATE 20 +#define M_PM_CURRENTSTATE 0x7U +#define V_PM_CURRENTSTATE(x) ((x) << S_PM_CURRENTSTATE) +#define G_PM_CURRENTSTATE(x) (((x) >> S_PM_CURRENTSTATE) & M_PM_CURRENTSTATE) + +#define S_LTSSMENABLE 12 +#define V_LTSSMENABLE(x) ((x) << S_LTSSMENABLE) +#define F_LTSSMENABLE V_LTSSMENABLE(1U) + +#define S_STATECFGINITF 4 +#define M_STATECFGINITF 0x7fU +#define V_STATECFGINITF(x) ((x) << S_STATECFGINITF) +#define G_STATECFGINITF(x) (((x) >> S_STATECFGINITF) & M_STATECFGINITF) + +#define S_STATECFGINIT 0 +#define M_STATECFGINIT 0xfU +#define V_STATECFGINIT(x) ((x) << S_STATECFGINIT) +#define G_STATECFGINIT(x) (((x) >> S_STATECFGINIT) & M_STATECFGINIT) + +#define A_PCIE_CRS 0x56f8 + +#define S_CRS_ENABLE 0 +#define V_CRS_ENABLE(x) ((x) << S_CRS_ENABLE) +#define F_CRS_ENABLE V_CRS_ENABLE(1U) + +#define A_PCIE_LTSSM 0x56fc + +#define S_LTSSM_ENABLE 0 +#define V_LTSSM_ENABLE(x) ((x) << S_LTSSM_ENABLE) +#define F_LTSSM_ENABLE V_LTSSM_ENABLE(1U) + +#define A_PCIE_CORE_ACK_LATENCY_TIMER_REPLAY_TIMER 0x5700 + +#define S_REPLAY_TIME_LIMIT 16 +#define M_REPLAY_TIME_LIMIT 0xffffU +#define V_REPLAY_TIME_LIMIT(x) ((x) << S_REPLAY_TIME_LIMIT) +#define G_REPLAY_TIME_LIMIT(x) (((x) >> S_REPLAY_TIME_LIMIT) & M_REPLAY_TIME_LIMIT) + +#define S_ACK_LATENCY_TIMER_LIMIT 0 +#define M_ACK_LATENCY_TIMER_LIMIT 0xffffU +#define V_ACK_LATENCY_TIMER_LIMIT(x) ((x) << S_ACK_LATENCY_TIMER_LIMIT) +#define G_ACK_LATENCY_TIMER_LIMIT(x) (((x) >> S_ACK_LATENCY_TIMER_LIMIT) & M_ACK_LATENCY_TIMER_LIMIT) + +#define A_PCIE_CORE_VENDOR_SPECIFIC_DLLP 0x5704 +#define A_PCIE_CORE_PORT_FORCE_LINK 0x5708 + +#define S_LOW_POWER_ENTRANCE_COUNT 24 +#define M_LOW_POWER_ENTRANCE_COUNT 0xffU +#define V_LOW_POWER_ENTRANCE_COUNT(x) ((x) << S_LOW_POWER_ENTRANCE_COUNT) +#define G_LOW_POWER_ENTRANCE_COUNT(x) (((x) >> S_LOW_POWER_ENTRANCE_COUNT) & M_LOW_POWER_ENTRANCE_COUNT) + +#define S_LINK_STATE 16 +#define M_LINK_STATE 0x3fU +#define V_LINK_STATE(x) ((x) << S_LINK_STATE) +#define G_LINK_STATE(x) (((x) >> S_LINK_STATE) & M_LINK_STATE) + +#define S_FORCE_LINK 15 +#define V_FORCE_LINK(x) ((x) << S_FORCE_LINK) +#define F_FORCE_LINK V_FORCE_LINK(1U) + +#define S_LINK_NUMBER 0 +#define M_LINK_NUMBER 0xffU +#define V_LINK_NUMBER(x) ((x) << S_LINK_NUMBER) +#define G_LINK_NUMBER(x) (((x) >> S_LINK_NUMBER) & M_LINK_NUMBER) + +#define A_PCIE_CORE_ACK_FREQUENCY_L0L1_ASPM_CONTROL 0x570c + +#define S_ENTER_ASPM_L1_WO_L0S 30 +#define V_ENTER_ASPM_L1_WO_L0S(x) ((x) << S_ENTER_ASPM_L1_WO_L0S) +#define F_ENTER_ASPM_L1_WO_L0S V_ENTER_ASPM_L1_WO_L0S(1U) + +#define S_L1_ENTRANCE_LATENCY 27 +#define M_L1_ENTRANCE_LATENCY 0x7U +#define V_L1_ENTRANCE_LATENCY(x) ((x) << S_L1_ENTRANCE_LATENCY) +#define G_L1_ENTRANCE_LATENCY(x) (((x) >> S_L1_ENTRANCE_LATENCY) & M_L1_ENTRANCE_LATENCY) + +#define S_L0S_ENTRANCE_LATENCY 24 +#define M_L0S_ENTRANCE_LATENCY 0x7U +#define V_L0S_ENTRANCE_LATENCY(x) ((x) << S_L0S_ENTRANCE_LATENCY) +#define G_L0S_ENTRANCE_LATENCY(x) (((x) >> S_L0S_ENTRANCE_LATENCY) & M_L0S_ENTRANCE_LATENCY) + +#define S_COMMON_CLOCK_N_FTS 16 +#define M_COMMON_CLOCK_N_FTS 0xffU +#define V_COMMON_CLOCK_N_FTS(x) ((x) << S_COMMON_CLOCK_N_FTS) +#define G_COMMON_CLOCK_N_FTS(x) (((x) >> S_COMMON_CLOCK_N_FTS) & M_COMMON_CLOCK_N_FTS) + +#define S_N_FTS 8 +#define M_N_FTS 0xffU +#define V_N_FTS(x) ((x) << S_N_FTS) +#define G_N_FTS(x) (((x) >> S_N_FTS) & M_N_FTS) + +#define S_ACK_FREQUENCY 0 +#define M_ACK_FREQUENCY 0xffU +#define V_ACK_FREQUENCY(x) ((x) << S_ACK_FREQUENCY) +#define G_ACK_FREQUENCY(x) (((x) >> S_ACK_FREQUENCY) & M_ACK_FREQUENCY) + +#define A_PCIE_CORE_PORT_LINK_CONTROL 0x5710 + +#define S_CROSSLINK_ACTIVE 23 +#define V_CROSSLINK_ACTIVE(x) ((x) << S_CROSSLINK_ACTIVE) +#define F_CROSSLINK_ACTIVE V_CROSSLINK_ACTIVE(1U) + +#define S_CROSSLINK_ENABLE 22 +#define V_CROSSLINK_ENABLE(x) ((x) << S_CROSSLINK_ENABLE) +#define F_CROSSLINK_ENABLE V_CROSSLINK_ENABLE(1U) + +#define S_LINK_MODE_ENABLE 16 +#define M_LINK_MODE_ENABLE 0x3fU +#define V_LINK_MODE_ENABLE(x) ((x) << S_LINK_MODE_ENABLE) +#define G_LINK_MODE_ENABLE(x) (((x) >> S_LINK_MODE_ENABLE) & M_LINK_MODE_ENABLE) + +#define S_FAST_LINK_MODE 7 +#define V_FAST_LINK_MODE(x) ((x) << S_FAST_LINK_MODE) +#define F_FAST_LINK_MODE V_FAST_LINK_MODE(1U) + +#define S_DLL_LINK_ENABLE 5 +#define V_DLL_LINK_ENABLE(x) ((x) << S_DLL_LINK_ENABLE) +#define F_DLL_LINK_ENABLE V_DLL_LINK_ENABLE(1U) + +#define S_RESET_ASSERT 3 +#define V_RESET_ASSERT(x) ((x) << S_RESET_ASSERT) +#define F_RESET_ASSERT V_RESET_ASSERT(1U) + +#define S_LOOPBACK_ENABLE 2 +#define V_LOOPBACK_ENABLE(x) ((x) << S_LOOPBACK_ENABLE) +#define F_LOOPBACK_ENABLE V_LOOPBACK_ENABLE(1U) + +#define S_SCRAMBLE_DISABLE 1 +#define V_SCRAMBLE_DISABLE(x) ((x) << S_SCRAMBLE_DISABLE) +#define F_SCRAMBLE_DISABLE V_SCRAMBLE_DISABLE(1U) + +#define S_VENDOR_SPECIFIC_DLLP_REQUEST 0 +#define V_VENDOR_SPECIFIC_DLLP_REQUEST(x) ((x) << S_VENDOR_SPECIFIC_DLLP_REQUEST) +#define F_VENDOR_SPECIFIC_DLLP_REQUEST V_VENDOR_SPECIFIC_DLLP_REQUEST(1U) + +#define A_PCIE_CORE_LANE_SKEW 0x5714 + +#define S_DISABLE_DESKEW 31 +#define V_DISABLE_DESKEW(x) ((x) << S_DISABLE_DESKEW) +#define F_DISABLE_DESKEW V_DISABLE_DESKEW(1U) + +#define S_ACK_NAK_DISABLE 25 +#define V_ACK_NAK_DISABLE(x) ((x) << S_ACK_NAK_DISABLE) +#define F_ACK_NAK_DISABLE V_ACK_NAK_DISABLE(1U) + +#define S_FLOW_CONTROL_DISABLE 24 +#define V_FLOW_CONTROL_DISABLE(x) ((x) << S_FLOW_CONTROL_DISABLE) +#define F_FLOW_CONTROL_DISABLE V_FLOW_CONTROL_DISABLE(1U) + +#define S_INSERT_TXSKEW 0 +#define M_INSERT_TXSKEW 0xffffffU +#define V_INSERT_TXSKEW(x) ((x) << S_INSERT_TXSKEW) +#define G_INSERT_TXSKEW(x) (((x) >> S_INSERT_TXSKEW) & M_INSERT_TXSKEW) + +#define A_PCIE_CORE_SYMBOL_NUMBER 0x5718 + +#define S_FLOW_CONTROL_TIMER_MODIFIER 24 +#define M_FLOW_CONTROL_TIMER_MODIFIER 0x1fU +#define V_FLOW_CONTROL_TIMER_MODIFIER(x) ((x) << S_FLOW_CONTROL_TIMER_MODIFIER) +#define G_FLOW_CONTROL_TIMER_MODIFIER(x) (((x) >> S_FLOW_CONTROL_TIMER_MODIFIER) & M_FLOW_CONTROL_TIMER_MODIFIER) + +#define S_ACK_NAK_TIMER_MODIFIER 19 +#define M_ACK_NAK_TIMER_MODIFIER 0x1fU +#define V_ACK_NAK_TIMER_MODIFIER(x) ((x) << S_ACK_NAK_TIMER_MODIFIER) +#define G_ACK_NAK_TIMER_MODIFIER(x) (((x) >> S_ACK_NAK_TIMER_MODIFIER) & M_ACK_NAK_TIMER_MODIFIER) + +#define S_REPLAY_TIMER_MODIFIER 14 +#define M_REPLAY_TIMER_MODIFIER 0x1fU +#define V_REPLAY_TIMER_MODIFIER(x) ((x) << S_REPLAY_TIMER_MODIFIER) +#define G_REPLAY_TIMER_MODIFIER(x) (((x) >> S_REPLAY_TIMER_MODIFIER) & M_REPLAY_TIMER_MODIFIER) + +#define S_MAXFUNC 0 +#define M_MAXFUNC 0x7U +#define V_MAXFUNC(x) ((x) << S_MAXFUNC) +#define G_MAXFUNC(x) (((x) >> S_MAXFUNC) & M_MAXFUNC) + +#define A_PCIE_CORE_SYMBOL_TIMER_FILTER_MASK1 0x571c + +#define S_MASK_RADM_FILTER 16 +#define M_MASK_RADM_FILTER 0xffffU +#define V_MASK_RADM_FILTER(x) ((x) << S_MASK_RADM_FILTER) +#define G_MASK_RADM_FILTER(x) (((x) >> S_MASK_RADM_FILTER) & M_MASK_RADM_FILTER) + +#define S_DISABLE_FC_WATCHDOG 15 +#define V_DISABLE_FC_WATCHDOG(x) ((x) << S_DISABLE_FC_WATCHDOG) +#define F_DISABLE_FC_WATCHDOG V_DISABLE_FC_WATCHDOG(1U) + +#define S_SKP_INTERVAL 0 +#define M_SKP_INTERVAL 0x7ffU +#define V_SKP_INTERVAL(x) ((x) << S_SKP_INTERVAL) +#define G_SKP_INTERVAL(x) (((x) >> S_SKP_INTERVAL) & M_SKP_INTERVAL) + +#define A_PCIE_CORE_FILTER_MASK2 0x5720 +#define A_PCIE_CORE_DEBUG_0 0x5728 +#define A_PCIE_CORE_DEBUG_1 0x572c +#define A_PCIE_CORE_TRANSMIT_POSTED_FC_CREDIT_STATUS 0x5730 + +#define S_TXPH_FC 12 +#define M_TXPH_FC 0xffU +#define V_TXPH_FC(x) ((x) << S_TXPH_FC) +#define G_TXPH_FC(x) (((x) >> S_TXPH_FC) & M_TXPH_FC) + +#define S_TXPD_FC 0 +#define M_TXPD_FC 0xfffU +#define V_TXPD_FC(x) ((x) << S_TXPD_FC) +#define G_TXPD_FC(x) (((x) >> S_TXPD_FC) & M_TXPD_FC) + +#define A_PCIE_CORE_TRANSMIT_NONPOSTED_FC_CREDIT_STATUS 0x5734 + +#define S_TXNPH_FC 12 +#define M_TXNPH_FC 0xffU +#define V_TXNPH_FC(x) ((x) << S_TXNPH_FC) +#define G_TXNPH_FC(x) (((x) >> S_TXNPH_FC) & M_TXNPH_FC) + +#define S_TXNPD_FC 0 +#define M_TXNPD_FC 0xfffU +#define V_TXNPD_FC(x) ((x) << S_TXNPD_FC) +#define G_TXNPD_FC(x) (((x) >> S_TXNPD_FC) & M_TXNPD_FC) + +#define A_PCIE_CORE_TRANSMIT_COMPLETION_FC_CREDIT_STATUS 0x5738 + +#define S_TXCPLH_FC 12 +#define M_TXCPLH_FC 0xffU +#define V_TXCPLH_FC(x) ((x) << S_TXCPLH_FC) +#define G_TXCPLH_FC(x) (((x) >> S_TXCPLH_FC) & M_TXCPLH_FC) + +#define S_TXCPLD_FC 0 +#define M_TXCPLD_FC 0xfffU +#define V_TXCPLD_FC(x) ((x) << S_TXCPLD_FC) +#define G_TXCPLD_FC(x) (((x) >> S_TXCPLD_FC) & M_TXCPLD_FC) + +#define A_PCIE_CORE_QUEUE_STATUS 0x573c + +#define S_RXQUEUE_NOT_EMPTY 2 +#define V_RXQUEUE_NOT_EMPTY(x) ((x) << S_RXQUEUE_NOT_EMPTY) +#define F_RXQUEUE_NOT_EMPTY V_RXQUEUE_NOT_EMPTY(1U) + +#define S_TXRETRYBUF_NOT_EMPTY 1 +#define V_TXRETRYBUF_NOT_EMPTY(x) ((x) << S_TXRETRYBUF_NOT_EMPTY) +#define F_TXRETRYBUF_NOT_EMPTY V_TXRETRYBUF_NOT_EMPTY(1U) + +#define S_RXTLP_FC_NOT_RETURNED 0 +#define V_RXTLP_FC_NOT_RETURNED(x) ((x) << S_RXTLP_FC_NOT_RETURNED) +#define F_RXTLP_FC_NOT_RETURNED V_RXTLP_FC_NOT_RETURNED(1U) + +#define A_PCIE_CORE_VC_TRANSMIT_ARBITRATION_1 0x5740 + +#define S_VC3_WRR 24 +#define M_VC3_WRR 0xffU +#define V_VC3_WRR(x) ((x) << S_VC3_WRR) +#define G_VC3_WRR(x) (((x) >> S_VC3_WRR) & M_VC3_WRR) + +#define S_VC2_WRR 16 +#define M_VC2_WRR 0xffU +#define V_VC2_WRR(x) ((x) << S_VC2_WRR) +#define G_VC2_WRR(x) (((x) >> S_VC2_WRR) & M_VC2_WRR) + +#define S_VC1_WRR 8 +#define M_VC1_WRR 0xffU +#define V_VC1_WRR(x) ((x) << S_VC1_WRR) +#define G_VC1_WRR(x) (((x) >> S_VC1_WRR) & M_VC1_WRR) + +#define S_VC0_WRR 0 +#define M_VC0_WRR 0xffU +#define V_VC0_WRR(x) ((x) << S_VC0_WRR) +#define G_VC0_WRR(x) (((x) >> S_VC0_WRR) & M_VC0_WRR) + +#define A_PCIE_CORE_VC_TRANSMIT_ARBITRATION_2 0x5744 + +#define S_VC7_WRR 24 +#define M_VC7_WRR 0xffU +#define V_VC7_WRR(x) ((x) << S_VC7_WRR) +#define G_VC7_WRR(x) (((x) >> S_VC7_WRR) & M_VC7_WRR) + +#define S_VC6_WRR 16 +#define M_VC6_WRR 0xffU +#define V_VC6_WRR(x) ((x) << S_VC6_WRR) +#define G_VC6_WRR(x) (((x) >> S_VC6_WRR) & M_VC6_WRR) + +#define S_VC5_WRR 8 +#define M_VC5_WRR 0xffU +#define V_VC5_WRR(x) ((x) << S_VC5_WRR) +#define G_VC5_WRR(x) (((x) >> S_VC5_WRR) & M_VC5_WRR) + +#define S_VC4_WRR 0 +#define M_VC4_WRR 0xffU +#define V_VC4_WRR(x) ((x) << S_VC4_WRR) +#define G_VC4_WRR(x) (((x) >> S_VC4_WRR) & M_VC4_WRR) + +#define A_PCIE_CORE_VC0_POSTED_RECEIVE_QUEUE_CONTROL 0x5748 + +#define S_VC0_RX_ORDERING 31 +#define V_VC0_RX_ORDERING(x) ((x) << S_VC0_RX_ORDERING) +#define F_VC0_RX_ORDERING V_VC0_RX_ORDERING(1U) + +#define S_VC0_TLP_ORDERING 30 +#define V_VC0_TLP_ORDERING(x) ((x) << S_VC0_TLP_ORDERING) +#define F_VC0_TLP_ORDERING V_VC0_TLP_ORDERING(1U) + +#define S_VC0_PTLP_QUEUE_MODE 21 +#define M_VC0_PTLP_QUEUE_MODE 0x7U +#define V_VC0_PTLP_QUEUE_MODE(x) ((x) << S_VC0_PTLP_QUEUE_MODE) +#define G_VC0_PTLP_QUEUE_MODE(x) (((x) >> S_VC0_PTLP_QUEUE_MODE) & M_VC0_PTLP_QUEUE_MODE) + +#define S_VC0_PH_CREDITS 12 +#define M_VC0_PH_CREDITS 0xffU +#define V_VC0_PH_CREDITS(x) ((x) << S_VC0_PH_CREDITS) +#define G_VC0_PH_CREDITS(x) (((x) >> S_VC0_PH_CREDITS) & M_VC0_PH_CREDITS) + +#define S_VC0_PD_CREDITS 0 +#define M_VC0_PD_CREDITS 0xfffU +#define V_VC0_PD_CREDITS(x) ((x) << S_VC0_PD_CREDITS) +#define G_VC0_PD_CREDITS(x) (((x) >> S_VC0_PD_CREDITS) & M_VC0_PD_CREDITS) + +#define A_PCIE_CORE_VC0_NONPOSTED_RECEIVE_QUEUE_CONTROL 0x574c + +#define S_VC0_NPTLP_QUEUE_MODE 21 +#define M_VC0_NPTLP_QUEUE_MODE 0x7U +#define V_VC0_NPTLP_QUEUE_MODE(x) ((x) << S_VC0_NPTLP_QUEUE_MODE) +#define G_VC0_NPTLP_QUEUE_MODE(x) (((x) >> S_VC0_NPTLP_QUEUE_MODE) & M_VC0_NPTLP_QUEUE_MODE) + +#define S_VC0_NPH_CREDITS 12 +#define M_VC0_NPH_CREDITS 0xffU +#define V_VC0_NPH_CREDITS(x) ((x) << S_VC0_NPH_CREDITS) +#define G_VC0_NPH_CREDITS(x) (((x) >> S_VC0_NPH_CREDITS) & M_VC0_NPH_CREDITS) + +#define S_VC0_NPD_CREDITS 0 +#define M_VC0_NPD_CREDITS 0xfffU +#define V_VC0_NPD_CREDITS(x) ((x) << S_VC0_NPD_CREDITS) +#define G_VC0_NPD_CREDITS(x) (((x) >> S_VC0_NPD_CREDITS) & M_VC0_NPD_CREDITS) + +#define A_PCIE_CORE_VC0_COMPLETION_RECEIVE_QUEUE_CONTROL 0x5750 + +#define S_VC0_CPLTLP_QUEUE_MODE 21 +#define M_VC0_CPLTLP_QUEUE_MODE 0x7U +#define V_VC0_CPLTLP_QUEUE_MODE(x) ((x) << S_VC0_CPLTLP_QUEUE_MODE) +#define G_VC0_CPLTLP_QUEUE_MODE(x) (((x) >> S_VC0_CPLTLP_QUEUE_MODE) & M_VC0_CPLTLP_QUEUE_MODE) + +#define S_VC0_CPLH_CREDITS 12 +#define M_VC0_CPLH_CREDITS 0xffU +#define V_VC0_CPLH_CREDITS(x) ((x) << S_VC0_CPLH_CREDITS) +#define G_VC0_CPLH_CREDITS(x) (((x) >> S_VC0_CPLH_CREDITS) & M_VC0_CPLH_CREDITS) + +#define S_VC0_CPLD_CREDITS 0 +#define M_VC0_CPLD_CREDITS 0xfffU +#define V_VC0_CPLD_CREDITS(x) ((x) << S_VC0_CPLD_CREDITS) +#define G_VC0_CPLD_CREDITS(x) (((x) >> S_VC0_CPLD_CREDITS) & M_VC0_CPLD_CREDITS) + +#define A_PCIE_CORE_VC1_POSTED_RECEIVE_QUEUE_CONTROL 0x5754 + +#define S_VC1_TLP_ORDERING 30 +#define V_VC1_TLP_ORDERING(x) ((x) << S_VC1_TLP_ORDERING) +#define F_VC1_TLP_ORDERING V_VC1_TLP_ORDERING(1U) + +#define S_VC1_PTLP_QUEUE_MODE 21 +#define M_VC1_PTLP_QUEUE_MODE 0x7U +#define V_VC1_PTLP_QUEUE_MODE(x) ((x) << S_VC1_PTLP_QUEUE_MODE) +#define G_VC1_PTLP_QUEUE_MODE(x) (((x) >> S_VC1_PTLP_QUEUE_MODE) & M_VC1_PTLP_QUEUE_MODE) + +#define S_VC1_PH_CREDITS 12 +#define M_VC1_PH_CREDITS 0xffU +#define V_VC1_PH_CREDITS(x) ((x) << S_VC1_PH_CREDITS) +#define G_VC1_PH_CREDITS(x) (((x) >> S_VC1_PH_CREDITS) & M_VC1_PH_CREDITS) + +#define S_VC1_PD_CREDITS 0 +#define M_VC1_PD_CREDITS 0xfffU +#define V_VC1_PD_CREDITS(x) ((x) << S_VC1_PD_CREDITS) +#define G_VC1_PD_CREDITS(x) (((x) >> S_VC1_PD_CREDITS) & M_VC1_PD_CREDITS) + +#define A_PCIE_CORE_VC1_NONPOSTED_RECEIVE_QUEUE_CONTROL 0x5758 + +#define S_VC1_NPTLP_QUEUE_MODE 21 +#define M_VC1_NPTLP_QUEUE_MODE 0x7U +#define V_VC1_NPTLP_QUEUE_MODE(x) ((x) << S_VC1_NPTLP_QUEUE_MODE) +#define G_VC1_NPTLP_QUEUE_MODE(x) (((x) >> S_VC1_NPTLP_QUEUE_MODE) & M_VC1_NPTLP_QUEUE_MODE) + +#define S_VC1_NPH_CREDITS 12 +#define M_VC1_NPH_CREDITS 0xffU +#define V_VC1_NPH_CREDITS(x) ((x) << S_VC1_NPH_CREDITS) +#define G_VC1_NPH_CREDITS(x) (((x) >> S_VC1_NPH_CREDITS) & M_VC1_NPH_CREDITS) + +#define S_VC1_NPD_CREDITS 0 +#define M_VC1_NPD_CREDITS 0xfffU +#define V_VC1_NPD_CREDITS(x) ((x) << S_VC1_NPD_CREDITS) +#define G_VC1_NPD_CREDITS(x) (((x) >> S_VC1_NPD_CREDITS) & M_VC1_NPD_CREDITS) + +#define A_PCIE_CORE_VC1_COMPLETION_RECEIVE_QUEUE_CONTROL 0x575c + +#define S_VC1_CPLTLP_QUEUE_MODE 21 +#define M_VC1_CPLTLP_QUEUE_MODE 0x7U +#define V_VC1_CPLTLP_QUEUE_MODE(x) ((x) << S_VC1_CPLTLP_QUEUE_MODE) +#define G_VC1_CPLTLP_QUEUE_MODE(x) (((x) >> S_VC1_CPLTLP_QUEUE_MODE) & M_VC1_CPLTLP_QUEUE_MODE) + +#define S_VC1_CPLH_CREDITS 12 +#define M_VC1_CPLH_CREDITS 0xffU +#define V_VC1_CPLH_CREDITS(x) ((x) << S_VC1_CPLH_CREDITS) +#define G_VC1_CPLH_CREDITS(x) (((x) >> S_VC1_CPLH_CREDITS) & M_VC1_CPLH_CREDITS) + +#define S_VC1_CPLD_CREDITS 0 +#define M_VC1_CPLD_CREDITS 0xfffU +#define V_VC1_CPLD_CREDITS(x) ((x) << S_VC1_CPLD_CREDITS) +#define G_VC1_CPLD_CREDITS(x) (((x) >> S_VC1_CPLD_CREDITS) & M_VC1_CPLD_CREDITS) + +#define A_PCIE_CORE_LINK_WIDTH_SPEED_CHANGE 0x580c + +#define S_SEL_DEEMPHASIS 20 +#define V_SEL_DEEMPHASIS(x) ((x) << S_SEL_DEEMPHASIS) +#define F_SEL_DEEMPHASIS V_SEL_DEEMPHASIS(1U) + +#define S_TXCMPLRCV 19 +#define V_TXCMPLRCV(x) ((x) << S_TXCMPLRCV) +#define F_TXCMPLRCV V_TXCMPLRCV(1U) + +#define S_PHYTXSWING 18 +#define V_PHYTXSWING(x) ((x) << S_PHYTXSWING) +#define F_PHYTXSWING V_PHYTXSWING(1U) + +#define S_DIRSPDCHANGE 17 +#define V_DIRSPDCHANGE(x) ((x) << S_DIRSPDCHANGE) +#define F_DIRSPDCHANGE V_DIRSPDCHANGE(1U) + +#define S_NUM_LANES 8 +#define M_NUM_LANES 0x1ffU +#define V_NUM_LANES(x) ((x) << S_NUM_LANES) +#define G_NUM_LANES(x) (((x) >> S_NUM_LANES) & M_NUM_LANES) + +#define S_NFTS_GEN2_3 0 +#define M_NFTS_GEN2_3 0xffU +#define V_NFTS_GEN2_3(x) ((x) << S_NFTS_GEN2_3) +#define G_NFTS_GEN2_3(x) (((x) >> S_NFTS_GEN2_3) & M_NFTS_GEN2_3) + +#define A_PCIE_CORE_PHY_STATUS 0x5810 +#define A_PCIE_CORE_PHY_CONTROL 0x5814 +#define A_PCIE_CORE_GEN3_CONTROL 0x5890 + +#define S_DC_BALANCE_DISABLE 18 +#define V_DC_BALANCE_DISABLE(x) ((x) << S_DC_BALANCE_DISABLE) +#define F_DC_BALANCE_DISABLE V_DC_BALANCE_DISABLE(1U) + +#define S_DLLP_DELAY_DISABLE 17 +#define V_DLLP_DELAY_DISABLE(x) ((x) << S_DLLP_DELAY_DISABLE) +#define F_DLLP_DELAY_DISABLE V_DLLP_DELAY_DISABLE(1U) + +#define S_EQL_DISABLE 16 +#define V_EQL_DISABLE(x) ((x) << S_EQL_DISABLE) +#define F_EQL_DISABLE V_EQL_DISABLE(1U) + +#define S_EQL_REDO_DISABLE 11 +#define V_EQL_REDO_DISABLE(x) ((x) << S_EQL_REDO_DISABLE) +#define F_EQL_REDO_DISABLE V_EQL_REDO_DISABLE(1U) + +#define S_EQL_EIEOS_CNTRST_DISABLE 10 +#define V_EQL_EIEOS_CNTRST_DISABLE(x) ((x) << S_EQL_EIEOS_CNTRST_DISABLE) +#define F_EQL_EIEOS_CNTRST_DISABLE V_EQL_EIEOS_CNTRST_DISABLE(1U) + +#define S_EQL_PH2_PH3_DISABLE 9 +#define V_EQL_PH2_PH3_DISABLE(x) ((x) << S_EQL_PH2_PH3_DISABLE) +#define F_EQL_PH2_PH3_DISABLE V_EQL_PH2_PH3_DISABLE(1U) + +#define S_DISABLE_SCRAMBLER 8 +#define V_DISABLE_SCRAMBLER(x) ((x) << S_DISABLE_SCRAMBLER) +#define F_DISABLE_SCRAMBLER V_DISABLE_SCRAMBLER(1U) + +#define A_PCIE_CORE_GEN3_EQ_FS_LF 0x5894 + +#define S_FULL_SWING 6 +#define M_FULL_SWING 0x3fU +#define V_FULL_SWING(x) ((x) << S_FULL_SWING) +#define G_FULL_SWING(x) (((x) >> S_FULL_SWING) & M_FULL_SWING) + +#define S_LOW_FREQUENCY 0 +#define M_LOW_FREQUENCY 0x3fU +#define V_LOW_FREQUENCY(x) ((x) << S_LOW_FREQUENCY) +#define G_LOW_FREQUENCY(x) (((x) >> S_LOW_FREQUENCY) & M_LOW_FREQUENCY) + +#define A_PCIE_CORE_GEN3_EQ_PRESET_COEFF 0x5898 + +#define S_POSTCURSOR 12 +#define M_POSTCURSOR 0x3fU +#define V_POSTCURSOR(x) ((x) << S_POSTCURSOR) +#define G_POSTCURSOR(x) (((x) >> S_POSTCURSOR) & M_POSTCURSOR) + +#define S_CURSOR 6 +#define M_CURSOR 0x3fU +#define V_CURSOR(x) ((x) << S_CURSOR) +#define G_CURSOR(x) (((x) >> S_CURSOR) & M_CURSOR) + +#define S_PRECURSOR 0 +#define M_PRECURSOR 0x3fU +#define V_PRECURSOR(x) ((x) << S_PRECURSOR) +#define G_PRECURSOR(x) (((x) >> S_PRECURSOR) & M_PRECURSOR) + +#define A_PCIE_CORE_GEN3_EQ_PRESET_INDEX 0x589c + +#define S_INDEX 0 +#define M_INDEX 0xfU +#define V_INDEX(x) ((x) << S_INDEX) +#define G_INDEX(x) (((x) >> S_INDEX) & M_INDEX) + +#define A_PCIE_CORE_GEN3_EQ_STATUS 0x58a4 + +#define S_LEGALITY_STATUS 0 +#define V_LEGALITY_STATUS(x) ((x) << S_LEGALITY_STATUS) +#define F_LEGALITY_STATUS V_LEGALITY_STATUS(1U) + +#define A_PCIE_CORE_GEN3_EQ_CONTROL 0x58a8 + +#define S_INCLUDE_INITIAL_FOM 24 +#define V_INCLUDE_INITIAL_FOM(x) ((x) << S_INCLUDE_INITIAL_FOM) +#define F_INCLUDE_INITIAL_FOM V_INCLUDE_INITIAL_FOM(1U) + +#define S_PRESET_REQUEST_VECTOR 8 +#define M_PRESET_REQUEST_VECTOR 0xffffU +#define V_PRESET_REQUEST_VECTOR(x) ((x) << S_PRESET_REQUEST_VECTOR) +#define G_PRESET_REQUEST_VECTOR(x) (((x) >> S_PRESET_REQUEST_VECTOR) & M_PRESET_REQUEST_VECTOR) + +#define S_PHASE23_2MS_TIMEOUT_DISABLE 5 +#define V_PHASE23_2MS_TIMEOUT_DISABLE(x) ((x) << S_PHASE23_2MS_TIMEOUT_DISABLE) +#define F_PHASE23_2MS_TIMEOUT_DISABLE V_PHASE23_2MS_TIMEOUT_DISABLE(1U) + +#define S_AFTER24MS 4 +#define V_AFTER24MS(x) ((x) << S_AFTER24MS) +#define F_AFTER24MS V_AFTER24MS(1U) + +#define S_FEEDBACK_MODE 0 +#define M_FEEDBACK_MODE 0xfU +#define V_FEEDBACK_MODE(x) ((x) << S_FEEDBACK_MODE) +#define G_FEEDBACK_MODE(x) (((x) >> S_FEEDBACK_MODE) & M_FEEDBACK_MODE) + +#define A_PCIE_CORE_GEN3_EQ_DIRCHANGE_FEEDBACK 0x58ac + +#define S_WINAPERTURE_CPLUS1 14 +#define M_WINAPERTURE_CPLUS1 0xfU +#define V_WINAPERTURE_CPLUS1(x) ((x) << S_WINAPERTURE_CPLUS1) +#define G_WINAPERTURE_CPLUS1(x) (((x) >> S_WINAPERTURE_CPLUS1) & M_WINAPERTURE_CPLUS1) + +#define S_WINAPERTURE_CMINS1 10 +#define M_WINAPERTURE_CMINS1 0xfU +#define V_WINAPERTURE_CMINS1(x) ((x) << S_WINAPERTURE_CMINS1) +#define G_WINAPERTURE_CMINS1(x) (((x) >> S_WINAPERTURE_CMINS1) & M_WINAPERTURE_CMINS1) + +#define S_CONVERGENCE_WINDEPTH 5 +#define M_CONVERGENCE_WINDEPTH 0x1fU +#define V_CONVERGENCE_WINDEPTH(x) ((x) << S_CONVERGENCE_WINDEPTH) +#define G_CONVERGENCE_WINDEPTH(x) (((x) >> S_CONVERGENCE_WINDEPTH) & M_CONVERGENCE_WINDEPTH) + +#define S_EQMASTERPHASE_MINTIME 0 +#define M_EQMASTERPHASE_MINTIME 0x1fU +#define V_EQMASTERPHASE_MINTIME(x) ((x) << S_EQMASTERPHASE_MINTIME) +#define G_EQMASTERPHASE_MINTIME(x) (((x) >> S_EQMASTERPHASE_MINTIME) & M_EQMASTERPHASE_MINTIME) + +#define A_PCIE_CORE_PIPE_CONTROL 0x58b8 + +#define S_PIPE_LOOPBACK_EN 0 +#define V_PIPE_LOOPBACK_EN(x) ((x) << S_PIPE_LOOPBACK_EN) +#define F_PIPE_LOOPBACK_EN V_PIPE_LOOPBACK_EN(1U) + +#define A_PCIE_CORE_DBI_RO_WE 0x58bc + +#define S_READONLY_WRITEEN 0 +#define V_READONLY_WRITEEN(x) ((x) << S_READONLY_WRITEEN) +#define F_READONLY_WRITEEN V_READONLY_WRITEEN(1U) + +#define A_PCIE_CORE_UTL_SYSTEM_BUS_CONTROL 0x5900 + +#define S_SMTD 27 +#define V_SMTD(x) ((x) << S_SMTD) +#define F_SMTD V_SMTD(1U) + +#define S_SSTD 26 +#define V_SSTD(x) ((x) << S_SSTD) +#define F_SSTD V_SSTD(1U) + +#define S_SWD0 23 +#define V_SWD0(x) ((x) << S_SWD0) +#define F_SWD0 V_SWD0(1U) + +#define S_SWD1 22 +#define V_SWD1(x) ((x) << S_SWD1) +#define F_SWD1 V_SWD1(1U) + +#define S_SWD2 21 +#define V_SWD2(x) ((x) << S_SWD2) +#define F_SWD2 V_SWD2(1U) + +#define S_SWD3 20 +#define V_SWD3(x) ((x) << S_SWD3) +#define F_SWD3 V_SWD3(1U) + +#define S_SWD4 19 +#define V_SWD4(x) ((x) << S_SWD4) +#define F_SWD4 V_SWD4(1U) + +#define S_SWD5 18 +#define V_SWD5(x) ((x) << S_SWD5) +#define F_SWD5 V_SWD5(1U) + +#define S_SWD6 17 +#define V_SWD6(x) ((x) << S_SWD6) +#define F_SWD6 V_SWD6(1U) + +#define S_SWD7 16 +#define V_SWD7(x) ((x) << S_SWD7) +#define F_SWD7 V_SWD7(1U) + +#define S_SWD8 15 +#define V_SWD8(x) ((x) << S_SWD8) +#define F_SWD8 V_SWD8(1U) + +#define S_SRD0 13 +#define V_SRD0(x) ((x) << S_SRD0) +#define F_SRD0 V_SRD0(1U) + +#define S_SRD1 12 +#define V_SRD1(x) ((x) << S_SRD1) +#define F_SRD1 V_SRD1(1U) + +#define S_SRD2 11 +#define V_SRD2(x) ((x) << S_SRD2) +#define F_SRD2 V_SRD2(1U) + +#define S_SRD3 10 +#define V_SRD3(x) ((x) << S_SRD3) +#define F_SRD3 V_SRD3(1U) + +#define S_SRD4 9 +#define V_SRD4(x) ((x) << S_SRD4) +#define F_SRD4 V_SRD4(1U) + +#define S_SRD5 8 +#define V_SRD5(x) ((x) << S_SRD5) +#define F_SRD5 V_SRD5(1U) + +#define S_SRD6 7 +#define V_SRD6(x) ((x) << S_SRD6) +#define F_SRD6 V_SRD6(1U) + +#define S_SRD7 6 +#define V_SRD7(x) ((x) << S_SRD7) +#define F_SRD7 V_SRD7(1U) + +#define S_SRD8 5 +#define V_SRD8(x) ((x) << S_SRD8) +#define F_SRD8 V_SRD8(1U) + +#define S_CRRE 3 +#define V_CRRE(x) ((x) << S_CRRE) +#define F_CRRE V_CRRE(1U) + +#define S_CRMC 0 +#define M_CRMC 0x7U +#define V_CRMC(x) ((x) << S_CRMC) +#define G_CRMC(x) (((x) >> S_CRMC) & M_CRMC) + +#define A_PCIE_CORE_UTL_STATUS 0x5904 + +#define S_USBP 31 +#define V_USBP(x) ((x) << S_USBP) +#define F_USBP V_USBP(1U) + +#define S_UPEP 30 +#define V_UPEP(x) ((x) << S_UPEP) +#define F_UPEP V_UPEP(1U) + +#define S_RCEP 29 +#define V_RCEP(x) ((x) << S_RCEP) +#define F_RCEP V_RCEP(1U) + +#define S_EPEP 28 +#define V_EPEP(x) ((x) << S_EPEP) +#define F_EPEP V_EPEP(1U) + +#define S_USBS 27 +#define V_USBS(x) ((x) << S_USBS) +#define F_USBS V_USBS(1U) + +#define S_UPES 26 +#define V_UPES(x) ((x) << S_UPES) +#define F_UPES V_UPES(1U) + +#define S_RCES 25 +#define V_RCES(x) ((x) << S_RCES) +#define F_RCES V_RCES(1U) + +#define S_EPES 24 +#define V_EPES(x) ((x) << S_EPES) +#define F_EPES V_EPES(1U) + +#define A_PCIE_CORE_UTL_SYSTEM_BUS_AGENT_STATUS 0x5908 + +#define S_RNPP 31 +#define V_RNPP(x) ((x) << S_RNPP) +#define F_RNPP V_RNPP(1U) + +#define S_RPCP 29 +#define V_RPCP(x) ((x) << S_RPCP) +#define F_RPCP V_RPCP(1U) + +#define S_RCIP 27 +#define V_RCIP(x) ((x) << S_RCIP) +#define F_RCIP V_RCIP(1U) + +#define S_RCCP 26 +#define V_RCCP(x) ((x) << S_RCCP) +#define F_RCCP V_RCCP(1U) + +#define S_RFTP 23 +#define V_RFTP(x) ((x) << S_RFTP) +#define F_RFTP V_RFTP(1U) + +#define S_PTRP 20 +#define V_PTRP(x) ((x) << S_PTRP) +#define F_PTRP V_PTRP(1U) + +#define A_PCIE_CORE_UTL_SYSTEM_BUS_AGENT_ERROR_SEVERITY 0x590c + +#define S_RNPS 31 +#define V_RNPS(x) ((x) << S_RNPS) +#define F_RNPS V_RNPS(1U) + +#define S_RPCS 29 +#define V_RPCS(x) ((x) << S_RPCS) +#define F_RPCS V_RPCS(1U) + +#define S_RCIS 27 +#define V_RCIS(x) ((x) << S_RCIS) +#define F_RCIS V_RCIS(1U) + +#define S_RCCS 26 +#define V_RCCS(x) ((x) << S_RCCS) +#define F_RCCS V_RCCS(1U) + +#define S_RFTS 23 +#define V_RFTS(x) ((x) << S_RFTS) +#define F_RFTS V_RFTS(1U) + +#define A_PCIE_CORE_UTL_SYSTEM_BUS_AGENT_INTERRUPT_ENABLE 0x5910 + +#define S_RNPI 31 +#define V_RNPI(x) ((x) << S_RNPI) +#define F_RNPI V_RNPI(1U) + +#define S_RPCI 29 +#define V_RPCI(x) ((x) << S_RPCI) +#define F_RPCI V_RPCI(1U) + +#define S_RCII 27 +#define V_RCII(x) ((x) << S_RCII) +#define F_RCII V_RCII(1U) + +#define S_RCCI 26 +#define V_RCCI(x) ((x) << S_RCCI) +#define F_RCCI V_RCCI(1U) + +#define S_RFTI 23 +#define V_RFTI(x) ((x) << S_RFTI) +#define F_RFTI V_RFTI(1U) + +#define A_PCIE_CORE_SYSTEM_BUS_BURST_SIZE_CONFIGURATION 0x5920 + +#define S_SBRS 28 +#define M_SBRS 0x7U +#define V_SBRS(x) ((x) << S_SBRS) +#define G_SBRS(x) (((x) >> S_SBRS) & M_SBRS) + +#define S_OTWS 20 +#define M_OTWS 0x7U +#define V_OTWS(x) ((x) << S_OTWS) +#define G_OTWS(x) (((x) >> S_OTWS) & M_OTWS) + +#define A_PCIE_CORE_REVISION_ID 0x5924 + +#define S_RVID 20 +#define M_RVID 0xfffU +#define V_RVID(x) ((x) << S_RVID) +#define G_RVID(x) (((x) >> S_RVID) & M_RVID) + +#define S_BRVN 12 +#define M_BRVN 0xffU +#define V_BRVN(x) ((x) << S_BRVN) +#define G_BRVN(x) (((x) >> S_BRVN) & M_BRVN) + +#define A_PCIE_T5_DMA_CFG 0x5940 + +#define S_T5_DMA_MAXREQCNT 20 +#define M_T5_DMA_MAXREQCNT 0xffU +#define V_T5_DMA_MAXREQCNT(x) ((x) << S_T5_DMA_MAXREQCNT) +#define G_T5_DMA_MAXREQCNT(x) (((x) >> S_T5_DMA_MAXREQCNT) & M_T5_DMA_MAXREQCNT) + +#define S_T5_DMA_MAXRDREQSIZE 17 +#define M_T5_DMA_MAXRDREQSIZE 0x7U +#define V_T5_DMA_MAXRDREQSIZE(x) ((x) << S_T5_DMA_MAXRDREQSIZE) +#define G_T5_DMA_MAXRDREQSIZE(x) (((x) >> S_T5_DMA_MAXRDREQSIZE) & M_T5_DMA_MAXRDREQSIZE) + +#define S_T5_DMA_MAXRSPCNT 8 +#define M_T5_DMA_MAXRSPCNT 0x1ffU +#define V_T5_DMA_MAXRSPCNT(x) ((x) << S_T5_DMA_MAXRSPCNT) +#define G_T5_DMA_MAXRSPCNT(x) (((x) >> S_T5_DMA_MAXRSPCNT) & M_T5_DMA_MAXRSPCNT) + +#define S_SEQCHKDIS 7 +#define V_SEQCHKDIS(x) ((x) << S_SEQCHKDIS) +#define F_SEQCHKDIS V_SEQCHKDIS(1U) + +#define S_MINTAG 0 +#define M_MINTAG 0x7fU +#define V_MINTAG(x) ((x) << S_MINTAG) +#define G_MINTAG(x) (((x) >> S_MINTAG) & M_MINTAG) + +#define A_PCIE_T5_DMA_STAT 0x5944 + +#define S_DMA_RESPCNT 20 +#define M_DMA_RESPCNT 0xfffU +#define V_DMA_RESPCNT(x) ((x) << S_DMA_RESPCNT) +#define G_DMA_RESPCNT(x) (((x) >> S_DMA_RESPCNT) & M_DMA_RESPCNT) + +#define S_DMA_RDREQCNT 12 +#define M_DMA_RDREQCNT 0xffU +#define V_DMA_RDREQCNT(x) ((x) << S_DMA_RDREQCNT) +#define G_DMA_RDREQCNT(x) (((x) >> S_DMA_RDREQCNT) & M_DMA_RDREQCNT) + +#define S_DMA_WRREQCNT 0 +#define M_DMA_WRREQCNT 0x7ffU +#define V_DMA_WRREQCNT(x) ((x) << S_DMA_WRREQCNT) +#define G_DMA_WRREQCNT(x) (((x) >> S_DMA_WRREQCNT) & M_DMA_WRREQCNT) + +#define A_PCIE_T5_DMA_STAT2 0x5948 + +#define S_COOKIECNT 24 +#define M_COOKIECNT 0xfU +#define V_COOKIECNT(x) ((x) << S_COOKIECNT) +#define G_COOKIECNT(x) (((x) >> S_COOKIECNT) & M_COOKIECNT) + +#define S_RDSEQNUMUPDCNT 20 +#define M_RDSEQNUMUPDCNT 0xfU +#define V_RDSEQNUMUPDCNT(x) ((x) << S_RDSEQNUMUPDCNT) +#define G_RDSEQNUMUPDCNT(x) (((x) >> S_RDSEQNUMUPDCNT) & M_RDSEQNUMUPDCNT) + +#define S_SIREQCNT 16 +#define M_SIREQCNT 0xfU +#define V_SIREQCNT(x) ((x) << S_SIREQCNT) +#define G_SIREQCNT(x) (((x) >> S_SIREQCNT) & M_SIREQCNT) + +#define S_WREOPMATCHSOP 12 +#define V_WREOPMATCHSOP(x) ((x) << S_WREOPMATCHSOP) +#define F_WREOPMATCHSOP V_WREOPMATCHSOP(1U) + +#define S_WRSOPCNT 8 +#define M_WRSOPCNT 0xfU +#define V_WRSOPCNT(x) ((x) << S_WRSOPCNT) +#define G_WRSOPCNT(x) (((x) >> S_WRSOPCNT) & M_WRSOPCNT) + +#define S_RDSOPCNT 0 +#define M_RDSOPCNT 0xffU +#define V_RDSOPCNT(x) ((x) << S_RDSOPCNT) +#define G_RDSOPCNT(x) (((x) >> S_RDSOPCNT) & M_RDSOPCNT) + +#define A_PCIE_T5_DMA_STAT3 0x594c + +#define S_ATMREQSOPCNT 24 +#define M_ATMREQSOPCNT 0xffU +#define V_ATMREQSOPCNT(x) ((x) << S_ATMREQSOPCNT) +#define G_ATMREQSOPCNT(x) (((x) >> S_ATMREQSOPCNT) & M_ATMREQSOPCNT) + +#define S_ATMEOPMATCHSOP 17 +#define V_ATMEOPMATCHSOP(x) ((x) << S_ATMEOPMATCHSOP) +#define F_ATMEOPMATCHSOP V_ATMEOPMATCHSOP(1U) + +#define S_RSPEOPMATCHSOP 16 +#define V_RSPEOPMATCHSOP(x) ((x) << S_RSPEOPMATCHSOP) +#define F_RSPEOPMATCHSOP V_RSPEOPMATCHSOP(1U) + +#define S_RSPERRCNT 8 +#define M_RSPERRCNT 0xffU +#define V_RSPERRCNT(x) ((x) << S_RSPERRCNT) +#define G_RSPERRCNT(x) (((x) >> S_RSPERRCNT) & M_RSPERRCNT) + +#define S_RSPSOPCNT 0 +#define M_RSPSOPCNT 0xffU +#define V_RSPSOPCNT(x) ((x) << S_RSPSOPCNT) +#define G_RSPSOPCNT(x) (((x) >> S_RSPSOPCNT) & M_RSPSOPCNT) + +#define A_PCIE_CORE_OUTBOUND_POSTED_HEADER_BUFFER_ALLOCATION 0x5960 + +#define S_OP0H 24 +#define M_OP0H 0xfU +#define V_OP0H(x) ((x) << S_OP0H) +#define G_OP0H(x) (((x) >> S_OP0H) & M_OP0H) + +#define S_OP1H 16 +#define M_OP1H 0xfU +#define V_OP1H(x) ((x) << S_OP1H) +#define G_OP1H(x) (((x) >> S_OP1H) & M_OP1H) + +#define S_OP2H 8 +#define M_OP2H 0xfU +#define V_OP2H(x) ((x) << S_OP2H) +#define G_OP2H(x) (((x) >> S_OP2H) & M_OP2H) + +#define S_OP3H 0 +#define M_OP3H 0xfU +#define V_OP3H(x) ((x) << S_OP3H) +#define G_OP3H(x) (((x) >> S_OP3H) & M_OP3H) + +#define A_PCIE_CORE_OUTBOUND_POSTED_DATA_BUFFER_ALLOCATION 0x5968 + +#define S_OP0D 24 +#define M_OP0D 0x7fU +#define V_OP0D(x) ((x) << S_OP0D) +#define G_OP0D(x) (((x) >> S_OP0D) & M_OP0D) + +#define S_OP1D 16 +#define M_OP1D 0x7fU +#define V_OP1D(x) ((x) << S_OP1D) +#define G_OP1D(x) (((x) >> S_OP1D) & M_OP1D) + +#define S_OP2D 8 +#define M_OP2D 0x7fU +#define V_OP2D(x) ((x) << S_OP2D) +#define G_OP2D(x) (((x) >> S_OP2D) & M_OP2D) + +#define S_OP3D 0 +#define M_OP3D 0x7fU +#define V_OP3D(x) ((x) << S_OP3D) +#define G_OP3D(x) (((x) >> S_OP3D) & M_OP3D) + +#define A_PCIE_CORE_INBOUND_POSTED_HEADER_BUFFER_ALLOCATION 0x5970 + +#define S_IP0H 24 +#define M_IP0H 0x3fU +#define V_IP0H(x) ((x) << S_IP0H) +#define G_IP0H(x) (((x) >> S_IP0H) & M_IP0H) + +#define S_IP1H 16 +#define M_IP1H 0x3fU +#define V_IP1H(x) ((x) << S_IP1H) +#define G_IP1H(x) (((x) >> S_IP1H) & M_IP1H) + +#define S_IP2H 8 +#define M_IP2H 0x3fU +#define V_IP2H(x) ((x) << S_IP2H) +#define G_IP2H(x) (((x) >> S_IP2H) & M_IP2H) + +#define S_IP3H 0 +#define M_IP3H 0x3fU +#define V_IP3H(x) ((x) << S_IP3H) +#define G_IP3H(x) (((x) >> S_IP3H) & M_IP3H) + +#define A_PCIE_CORE_INBOUND_POSTED_DATA_BUFFER_ALLOCATION 0x5978 + +#define S_IP0D 24 +#define M_IP0D 0xffU +#define V_IP0D(x) ((x) << S_IP0D) +#define G_IP0D(x) (((x) >> S_IP0D) & M_IP0D) + +#define S_IP1D 16 +#define M_IP1D 0xffU +#define V_IP1D(x) ((x) << S_IP1D) +#define G_IP1D(x) (((x) >> S_IP1D) & M_IP1D) + +#define S_IP2D 8 +#define M_IP2D 0xffU +#define V_IP2D(x) ((x) << S_IP2D) +#define G_IP2D(x) (((x) >> S_IP2D) & M_IP2D) + +#define S_IP3D 0 +#define M_IP3D 0xffU +#define V_IP3D(x) ((x) << S_IP3D) +#define G_IP3D(x) (((x) >> S_IP3D) & M_IP3D) + +#define A_PCIE_CORE_OUTBOUND_NON_POSTED_BUFFER_ALLOCATION 0x5980 + +#define S_ON0H 24 +#define M_ON0H 0xfU +#define V_ON0H(x) ((x) << S_ON0H) +#define G_ON0H(x) (((x) >> S_ON0H) & M_ON0H) + +#define S_ON1H 16 +#define M_ON1H 0xfU +#define V_ON1H(x) ((x) << S_ON1H) +#define G_ON1H(x) (((x) >> S_ON1H) & M_ON1H) + +#define S_ON2H 8 +#define M_ON2H 0xfU +#define V_ON2H(x) ((x) << S_ON2H) +#define G_ON2H(x) (((x) >> S_ON2H) & M_ON2H) + +#define S_ON3H 0 +#define M_ON3H 0xfU +#define V_ON3H(x) ((x) << S_ON3H) +#define G_ON3H(x) (((x) >> S_ON3H) & M_ON3H) + +#define A_PCIE_T5_CMD_CFG 0x5980 + +#define S_T5_CMD_MAXRDREQSIZE 17 +#define M_T5_CMD_MAXRDREQSIZE 0x7U +#define V_T5_CMD_MAXRDREQSIZE(x) ((x) << S_T5_CMD_MAXRDREQSIZE) +#define G_T5_CMD_MAXRDREQSIZE(x) (((x) >> S_T5_CMD_MAXRDREQSIZE) & M_T5_CMD_MAXRDREQSIZE) + +#define S_T5_CMD_MAXRSPCNT 8 +#define M_T5_CMD_MAXRSPCNT 0xffU +#define V_T5_CMD_MAXRSPCNT(x) ((x) << S_T5_CMD_MAXRSPCNT) +#define G_T5_CMD_MAXRSPCNT(x) (((x) >> S_T5_CMD_MAXRSPCNT) & M_T5_CMD_MAXRSPCNT) + +#define S_USECMDPOOL 7 +#define V_USECMDPOOL(x) ((x) << S_USECMDPOOL) +#define F_USECMDPOOL V_USECMDPOOL(1U) + +#define A_PCIE_T5_CMD_STAT 0x5984 + +#define S_T5_STAT_RSPCNT 20 +#define M_T5_STAT_RSPCNT 0x7ffU +#define V_T5_STAT_RSPCNT(x) ((x) << S_T5_STAT_RSPCNT) +#define G_T5_STAT_RSPCNT(x) (((x) >> S_T5_STAT_RSPCNT) & M_T5_STAT_RSPCNT) + +#define S_RDREQCNT 12 +#define M_RDREQCNT 0x1fU +#define V_RDREQCNT(x) ((x) << S_RDREQCNT) +#define G_RDREQCNT(x) (((x) >> S_RDREQCNT) & M_RDREQCNT) + +#define A_PCIE_CORE_INBOUND_NON_POSTED_REQUESTS_BUFFER_ALLOCATION 0x5988 + +#define S_IN0H 24 +#define M_IN0H 0x3fU +#define V_IN0H(x) ((x) << S_IN0H) +#define G_IN0H(x) (((x) >> S_IN0H) & M_IN0H) + +#define S_IN1H 16 +#define M_IN1H 0x3fU +#define V_IN1H(x) ((x) << S_IN1H) +#define G_IN1H(x) (((x) >> S_IN1H) & M_IN1H) + +#define S_IN2H 8 +#define M_IN2H 0x3fU +#define V_IN2H(x) ((x) << S_IN2H) +#define G_IN2H(x) (((x) >> S_IN2H) & M_IN2H) + +#define S_IN3H 0 +#define M_IN3H 0x3fU +#define V_IN3H(x) ((x) << S_IN3H) +#define G_IN3H(x) (((x) >> S_IN3H) & M_IN3H) + +#define A_PCIE_T5_CMD_STAT2 0x5988 +#define A_PCIE_T5_CMD_STAT3 0x598c +#define A_PCIE_CORE_PCI_EXPRESS_TAGS_ALLOCATION 0x5990 + +#define S_OC0T 24 +#define M_OC0T 0xffU +#define V_OC0T(x) ((x) << S_OC0T) +#define G_OC0T(x) (((x) >> S_OC0T) & M_OC0T) + +#define S_OC1T 16 +#define M_OC1T 0xffU +#define V_OC1T(x) ((x) << S_OC1T) +#define G_OC1T(x) (((x) >> S_OC1T) & M_OC1T) + +#define S_OC2T 8 +#define M_OC2T 0xffU +#define V_OC2T(x) ((x) << S_OC2T) +#define G_OC2T(x) (((x) >> S_OC2T) & M_OC2T) + +#define S_OC3T 0 +#define M_OC3T 0xffU +#define V_OC3T(x) ((x) << S_OC3T) +#define G_OC3T(x) (((x) >> S_OC3T) & M_OC3T) + +#define A_PCIE_CORE_GBIF_READ_TAGS_ALLOCATION 0x5998 + +#define S_IC0T 24 +#define M_IC0T 0x3fU +#define V_IC0T(x) ((x) << S_IC0T) +#define G_IC0T(x) (((x) >> S_IC0T) & M_IC0T) + +#define S_IC1T 16 +#define M_IC1T 0x3fU +#define V_IC1T(x) ((x) << S_IC1T) +#define G_IC1T(x) (((x) >> S_IC1T) & M_IC1T) + +#define S_IC2T 8 +#define M_IC2T 0x3fU +#define V_IC2T(x) ((x) << S_IC2T) +#define G_IC2T(x) (((x) >> S_IC2T) & M_IC2T) + +#define S_IC3T 0 +#define M_IC3T 0x3fU +#define V_IC3T(x) ((x) << S_IC3T) +#define G_IC3T(x) (((x) >> S_IC3T) & M_IC3T) + +#define A_PCIE_CORE_UTL_PCI_EXPRESS_PORT_CONTROL 0x59a0 + +#define S_VRB0 31 +#define V_VRB0(x) ((x) << S_VRB0) +#define F_VRB0 V_VRB0(1U) + +#define S_VRB1 30 +#define V_VRB1(x) ((x) << S_VRB1) +#define F_VRB1 V_VRB1(1U) + +#define S_VRB2 29 +#define V_VRB2(x) ((x) << S_VRB2) +#define F_VRB2 V_VRB2(1U) + +#define S_VRB3 28 +#define V_VRB3(x) ((x) << S_VRB3) +#define F_VRB3 V_VRB3(1U) + +#define S_PSFE 26 +#define V_PSFE(x) ((x) << S_PSFE) +#define F_PSFE V_PSFE(1U) + +#define S_RVDE 25 +#define V_RVDE(x) ((x) << S_RVDE) +#define F_RVDE V_RVDE(1U) + +#define S_TXE0 23 +#define V_TXE0(x) ((x) << S_TXE0) +#define F_TXE0 V_TXE0(1U) + +#define S_TXE1 22 +#define V_TXE1(x) ((x) << S_TXE1) +#define F_TXE1 V_TXE1(1U) + +#define S_TXE2 21 +#define V_TXE2(x) ((x) << S_TXE2) +#define F_TXE2 V_TXE2(1U) + +#define S_TXE3 20 +#define V_TXE3(x) ((x) << S_TXE3) +#define F_TXE3 V_TXE3(1U) + +#define S_RPAM 13 +#define V_RPAM(x) ((x) << S_RPAM) +#define F_RPAM V_RPAM(1U) + +#define S_RTOS 4 +#define M_RTOS 0xfU +#define V_RTOS(x) ((x) << S_RTOS) +#define G_RTOS(x) (((x) >> S_RTOS) & M_RTOS) + +#define A_PCIE_CORE_UTL_PCI_EXPRESS_PORT_STATUS 0x59a4 + +#define S_TPCP 30 +#define V_TPCP(x) ((x) << S_TPCP) +#define F_TPCP V_TPCP(1U) + +#define S_TNPP 29 +#define V_TNPP(x) ((x) << S_TNPP) +#define F_TNPP V_TNPP(1U) + +#define S_TFTP 28 +#define V_TFTP(x) ((x) << S_TFTP) +#define F_TFTP V_TFTP(1U) + +#define S_TCAP 27 +#define V_TCAP(x) ((x) << S_TCAP) +#define F_TCAP V_TCAP(1U) + +#define S_TCIP 26 +#define V_TCIP(x) ((x) << S_TCIP) +#define F_TCIP V_TCIP(1U) + +#define S_RCAP 25 +#define V_RCAP(x) ((x) << S_RCAP) +#define F_RCAP V_RCAP(1U) + +#define S_PLUP 23 +#define V_PLUP(x) ((x) << S_PLUP) +#define F_PLUP V_PLUP(1U) + +#define S_PLDN 22 +#define V_PLDN(x) ((x) << S_PLDN) +#define F_PLDN V_PLDN(1U) + +#define S_OTDD 21 +#define V_OTDD(x) ((x) << S_OTDD) +#define F_OTDD V_OTDD(1U) + +#define S_GTRP 20 +#define V_GTRP(x) ((x) << S_GTRP) +#define F_GTRP V_GTRP(1U) + +#define S_RDPE 18 +#define V_RDPE(x) ((x) << S_RDPE) +#define F_RDPE V_RDPE(1U) + +#define S_TDCE 17 +#define V_TDCE(x) ((x) << S_TDCE) +#define F_TDCE V_TDCE(1U) + +#define S_TDUE 16 +#define V_TDUE(x) ((x) << S_TDUE) +#define F_TDUE V_TDUE(1U) + +#define A_PCIE_CORE_UTL_PCI_EXPRESS_PORT_ERROR_SEVERITY 0x59a8 + +#define S_TPCS 30 +#define V_TPCS(x) ((x) << S_TPCS) +#define F_TPCS V_TPCS(1U) + +#define S_TNPS 29 +#define V_TNPS(x) ((x) << S_TNPS) +#define F_TNPS V_TNPS(1U) + +#define S_TFTS 28 +#define V_TFTS(x) ((x) << S_TFTS) +#define F_TFTS V_TFTS(1U) + +#define S_TCAS 27 +#define V_TCAS(x) ((x) << S_TCAS) +#define F_TCAS V_TCAS(1U) + +#define S_TCIS 26 +#define V_TCIS(x) ((x) << S_TCIS) +#define F_TCIS V_TCIS(1U) + +#define S_RCAS 25 +#define V_RCAS(x) ((x) << S_RCAS) +#define F_RCAS V_RCAS(1U) + +#define S_PLUS 23 +#define V_PLUS(x) ((x) << S_PLUS) +#define F_PLUS V_PLUS(1U) + +#define S_PLDS 22 +#define V_PLDS(x) ((x) << S_PLDS) +#define F_PLDS V_PLDS(1U) + +#define S_OTDS 21 +#define V_OTDS(x) ((x) << S_OTDS) +#define F_OTDS V_OTDS(1U) + +#define S_RDPS 18 +#define V_RDPS(x) ((x) << S_RDPS) +#define F_RDPS V_RDPS(1U) + +#define S_TDCS 17 +#define V_TDCS(x) ((x) << S_TDCS) +#define F_TDCS V_TDCS(1U) + +#define S_TDUS 16 +#define V_TDUS(x) ((x) << S_TDUS) +#define F_TDUS V_TDUS(1U) + +#define A_PCIE_CORE_UTL_PCI_EXPRESS_PORT_INTERRUPT_ENABLE 0x59ac + +#define S_TPCI 30 +#define V_TPCI(x) ((x) << S_TPCI) +#define F_TPCI V_TPCI(1U) + +#define S_TNPI 29 +#define V_TNPI(x) ((x) << S_TNPI) +#define F_TNPI V_TNPI(1U) + +#define S_TFTI 28 +#define V_TFTI(x) ((x) << S_TFTI) +#define F_TFTI V_TFTI(1U) + +#define S_TCAI 27 +#define V_TCAI(x) ((x) << S_TCAI) +#define F_TCAI V_TCAI(1U) + +#define S_TCII 26 +#define V_TCII(x) ((x) << S_TCII) +#define F_TCII V_TCII(1U) + +#define S_RCAI 25 +#define V_RCAI(x) ((x) << S_RCAI) +#define F_RCAI V_RCAI(1U) + +#define S_PLUI 23 +#define V_PLUI(x) ((x) << S_PLUI) +#define F_PLUI V_PLUI(1U) + +#define S_PLDI 22 +#define V_PLDI(x) ((x) << S_PLDI) +#define F_PLDI V_PLDI(1U) + +#define S_OTDI 21 +#define V_OTDI(x) ((x) << S_OTDI) +#define F_OTDI V_OTDI(1U) + +#define A_PCIE_CORE_ROOT_COMPLEX_STATUS 0x59b0 + +#define S_RLCE 31 +#define V_RLCE(x) ((x) << S_RLCE) +#define F_RLCE V_RLCE(1U) + +#define S_RLNE 30 +#define V_RLNE(x) ((x) << S_RLNE) +#define F_RLNE V_RLNE(1U) + +#define S_RLFE 29 +#define V_RLFE(x) ((x) << S_RLFE) +#define F_RLFE V_RLFE(1U) + +#define S_RCPE 25 +#define V_RCPE(x) ((x) << S_RCPE) +#define F_RCPE V_RCPE(1U) + +#define S_RCTO 24 +#define V_RCTO(x) ((x) << S_RCTO) +#define F_RCTO V_RCTO(1U) + +#define S_PINA 23 +#define V_PINA(x) ((x) << S_PINA) +#define F_PINA V_PINA(1U) + +#define S_PINB 22 +#define V_PINB(x) ((x) << S_PINB) +#define F_PINB V_PINB(1U) + +#define S_PINC 21 +#define V_PINC(x) ((x) << S_PINC) +#define F_PINC V_PINC(1U) + +#define S_PIND 20 +#define V_PIND(x) ((x) << S_PIND) +#define F_PIND V_PIND(1U) + +#define S_ALER 19 +#define V_ALER(x) ((x) << S_ALER) +#define F_ALER V_ALER(1U) + +#define S_CRSE 18 +#define V_CRSE(x) ((x) << S_CRSE) +#define F_CRSE V_CRSE(1U) + +#define A_PCIE_T5_HMA_CFG 0x59b0 + +#define S_HMA_MAXREQCNT 20 +#define M_HMA_MAXREQCNT 0x1fU +#define V_HMA_MAXREQCNT(x) ((x) << S_HMA_MAXREQCNT) +#define G_HMA_MAXREQCNT(x) (((x) >> S_HMA_MAXREQCNT) & M_HMA_MAXREQCNT) + +#define S_T5_HMA_MAXRDREQSIZE 17 +#define M_T5_HMA_MAXRDREQSIZE 0x7U +#define V_T5_HMA_MAXRDREQSIZE(x) ((x) << S_T5_HMA_MAXRDREQSIZE) +#define G_T5_HMA_MAXRDREQSIZE(x) (((x) >> S_T5_HMA_MAXRDREQSIZE) & M_T5_HMA_MAXRDREQSIZE) + +#define S_T5_HMA_MAXRSPCNT 8 +#define M_T5_HMA_MAXRSPCNT 0x1fU +#define V_T5_HMA_MAXRSPCNT(x) ((x) << S_T5_HMA_MAXRSPCNT) +#define G_T5_HMA_MAXRSPCNT(x) (((x) >> S_T5_HMA_MAXRSPCNT) & M_T5_HMA_MAXRSPCNT) + +#define A_PCIE_CORE_ROOT_COMPLEX_ERROR_SEVERITY 0x59b4 + +#define S_RLCS 31 +#define V_RLCS(x) ((x) << S_RLCS) +#define F_RLCS V_RLCS(1U) + +#define S_RLNS 30 +#define V_RLNS(x) ((x) << S_RLNS) +#define F_RLNS V_RLNS(1U) + +#define S_RLFS 29 +#define V_RLFS(x) ((x) << S_RLFS) +#define F_RLFS V_RLFS(1U) + +#define S_RCPS 25 +#define V_RCPS(x) ((x) << S_RCPS) +#define F_RCPS V_RCPS(1U) + +#define S_RCTS 24 +#define V_RCTS(x) ((x) << S_RCTS) +#define F_RCTS V_RCTS(1U) + +#define S_PAAS 23 +#define V_PAAS(x) ((x) << S_PAAS) +#define F_PAAS V_PAAS(1U) + +#define S_PABS 22 +#define V_PABS(x) ((x) << S_PABS) +#define F_PABS V_PABS(1U) + +#define S_PACS 21 +#define V_PACS(x) ((x) << S_PACS) +#define F_PACS V_PACS(1U) + +#define S_PADS 20 +#define V_PADS(x) ((x) << S_PADS) +#define F_PADS V_PADS(1U) + +#define S_ALES 19 +#define V_ALES(x) ((x) << S_ALES) +#define F_ALES V_ALES(1U) + +#define S_CRSS 18 +#define V_CRSS(x) ((x) << S_CRSS) +#define F_CRSS V_CRSS(1U) + +#define A_PCIE_T5_HMA_STAT 0x59b4 + +#define S_HMA_RESPCNT 20 +#define M_HMA_RESPCNT 0x1ffU +#define V_HMA_RESPCNT(x) ((x) << S_HMA_RESPCNT) +#define G_HMA_RESPCNT(x) (((x) >> S_HMA_RESPCNT) & M_HMA_RESPCNT) + +#define S_HMA_RDREQCNT 12 +#define M_HMA_RDREQCNT 0x3fU +#define V_HMA_RDREQCNT(x) ((x) << S_HMA_RDREQCNT) +#define G_HMA_RDREQCNT(x) (((x) >> S_HMA_RDREQCNT) & M_HMA_RDREQCNT) + +#define S_HMA_WRREQCNT 0 +#define M_HMA_WRREQCNT 0x1ffU +#define V_HMA_WRREQCNT(x) ((x) << S_HMA_WRREQCNT) +#define G_HMA_WRREQCNT(x) (((x) >> S_HMA_WRREQCNT) & M_HMA_WRREQCNT) + +#define A_PCIE_CORE_ROOT_COMPLEX_INTERRUPT_ENABLE 0x59b8 + +#define S_RLCI 31 +#define V_RLCI(x) ((x) << S_RLCI) +#define F_RLCI V_RLCI(1U) + +#define S_RLNI 30 +#define V_RLNI(x) ((x) << S_RLNI) +#define F_RLNI V_RLNI(1U) + +#define S_RLFI 29 +#define V_RLFI(x) ((x) << S_RLFI) +#define F_RLFI V_RLFI(1U) + +#define S_RCPI 25 +#define V_RCPI(x) ((x) << S_RCPI) +#define F_RCPI V_RCPI(1U) + +#define S_RCTI 24 +#define V_RCTI(x) ((x) << S_RCTI) +#define F_RCTI V_RCTI(1U) + +#define S_PAAI 23 +#define V_PAAI(x) ((x) << S_PAAI) +#define F_PAAI V_PAAI(1U) + +#define S_PABI 22 +#define V_PABI(x) ((x) << S_PABI) +#define F_PABI V_PABI(1U) + +#define S_PACI 21 +#define V_PACI(x) ((x) << S_PACI) +#define F_PACI V_PACI(1U) + +#define S_PADI 20 +#define V_PADI(x) ((x) << S_PADI) +#define F_PADI V_PADI(1U) + +#define S_ALEI 19 +#define V_ALEI(x) ((x) << S_ALEI) +#define F_ALEI V_ALEI(1U) + +#define S_CRSI 18 +#define V_CRSI(x) ((x) << S_CRSI) +#define F_CRSI V_CRSI(1U) + +#define A_PCIE_T5_HMA_STAT2 0x59b8 +#define A_PCIE_CORE_ENDPOINT_STATUS 0x59bc + +#define S_PTOM 31 +#define V_PTOM(x) ((x) << S_PTOM) +#define F_PTOM V_PTOM(1U) + +#define S_ALEA 29 +#define V_ALEA(x) ((x) << S_ALEA) +#define F_ALEA V_ALEA(1U) + +#define S_PMC0 23 +#define V_PMC0(x) ((x) << S_PMC0) +#define F_PMC0 V_PMC0(1U) + +#define S_PMC1 22 +#define V_PMC1(x) ((x) << S_PMC1) +#define F_PMC1 V_PMC1(1U) + +#define S_PMC2 21 +#define V_PMC2(x) ((x) << S_PMC2) +#define F_PMC2 V_PMC2(1U) + +#define S_PMC3 20 +#define V_PMC3(x) ((x) << S_PMC3) +#define F_PMC3 V_PMC3(1U) + +#define S_PMC4 19 +#define V_PMC4(x) ((x) << S_PMC4) +#define F_PMC4 V_PMC4(1U) + +#define S_PMC5 18 +#define V_PMC5(x) ((x) << S_PMC5) +#define F_PMC5 V_PMC5(1U) + +#define S_PMC6 17 +#define V_PMC6(x) ((x) << S_PMC6) +#define F_PMC6 V_PMC6(1U) + +#define S_PMC7 16 +#define V_PMC7(x) ((x) << S_PMC7) +#define F_PMC7 V_PMC7(1U) + +#define A_PCIE_T5_HMA_STAT3 0x59bc +#define A_PCIE_CORE_ENDPOINT_ERROR_SEVERITY 0x59c0 + +#define S_PTOS 31 +#define V_PTOS(x) ((x) << S_PTOS) +#define F_PTOS V_PTOS(1U) + +#define S_AENS 29 +#define V_AENS(x) ((x) << S_AENS) +#define F_AENS V_AENS(1U) + +#define S_PC0S 23 +#define V_PC0S(x) ((x) << S_PC0S) +#define F_PC0S V_PC0S(1U) + +#define S_PC1S 22 +#define V_PC1S(x) ((x) << S_PC1S) +#define F_PC1S V_PC1S(1U) + +#define S_PC2S 21 +#define V_PC2S(x) ((x) << S_PC2S) +#define F_PC2S V_PC2S(1U) + +#define S_PC3S 20 +#define V_PC3S(x) ((x) << S_PC3S) +#define F_PC3S V_PC3S(1U) + +#define S_PC4S 19 +#define V_PC4S(x) ((x) << S_PC4S) +#define F_PC4S V_PC4S(1U) + +#define S_PC5S 18 +#define V_PC5S(x) ((x) << S_PC5S) +#define F_PC5S V_PC5S(1U) + +#define S_PC6S 17 +#define V_PC6S(x) ((x) << S_PC6S) +#define F_PC6S V_PC6S(1U) + +#define S_PC7S 16 +#define V_PC7S(x) ((x) << S_PC7S) +#define F_PC7S V_PC7S(1U) + +#define S_PME0 15 +#define V_PME0(x) ((x) << S_PME0) +#define F_PME0 V_PME0(1U) + +#define S_PME1 14 +#define V_PME1(x) ((x) << S_PME1) +#define F_PME1 V_PME1(1U) + +#define S_PME2 13 +#define V_PME2(x) ((x) << S_PME2) +#define F_PME2 V_PME2(1U) + +#define S_PME3 12 +#define V_PME3(x) ((x) << S_PME3) +#define F_PME3 V_PME3(1U) + +#define S_PME4 11 +#define V_PME4(x) ((x) << S_PME4) +#define F_PME4 V_PME4(1U) + +#define S_PME5 10 +#define V_PME5(x) ((x) << S_PME5) +#define F_PME5 V_PME5(1U) + +#define S_PME6 9 +#define V_PME6(x) ((x) << S_PME6) +#define F_PME6 V_PME6(1U) + +#define S_PME7 8 +#define V_PME7(x) ((x) << S_PME7) +#define F_PME7 V_PME7(1U) + +#define A_PCIE_CGEN 0x59c0 + +#define S_VPD_DYNAMIC_CGEN 26 +#define V_VPD_DYNAMIC_CGEN(x) ((x) << S_VPD_DYNAMIC_CGEN) +#define F_VPD_DYNAMIC_CGEN V_VPD_DYNAMIC_CGEN(1U) + +#define S_MA_DYNAMIC_CGEN 25 +#define V_MA_DYNAMIC_CGEN(x) ((x) << S_MA_DYNAMIC_CGEN) +#define F_MA_DYNAMIC_CGEN V_MA_DYNAMIC_CGEN(1U) + +#define S_TAGQ_DYNAMIC_CGEN 24 +#define V_TAGQ_DYNAMIC_CGEN(x) ((x) << S_TAGQ_DYNAMIC_CGEN) +#define F_TAGQ_DYNAMIC_CGEN V_TAGQ_DYNAMIC_CGEN(1U) + +#define S_REQCTL_DYNAMIC_CGEN 23 +#define V_REQCTL_DYNAMIC_CGEN(x) ((x) << S_REQCTL_DYNAMIC_CGEN) +#define F_REQCTL_DYNAMIC_CGEN V_REQCTL_DYNAMIC_CGEN(1U) + +#define S_RSPDATAPROC_DYNAMIC_CGEN 22 +#define V_RSPDATAPROC_DYNAMIC_CGEN(x) ((x) << S_RSPDATAPROC_DYNAMIC_CGEN) +#define F_RSPDATAPROC_DYNAMIC_CGEN V_RSPDATAPROC_DYNAMIC_CGEN(1U) + +#define S_RSPRDQ_DYNAMIC_CGEN 21 +#define V_RSPRDQ_DYNAMIC_CGEN(x) ((x) << S_RSPRDQ_DYNAMIC_CGEN) +#define F_RSPRDQ_DYNAMIC_CGEN V_RSPRDQ_DYNAMIC_CGEN(1U) + +#define S_RSPIPIF_DYNAMIC_CGEN 20 +#define V_RSPIPIF_DYNAMIC_CGEN(x) ((x) << S_RSPIPIF_DYNAMIC_CGEN) +#define F_RSPIPIF_DYNAMIC_CGEN V_RSPIPIF_DYNAMIC_CGEN(1U) + +#define S_HMA_STATIC_CGEN 19 +#define V_HMA_STATIC_CGEN(x) ((x) << S_HMA_STATIC_CGEN) +#define F_HMA_STATIC_CGEN V_HMA_STATIC_CGEN(1U) + +#define S_HMA_DYNAMIC_CGEN 18 +#define V_HMA_DYNAMIC_CGEN(x) ((x) << S_HMA_DYNAMIC_CGEN) +#define F_HMA_DYNAMIC_CGEN V_HMA_DYNAMIC_CGEN(1U) + +#define S_CMD_STATIC_CGEN 16 +#define V_CMD_STATIC_CGEN(x) ((x) << S_CMD_STATIC_CGEN) +#define F_CMD_STATIC_CGEN V_CMD_STATIC_CGEN(1U) + +#define S_CMD_DYNAMIC_CGEN 15 +#define V_CMD_DYNAMIC_CGEN(x) ((x) << S_CMD_DYNAMIC_CGEN) +#define F_CMD_DYNAMIC_CGEN V_CMD_DYNAMIC_CGEN(1U) + +#define S_DMA_STATIC_CGEN 13 +#define V_DMA_STATIC_CGEN(x) ((x) << S_DMA_STATIC_CGEN) +#define F_DMA_STATIC_CGEN V_DMA_STATIC_CGEN(1U) + +#define S_DMA_DYNAMIC_CGEN 12 +#define V_DMA_DYNAMIC_CGEN(x) ((x) << S_DMA_DYNAMIC_CGEN) +#define F_DMA_DYNAMIC_CGEN V_DMA_DYNAMIC_CGEN(1U) + +#define S_VFID_SLEEPSTATUS 10 +#define V_VFID_SLEEPSTATUS(x) ((x) << S_VFID_SLEEPSTATUS) +#define F_VFID_SLEEPSTATUS V_VFID_SLEEPSTATUS(1U) + +#define S_VC1_SLEEPSTATUS 9 +#define V_VC1_SLEEPSTATUS(x) ((x) << S_VC1_SLEEPSTATUS) +#define F_VC1_SLEEPSTATUS V_VC1_SLEEPSTATUS(1U) + +#define S_STI_SLEEPSTATUS 8 +#define V_STI_SLEEPSTATUS(x) ((x) << S_STI_SLEEPSTATUS) +#define F_STI_SLEEPSTATUS V_STI_SLEEPSTATUS(1U) + +#define S_VFID_SLEEPREQ 2 +#define V_VFID_SLEEPREQ(x) ((x) << S_VFID_SLEEPREQ) +#define F_VFID_SLEEPREQ V_VFID_SLEEPREQ(1U) + +#define S_VC1_SLEEPREQ 1 +#define V_VC1_SLEEPREQ(x) ((x) << S_VC1_SLEEPREQ) +#define F_VC1_SLEEPREQ V_VC1_SLEEPREQ(1U) + +#define S_STI_SLEEPREQ 0 +#define V_STI_SLEEPREQ(x) ((x) << S_STI_SLEEPREQ) +#define F_STI_SLEEPREQ V_STI_SLEEPREQ(1U) + +#define A_PCIE_CORE_ENDPOINT_INTERRUPT_ENABLE 0x59c4 + +#define S_PTOI 31 +#define V_PTOI(x) ((x) << S_PTOI) +#define F_PTOI V_PTOI(1U) + +#define S_AENI 29 +#define V_AENI(x) ((x) << S_AENI) +#define F_AENI V_AENI(1U) + +#define S_PC0I 23 +#define V_PC0I(x) ((x) << S_PC0I) +#define F_PC0I V_PC0I(1U) + +#define S_PC1I 22 +#define V_PC1I(x) ((x) << S_PC1I) +#define F_PC1I V_PC1I(1U) + +#define S_PC2I 21 +#define V_PC2I(x) ((x) << S_PC2I) +#define F_PC2I V_PC2I(1U) + +#define S_PC3I 20 +#define V_PC3I(x) ((x) << S_PC3I) +#define F_PC3I V_PC3I(1U) + +#define S_PC4I 19 +#define V_PC4I(x) ((x) << S_PC4I) +#define F_PC4I V_PC4I(1U) + +#define S_PC5I 18 +#define V_PC5I(x) ((x) << S_PC5I) +#define F_PC5I V_PC5I(1U) + +#define S_PC6I 17 +#define V_PC6I(x) ((x) << S_PC6I) +#define F_PC6I V_PC6I(1U) + +#define S_PC7I 16 +#define V_PC7I(x) ((x) << S_PC7I) +#define F_PC7I V_PC7I(1U) + +#define A_PCIE_MA_RSP 0x59c4 + +#define S_TIMERVALUE 8 +#define M_TIMERVALUE 0xffffffU +#define V_TIMERVALUE(x) ((x) << S_TIMERVALUE) +#define G_TIMERVALUE(x) (((x) >> S_TIMERVALUE) & M_TIMERVALUE) + +#define S_MAREQTIMEREN 1 +#define V_MAREQTIMEREN(x) ((x) << S_MAREQTIMEREN) +#define F_MAREQTIMEREN V_MAREQTIMEREN(1U) + +#define S_MARSPTIMEREN 0 +#define V_MARSPTIMEREN(x) ((x) << S_MARSPTIMEREN) +#define F_MARSPTIMEREN V_MARSPTIMEREN(1U) + +#define A_PCIE_CORE_PCI_POWER_MANAGEMENT_CONTROL_1 0x59c8 + +#define S_TOAK 31 +#define V_TOAK(x) ((x) << S_TOAK) +#define F_TOAK V_TOAK(1U) + +#define S_L1RS 23 +#define V_L1RS(x) ((x) << S_L1RS) +#define F_L1RS V_L1RS(1U) + +#define S_L23S 22 +#define V_L23S(x) ((x) << S_L23S) +#define F_L23S V_L23S(1U) + +#define S_AL1S 21 +#define V_AL1S(x) ((x) << S_AL1S) +#define F_AL1S V_AL1S(1U) + +#define S_ALET 19 +#define V_ALET(x) ((x) << S_ALET) +#define F_ALET V_ALET(1U) + +#define A_PCIE_HPRD 0x59c8 + +#define S_NPH_CREDITSAVAILVC0 19 +#define M_NPH_CREDITSAVAILVC0 0x3U +#define V_NPH_CREDITSAVAILVC0(x) ((x) << S_NPH_CREDITSAVAILVC0) +#define G_NPH_CREDITSAVAILVC0(x) (((x) >> S_NPH_CREDITSAVAILVC0) & M_NPH_CREDITSAVAILVC0) + +#define S_NPD_CREDITSAVAILVC0 17 +#define M_NPD_CREDITSAVAILVC0 0x3U +#define V_NPD_CREDITSAVAILVC0(x) ((x) << S_NPD_CREDITSAVAILVC0) +#define G_NPD_CREDITSAVAILVC0(x) (((x) >> S_NPD_CREDITSAVAILVC0) & M_NPD_CREDITSAVAILVC0) + +#define S_NPH_CREDITSAVAILVC1 15 +#define M_NPH_CREDITSAVAILVC1 0x3U +#define V_NPH_CREDITSAVAILVC1(x) ((x) << S_NPH_CREDITSAVAILVC1) +#define G_NPH_CREDITSAVAILVC1(x) (((x) >> S_NPH_CREDITSAVAILVC1) & M_NPH_CREDITSAVAILVC1) + +#define S_NPD_CREDITSAVAILVC1 13 +#define M_NPD_CREDITSAVAILVC1 0x3U +#define V_NPD_CREDITSAVAILVC1(x) ((x) << S_NPD_CREDITSAVAILVC1) +#define G_NPD_CREDITSAVAILVC1(x) (((x) >> S_NPD_CREDITSAVAILVC1) & M_NPD_CREDITSAVAILVC1) + +#define S_NPH_CREDITSREQUIRED 11 +#define M_NPH_CREDITSREQUIRED 0x3U +#define V_NPH_CREDITSREQUIRED(x) ((x) << S_NPH_CREDITSREQUIRED) +#define G_NPH_CREDITSREQUIRED(x) (((x) >> S_NPH_CREDITSREQUIRED) & M_NPH_CREDITSREQUIRED) + +#define S_NPD_CREDITSREQUIRED 9 +#define M_NPD_CREDITSREQUIRED 0x3U +#define V_NPD_CREDITSREQUIRED(x) ((x) << S_NPD_CREDITSREQUIRED) +#define G_NPD_CREDITSREQUIRED(x) (((x) >> S_NPD_CREDITSREQUIRED) & M_NPD_CREDITSREQUIRED) + +#define S_REQBURSTCOUNT 5 +#define M_REQBURSTCOUNT 0xfU +#define V_REQBURSTCOUNT(x) ((x) << S_REQBURSTCOUNT) +#define G_REQBURSTCOUNT(x) (((x) >> S_REQBURSTCOUNT) & M_REQBURSTCOUNT) + +#define S_REQBURSTFREQUENCY 1 +#define M_REQBURSTFREQUENCY 0xfU +#define V_REQBURSTFREQUENCY(x) ((x) << S_REQBURSTFREQUENCY) +#define G_REQBURSTFREQUENCY(x) (((x) >> S_REQBURSTFREQUENCY) & M_REQBURSTFREQUENCY) + +#define S_ENABLEVC1 0 +#define V_ENABLEVC1(x) ((x) << S_ENABLEVC1) +#define F_ENABLEVC1 V_ENABLEVC1(1U) + +#define A_PCIE_CORE_PCI_POWER_MANAGEMENT_CONTROL_2 0x59cc + +#define S_CPM0 30 +#define M_CPM0 0x3U +#define V_CPM0(x) ((x) << S_CPM0) +#define G_CPM0(x) (((x) >> S_CPM0) & M_CPM0) + +#define S_CPM1 28 +#define M_CPM1 0x3U +#define V_CPM1(x) ((x) << S_CPM1) +#define G_CPM1(x) (((x) >> S_CPM1) & M_CPM1) + +#define S_CPM2 26 +#define M_CPM2 0x3U +#define V_CPM2(x) ((x) << S_CPM2) +#define G_CPM2(x) (((x) >> S_CPM2) & M_CPM2) + +#define S_CPM3 24 +#define M_CPM3 0x3U +#define V_CPM3(x) ((x) << S_CPM3) +#define G_CPM3(x) (((x) >> S_CPM3) & M_CPM3) + +#define S_CPM4 22 +#define M_CPM4 0x3U +#define V_CPM4(x) ((x) << S_CPM4) +#define G_CPM4(x) (((x) >> S_CPM4) & M_CPM4) + +#define S_CPM5 20 +#define M_CPM5 0x3U +#define V_CPM5(x) ((x) << S_CPM5) +#define G_CPM5(x) (((x) >> S_CPM5) & M_CPM5) + +#define S_CPM6 18 +#define M_CPM6 0x3U +#define V_CPM6(x) ((x) << S_CPM6) +#define G_CPM6(x) (((x) >> S_CPM6) & M_CPM6) + +#define S_CPM7 16 +#define M_CPM7 0x3U +#define V_CPM7(x) ((x) << S_CPM7) +#define G_CPM7(x) (((x) >> S_CPM7) & M_CPM7) + +#define S_OPM0 14 +#define M_OPM0 0x3U +#define V_OPM0(x) ((x) << S_OPM0) +#define G_OPM0(x) (((x) >> S_OPM0) & M_OPM0) + +#define S_OPM1 12 +#define M_OPM1 0x3U +#define V_OPM1(x) ((x) << S_OPM1) +#define G_OPM1(x) (((x) >> S_OPM1) & M_OPM1) + +#define S_OPM2 10 +#define M_OPM2 0x3U +#define V_OPM2(x) ((x) << S_OPM2) +#define G_OPM2(x) (((x) >> S_OPM2) & M_OPM2) + +#define S_OPM3 8 +#define M_OPM3 0x3U +#define V_OPM3(x) ((x) << S_OPM3) +#define G_OPM3(x) (((x) >> S_OPM3) & M_OPM3) + +#define S_OPM4 6 +#define M_OPM4 0x3U +#define V_OPM4(x) ((x) << S_OPM4) +#define G_OPM4(x) (((x) >> S_OPM4) & M_OPM4) + +#define S_OPM5 4 +#define M_OPM5 0x3U +#define V_OPM5(x) ((x) << S_OPM5) +#define G_OPM5(x) (((x) >> S_OPM5) & M_OPM5) + +#define S_OPM6 2 +#define M_OPM6 0x3U +#define V_OPM6(x) ((x) << S_OPM6) +#define G_OPM6(x) (((x) >> S_OPM6) & M_OPM6) + +#define S_OPM7 0 +#define M_OPM7 0x3U +#define V_OPM7(x) ((x) << S_OPM7) +#define G_OPM7(x) (((x) >> S_OPM7) & M_OPM7) + +#define A_PCIE_CORE_GENERAL_PURPOSE_CONTROL_1 0x59d0 +#define A_PCIE_PERR_GROUP 0x59d0 + +#define S_MST_DATAPATHPERR 25 +#define V_MST_DATAPATHPERR(x) ((x) << S_MST_DATAPATHPERR) +#define F_MST_DATAPATHPERR V_MST_DATAPATHPERR(1U) + +#define S_MST_RSPRDQPERR 24 +#define V_MST_RSPRDQPERR(x) ((x) << S_MST_RSPRDQPERR) +#define F_MST_RSPRDQPERR V_MST_RSPRDQPERR(1U) + +#define S_IP_RXPERR 23 +#define V_IP_RXPERR(x) ((x) << S_IP_RXPERR) +#define F_IP_RXPERR V_IP_RXPERR(1U) + +#define S_IP_BACKTXPERR 22 +#define V_IP_BACKTXPERR(x) ((x) << S_IP_BACKTXPERR) +#define F_IP_BACKTXPERR V_IP_BACKTXPERR(1U) + +#define S_IP_FRONTTXPERR 21 +#define V_IP_FRONTTXPERR(x) ((x) << S_IP_FRONTTXPERR) +#define F_IP_FRONTTXPERR V_IP_FRONTTXPERR(1U) + +#define S_TRGT1_FIDLKUPHDRPERR 20 +#define V_TRGT1_FIDLKUPHDRPERR(x) ((x) << S_TRGT1_FIDLKUPHDRPERR) +#define F_TRGT1_FIDLKUPHDRPERR V_TRGT1_FIDLKUPHDRPERR(1U) + +#define S_TRGT1_ALINDDATAPERR 19 +#define V_TRGT1_ALINDDATAPERR(x) ((x) << S_TRGT1_ALINDDATAPERR) +#define F_TRGT1_ALINDDATAPERR V_TRGT1_ALINDDATAPERR(1U) + +#define S_TRGT1_UNALINDATAPERR 18 +#define V_TRGT1_UNALINDATAPERR(x) ((x) << S_TRGT1_UNALINDATAPERR) +#define F_TRGT1_UNALINDATAPERR V_TRGT1_UNALINDATAPERR(1U) + +#define S_TRGT1_REQDATAPERR 17 +#define V_TRGT1_REQDATAPERR(x) ((x) << S_TRGT1_REQDATAPERR) +#define F_TRGT1_REQDATAPERR V_TRGT1_REQDATAPERR(1U) + +#define S_TRGT1_REQHDRPERR 16 +#define V_TRGT1_REQHDRPERR(x) ((x) << S_TRGT1_REQHDRPERR) +#define F_TRGT1_REQHDRPERR V_TRGT1_REQHDRPERR(1U) + +#define S_IPRXDATA_VC1PERR 15 +#define V_IPRXDATA_VC1PERR(x) ((x) << S_IPRXDATA_VC1PERR) +#define F_IPRXDATA_VC1PERR V_IPRXDATA_VC1PERR(1U) + +#define S_IPRXDATA_VC0PERR 14 +#define V_IPRXDATA_VC0PERR(x) ((x) << S_IPRXDATA_VC0PERR) +#define F_IPRXDATA_VC0PERR V_IPRXDATA_VC0PERR(1U) + +#define S_IPRXHDR_VC1PERR 13 +#define V_IPRXHDR_VC1PERR(x) ((x) << S_IPRXHDR_VC1PERR) +#define F_IPRXHDR_VC1PERR V_IPRXHDR_VC1PERR(1U) + +#define S_IPRXHDR_VC0PERR 12 +#define V_IPRXHDR_VC0PERR(x) ((x) << S_IPRXHDR_VC0PERR) +#define F_IPRXHDR_VC0PERR V_IPRXHDR_VC0PERR(1U) + +#define S_MA_RSPDATAPERR 11 +#define V_MA_RSPDATAPERR(x) ((x) << S_MA_RSPDATAPERR) +#define F_MA_RSPDATAPERR V_MA_RSPDATAPERR(1U) + +#define S_MA_CPLTAGQPERR 10 +#define V_MA_CPLTAGQPERR(x) ((x) << S_MA_CPLTAGQPERR) +#define F_MA_CPLTAGQPERR V_MA_CPLTAGQPERR(1U) + +#define S_MA_REQTAGQPERR 9 +#define V_MA_REQTAGQPERR(x) ((x) << S_MA_REQTAGQPERR) +#define F_MA_REQTAGQPERR V_MA_REQTAGQPERR(1U) + +#define S_PIOREQ_BAR2CTLPERR 8 +#define V_PIOREQ_BAR2CTLPERR(x) ((x) << S_PIOREQ_BAR2CTLPERR) +#define F_PIOREQ_BAR2CTLPERR V_PIOREQ_BAR2CTLPERR(1U) + +#define S_PIOREQ_MEMCTLPERR 7 +#define V_PIOREQ_MEMCTLPERR(x) ((x) << S_PIOREQ_MEMCTLPERR) +#define F_PIOREQ_MEMCTLPERR V_PIOREQ_MEMCTLPERR(1U) + +#define S_PIOREQ_PLMCTLPERR 6 +#define V_PIOREQ_PLMCTLPERR(x) ((x) << S_PIOREQ_PLMCTLPERR) +#define F_PIOREQ_PLMCTLPERR V_PIOREQ_PLMCTLPERR(1U) + +#define S_PIOREQ_BAR2DATAPERR 5 +#define V_PIOREQ_BAR2DATAPERR(x) ((x) << S_PIOREQ_BAR2DATAPERR) +#define F_PIOREQ_BAR2DATAPERR V_PIOREQ_BAR2DATAPERR(1U) + +#define S_PIOREQ_MEMDATAPERR 4 +#define V_PIOREQ_MEMDATAPERR(x) ((x) << S_PIOREQ_MEMDATAPERR) +#define F_PIOREQ_MEMDATAPERR V_PIOREQ_MEMDATAPERR(1U) + +#define S_PIOREQ_PLMDATAPERR 3 +#define V_PIOREQ_PLMDATAPERR(x) ((x) << S_PIOREQ_PLMDATAPERR) +#define F_PIOREQ_PLMDATAPERR V_PIOREQ_PLMDATAPERR(1U) + +#define S_PIOCPL_CTLPERR 2 +#define V_PIOCPL_CTLPERR(x) ((x) << S_PIOCPL_CTLPERR) +#define F_PIOCPL_CTLPERR V_PIOCPL_CTLPERR(1U) + +#define S_PIOCPL_DATAPERR 1 +#define V_PIOCPL_DATAPERR(x) ((x) << S_PIOCPL_DATAPERR) +#define F_PIOCPL_DATAPERR V_PIOCPL_DATAPERR(1U) + +#define S_PIOCPL_PLMRSPPERR 0 +#define V_PIOCPL_PLMRSPPERR(x) ((x) << S_PIOCPL_PLMRSPPERR) +#define F_PIOCPL_PLMRSPPERR V_PIOCPL_PLMRSPPERR(1U) + +#define A_PCIE_CORE_GENERAL_PURPOSE_CONTROL_2 0x59d4 +#define A_PCIE_RSP_ERR_INT_LOG_EN 0x59d4 + +#define S_CPLSTATUSINTEN 12 +#define V_CPLSTATUSINTEN(x) ((x) << S_CPLSTATUSINTEN) +#define F_CPLSTATUSINTEN V_CPLSTATUSINTEN(1U) + +#define S_REQTIMEOUTINTEN 11 +#define V_REQTIMEOUTINTEN(x) ((x) << S_REQTIMEOUTINTEN) +#define F_REQTIMEOUTINTEN V_REQTIMEOUTINTEN(1U) + +#define S_DISABLEDINTEN 10 +#define V_DISABLEDINTEN(x) ((x) << S_DISABLEDINTEN) +#define F_DISABLEDINTEN V_DISABLEDINTEN(1U) + +#define S_RSPDROPFLRINTEN 9 +#define V_RSPDROPFLRINTEN(x) ((x) << S_RSPDROPFLRINTEN) +#define F_RSPDROPFLRINTEN V_RSPDROPFLRINTEN(1U) + +#define S_REQUNDERFLRINTEN 8 +#define V_REQUNDERFLRINTEN(x) ((x) << S_REQUNDERFLRINTEN) +#define F_REQUNDERFLRINTEN V_REQUNDERFLRINTEN(1U) + +#define S_CPLSTATUSLOGEN 4 +#define V_CPLSTATUSLOGEN(x) ((x) << S_CPLSTATUSLOGEN) +#define F_CPLSTATUSLOGEN V_CPLSTATUSLOGEN(1U) + +#define S_TIMEOUTLOGEN 3 +#define V_TIMEOUTLOGEN(x) ((x) << S_TIMEOUTLOGEN) +#define F_TIMEOUTLOGEN V_TIMEOUTLOGEN(1U) + +#define S_DISABLEDLOGEN 2 +#define V_DISABLEDLOGEN(x) ((x) << S_DISABLEDLOGEN) +#define F_DISABLEDLOGEN V_DISABLEDLOGEN(1U) + +#define S_RSPDROPFLRLOGEN 1 +#define V_RSPDROPFLRLOGEN(x) ((x) << S_RSPDROPFLRLOGEN) +#define F_RSPDROPFLRLOGEN V_RSPDROPFLRLOGEN(1U) + +#define S_REQUNDERFLRLOGEN 0 +#define V_REQUNDERFLRLOGEN(x) ((x) << S_REQUNDERFLRLOGEN) +#define F_REQUNDERFLRLOGEN V_REQUNDERFLRLOGEN(1U) + +#define A_PCIE_RSP_ERR_LOG1 0x59d8 + +#define S_REQTAG 25 +#define M_REQTAG 0x7fU +#define V_REQTAG(x) ((x) << S_REQTAG) +#define G_REQTAG(x) (((x) >> S_REQTAG) & M_REQTAG) + +#define S_CID 22 +#define M_CID 0x7U +#define V_CID(x) ((x) << S_CID) +#define G_CID(x) (((x) >> S_CID) & M_CID) + +#define S_CHNUM 19 +#define M_CHNUM 0x7U +#define V_CHNUM(x) ((x) << S_CHNUM) +#define G_CHNUM(x) (((x) >> S_CHNUM) & M_CHNUM) + +#define S_BYTELEN 6 +#define M_BYTELEN 0x1fffU +#define V_BYTELEN(x) ((x) << S_BYTELEN) +#define G_BYTELEN(x) (((x) >> S_BYTELEN) & M_BYTELEN) + +#define S_REASON 3 +#define M_REASON 0x7U +#define V_REASON(x) ((x) << S_REASON) +#define G_REASON(x) (((x) >> S_REASON) & M_REASON) + +#define S_CPLSTATUS 0 +#define M_CPLSTATUS 0x7U +#define V_CPLSTATUS(x) ((x) << S_CPLSTATUS) +#define G_CPLSTATUS(x) (((x) >> S_CPLSTATUS) & M_CPLSTATUS) + +#define A_PCIE_RSP_ERR_LOG2 0x59dc + +#define S_LOGVALID 31 +#define V_LOGVALID(x) ((x) << S_LOGVALID) +#define F_LOGVALID V_LOGVALID(1U) + +#define S_ADDR10B 8 +#define M_ADDR10B 0x3ffU +#define V_ADDR10B(x) ((x) << S_ADDR10B) +#define G_ADDR10B(x) (((x) >> S_ADDR10B) & M_ADDR10B) + +#define S_REQVFID 0 +#define M_REQVFID 0xffU +#define V_REQVFID(x) ((x) << S_REQVFID) +#define G_REQVFID(x) (((x) >> S_REQVFID) & M_REQVFID) + +#define A_PCIE_CHANGESET 0x59fc +#define A_PCIE_REVISION 0x5a00 +#define A_PCIE_PDEBUG_INDEX 0x5a04 + +#define S_PDEBUGSELH 16 +#define M_PDEBUGSELH 0x3fU +#define V_PDEBUGSELH(x) ((x) << S_PDEBUGSELH) +#define G_PDEBUGSELH(x) (((x) >> S_PDEBUGSELH) & M_PDEBUGSELH) + +#define S_PDEBUGSELL 0 +#define M_PDEBUGSELL 0x3fU +#define V_PDEBUGSELL(x) ((x) << S_PDEBUGSELL) +#define G_PDEBUGSELL(x) (((x) >> S_PDEBUGSELL) & M_PDEBUGSELL) + +#define A_PCIE_PDEBUG_DATA_HIGH 0x5a08 +#define A_PCIE_PDEBUG_DATA_LOW 0x5a0c +#define A_PCIE_CDEBUG_INDEX 0x5a10 + +#define S_CDEBUGSELH 16 +#define M_CDEBUGSELH 0xffU +#define V_CDEBUGSELH(x) ((x) << S_CDEBUGSELH) +#define G_CDEBUGSELH(x) (((x) >> S_CDEBUGSELH) & M_CDEBUGSELH) + +#define S_CDEBUGSELL 0 +#define M_CDEBUGSELL 0xffU +#define V_CDEBUGSELL(x) ((x) << S_CDEBUGSELL) +#define G_CDEBUGSELL(x) (((x) >> S_CDEBUGSELL) & M_CDEBUGSELL) + +#define A_PCIE_CDEBUG_DATA_HIGH 0x5a14 +#define A_PCIE_CDEBUG_DATA_LOW 0x5a18 +#define A_PCIE_DMAW_SOP_CNT 0x5a1c + +#define S_CH3 24 +#define M_CH3 0xffU +#define V_CH3(x) ((x) << S_CH3) +#define G_CH3(x) (((x) >> S_CH3) & M_CH3) + +#define S_CH2 16 +#define M_CH2 0xffU +#define V_CH2(x) ((x) << S_CH2) +#define G_CH2(x) (((x) >> S_CH2) & M_CH2) + +#define S_CH1 8 +#define M_CH1 0xffU +#define V_CH1(x) ((x) << S_CH1) +#define G_CH1(x) (((x) >> S_CH1) & M_CH1) + +#define S_CH0 0 +#define M_CH0 0xffU +#define V_CH0(x) ((x) << S_CH0) +#define G_CH0(x) (((x) >> S_CH0) & M_CH0) + +#define A_PCIE_DMAW_EOP_CNT 0x5a20 +#define A_PCIE_DMAR_REQ_CNT 0x5a24 +#define A_PCIE_DMAR_RSP_SOP_CNT 0x5a28 +#define A_PCIE_DMAR_RSP_EOP_CNT 0x5a2c +#define A_PCIE_DMAR_RSP_ERR_CNT 0x5a30 +#define A_PCIE_DMAI_CNT 0x5a34 +#define A_PCIE_CMDW_CNT 0x5a38 + +#define S_CH1_EOP 24 +#define M_CH1_EOP 0xffU +#define V_CH1_EOP(x) ((x) << S_CH1_EOP) +#define G_CH1_EOP(x) (((x) >> S_CH1_EOP) & M_CH1_EOP) + +#define S_CH1_SOP 16 +#define M_CH1_SOP 0xffU +#define V_CH1_SOP(x) ((x) << S_CH1_SOP) +#define G_CH1_SOP(x) (((x) >> S_CH1_SOP) & M_CH1_SOP) + +#define S_CH0_EOP 8 +#define M_CH0_EOP 0xffU +#define V_CH0_EOP(x) ((x) << S_CH0_EOP) +#define G_CH0_EOP(x) (((x) >> S_CH0_EOP) & M_CH0_EOP) + +#define S_CH0_SOP 0 +#define M_CH0_SOP 0xffU +#define V_CH0_SOP(x) ((x) << S_CH0_SOP) +#define G_CH0_SOP(x) (((x) >> S_CH0_SOP) & M_CH0_SOP) + +#define A_PCIE_CMDR_REQ_CNT 0x5a3c +#define A_PCIE_CMDR_RSP_CNT 0x5a40 +#define A_PCIE_CMDR_RSP_ERR_CNT 0x5a44 +#define A_PCIE_HMA_REQ_CNT 0x5a48 + +#define S_CH0_READ 16 +#define M_CH0_READ 0xffU +#define V_CH0_READ(x) ((x) << S_CH0_READ) +#define G_CH0_READ(x) (((x) >> S_CH0_READ) & M_CH0_READ) + +#define S_CH0_WEOP 8 +#define M_CH0_WEOP 0xffU +#define V_CH0_WEOP(x) ((x) << S_CH0_WEOP) +#define G_CH0_WEOP(x) (((x) >> S_CH0_WEOP) & M_CH0_WEOP) + +#define S_CH0_WSOP 0 +#define M_CH0_WSOP 0xffU +#define V_CH0_WSOP(x) ((x) << S_CH0_WSOP) +#define G_CH0_WSOP(x) (((x) >> S_CH0_WSOP) & M_CH0_WSOP) + +#define A_PCIE_HMA_RSP_CNT 0x5a4c +#define A_PCIE_DMA10_RSP_FREE 0x5a50 + +#define S_CH1_RSP_FREE 16 +#define M_CH1_RSP_FREE 0xfffU +#define V_CH1_RSP_FREE(x) ((x) << S_CH1_RSP_FREE) +#define G_CH1_RSP_FREE(x) (((x) >> S_CH1_RSP_FREE) & M_CH1_RSP_FREE) + +#define S_CH0_RSP_FREE 0 +#define M_CH0_RSP_FREE 0xfffU +#define V_CH0_RSP_FREE(x) ((x) << S_CH0_RSP_FREE) +#define G_CH0_RSP_FREE(x) (((x) >> S_CH0_RSP_FREE) & M_CH0_RSP_FREE) + +#define A_PCIE_DMA32_RSP_FREE 0x5a54 + +#define S_CH3_RSP_FREE 16 +#define M_CH3_RSP_FREE 0xfffU +#define V_CH3_RSP_FREE(x) ((x) << S_CH3_RSP_FREE) +#define G_CH3_RSP_FREE(x) (((x) >> S_CH3_RSP_FREE) & M_CH3_RSP_FREE) + +#define S_CH2_RSP_FREE 0 +#define M_CH2_RSP_FREE 0xfffU +#define V_CH2_RSP_FREE(x) ((x) << S_CH2_RSP_FREE) +#define G_CH2_RSP_FREE(x) (((x) >> S_CH2_RSP_FREE) & M_CH2_RSP_FREE) + +#define A_PCIE_CMD_RSP_FREE 0x5a58 + +#define S_CMD_CH1_RSP_FREE 16 +#define M_CMD_CH1_RSP_FREE 0x7fU +#define V_CMD_CH1_RSP_FREE(x) ((x) << S_CMD_CH1_RSP_FREE) +#define G_CMD_CH1_RSP_FREE(x) (((x) >> S_CMD_CH1_RSP_FREE) & M_CMD_CH1_RSP_FREE) + +#define S_CMD_CH0_RSP_FREE 0 +#define M_CMD_CH0_RSP_FREE 0x7fU +#define V_CMD_CH0_RSP_FREE(x) ((x) << S_CMD_CH0_RSP_FREE) +#define G_CMD_CH0_RSP_FREE(x) (((x) >> S_CMD_CH0_RSP_FREE) & M_CMD_CH0_RSP_FREE) + +#define A_PCIE_HMA_RSP_FREE 0x5a5c +#define A_PCIE_BUS_MST_STAT_0 0x5a60 +#define A_PCIE_BUS_MST_STAT_1 0x5a64 +#define A_PCIE_BUS_MST_STAT_2 0x5a68 +#define A_PCIE_BUS_MST_STAT_3 0x5a6c +#define A_PCIE_BUS_MST_STAT_4 0x5a70 + +#define S_BUSMST_135_128 0 +#define M_BUSMST_135_128 0xffU +#define V_BUSMST_135_128(x) ((x) << S_BUSMST_135_128) +#define G_BUSMST_135_128(x) (((x) >> S_BUSMST_135_128) & M_BUSMST_135_128) + +#define A_PCIE_BUS_MST_STAT_5 0x5a74 +#define A_PCIE_BUS_MST_STAT_6 0x5a78 +#define A_PCIE_BUS_MST_STAT_7 0x5a7c +#define A_PCIE_RSP_ERR_STAT_0 0x5a80 +#define A_PCIE_RSP_ERR_STAT_1 0x5a84 +#define A_PCIE_RSP_ERR_STAT_2 0x5a88 +#define A_PCIE_RSP_ERR_STAT_3 0x5a8c +#define A_PCIE_RSP_ERR_STAT_4 0x5a90 + +#define S_RSPERR_135_128 0 +#define M_RSPERR_135_128 0xffU +#define V_RSPERR_135_128(x) ((x) << S_RSPERR_135_128) +#define G_RSPERR_135_128(x) (((x) >> S_RSPERR_135_128) & M_RSPERR_135_128) + +#define A_PCIE_RSP_ERR_STAT_5 0x5a94 +#define A_PCIE_DBI_TIMEOUT_CTL 0x5a94 + +#define S_DBI_TIMER 0 +#define M_DBI_TIMER 0xffffU +#define V_DBI_TIMER(x) ((x) << S_DBI_TIMER) +#define G_DBI_TIMER(x) (((x) >> S_DBI_TIMER) & M_DBI_TIMER) + +#define A_PCIE_RSP_ERR_STAT_6 0x5a98 +#define A_PCIE_DBI_TIMEOUT_STATUS0 0x5a98 +#define A_PCIE_RSP_ERR_STAT_7 0x5a9c +#define A_PCIE_DBI_TIMEOUT_STATUS1 0x5a9c + +#define S_SOURCE 16 +#define M_SOURCE 0x3U +#define V_SOURCE(x) ((x) << S_SOURCE) +#define G_SOURCE(x) (((x) >> S_SOURCE) & M_SOURCE) + +#define S_DBI_WRITE 12 +#define M_DBI_WRITE 0xfU +#define V_DBI_WRITE(x) ((x) << S_DBI_WRITE) +#define G_DBI_WRITE(x) (((x) >> S_DBI_WRITE) & M_DBI_WRITE) + +#define S_DBI_CS2 11 +#define V_DBI_CS2(x) ((x) << S_DBI_CS2) +#define F_DBI_CS2 V_DBI_CS2(1U) + +#define S_DBI_PF 8 +#define M_DBI_PF 0x7U +#define V_DBI_PF(x) ((x) << S_DBI_PF) +#define G_DBI_PF(x) (((x) >> S_DBI_PF) & M_DBI_PF) + +#define S_PL_TOVFVLD 7 +#define V_PL_TOVFVLD(x) ((x) << S_PL_TOVFVLD) +#define F_PL_TOVFVLD V_PL_TOVFVLD(1U) + +#define S_PL_TOVF 0 +#define M_PL_TOVF 0x7fU +#define V_PL_TOVF(x) ((x) << S_PL_TOVF) +#define G_PL_TOVF(x) (((x) >> S_PL_TOVF) & M_PL_TOVF) + +#define A_PCIE_MSI_EN_0 0x5aa0 +#define A_PCIE_MSI_EN_1 0x5aa4 +#define A_PCIE_MSI_EN_2 0x5aa8 +#define A_PCIE_MSI_EN_3 0x5aac +#define A_PCIE_MSI_EN_4 0x5ab0 +#define A_PCIE_MSI_EN_5 0x5ab4 +#define A_PCIE_MSI_EN_6 0x5ab8 +#define A_PCIE_MSI_EN_7 0x5abc +#define A_PCIE_MSIX_EN_0 0x5ac0 +#define A_PCIE_MSIX_EN_1 0x5ac4 +#define A_PCIE_MSIX_EN_2 0x5ac8 +#define A_PCIE_MSIX_EN_3 0x5acc +#define A_PCIE_MSIX_EN_4 0x5ad0 +#define A_PCIE_MSIX_EN_5 0x5ad4 +#define A_PCIE_MSIX_EN_6 0x5ad8 +#define A_PCIE_MSIX_EN_7 0x5adc +#define A_PCIE_DMA_BUF_CTL 0x5ae0 + +#define S_BUFRDCNT 18 +#define M_BUFRDCNT 0x3fffU +#define V_BUFRDCNT(x) ((x) << S_BUFRDCNT) +#define G_BUFRDCNT(x) (((x) >> S_BUFRDCNT) & M_BUFRDCNT) + +#define S_BUFWRCNT 9 +#define M_BUFWRCNT 0x1ffU +#define V_BUFWRCNT(x) ((x) << S_BUFWRCNT) +#define G_BUFWRCNT(x) (((x) >> S_BUFWRCNT) & M_BUFWRCNT) + +#define S_MAXBUFWRREQ 0 +#define M_MAXBUFWRREQ 0x1ffU +#define V_MAXBUFWRREQ(x) ((x) << S_MAXBUFWRREQ) +#define G_MAXBUFWRREQ(x) (((x) >> S_MAXBUFWRREQ) & M_MAXBUFWRREQ) + +#define A_PCIE_PB_CTL 0x5b94 + +#define S_PB_SEL 16 +#define M_PB_SEL 0xffU +#define V_PB_SEL(x) ((x) << S_PB_SEL) +#define G_PB_SEL(x) (((x) >> S_PB_SEL) & M_PB_SEL) + +#define S_PB_SELREG 8 +#define M_PB_SELREG 0xffU +#define V_PB_SELREG(x) ((x) << S_PB_SELREG) +#define G_PB_SELREG(x) (((x) >> S_PB_SELREG) & M_PB_SELREG) + +#define S_PB_FUNC 0 +#define M_PB_FUNC 0x7U +#define V_PB_FUNC(x) ((x) << S_PB_FUNC) +#define G_PB_FUNC(x) (((x) >> S_PB_FUNC) & M_PB_FUNC) + +#define A_PCIE_PB_DATA 0x5b98 +#define A_PCIE_CUR_LINK 0x5b9c + +#define S_CFGINITCOEFFDONESEEN 22 +#define V_CFGINITCOEFFDONESEEN(x) ((x) << S_CFGINITCOEFFDONESEEN) +#define F_CFGINITCOEFFDONESEEN V_CFGINITCOEFFDONESEEN(1U) + +#define S_CFGINITCOEFFDONE 21 +#define V_CFGINITCOEFFDONE(x) ((x) << S_CFGINITCOEFFDONE) +#define F_CFGINITCOEFFDONE V_CFGINITCOEFFDONE(1U) + +#define S_XMLH_LINK_UP 20 +#define V_XMLH_LINK_UP(x) ((x) << S_XMLH_LINK_UP) +#define F_XMLH_LINK_UP V_XMLH_LINK_UP(1U) + +#define S_PM_LINKST_IN_L0S 19 +#define V_PM_LINKST_IN_L0S(x) ((x) << S_PM_LINKST_IN_L0S) +#define F_PM_LINKST_IN_L0S V_PM_LINKST_IN_L0S(1U) + +#define S_PM_LINKST_IN_L1 18 +#define V_PM_LINKST_IN_L1(x) ((x) << S_PM_LINKST_IN_L1) +#define F_PM_LINKST_IN_L1 V_PM_LINKST_IN_L1(1U) + +#define S_PM_LINKST_IN_L2 17 +#define V_PM_LINKST_IN_L2(x) ((x) << S_PM_LINKST_IN_L2) +#define F_PM_LINKST_IN_L2 V_PM_LINKST_IN_L2(1U) + +#define S_PM_LINKST_L2_EXIT 16 +#define V_PM_LINKST_L2_EXIT(x) ((x) << S_PM_LINKST_L2_EXIT) +#define F_PM_LINKST_L2_EXIT V_PM_LINKST_L2_EXIT(1U) + +#define S_XMLH_IN_RL0S 15 +#define V_XMLH_IN_RL0S(x) ((x) << S_XMLH_IN_RL0S) +#define F_XMLH_IN_RL0S V_XMLH_IN_RL0S(1U) + +#define S_XMLH_LTSSM_STATE_RCVRY_EQ 14 +#define V_XMLH_LTSSM_STATE_RCVRY_EQ(x) ((x) << S_XMLH_LTSSM_STATE_RCVRY_EQ) +#define F_XMLH_LTSSM_STATE_RCVRY_EQ V_XMLH_LTSSM_STATE_RCVRY_EQ(1U) + +#define S_NEGOTIATEDWIDTH 8 +#define M_NEGOTIATEDWIDTH 0x3fU +#define V_NEGOTIATEDWIDTH(x) ((x) << S_NEGOTIATEDWIDTH) +#define G_NEGOTIATEDWIDTH(x) (((x) >> S_NEGOTIATEDWIDTH) & M_NEGOTIATEDWIDTH) + +#define S_ACTIVELANES 0 +#define M_ACTIVELANES 0xffU +#define V_ACTIVELANES(x) ((x) << S_ACTIVELANES) +#define G_ACTIVELANES(x) (((x) >> S_ACTIVELANES) & M_ACTIVELANES) + +#define A_PCIE_PHY_REQRXPWR 0x5ba0 + +#define S_LNH_RXSTATEDONE 31 +#define V_LNH_RXSTATEDONE(x) ((x) << S_LNH_RXSTATEDONE) +#define F_LNH_RXSTATEDONE V_LNH_RXSTATEDONE(1U) + +#define S_LNH_RXSTATEREQ 30 +#define V_LNH_RXSTATEREQ(x) ((x) << S_LNH_RXSTATEREQ) +#define F_LNH_RXSTATEREQ V_LNH_RXSTATEREQ(1U) + +#define S_LNH_RXPWRSTATE 28 +#define M_LNH_RXPWRSTATE 0x3U +#define V_LNH_RXPWRSTATE(x) ((x) << S_LNH_RXPWRSTATE) +#define G_LNH_RXPWRSTATE(x) (((x) >> S_LNH_RXPWRSTATE) & M_LNH_RXPWRSTATE) + +#define S_LNG_RXSTATEDONE 27 +#define V_LNG_RXSTATEDONE(x) ((x) << S_LNG_RXSTATEDONE) +#define F_LNG_RXSTATEDONE V_LNG_RXSTATEDONE(1U) + +#define S_LNG_RXSTATEREQ 26 +#define V_LNG_RXSTATEREQ(x) ((x) << S_LNG_RXSTATEREQ) +#define F_LNG_RXSTATEREQ V_LNG_RXSTATEREQ(1U) + +#define S_LNG_RXPWRSTATE 24 +#define M_LNG_RXPWRSTATE 0x3U +#define V_LNG_RXPWRSTATE(x) ((x) << S_LNG_RXPWRSTATE) +#define G_LNG_RXPWRSTATE(x) (((x) >> S_LNG_RXPWRSTATE) & M_LNG_RXPWRSTATE) + +#define S_LNF_RXSTATEDONE 23 +#define V_LNF_RXSTATEDONE(x) ((x) << S_LNF_RXSTATEDONE) +#define F_LNF_RXSTATEDONE V_LNF_RXSTATEDONE(1U) + +#define S_LNF_RXSTATEREQ 22 +#define V_LNF_RXSTATEREQ(x) ((x) << S_LNF_RXSTATEREQ) +#define F_LNF_RXSTATEREQ V_LNF_RXSTATEREQ(1U) + +#define S_LNF_RXPWRSTATE 20 +#define M_LNF_RXPWRSTATE 0x3U +#define V_LNF_RXPWRSTATE(x) ((x) << S_LNF_RXPWRSTATE) +#define G_LNF_RXPWRSTATE(x) (((x) >> S_LNF_RXPWRSTATE) & M_LNF_RXPWRSTATE) + +#define S_LNE_RXSTATEDONE 19 +#define V_LNE_RXSTATEDONE(x) ((x) << S_LNE_RXSTATEDONE) +#define F_LNE_RXSTATEDONE V_LNE_RXSTATEDONE(1U) + +#define S_LNE_RXSTATEREQ 18 +#define V_LNE_RXSTATEREQ(x) ((x) << S_LNE_RXSTATEREQ) +#define F_LNE_RXSTATEREQ V_LNE_RXSTATEREQ(1U) + +#define S_LNE_RXPWRSTATE 16 +#define M_LNE_RXPWRSTATE 0x3U +#define V_LNE_RXPWRSTATE(x) ((x) << S_LNE_RXPWRSTATE) +#define G_LNE_RXPWRSTATE(x) (((x) >> S_LNE_RXPWRSTATE) & M_LNE_RXPWRSTATE) + +#define S_LND_RXSTATEDONE 15 +#define V_LND_RXSTATEDONE(x) ((x) << S_LND_RXSTATEDONE) +#define F_LND_RXSTATEDONE V_LND_RXSTATEDONE(1U) + +#define S_LND_RXSTATEREQ 14 +#define V_LND_RXSTATEREQ(x) ((x) << S_LND_RXSTATEREQ) +#define F_LND_RXSTATEREQ V_LND_RXSTATEREQ(1U) + +#define S_LND_RXPWRSTATE 12 +#define M_LND_RXPWRSTATE 0x3U +#define V_LND_RXPWRSTATE(x) ((x) << S_LND_RXPWRSTATE) +#define G_LND_RXPWRSTATE(x) (((x) >> S_LND_RXPWRSTATE) & M_LND_RXPWRSTATE) + +#define S_LNC_RXSTATEDONE 11 +#define V_LNC_RXSTATEDONE(x) ((x) << S_LNC_RXSTATEDONE) +#define F_LNC_RXSTATEDONE V_LNC_RXSTATEDONE(1U) + +#define S_LNC_RXSTATEREQ 10 +#define V_LNC_RXSTATEREQ(x) ((x) << S_LNC_RXSTATEREQ) +#define F_LNC_RXSTATEREQ V_LNC_RXSTATEREQ(1U) + +#define S_LNC_RXPWRSTATE 8 +#define M_LNC_RXPWRSTATE 0x3U +#define V_LNC_RXPWRSTATE(x) ((x) << S_LNC_RXPWRSTATE) +#define G_LNC_RXPWRSTATE(x) (((x) >> S_LNC_RXPWRSTATE) & M_LNC_RXPWRSTATE) + +#define S_LNB_RXSTATEDONE 7 +#define V_LNB_RXSTATEDONE(x) ((x) << S_LNB_RXSTATEDONE) +#define F_LNB_RXSTATEDONE V_LNB_RXSTATEDONE(1U) + +#define S_LNB_RXSTATEREQ 6 +#define V_LNB_RXSTATEREQ(x) ((x) << S_LNB_RXSTATEREQ) +#define F_LNB_RXSTATEREQ V_LNB_RXSTATEREQ(1U) + +#define S_LNB_RXPWRSTATE 4 +#define M_LNB_RXPWRSTATE 0x3U +#define V_LNB_RXPWRSTATE(x) ((x) << S_LNB_RXPWRSTATE) +#define G_LNB_RXPWRSTATE(x) (((x) >> S_LNB_RXPWRSTATE) & M_LNB_RXPWRSTATE) + +#define S_LNA_RXSTATEDONE 3 +#define V_LNA_RXSTATEDONE(x) ((x) << S_LNA_RXSTATEDONE) +#define F_LNA_RXSTATEDONE V_LNA_RXSTATEDONE(1U) + +#define S_LNA_RXSTATEREQ 2 +#define V_LNA_RXSTATEREQ(x) ((x) << S_LNA_RXSTATEREQ) +#define F_LNA_RXSTATEREQ V_LNA_RXSTATEREQ(1U) + +#define S_LNA_RXPWRSTATE 0 +#define M_LNA_RXPWRSTATE 0x3U +#define V_LNA_RXPWRSTATE(x) ((x) << S_LNA_RXPWRSTATE) +#define G_LNA_RXPWRSTATE(x) (((x) >> S_LNA_RXPWRSTATE) & M_LNA_RXPWRSTATE) + +#define A_PCIE_PHY_CURRXPWR 0x5ba4 +#define A_PCIE_PHY_GEN3_AE0 0x5ba8 + +#define S_LND_STAT 28 +#define M_LND_STAT 0x7U +#define V_LND_STAT(x) ((x) << S_LND_STAT) +#define G_LND_STAT(x) (((x) >> S_LND_STAT) & M_LND_STAT) + +#define S_LND_CMD 24 +#define M_LND_CMD 0x7U +#define V_LND_CMD(x) ((x) << S_LND_CMD) +#define G_LND_CMD(x) (((x) >> S_LND_CMD) & M_LND_CMD) + +#define S_LNC_STAT 20 +#define M_LNC_STAT 0x7U +#define V_LNC_STAT(x) ((x) << S_LNC_STAT) +#define G_LNC_STAT(x) (((x) >> S_LNC_STAT) & M_LNC_STAT) + +#define S_LNC_CMD 16 +#define M_LNC_CMD 0x7U +#define V_LNC_CMD(x) ((x) << S_LNC_CMD) +#define G_LNC_CMD(x) (((x) >> S_LNC_CMD) & M_LNC_CMD) + +#define S_LNB_STAT 12 +#define M_LNB_STAT 0x7U +#define V_LNB_STAT(x) ((x) << S_LNB_STAT) +#define G_LNB_STAT(x) (((x) >> S_LNB_STAT) & M_LNB_STAT) + +#define S_LNB_CMD 8 +#define M_LNB_CMD 0x7U +#define V_LNB_CMD(x) ((x) << S_LNB_CMD) +#define G_LNB_CMD(x) (((x) >> S_LNB_CMD) & M_LNB_CMD) + +#define S_LNA_STAT 4 +#define M_LNA_STAT 0x7U +#define V_LNA_STAT(x) ((x) << S_LNA_STAT) +#define G_LNA_STAT(x) (((x) >> S_LNA_STAT) & M_LNA_STAT) + +#define S_LNA_CMD 0 +#define M_LNA_CMD 0x7U +#define V_LNA_CMD(x) ((x) << S_LNA_CMD) +#define G_LNA_CMD(x) (((x) >> S_LNA_CMD) & M_LNA_CMD) + +#define A_PCIE_PHY_GEN3_AE1 0x5bac + +#define S_LNH_STAT 28 +#define M_LNH_STAT 0x7U +#define V_LNH_STAT(x) ((x) << S_LNH_STAT) +#define G_LNH_STAT(x) (((x) >> S_LNH_STAT) & M_LNH_STAT) + +#define S_LNH_CMD 24 +#define M_LNH_CMD 0x7U +#define V_LNH_CMD(x) ((x) << S_LNH_CMD) +#define G_LNH_CMD(x) (((x) >> S_LNH_CMD) & M_LNH_CMD) + +#define S_LNG_STAT 20 +#define M_LNG_STAT 0x7U +#define V_LNG_STAT(x) ((x) << S_LNG_STAT) +#define G_LNG_STAT(x) (((x) >> S_LNG_STAT) & M_LNG_STAT) + +#define S_LNG_CMD 16 +#define M_LNG_CMD 0x7U +#define V_LNG_CMD(x) ((x) << S_LNG_CMD) +#define G_LNG_CMD(x) (((x) >> S_LNG_CMD) & M_LNG_CMD) + +#define S_LNF_STAT 12 +#define M_LNF_STAT 0x7U +#define V_LNF_STAT(x) ((x) << S_LNF_STAT) +#define G_LNF_STAT(x) (((x) >> S_LNF_STAT) & M_LNF_STAT) + +#define S_LNF_CMD 8 +#define M_LNF_CMD 0x7U +#define V_LNF_CMD(x) ((x) << S_LNF_CMD) +#define G_LNF_CMD(x) (((x) >> S_LNF_CMD) & M_LNF_CMD) + +#define S_LNE_STAT 4 +#define M_LNE_STAT 0x7U +#define V_LNE_STAT(x) ((x) << S_LNE_STAT) +#define G_LNE_STAT(x) (((x) >> S_LNE_STAT) & M_LNE_STAT) + +#define S_LNE_CMD 0 +#define M_LNE_CMD 0x7U +#define V_LNE_CMD(x) ((x) << S_LNE_CMD) +#define G_LNE_CMD(x) (((x) >> S_LNE_CMD) & M_LNE_CMD) + +#define A_PCIE_PHY_FS_LF0 0x5bb0 + +#define S_LANE1LF 24 +#define M_LANE1LF 0x3fU +#define V_LANE1LF(x) ((x) << S_LANE1LF) +#define G_LANE1LF(x) (((x) >> S_LANE1LF) & M_LANE1LF) + +#define S_LANE1FS 16 +#define M_LANE1FS 0x3fU +#define V_LANE1FS(x) ((x) << S_LANE1FS) +#define G_LANE1FS(x) (((x) >> S_LANE1FS) & M_LANE1FS) + +#define S_LANE0LF 8 +#define M_LANE0LF 0x3fU +#define V_LANE0LF(x) ((x) << S_LANE0LF) +#define G_LANE0LF(x) (((x) >> S_LANE0LF) & M_LANE0LF) + +#define S_LANE0FS 0 +#define M_LANE0FS 0x3fU +#define V_LANE0FS(x) ((x) << S_LANE0FS) +#define G_LANE0FS(x) (((x) >> S_LANE0FS) & M_LANE0FS) + +#define A_PCIE_PHY_FS_LF1 0x5bb4 + +#define S_LANE3LF 24 +#define M_LANE3LF 0x3fU +#define V_LANE3LF(x) ((x) << S_LANE3LF) +#define G_LANE3LF(x) (((x) >> S_LANE3LF) & M_LANE3LF) + +#define S_LANE3FS 16 +#define M_LANE3FS 0x3fU +#define V_LANE3FS(x) ((x) << S_LANE3FS) +#define G_LANE3FS(x) (((x) >> S_LANE3FS) & M_LANE3FS) + +#define S_LANE2LF 8 +#define M_LANE2LF 0x3fU +#define V_LANE2LF(x) ((x) << S_LANE2LF) +#define G_LANE2LF(x) (((x) >> S_LANE2LF) & M_LANE2LF) + +#define S_LANE2FS 0 +#define M_LANE2FS 0x3fU +#define V_LANE2FS(x) ((x) << S_LANE2FS) +#define G_LANE2FS(x) (((x) >> S_LANE2FS) & M_LANE2FS) + +#define A_PCIE_PHY_FS_LF2 0x5bb8 + +#define S_LANE5LF 24 +#define M_LANE5LF 0x3fU +#define V_LANE5LF(x) ((x) << S_LANE5LF) +#define G_LANE5LF(x) (((x) >> S_LANE5LF) & M_LANE5LF) + +#define S_LANE5FS 16 +#define M_LANE5FS 0x3fU +#define V_LANE5FS(x) ((x) << S_LANE5FS) +#define G_LANE5FS(x) (((x) >> S_LANE5FS) & M_LANE5FS) + +#define S_LANE4LF 8 +#define M_LANE4LF 0x3fU +#define V_LANE4LF(x) ((x) << S_LANE4LF) +#define G_LANE4LF(x) (((x) >> S_LANE4LF) & M_LANE4LF) + +#define S_LANE4FS 0 +#define M_LANE4FS 0x3fU +#define V_LANE4FS(x) ((x) << S_LANE4FS) +#define G_LANE4FS(x) (((x) >> S_LANE4FS) & M_LANE4FS) + +#define A_PCIE_PHY_FS_LF3 0x5bbc + +#define S_LANE7LF 24 +#define M_LANE7LF 0x3fU +#define V_LANE7LF(x) ((x) << S_LANE7LF) +#define G_LANE7LF(x) (((x) >> S_LANE7LF) & M_LANE7LF) + +#define S_LANE7FS 16 +#define M_LANE7FS 0x3fU +#define V_LANE7FS(x) ((x) << S_LANE7FS) +#define G_LANE7FS(x) (((x) >> S_LANE7FS) & M_LANE7FS) + +#define S_LANE6LF 8 +#define M_LANE6LF 0x3fU +#define V_LANE6LF(x) ((x) << S_LANE6LF) +#define G_LANE6LF(x) (((x) >> S_LANE6LF) & M_LANE6LF) + +#define S_LANE6FS 0 +#define M_LANE6FS 0x3fU +#define V_LANE6FS(x) ((x) << S_LANE6FS) +#define G_LANE6FS(x) (((x) >> S_LANE6FS) & M_LANE6FS) + +#define A_PCIE_PHY_PRESET_REQ 0x5bc0 + +#define S_COEFFDONE 16 +#define V_COEFFDONE(x) ((x) << S_COEFFDONE) +#define F_COEFFDONE V_COEFFDONE(1U) + +#define S_COEFFLANE 8 +#define M_COEFFLANE 0x7U +#define V_COEFFLANE(x) ((x) << S_COEFFLANE) +#define G_COEFFLANE(x) (((x) >> S_COEFFLANE) & M_COEFFLANE) + +#define S_COEFFSTART 0 +#define V_COEFFSTART(x) ((x) << S_COEFFSTART) +#define F_COEFFSTART V_COEFFSTART(1U) + +#define A_PCIE_PHY_PRESET_COEFF 0x5bc4 + +#define S_COEFF 0 +#define M_COEFF 0x3ffffU +#define V_COEFF(x) ((x) << S_COEFF) +#define G_COEFF(x) (((x) >> S_COEFF) & M_COEFF) + +#define A_PCIE_PHY_INDIR_REQ 0x5bf0 + +#define S_PHYENABLE 31 +#define V_PHYENABLE(x) ((x) << S_PHYENABLE) +#define F_PHYENABLE V_PHYENABLE(1U) + +#define S_PCIE_PHY_REGADDR 0 +#define M_PCIE_PHY_REGADDR 0xffffU +#define V_PCIE_PHY_REGADDR(x) ((x) << S_PCIE_PHY_REGADDR) +#define G_PCIE_PHY_REGADDR(x) (((x) >> S_PCIE_PHY_REGADDR) & M_PCIE_PHY_REGADDR) + +#define A_PCIE_PHY_INDIR_DATA 0x5bf4 +#define A_PCIE_STATIC_SPARE1 0x5bf8 +#define A_PCIE_STATIC_SPARE2 0x5bfc + +/* registers for module DBG */ +#define DBG_BASE_ADDR 0x6000 + +#define A_DBG_DBG0_CFG 0x6000 + +#define S_MODULESELECT 12 +#define M_MODULESELECT 0xffU +#define V_MODULESELECT(x) ((x) << S_MODULESELECT) +#define G_MODULESELECT(x) (((x) >> S_MODULESELECT) & M_MODULESELECT) + +#define S_REGSELECT 4 +#define M_REGSELECT 0xffU +#define V_REGSELECT(x) ((x) << S_REGSELECT) +#define G_REGSELECT(x) (((x) >> S_REGSELECT) & M_REGSELECT) + +#define S_CLKSELECT 0 +#define M_CLKSELECT 0xfU +#define V_CLKSELECT(x) ((x) << S_CLKSELECT) +#define G_CLKSELECT(x) (((x) >> S_CLKSELECT) & M_CLKSELECT) + +#define A_DBG_DBG0_EN 0x6004 + +#define S_PORTEN_PONR 16 +#define V_PORTEN_PONR(x) ((x) << S_PORTEN_PONR) +#define F_PORTEN_PONR V_PORTEN_PONR(1U) + +#define S_PORTEN_POND 12 +#define V_PORTEN_POND(x) ((x) << S_PORTEN_POND) +#define F_PORTEN_POND V_PORTEN_POND(1U) + +#define S_SDRHALFWORD0 8 +#define V_SDRHALFWORD0(x) ((x) << S_SDRHALFWORD0) +#define F_SDRHALFWORD0 V_SDRHALFWORD0(1U) + +#define S_DDREN 4 +#define V_DDREN(x) ((x) << S_DDREN) +#define F_DDREN V_DDREN(1U) + +#define S_DBG_PORTEN 0 +#define V_DBG_PORTEN(x) ((x) << S_DBG_PORTEN) +#define F_DBG_PORTEN V_DBG_PORTEN(1U) + +#define A_DBG_DBG1_CFG 0x6008 +#define A_DBG_DBG1_EN 0x600c + +#define S_CLK_EN_ON_DBG1 20 +#define V_CLK_EN_ON_DBG1(x) ((x) << S_CLK_EN_ON_DBG1) +#define F_CLK_EN_ON_DBG1 V_CLK_EN_ON_DBG1(1U) + +#define A_DBG_GPIO_EN 0x6010 + +#define S_GPIO15_OEN 31 +#define V_GPIO15_OEN(x) ((x) << S_GPIO15_OEN) +#define F_GPIO15_OEN V_GPIO15_OEN(1U) + +#define S_GPIO14_OEN 30 +#define V_GPIO14_OEN(x) ((x) << S_GPIO14_OEN) +#define F_GPIO14_OEN V_GPIO14_OEN(1U) + +#define S_GPIO13_OEN 29 +#define V_GPIO13_OEN(x) ((x) << S_GPIO13_OEN) +#define F_GPIO13_OEN V_GPIO13_OEN(1U) + +#define S_GPIO12_OEN 28 +#define V_GPIO12_OEN(x) ((x) << S_GPIO12_OEN) +#define F_GPIO12_OEN V_GPIO12_OEN(1U) + +#define S_GPIO11_OEN 27 +#define V_GPIO11_OEN(x) ((x) << S_GPIO11_OEN) +#define F_GPIO11_OEN V_GPIO11_OEN(1U) + +#define S_GPIO10_OEN 26 +#define V_GPIO10_OEN(x) ((x) << S_GPIO10_OEN) +#define F_GPIO10_OEN V_GPIO10_OEN(1U) + +#define S_GPIO9_OEN 25 +#define V_GPIO9_OEN(x) ((x) << S_GPIO9_OEN) +#define F_GPIO9_OEN V_GPIO9_OEN(1U) + +#define S_GPIO8_OEN 24 +#define V_GPIO8_OEN(x) ((x) << S_GPIO8_OEN) +#define F_GPIO8_OEN V_GPIO8_OEN(1U) + +#define S_GPIO7_OEN 23 +#define V_GPIO7_OEN(x) ((x) << S_GPIO7_OEN) +#define F_GPIO7_OEN V_GPIO7_OEN(1U) + +#define S_GPIO6_OEN 22 +#define V_GPIO6_OEN(x) ((x) << S_GPIO6_OEN) +#define F_GPIO6_OEN V_GPIO6_OEN(1U) + +#define S_GPIO5_OEN 21 +#define V_GPIO5_OEN(x) ((x) << S_GPIO5_OEN) +#define F_GPIO5_OEN V_GPIO5_OEN(1U) + +#define S_GPIO4_OEN 20 +#define V_GPIO4_OEN(x) ((x) << S_GPIO4_OEN) +#define F_GPIO4_OEN V_GPIO4_OEN(1U) + +#define S_GPIO3_OEN 19 +#define V_GPIO3_OEN(x) ((x) << S_GPIO3_OEN) +#define F_GPIO3_OEN V_GPIO3_OEN(1U) + +#define S_GPIO2_OEN 18 +#define V_GPIO2_OEN(x) ((x) << S_GPIO2_OEN) +#define F_GPIO2_OEN V_GPIO2_OEN(1U) + +#define S_GPIO1_OEN 17 +#define V_GPIO1_OEN(x) ((x) << S_GPIO1_OEN) +#define F_GPIO1_OEN V_GPIO1_OEN(1U) + +#define S_GPIO0_OEN 16 +#define V_GPIO0_OEN(x) ((x) << S_GPIO0_OEN) +#define F_GPIO0_OEN V_GPIO0_OEN(1U) + +#define S_GPIO15_OUT_VAL 15 +#define V_GPIO15_OUT_VAL(x) ((x) << S_GPIO15_OUT_VAL) +#define F_GPIO15_OUT_VAL V_GPIO15_OUT_VAL(1U) + +#define S_GPIO14_OUT_VAL 14 +#define V_GPIO14_OUT_VAL(x) ((x) << S_GPIO14_OUT_VAL) +#define F_GPIO14_OUT_VAL V_GPIO14_OUT_VAL(1U) + +#define S_GPIO13_OUT_VAL 13 +#define V_GPIO13_OUT_VAL(x) ((x) << S_GPIO13_OUT_VAL) +#define F_GPIO13_OUT_VAL V_GPIO13_OUT_VAL(1U) + +#define S_GPIO12_OUT_VAL 12 +#define V_GPIO12_OUT_VAL(x) ((x) << S_GPIO12_OUT_VAL) +#define F_GPIO12_OUT_VAL V_GPIO12_OUT_VAL(1U) + +#define S_GPIO11_OUT_VAL 11 +#define V_GPIO11_OUT_VAL(x) ((x) << S_GPIO11_OUT_VAL) +#define F_GPIO11_OUT_VAL V_GPIO11_OUT_VAL(1U) + +#define S_GPIO10_OUT_VAL 10 +#define V_GPIO10_OUT_VAL(x) ((x) << S_GPIO10_OUT_VAL) +#define F_GPIO10_OUT_VAL V_GPIO10_OUT_VAL(1U) + +#define S_GPIO9_OUT_VAL 9 +#define V_GPIO9_OUT_VAL(x) ((x) << S_GPIO9_OUT_VAL) +#define F_GPIO9_OUT_VAL V_GPIO9_OUT_VAL(1U) + +#define S_GPIO8_OUT_VAL 8 +#define V_GPIO8_OUT_VAL(x) ((x) << S_GPIO8_OUT_VAL) +#define F_GPIO8_OUT_VAL V_GPIO8_OUT_VAL(1U) + +#define S_GPIO7_OUT_VAL 7 +#define V_GPIO7_OUT_VAL(x) ((x) << S_GPIO7_OUT_VAL) +#define F_GPIO7_OUT_VAL V_GPIO7_OUT_VAL(1U) + +#define S_GPIO6_OUT_VAL 6 +#define V_GPIO6_OUT_VAL(x) ((x) << S_GPIO6_OUT_VAL) +#define F_GPIO6_OUT_VAL V_GPIO6_OUT_VAL(1U) + +#define S_GPIO5_OUT_VAL 5 +#define V_GPIO5_OUT_VAL(x) ((x) << S_GPIO5_OUT_VAL) +#define F_GPIO5_OUT_VAL V_GPIO5_OUT_VAL(1U) + +#define S_GPIO4_OUT_VAL 4 +#define V_GPIO4_OUT_VAL(x) ((x) << S_GPIO4_OUT_VAL) +#define F_GPIO4_OUT_VAL V_GPIO4_OUT_VAL(1U) + +#define S_GPIO3_OUT_VAL 3 +#define V_GPIO3_OUT_VAL(x) ((x) << S_GPIO3_OUT_VAL) +#define F_GPIO3_OUT_VAL V_GPIO3_OUT_VAL(1U) + +#define S_GPIO2_OUT_VAL 2 +#define V_GPIO2_OUT_VAL(x) ((x) << S_GPIO2_OUT_VAL) +#define F_GPIO2_OUT_VAL V_GPIO2_OUT_VAL(1U) + +#define S_GPIO1_OUT_VAL 1 +#define V_GPIO1_OUT_VAL(x) ((x) << S_GPIO1_OUT_VAL) +#define F_GPIO1_OUT_VAL V_GPIO1_OUT_VAL(1U) + +#define S_GPIO0_OUT_VAL 0 +#define V_GPIO0_OUT_VAL(x) ((x) << S_GPIO0_OUT_VAL) +#define F_GPIO0_OUT_VAL V_GPIO0_OUT_VAL(1U) + +#define A_DBG_GPIO_IN 0x6014 + +#define S_GPIO15_CHG_DET 31 +#define V_GPIO15_CHG_DET(x) ((x) << S_GPIO15_CHG_DET) +#define F_GPIO15_CHG_DET V_GPIO15_CHG_DET(1U) + +#define S_GPIO14_CHG_DET 30 +#define V_GPIO14_CHG_DET(x) ((x) << S_GPIO14_CHG_DET) +#define F_GPIO14_CHG_DET V_GPIO14_CHG_DET(1U) + +#define S_GPIO13_CHG_DET 29 +#define V_GPIO13_CHG_DET(x) ((x) << S_GPIO13_CHG_DET) +#define F_GPIO13_CHG_DET V_GPIO13_CHG_DET(1U) + +#define S_GPIO12_CHG_DET 28 +#define V_GPIO12_CHG_DET(x) ((x) << S_GPIO12_CHG_DET) +#define F_GPIO12_CHG_DET V_GPIO12_CHG_DET(1U) + +#define S_GPIO11_CHG_DET 27 +#define V_GPIO11_CHG_DET(x) ((x) << S_GPIO11_CHG_DET) +#define F_GPIO11_CHG_DET V_GPIO11_CHG_DET(1U) + +#define S_GPIO10_CHG_DET 26 +#define V_GPIO10_CHG_DET(x) ((x) << S_GPIO10_CHG_DET) +#define F_GPIO10_CHG_DET V_GPIO10_CHG_DET(1U) + +#define S_GPIO9_CHG_DET 25 +#define V_GPIO9_CHG_DET(x) ((x) << S_GPIO9_CHG_DET) +#define F_GPIO9_CHG_DET V_GPIO9_CHG_DET(1U) + +#define S_GPIO8_CHG_DET 24 +#define V_GPIO8_CHG_DET(x) ((x) << S_GPIO8_CHG_DET) +#define F_GPIO8_CHG_DET V_GPIO8_CHG_DET(1U) + +#define S_GPIO7_CHG_DET 23 +#define V_GPIO7_CHG_DET(x) ((x) << S_GPIO7_CHG_DET) +#define F_GPIO7_CHG_DET V_GPIO7_CHG_DET(1U) + +#define S_GPIO6_CHG_DET 22 +#define V_GPIO6_CHG_DET(x) ((x) << S_GPIO6_CHG_DET) +#define F_GPIO6_CHG_DET V_GPIO6_CHG_DET(1U) + +#define S_GPIO5_CHG_DET 21 +#define V_GPIO5_CHG_DET(x) ((x) << S_GPIO5_CHG_DET) +#define F_GPIO5_CHG_DET V_GPIO5_CHG_DET(1U) + +#define S_GPIO4_CHG_DET 20 +#define V_GPIO4_CHG_DET(x) ((x) << S_GPIO4_CHG_DET) +#define F_GPIO4_CHG_DET V_GPIO4_CHG_DET(1U) + +#define S_GPIO3_CHG_DET 19 +#define V_GPIO3_CHG_DET(x) ((x) << S_GPIO3_CHG_DET) +#define F_GPIO3_CHG_DET V_GPIO3_CHG_DET(1U) + +#define S_GPIO2_CHG_DET 18 +#define V_GPIO2_CHG_DET(x) ((x) << S_GPIO2_CHG_DET) +#define F_GPIO2_CHG_DET V_GPIO2_CHG_DET(1U) + +#define S_GPIO1_CHG_DET 17 +#define V_GPIO1_CHG_DET(x) ((x) << S_GPIO1_CHG_DET) +#define F_GPIO1_CHG_DET V_GPIO1_CHG_DET(1U) + +#define S_GPIO0_CHG_DET 16 +#define V_GPIO0_CHG_DET(x) ((x) << S_GPIO0_CHG_DET) +#define F_GPIO0_CHG_DET V_GPIO0_CHG_DET(1U) + +#define S_GPIO15_IN 15 +#define V_GPIO15_IN(x) ((x) << S_GPIO15_IN) +#define F_GPIO15_IN V_GPIO15_IN(1U) + +#define S_GPIO14_IN 14 +#define V_GPIO14_IN(x) ((x) << S_GPIO14_IN) +#define F_GPIO14_IN V_GPIO14_IN(1U) + +#define S_GPIO13_IN 13 +#define V_GPIO13_IN(x) ((x) << S_GPIO13_IN) +#define F_GPIO13_IN V_GPIO13_IN(1U) + +#define S_GPIO12_IN 12 +#define V_GPIO12_IN(x) ((x) << S_GPIO12_IN) +#define F_GPIO12_IN V_GPIO12_IN(1U) + +#define S_GPIO11_IN 11 +#define V_GPIO11_IN(x) ((x) << S_GPIO11_IN) +#define F_GPIO11_IN V_GPIO11_IN(1U) + +#define S_GPIO10_IN 10 +#define V_GPIO10_IN(x) ((x) << S_GPIO10_IN) +#define F_GPIO10_IN V_GPIO10_IN(1U) + +#define S_GPIO9_IN 9 +#define V_GPIO9_IN(x) ((x) << S_GPIO9_IN) +#define F_GPIO9_IN V_GPIO9_IN(1U) + +#define S_GPIO8_IN 8 +#define V_GPIO8_IN(x) ((x) << S_GPIO8_IN) +#define F_GPIO8_IN V_GPIO8_IN(1U) + +#define S_GPIO7_IN 7 +#define V_GPIO7_IN(x) ((x) << S_GPIO7_IN) +#define F_GPIO7_IN V_GPIO7_IN(1U) + +#define S_GPIO6_IN 6 +#define V_GPIO6_IN(x) ((x) << S_GPIO6_IN) +#define F_GPIO6_IN V_GPIO6_IN(1U) + +#define S_GPIO5_IN 5 +#define V_GPIO5_IN(x) ((x) << S_GPIO5_IN) +#define F_GPIO5_IN V_GPIO5_IN(1U) + +#define S_GPIO4_IN 4 +#define V_GPIO4_IN(x) ((x) << S_GPIO4_IN) +#define F_GPIO4_IN V_GPIO4_IN(1U) + +#define S_GPIO3_IN 3 +#define V_GPIO3_IN(x) ((x) << S_GPIO3_IN) +#define F_GPIO3_IN V_GPIO3_IN(1U) + +#define S_GPIO2_IN 2 +#define V_GPIO2_IN(x) ((x) << S_GPIO2_IN) +#define F_GPIO2_IN V_GPIO2_IN(1U) + +#define S_GPIO1_IN 1 +#define V_GPIO1_IN(x) ((x) << S_GPIO1_IN) +#define F_GPIO1_IN V_GPIO1_IN(1U) + +#define S_GPIO0_IN 0 +#define V_GPIO0_IN(x) ((x) << S_GPIO0_IN) +#define F_GPIO0_IN V_GPIO0_IN(1U) + +#define A_DBG_INT_ENABLE 0x6018 + +#define S_IBM_FDL_FAIL_INT_ENBL 25 +#define V_IBM_FDL_FAIL_INT_ENBL(x) ((x) << S_IBM_FDL_FAIL_INT_ENBL) +#define F_IBM_FDL_FAIL_INT_ENBL V_IBM_FDL_FAIL_INT_ENBL(1U) + +#define S_ARM_FAIL_INT_ENBL 24 +#define V_ARM_FAIL_INT_ENBL(x) ((x) << S_ARM_FAIL_INT_ENBL) +#define F_ARM_FAIL_INT_ENBL V_ARM_FAIL_INT_ENBL(1U) + +#define S_ARM_ERROR_OUT_INT_ENBL 23 +#define V_ARM_ERROR_OUT_INT_ENBL(x) ((x) << S_ARM_ERROR_OUT_INT_ENBL) +#define F_ARM_ERROR_OUT_INT_ENBL V_ARM_ERROR_OUT_INT_ENBL(1U) + +#define S_PLL_LOCK_LOST_INT_ENBL 22 +#define V_PLL_LOCK_LOST_INT_ENBL(x) ((x) << S_PLL_LOCK_LOST_INT_ENBL) +#define F_PLL_LOCK_LOST_INT_ENBL V_PLL_LOCK_LOST_INT_ENBL(1U) + +#define S_C_LOCK 21 +#define V_C_LOCK(x) ((x) << S_C_LOCK) +#define F_C_LOCK V_C_LOCK(1U) + +#define S_M_LOCK 20 +#define V_M_LOCK(x) ((x) << S_M_LOCK) +#define F_M_LOCK V_M_LOCK(1U) + +#define S_U_LOCK 19 +#define V_U_LOCK(x) ((x) << S_U_LOCK) +#define F_U_LOCK V_U_LOCK(1U) + +#define S_PCIE_LOCK 18 +#define V_PCIE_LOCK(x) ((x) << S_PCIE_LOCK) +#define F_PCIE_LOCK V_PCIE_LOCK(1U) + +#define S_KX_LOCK 17 +#define V_KX_LOCK(x) ((x) << S_KX_LOCK) +#define F_KX_LOCK V_KX_LOCK(1U) + +#define S_KR_LOCK 16 +#define V_KR_LOCK(x) ((x) << S_KR_LOCK) +#define F_KR_LOCK V_KR_LOCK(1U) + +#define S_GPIO15 15 +#define V_GPIO15(x) ((x) << S_GPIO15) +#define F_GPIO15 V_GPIO15(1U) + +#define S_GPIO14 14 +#define V_GPIO14(x) ((x) << S_GPIO14) +#define F_GPIO14 V_GPIO14(1U) + +#define S_GPIO13 13 +#define V_GPIO13(x) ((x) << S_GPIO13) +#define F_GPIO13 V_GPIO13(1U) + +#define S_GPIO12 12 +#define V_GPIO12(x) ((x) << S_GPIO12) +#define F_GPIO12 V_GPIO12(1U) + +#define S_GPIO11 11 +#define V_GPIO11(x) ((x) << S_GPIO11) +#define F_GPIO11 V_GPIO11(1U) + +#define S_GPIO10 10 +#define V_GPIO10(x) ((x) << S_GPIO10) +#define F_GPIO10 V_GPIO10(1U) + +#define S_GPIO9 9 +#define V_GPIO9(x) ((x) << S_GPIO9) +#define F_GPIO9 V_GPIO9(1U) + +#define S_GPIO8 8 +#define V_GPIO8(x) ((x) << S_GPIO8) +#define F_GPIO8 V_GPIO8(1U) + +#define S_GPIO7 7 +#define V_GPIO7(x) ((x) << S_GPIO7) +#define F_GPIO7 V_GPIO7(1U) + +#define S_GPIO6 6 +#define V_GPIO6(x) ((x) << S_GPIO6) +#define F_GPIO6 V_GPIO6(1U) + +#define S_GPIO5 5 +#define V_GPIO5(x) ((x) << S_GPIO5) +#define F_GPIO5 V_GPIO5(1U) + +#define S_GPIO4 4 +#define V_GPIO4(x) ((x) << S_GPIO4) +#define F_GPIO4 V_GPIO4(1U) + +#define S_GPIO3 3 +#define V_GPIO3(x) ((x) << S_GPIO3) +#define F_GPIO3 V_GPIO3(1U) + +#define S_GPIO2 2 +#define V_GPIO2(x) ((x) << S_GPIO2) +#define F_GPIO2 V_GPIO2(1U) + +#define S_GPIO1 1 +#define V_GPIO1(x) ((x) << S_GPIO1) +#define F_GPIO1 V_GPIO1(1U) + +#define S_GPIO0 0 +#define V_GPIO0(x) ((x) << S_GPIO0) +#define F_GPIO0 V_GPIO0(1U) + +#define S_GPIO19 29 +#define V_GPIO19(x) ((x) << S_GPIO19) +#define F_GPIO19 V_GPIO19(1U) + +#define S_GPIO18 28 +#define V_GPIO18(x) ((x) << S_GPIO18) +#define F_GPIO18 V_GPIO18(1U) + +#define S_GPIO17 27 +#define V_GPIO17(x) ((x) << S_GPIO17) +#define F_GPIO17 V_GPIO17(1U) + +#define S_GPIO16 26 +#define V_GPIO16(x) ((x) << S_GPIO16) +#define F_GPIO16 V_GPIO16(1U) + +#define A_DBG_INT_CAUSE 0x601c + +#define S_IBM_FDL_FAIL_INT_CAUSE 25 +#define V_IBM_FDL_FAIL_INT_CAUSE(x) ((x) << S_IBM_FDL_FAIL_INT_CAUSE) +#define F_IBM_FDL_FAIL_INT_CAUSE V_IBM_FDL_FAIL_INT_CAUSE(1U) + +#define S_ARM_FAIL_INT_CAUSE 24 +#define V_ARM_FAIL_INT_CAUSE(x) ((x) << S_ARM_FAIL_INT_CAUSE) +#define F_ARM_FAIL_INT_CAUSE V_ARM_FAIL_INT_CAUSE(1U) + +#define S_ARM_ERROR_OUT_INT_CAUSE 23 +#define V_ARM_ERROR_OUT_INT_CAUSE(x) ((x) << S_ARM_ERROR_OUT_INT_CAUSE) +#define F_ARM_ERROR_OUT_INT_CAUSE V_ARM_ERROR_OUT_INT_CAUSE(1U) + +#define S_PLL_LOCK_LOST_INT_CAUSE 22 +#define V_PLL_LOCK_LOST_INT_CAUSE(x) ((x) << S_PLL_LOCK_LOST_INT_CAUSE) +#define F_PLL_LOCK_LOST_INT_CAUSE V_PLL_LOCK_LOST_INT_CAUSE(1U) + +#define A_DBG_DBG0_RST_VALUE 0x6020 + +#define S_DEBUGDATA 0 +#define M_DEBUGDATA 0xffffU +#define V_DEBUGDATA(x) ((x) << S_DEBUGDATA) +#define G_DEBUGDATA(x) (((x) >> S_DEBUGDATA) & M_DEBUGDATA) + +#define A_DBG_OVERWRSERCFG_EN 0x6024 + +#define S_OVERWRSERCFG_EN 0 +#define V_OVERWRSERCFG_EN(x) ((x) << S_OVERWRSERCFG_EN) +#define F_OVERWRSERCFG_EN V_OVERWRSERCFG_EN(1U) + +#define A_DBG_PLL_OCLK_PAD_EN 0x6028 + +#define S_PCIE_OCLK_EN 20 +#define V_PCIE_OCLK_EN(x) ((x) << S_PCIE_OCLK_EN) +#define F_PCIE_OCLK_EN V_PCIE_OCLK_EN(1U) + +#define S_KX_OCLK_EN 16 +#define V_KX_OCLK_EN(x) ((x) << S_KX_OCLK_EN) +#define F_KX_OCLK_EN V_KX_OCLK_EN(1U) + +#define S_U_OCLK_EN 12 +#define V_U_OCLK_EN(x) ((x) << S_U_OCLK_EN) +#define F_U_OCLK_EN V_U_OCLK_EN(1U) + +#define S_KR_OCLK_EN 8 +#define V_KR_OCLK_EN(x) ((x) << S_KR_OCLK_EN) +#define F_KR_OCLK_EN V_KR_OCLK_EN(1U) + +#define S_M_OCLK_EN 4 +#define V_M_OCLK_EN(x) ((x) << S_M_OCLK_EN) +#define F_M_OCLK_EN V_M_OCLK_EN(1U) + +#define S_C_OCLK_EN 0 +#define V_C_OCLK_EN(x) ((x) << S_C_OCLK_EN) +#define F_C_OCLK_EN V_C_OCLK_EN(1U) + +#define A_DBG_PLL_LOCK 0x602c + +#define S_PLL_P_LOCK 20 +#define V_PLL_P_LOCK(x) ((x) << S_PLL_P_LOCK) +#define F_PLL_P_LOCK V_PLL_P_LOCK(1U) + +#define S_PLL_KX_LOCK 16 +#define V_PLL_KX_LOCK(x) ((x) << S_PLL_KX_LOCK) +#define F_PLL_KX_LOCK V_PLL_KX_LOCK(1U) + +#define S_PLL_U_LOCK 12 +#define V_PLL_U_LOCK(x) ((x) << S_PLL_U_LOCK) +#define F_PLL_U_LOCK V_PLL_U_LOCK(1U) + +#define S_PLL_KR_LOCK 8 +#define V_PLL_KR_LOCK(x) ((x) << S_PLL_KR_LOCK) +#define F_PLL_KR_LOCK V_PLL_KR_LOCK(1U) + +#define S_PLL_M_LOCK 4 +#define V_PLL_M_LOCK(x) ((x) << S_PLL_M_LOCK) +#define F_PLL_M_LOCK V_PLL_M_LOCK(1U) + +#define S_PLL_C_LOCK 0 +#define V_PLL_C_LOCK(x) ((x) << S_PLL_C_LOCK) +#define F_PLL_C_LOCK V_PLL_C_LOCK(1U) + +#define A_DBG_GPIO_ACT_LOW 0x6030 + +#define S_P_LOCK_ACT_LOW 21 +#define V_P_LOCK_ACT_LOW(x) ((x) << S_P_LOCK_ACT_LOW) +#define F_P_LOCK_ACT_LOW V_P_LOCK_ACT_LOW(1U) + +#define S_C_LOCK_ACT_LOW 20 +#define V_C_LOCK_ACT_LOW(x) ((x) << S_C_LOCK_ACT_LOW) +#define F_C_LOCK_ACT_LOW V_C_LOCK_ACT_LOW(1U) + +#define S_M_LOCK_ACT_LOW 19 +#define V_M_LOCK_ACT_LOW(x) ((x) << S_M_LOCK_ACT_LOW) +#define F_M_LOCK_ACT_LOW V_M_LOCK_ACT_LOW(1U) + +#define S_U_LOCK_ACT_LOW 18 +#define V_U_LOCK_ACT_LOW(x) ((x) << S_U_LOCK_ACT_LOW) +#define F_U_LOCK_ACT_LOW V_U_LOCK_ACT_LOW(1U) + +#define S_KR_LOCK_ACT_LOW 17 +#define V_KR_LOCK_ACT_LOW(x) ((x) << S_KR_LOCK_ACT_LOW) +#define F_KR_LOCK_ACT_LOW V_KR_LOCK_ACT_LOW(1U) + +#define S_KX_LOCK_ACT_LOW 16 +#define V_KX_LOCK_ACT_LOW(x) ((x) << S_KX_LOCK_ACT_LOW) +#define F_KX_LOCK_ACT_LOW V_KX_LOCK_ACT_LOW(1U) + +#define S_GPIO15_ACT_LOW 15 +#define V_GPIO15_ACT_LOW(x) ((x) << S_GPIO15_ACT_LOW) +#define F_GPIO15_ACT_LOW V_GPIO15_ACT_LOW(1U) + +#define S_GPIO14_ACT_LOW 14 +#define V_GPIO14_ACT_LOW(x) ((x) << S_GPIO14_ACT_LOW) +#define F_GPIO14_ACT_LOW V_GPIO14_ACT_LOW(1U) + +#define S_GPIO13_ACT_LOW 13 +#define V_GPIO13_ACT_LOW(x) ((x) << S_GPIO13_ACT_LOW) +#define F_GPIO13_ACT_LOW V_GPIO13_ACT_LOW(1U) + +#define S_GPIO12_ACT_LOW 12 +#define V_GPIO12_ACT_LOW(x) ((x) << S_GPIO12_ACT_LOW) +#define F_GPIO12_ACT_LOW V_GPIO12_ACT_LOW(1U) + +#define S_GPIO11_ACT_LOW 11 +#define V_GPIO11_ACT_LOW(x) ((x) << S_GPIO11_ACT_LOW) +#define F_GPIO11_ACT_LOW V_GPIO11_ACT_LOW(1U) + +#define S_GPIO10_ACT_LOW 10 +#define V_GPIO10_ACT_LOW(x) ((x) << S_GPIO10_ACT_LOW) +#define F_GPIO10_ACT_LOW V_GPIO10_ACT_LOW(1U) + +#define S_GPIO9_ACT_LOW 9 +#define V_GPIO9_ACT_LOW(x) ((x) << S_GPIO9_ACT_LOW) +#define F_GPIO9_ACT_LOW V_GPIO9_ACT_LOW(1U) + +#define S_GPIO8_ACT_LOW 8 +#define V_GPIO8_ACT_LOW(x) ((x) << S_GPIO8_ACT_LOW) +#define F_GPIO8_ACT_LOW V_GPIO8_ACT_LOW(1U) + +#define S_GPIO7_ACT_LOW 7 +#define V_GPIO7_ACT_LOW(x) ((x) << S_GPIO7_ACT_LOW) +#define F_GPIO7_ACT_LOW V_GPIO7_ACT_LOW(1U) + +#define S_GPIO6_ACT_LOW 6 +#define V_GPIO6_ACT_LOW(x) ((x) << S_GPIO6_ACT_LOW) +#define F_GPIO6_ACT_LOW V_GPIO6_ACT_LOW(1U) + +#define S_GPIO5_ACT_LOW 5 +#define V_GPIO5_ACT_LOW(x) ((x) << S_GPIO5_ACT_LOW) +#define F_GPIO5_ACT_LOW V_GPIO5_ACT_LOW(1U) + +#define S_GPIO4_ACT_LOW 4 +#define V_GPIO4_ACT_LOW(x) ((x) << S_GPIO4_ACT_LOW) +#define F_GPIO4_ACT_LOW V_GPIO4_ACT_LOW(1U) + +#define S_GPIO3_ACT_LOW 3 +#define V_GPIO3_ACT_LOW(x) ((x) << S_GPIO3_ACT_LOW) +#define F_GPIO3_ACT_LOW V_GPIO3_ACT_LOW(1U) + +#define S_GPIO2_ACT_LOW 2 +#define V_GPIO2_ACT_LOW(x) ((x) << S_GPIO2_ACT_LOW) +#define F_GPIO2_ACT_LOW V_GPIO2_ACT_LOW(1U) + +#define S_GPIO1_ACT_LOW 1 +#define V_GPIO1_ACT_LOW(x) ((x) << S_GPIO1_ACT_LOW) +#define F_GPIO1_ACT_LOW V_GPIO1_ACT_LOW(1U) + +#define S_GPIO0_ACT_LOW 0 +#define V_GPIO0_ACT_LOW(x) ((x) << S_GPIO0_ACT_LOW) +#define F_GPIO0_ACT_LOW V_GPIO0_ACT_LOW(1U) + +#define S_GPIO19_ACT_LOW 25 +#define V_GPIO19_ACT_LOW(x) ((x) << S_GPIO19_ACT_LOW) +#define F_GPIO19_ACT_LOW V_GPIO19_ACT_LOW(1U) + +#define S_GPIO18_ACT_LOW 24 +#define V_GPIO18_ACT_LOW(x) ((x) << S_GPIO18_ACT_LOW) +#define F_GPIO18_ACT_LOW V_GPIO18_ACT_LOW(1U) + +#define S_GPIO17_ACT_LOW 23 +#define V_GPIO17_ACT_LOW(x) ((x) << S_GPIO17_ACT_LOW) +#define F_GPIO17_ACT_LOW V_GPIO17_ACT_LOW(1U) + +#define S_GPIO16_ACT_LOW 22 +#define V_GPIO16_ACT_LOW(x) ((x) << S_GPIO16_ACT_LOW) +#define F_GPIO16_ACT_LOW V_GPIO16_ACT_LOW(1U) + +#define A_DBG_EFUSE_BYTE0_3 0x6034 +#define A_DBG_EFUSE_BYTE4_7 0x6038 +#define A_DBG_EFUSE_BYTE8_11 0x603c +#define A_DBG_EFUSE_BYTE12_15 0x6040 +#define A_DBG_STATIC_U_PLL_CONF 0x6044 + +#define S_STATIC_U_PLL_MULT 23 +#define M_STATIC_U_PLL_MULT 0x1ffU +#define V_STATIC_U_PLL_MULT(x) ((x) << S_STATIC_U_PLL_MULT) +#define G_STATIC_U_PLL_MULT(x) (((x) >> S_STATIC_U_PLL_MULT) & M_STATIC_U_PLL_MULT) + +#define S_STATIC_U_PLL_PREDIV 18 +#define M_STATIC_U_PLL_PREDIV 0x1fU +#define V_STATIC_U_PLL_PREDIV(x) ((x) << S_STATIC_U_PLL_PREDIV) +#define G_STATIC_U_PLL_PREDIV(x) (((x) >> S_STATIC_U_PLL_PREDIV) & M_STATIC_U_PLL_PREDIV) + +#define S_STATIC_U_PLL_RANGEA 14 +#define M_STATIC_U_PLL_RANGEA 0xfU +#define V_STATIC_U_PLL_RANGEA(x) ((x) << S_STATIC_U_PLL_RANGEA) +#define G_STATIC_U_PLL_RANGEA(x) (((x) >> S_STATIC_U_PLL_RANGEA) & M_STATIC_U_PLL_RANGEA) + +#define S_STATIC_U_PLL_RANGEB 10 +#define M_STATIC_U_PLL_RANGEB 0xfU +#define V_STATIC_U_PLL_RANGEB(x) ((x) << S_STATIC_U_PLL_RANGEB) +#define G_STATIC_U_PLL_RANGEB(x) (((x) >> S_STATIC_U_PLL_RANGEB) & M_STATIC_U_PLL_RANGEB) + +#define S_STATIC_U_PLL_TUNE 0 +#define M_STATIC_U_PLL_TUNE 0x3ffU +#define V_STATIC_U_PLL_TUNE(x) ((x) << S_STATIC_U_PLL_TUNE) +#define G_STATIC_U_PLL_TUNE(x) (((x) >> S_STATIC_U_PLL_TUNE) & M_STATIC_U_PLL_TUNE) + +#define A_DBG_STATIC_C_PLL_CONF 0x6048 + +#define S_STATIC_C_PLL_MULT 23 +#define M_STATIC_C_PLL_MULT 0x1ffU +#define V_STATIC_C_PLL_MULT(x) ((x) << S_STATIC_C_PLL_MULT) +#define G_STATIC_C_PLL_MULT(x) (((x) >> S_STATIC_C_PLL_MULT) & M_STATIC_C_PLL_MULT) + +#define S_STATIC_C_PLL_PREDIV 18 +#define M_STATIC_C_PLL_PREDIV 0x1fU +#define V_STATIC_C_PLL_PREDIV(x) ((x) << S_STATIC_C_PLL_PREDIV) +#define G_STATIC_C_PLL_PREDIV(x) (((x) >> S_STATIC_C_PLL_PREDIV) & M_STATIC_C_PLL_PREDIV) + +#define S_STATIC_C_PLL_RANGEA 14 +#define M_STATIC_C_PLL_RANGEA 0xfU +#define V_STATIC_C_PLL_RANGEA(x) ((x) << S_STATIC_C_PLL_RANGEA) +#define G_STATIC_C_PLL_RANGEA(x) (((x) >> S_STATIC_C_PLL_RANGEA) & M_STATIC_C_PLL_RANGEA) + +#define S_STATIC_C_PLL_RANGEB 10 +#define M_STATIC_C_PLL_RANGEB 0xfU +#define V_STATIC_C_PLL_RANGEB(x) ((x) << S_STATIC_C_PLL_RANGEB) +#define G_STATIC_C_PLL_RANGEB(x) (((x) >> S_STATIC_C_PLL_RANGEB) & M_STATIC_C_PLL_RANGEB) + +#define S_STATIC_C_PLL_TUNE 0 +#define M_STATIC_C_PLL_TUNE 0x3ffU +#define V_STATIC_C_PLL_TUNE(x) ((x) << S_STATIC_C_PLL_TUNE) +#define G_STATIC_C_PLL_TUNE(x) (((x) >> S_STATIC_C_PLL_TUNE) & M_STATIC_C_PLL_TUNE) + +#define A_DBG_STATIC_M_PLL_CONF 0x604c + +#define S_STATIC_M_PLL_MULT 23 +#define M_STATIC_M_PLL_MULT 0x1ffU +#define V_STATIC_M_PLL_MULT(x) ((x) << S_STATIC_M_PLL_MULT) +#define G_STATIC_M_PLL_MULT(x) (((x) >> S_STATIC_M_PLL_MULT) & M_STATIC_M_PLL_MULT) + +#define S_STATIC_M_PLL_PREDIV 18 +#define M_STATIC_M_PLL_PREDIV 0x1fU +#define V_STATIC_M_PLL_PREDIV(x) ((x) << S_STATIC_M_PLL_PREDIV) +#define G_STATIC_M_PLL_PREDIV(x) (((x) >> S_STATIC_M_PLL_PREDIV) & M_STATIC_M_PLL_PREDIV) + +#define S_STATIC_M_PLL_RANGEA 14 +#define M_STATIC_M_PLL_RANGEA 0xfU +#define V_STATIC_M_PLL_RANGEA(x) ((x) << S_STATIC_M_PLL_RANGEA) +#define G_STATIC_M_PLL_RANGEA(x) (((x) >> S_STATIC_M_PLL_RANGEA) & M_STATIC_M_PLL_RANGEA) + +#define S_STATIC_M_PLL_RANGEB 10 +#define M_STATIC_M_PLL_RANGEB 0xfU +#define V_STATIC_M_PLL_RANGEB(x) ((x) << S_STATIC_M_PLL_RANGEB) +#define G_STATIC_M_PLL_RANGEB(x) (((x) >> S_STATIC_M_PLL_RANGEB) & M_STATIC_M_PLL_RANGEB) + +#define S_STATIC_M_PLL_TUNE 0 +#define M_STATIC_M_PLL_TUNE 0x3ffU +#define V_STATIC_M_PLL_TUNE(x) ((x) << S_STATIC_M_PLL_TUNE) +#define G_STATIC_M_PLL_TUNE(x) (((x) >> S_STATIC_M_PLL_TUNE) & M_STATIC_M_PLL_TUNE) + +#define A_DBG_STATIC_KX_PLL_CONF 0x6050 + +#define S_STATIC_KX_PLL_C 21 +#define M_STATIC_KX_PLL_C 0xffU +#define V_STATIC_KX_PLL_C(x) ((x) << S_STATIC_KX_PLL_C) +#define G_STATIC_KX_PLL_C(x) (((x) >> S_STATIC_KX_PLL_C) & M_STATIC_KX_PLL_C) + +#define S_STATIC_KX_PLL_M 15 +#define M_STATIC_KX_PLL_M 0x3fU +#define V_STATIC_KX_PLL_M(x) ((x) << S_STATIC_KX_PLL_M) +#define G_STATIC_KX_PLL_M(x) (((x) >> S_STATIC_KX_PLL_M) & M_STATIC_KX_PLL_M) + +#define S_STATIC_KX_PLL_N1 11 +#define M_STATIC_KX_PLL_N1 0xfU +#define V_STATIC_KX_PLL_N1(x) ((x) << S_STATIC_KX_PLL_N1) +#define G_STATIC_KX_PLL_N1(x) (((x) >> S_STATIC_KX_PLL_N1) & M_STATIC_KX_PLL_N1) + +#define S_STATIC_KX_PLL_N2 7 +#define M_STATIC_KX_PLL_N2 0xfU +#define V_STATIC_KX_PLL_N2(x) ((x) << S_STATIC_KX_PLL_N2) +#define G_STATIC_KX_PLL_N2(x) (((x) >> S_STATIC_KX_PLL_N2) & M_STATIC_KX_PLL_N2) + +#define S_STATIC_KX_PLL_N3 3 +#define M_STATIC_KX_PLL_N3 0xfU +#define V_STATIC_KX_PLL_N3(x) ((x) << S_STATIC_KX_PLL_N3) +#define G_STATIC_KX_PLL_N3(x) (((x) >> S_STATIC_KX_PLL_N3) & M_STATIC_KX_PLL_N3) + +#define S_STATIC_KX_PLL_P 0 +#define M_STATIC_KX_PLL_P 0x7U +#define V_STATIC_KX_PLL_P(x) ((x) << S_STATIC_KX_PLL_P) +#define G_STATIC_KX_PLL_P(x) (((x) >> S_STATIC_KX_PLL_P) & M_STATIC_KX_PLL_P) + +#define A_DBG_STATIC_KR_PLL_CONF 0x6054 + +#define S_STATIC_KR_PLL_C 21 +#define M_STATIC_KR_PLL_C 0xffU +#define V_STATIC_KR_PLL_C(x) ((x) << S_STATIC_KR_PLL_C) +#define G_STATIC_KR_PLL_C(x) (((x) >> S_STATIC_KR_PLL_C) & M_STATIC_KR_PLL_C) + +#define S_STATIC_KR_PLL_M 15 +#define M_STATIC_KR_PLL_M 0x3fU +#define V_STATIC_KR_PLL_M(x) ((x) << S_STATIC_KR_PLL_M) +#define G_STATIC_KR_PLL_M(x) (((x) >> S_STATIC_KR_PLL_M) & M_STATIC_KR_PLL_M) + +#define S_STATIC_KR_PLL_N1 11 +#define M_STATIC_KR_PLL_N1 0xfU +#define V_STATIC_KR_PLL_N1(x) ((x) << S_STATIC_KR_PLL_N1) +#define G_STATIC_KR_PLL_N1(x) (((x) >> S_STATIC_KR_PLL_N1) & M_STATIC_KR_PLL_N1) + +#define S_STATIC_KR_PLL_N2 7 +#define M_STATIC_KR_PLL_N2 0xfU +#define V_STATIC_KR_PLL_N2(x) ((x) << S_STATIC_KR_PLL_N2) +#define G_STATIC_KR_PLL_N2(x) (((x) >> S_STATIC_KR_PLL_N2) & M_STATIC_KR_PLL_N2) + +#define S_STATIC_KR_PLL_N3 3 +#define M_STATIC_KR_PLL_N3 0xfU +#define V_STATIC_KR_PLL_N3(x) ((x) << S_STATIC_KR_PLL_N3) +#define G_STATIC_KR_PLL_N3(x) (((x) >> S_STATIC_KR_PLL_N3) & M_STATIC_KR_PLL_N3) + +#define S_STATIC_KR_PLL_P 0 +#define M_STATIC_KR_PLL_P 0x7U +#define V_STATIC_KR_PLL_P(x) ((x) << S_STATIC_KR_PLL_P) +#define G_STATIC_KR_PLL_P(x) (((x) >> S_STATIC_KR_PLL_P) & M_STATIC_KR_PLL_P) + +#define A_DBG_EXTRA_STATIC_BITS_CONF 0x6058 + +#define S_STATIC_M_PLL_RESET 30 +#define V_STATIC_M_PLL_RESET(x) ((x) << S_STATIC_M_PLL_RESET) +#define F_STATIC_M_PLL_RESET V_STATIC_M_PLL_RESET(1U) + +#define S_STATIC_M_PLL_SLEEP 29 +#define V_STATIC_M_PLL_SLEEP(x) ((x) << S_STATIC_M_PLL_SLEEP) +#define F_STATIC_M_PLL_SLEEP V_STATIC_M_PLL_SLEEP(1U) + +#define S_STATIC_M_PLL_BYPASS 28 +#define V_STATIC_M_PLL_BYPASS(x) ((x) << S_STATIC_M_PLL_BYPASS) +#define F_STATIC_M_PLL_BYPASS V_STATIC_M_PLL_BYPASS(1U) + +#define S_STATIC_MPLL_CLK_SEL 27 +#define V_STATIC_MPLL_CLK_SEL(x) ((x) << S_STATIC_MPLL_CLK_SEL) +#define F_STATIC_MPLL_CLK_SEL V_STATIC_MPLL_CLK_SEL(1U) + +#define S_STATIC_U_PLL_SLEEP 26 +#define V_STATIC_U_PLL_SLEEP(x) ((x) << S_STATIC_U_PLL_SLEEP) +#define F_STATIC_U_PLL_SLEEP V_STATIC_U_PLL_SLEEP(1U) + +#define S_STATIC_C_PLL_SLEEP 25 +#define V_STATIC_C_PLL_SLEEP(x) ((x) << S_STATIC_C_PLL_SLEEP) +#define F_STATIC_C_PLL_SLEEP V_STATIC_C_PLL_SLEEP(1U) + +#define S_STATIC_LVDS_CLKOUT_SEL 23 +#define M_STATIC_LVDS_CLKOUT_SEL 0x3U +#define V_STATIC_LVDS_CLKOUT_SEL(x) ((x) << S_STATIC_LVDS_CLKOUT_SEL) +#define G_STATIC_LVDS_CLKOUT_SEL(x) (((x) >> S_STATIC_LVDS_CLKOUT_SEL) & M_STATIC_LVDS_CLKOUT_SEL) + +#define S_STATIC_LVDS_CLKOUT_EN 22 +#define V_STATIC_LVDS_CLKOUT_EN(x) ((x) << S_STATIC_LVDS_CLKOUT_EN) +#define F_STATIC_LVDS_CLKOUT_EN V_STATIC_LVDS_CLKOUT_EN(1U) + +#define S_STATIC_CCLK_FREQ_SEL 20 +#define M_STATIC_CCLK_FREQ_SEL 0x3U +#define V_STATIC_CCLK_FREQ_SEL(x) ((x) << S_STATIC_CCLK_FREQ_SEL) +#define G_STATIC_CCLK_FREQ_SEL(x) (((x) >> S_STATIC_CCLK_FREQ_SEL) & M_STATIC_CCLK_FREQ_SEL) + +#define S_STATIC_UCLK_FREQ_SEL 18 +#define M_STATIC_UCLK_FREQ_SEL 0x3U +#define V_STATIC_UCLK_FREQ_SEL(x) ((x) << S_STATIC_UCLK_FREQ_SEL) +#define G_STATIC_UCLK_FREQ_SEL(x) (((x) >> S_STATIC_UCLK_FREQ_SEL) & M_STATIC_UCLK_FREQ_SEL) + +#define S_EXPHYCLK_SEL_EN 17 +#define V_EXPHYCLK_SEL_EN(x) ((x) << S_EXPHYCLK_SEL_EN) +#define F_EXPHYCLK_SEL_EN V_EXPHYCLK_SEL_EN(1U) + +#define S_EXPHYCLK_SEL 15 +#define M_EXPHYCLK_SEL 0x3U +#define V_EXPHYCLK_SEL(x) ((x) << S_EXPHYCLK_SEL) +#define G_EXPHYCLK_SEL(x) (((x) >> S_EXPHYCLK_SEL) & M_EXPHYCLK_SEL) + +#define S_STATIC_U_PLL_BYPASS 14 +#define V_STATIC_U_PLL_BYPASS(x) ((x) << S_STATIC_U_PLL_BYPASS) +#define F_STATIC_U_PLL_BYPASS V_STATIC_U_PLL_BYPASS(1U) + +#define S_STATIC_C_PLL_BYPASS 13 +#define V_STATIC_C_PLL_BYPASS(x) ((x) << S_STATIC_C_PLL_BYPASS) +#define F_STATIC_C_PLL_BYPASS V_STATIC_C_PLL_BYPASS(1U) + +#define S_STATIC_KR_PLL_BYPASS 12 +#define V_STATIC_KR_PLL_BYPASS(x) ((x) << S_STATIC_KR_PLL_BYPASS) +#define F_STATIC_KR_PLL_BYPASS V_STATIC_KR_PLL_BYPASS(1U) + +#define S_STATIC_KX_PLL_BYPASS 11 +#define V_STATIC_KX_PLL_BYPASS(x) ((x) << S_STATIC_KX_PLL_BYPASS) +#define F_STATIC_KX_PLL_BYPASS V_STATIC_KX_PLL_BYPASS(1U) + +#define S_STATIC_KX_PLL_V 7 +#define M_STATIC_KX_PLL_V 0xfU +#define V_STATIC_KX_PLL_V(x) ((x) << S_STATIC_KX_PLL_V) +#define G_STATIC_KX_PLL_V(x) (((x) >> S_STATIC_KX_PLL_V) & M_STATIC_KX_PLL_V) + +#define S_STATIC_KR_PLL_V 3 +#define M_STATIC_KR_PLL_V 0xfU +#define V_STATIC_KR_PLL_V(x) ((x) << S_STATIC_KR_PLL_V) +#define G_STATIC_KR_PLL_V(x) (((x) >> S_STATIC_KR_PLL_V) & M_STATIC_KR_PLL_V) + +#define S_PSRO_SEL 0 +#define M_PSRO_SEL 0x7U +#define V_PSRO_SEL(x) ((x) << S_PSRO_SEL) +#define G_PSRO_SEL(x) (((x) >> S_PSRO_SEL) & M_PSRO_SEL) + +#define A_DBG_STATIC_OCLK_MUXSEL_CONF 0x605c + +#define S_M_OCLK_MUXSEL 12 +#define V_M_OCLK_MUXSEL(x) ((x) << S_M_OCLK_MUXSEL) +#define F_M_OCLK_MUXSEL V_M_OCLK_MUXSEL(1U) + +#define S_C_OCLK_MUXSEL 10 +#define M_C_OCLK_MUXSEL 0x3U +#define V_C_OCLK_MUXSEL(x) ((x) << S_C_OCLK_MUXSEL) +#define G_C_OCLK_MUXSEL(x) (((x) >> S_C_OCLK_MUXSEL) & M_C_OCLK_MUXSEL) + +#define S_U_OCLK_MUXSEL 8 +#define M_U_OCLK_MUXSEL 0x3U +#define V_U_OCLK_MUXSEL(x) ((x) << S_U_OCLK_MUXSEL) +#define G_U_OCLK_MUXSEL(x) (((x) >> S_U_OCLK_MUXSEL) & M_U_OCLK_MUXSEL) + +#define S_P_OCLK_MUXSEL 6 +#define M_P_OCLK_MUXSEL 0x3U +#define V_P_OCLK_MUXSEL(x) ((x) << S_P_OCLK_MUXSEL) +#define G_P_OCLK_MUXSEL(x) (((x) >> S_P_OCLK_MUXSEL) & M_P_OCLK_MUXSEL) + +#define S_KX_OCLK_MUXSEL 3 +#define M_KX_OCLK_MUXSEL 0x7U +#define V_KX_OCLK_MUXSEL(x) ((x) << S_KX_OCLK_MUXSEL) +#define G_KX_OCLK_MUXSEL(x) (((x) >> S_KX_OCLK_MUXSEL) & M_KX_OCLK_MUXSEL) + +#define S_KR_OCLK_MUXSEL 0 +#define M_KR_OCLK_MUXSEL 0x7U +#define V_KR_OCLK_MUXSEL(x) ((x) << S_KR_OCLK_MUXSEL) +#define G_KR_OCLK_MUXSEL(x) (((x) >> S_KR_OCLK_MUXSEL) & M_KR_OCLK_MUXSEL) + +#define S_T5_P_OCLK_MUXSEL 13 +#define M_T5_P_OCLK_MUXSEL 0xfU +#define V_T5_P_OCLK_MUXSEL(x) ((x) << S_T5_P_OCLK_MUXSEL) +#define G_T5_P_OCLK_MUXSEL(x) (((x) >> S_T5_P_OCLK_MUXSEL) & M_T5_P_OCLK_MUXSEL) + +#define A_DBG_TRACE0_CONF_COMPREG0 0x6060 +#define A_DBG_TRACE0_CONF_COMPREG1 0x6064 +#define A_DBG_TRACE1_CONF_COMPREG0 0x6068 +#define A_DBG_TRACE1_CONF_COMPREG1 0x606c +#define A_DBG_TRACE0_CONF_MASKREG0 0x6070 +#define A_DBG_TRACE0_CONF_MASKREG1 0x6074 +#define A_DBG_TRACE1_CONF_MASKREG0 0x6078 +#define A_DBG_TRACE1_CONF_MASKREG1 0x607c +#define A_DBG_TRACE_COUNTER 0x6080 + +#define S_COUNTER1 16 +#define M_COUNTER1 0xffffU +#define V_COUNTER1(x) ((x) << S_COUNTER1) +#define G_COUNTER1(x) (((x) >> S_COUNTER1) & M_COUNTER1) + +#define S_COUNTER0 0 +#define M_COUNTER0 0xffffU +#define V_COUNTER0(x) ((x) << S_COUNTER0) +#define G_COUNTER0(x) (((x) >> S_COUNTER0) & M_COUNTER0) + +#define A_DBG_STATIC_REFCLK_PERIOD 0x6084 + +#define S_STATIC_REFCLK_PERIOD 0 +#define M_STATIC_REFCLK_PERIOD 0xffffU +#define V_STATIC_REFCLK_PERIOD(x) ((x) << S_STATIC_REFCLK_PERIOD) +#define G_STATIC_REFCLK_PERIOD(x) (((x) >> S_STATIC_REFCLK_PERIOD) & M_STATIC_REFCLK_PERIOD) + +#define A_DBG_TRACE_CONF 0x6088 + +#define S_DBG_TRACE_OPERATE_WITH_TRG 5 +#define V_DBG_TRACE_OPERATE_WITH_TRG(x) ((x) << S_DBG_TRACE_OPERATE_WITH_TRG) +#define F_DBG_TRACE_OPERATE_WITH_TRG V_DBG_TRACE_OPERATE_WITH_TRG(1U) + +#define S_DBG_TRACE_OPERATE_EN 4 +#define V_DBG_TRACE_OPERATE_EN(x) ((x) << S_DBG_TRACE_OPERATE_EN) +#define F_DBG_TRACE_OPERATE_EN V_DBG_TRACE_OPERATE_EN(1U) + +#define S_DBG_OPERATE_INDV_COMBINED 3 +#define V_DBG_OPERATE_INDV_COMBINED(x) ((x) << S_DBG_OPERATE_INDV_COMBINED) +#define F_DBG_OPERATE_INDV_COMBINED V_DBG_OPERATE_INDV_COMBINED(1U) + +#define S_DBG_OPERATE_ORDER_OF_TRIGGER 2 +#define V_DBG_OPERATE_ORDER_OF_TRIGGER(x) ((x) << S_DBG_OPERATE_ORDER_OF_TRIGGER) +#define F_DBG_OPERATE_ORDER_OF_TRIGGER V_DBG_OPERATE_ORDER_OF_TRIGGER(1U) + +#define S_DBG_OPERATE_SGL_DBL_TRIGGER 1 +#define V_DBG_OPERATE_SGL_DBL_TRIGGER(x) ((x) << S_DBG_OPERATE_SGL_DBL_TRIGGER) +#define F_DBG_OPERATE_SGL_DBL_TRIGGER V_DBG_OPERATE_SGL_DBL_TRIGGER(1U) + +#define S_DBG_OPERATE0_OR_1 0 +#define V_DBG_OPERATE0_OR_1(x) ((x) << S_DBG_OPERATE0_OR_1) +#define F_DBG_OPERATE0_OR_1 V_DBG_OPERATE0_OR_1(1U) + +#define A_DBG_TRACE_RDEN 0x608c + +#define S_RD_ADDR1 10 +#define M_RD_ADDR1 0xffU +#define V_RD_ADDR1(x) ((x) << S_RD_ADDR1) +#define G_RD_ADDR1(x) (((x) >> S_RD_ADDR1) & M_RD_ADDR1) + +#define S_RD_ADDR0 2 +#define M_RD_ADDR0 0xffU +#define V_RD_ADDR0(x) ((x) << S_RD_ADDR0) +#define G_RD_ADDR0(x) (((x) >> S_RD_ADDR0) & M_RD_ADDR0) + +#define S_RD_EN1 1 +#define V_RD_EN1(x) ((x) << S_RD_EN1) +#define F_RD_EN1 V_RD_EN1(1U) + +#define S_RD_EN0 0 +#define V_RD_EN0(x) ((x) << S_RD_EN0) +#define F_RD_EN0 V_RD_EN0(1U) + +#define A_DBG_TRACE_WRADDR 0x6090 + +#define S_WR_POINTER_ADDR1 16 +#define M_WR_POINTER_ADDR1 0xffU +#define V_WR_POINTER_ADDR1(x) ((x) << S_WR_POINTER_ADDR1) +#define G_WR_POINTER_ADDR1(x) (((x) >> S_WR_POINTER_ADDR1) & M_WR_POINTER_ADDR1) + +#define S_WR_POINTER_ADDR0 0 +#define M_WR_POINTER_ADDR0 0xffU +#define V_WR_POINTER_ADDR0(x) ((x) << S_WR_POINTER_ADDR0) +#define G_WR_POINTER_ADDR0(x) (((x) >> S_WR_POINTER_ADDR0) & M_WR_POINTER_ADDR0) + +#define A_DBG_TRACE0_DATA_OUT 0x6094 +#define A_DBG_TRACE1_DATA_OUT 0x6098 +#define A_DBG_FUSE_SENSE_DONE 0x609c + +#define S_STATIC_JTAG_VERSIONNR 5 +#define M_STATIC_JTAG_VERSIONNR 0xfU +#define V_STATIC_JTAG_VERSIONNR(x) ((x) << S_STATIC_JTAG_VERSIONNR) +#define G_STATIC_JTAG_VERSIONNR(x) (((x) >> S_STATIC_JTAG_VERSIONNR) & M_STATIC_JTAG_VERSIONNR) + +#define S_UNQ0 1 +#define M_UNQ0 0xfU +#define V_UNQ0(x) ((x) << S_UNQ0) +#define G_UNQ0(x) (((x) >> S_UNQ0) & M_UNQ0) + +#define S_FUSE_DONE_SENSE 0 +#define V_FUSE_DONE_SENSE(x) ((x) << S_FUSE_DONE_SENSE) +#define F_FUSE_DONE_SENSE V_FUSE_DONE_SENSE(1U) + +#define A_DBG_TVSENSE_EN 0x60a8 + +#define S_MCIMPED1_OUT 29 +#define V_MCIMPED1_OUT(x) ((x) << S_MCIMPED1_OUT) +#define F_MCIMPED1_OUT V_MCIMPED1_OUT(1U) + +#define S_MCIMPED2_OUT 28 +#define V_MCIMPED2_OUT(x) ((x) << S_MCIMPED2_OUT) +#define F_MCIMPED2_OUT V_MCIMPED2_OUT(1U) + +#define S_TVSENSE_SNSOUT 17 +#define M_TVSENSE_SNSOUT 0x1ffU +#define V_TVSENSE_SNSOUT(x) ((x) << S_TVSENSE_SNSOUT) +#define G_TVSENSE_SNSOUT(x) (((x) >> S_TVSENSE_SNSOUT) & M_TVSENSE_SNSOUT) + +#define S_TVSENSE_OUTPUTVALID 16 +#define V_TVSENSE_OUTPUTVALID(x) ((x) << S_TVSENSE_OUTPUTVALID) +#define F_TVSENSE_OUTPUTVALID V_TVSENSE_OUTPUTVALID(1U) + +#define S_TVSENSE_SLEEP 10 +#define V_TVSENSE_SLEEP(x) ((x) << S_TVSENSE_SLEEP) +#define F_TVSENSE_SLEEP V_TVSENSE_SLEEP(1U) + +#define S_TVSENSE_SENSV 9 +#define V_TVSENSE_SENSV(x) ((x) << S_TVSENSE_SENSV) +#define F_TVSENSE_SENSV V_TVSENSE_SENSV(1U) + +#define S_TVSENSE_RST 8 +#define V_TVSENSE_RST(x) ((x) << S_TVSENSE_RST) +#define F_TVSENSE_RST V_TVSENSE_RST(1U) + +#define S_TVSENSE_RATIO 0 +#define M_TVSENSE_RATIO 0xffU +#define V_TVSENSE_RATIO(x) ((x) << S_TVSENSE_RATIO) +#define G_TVSENSE_RATIO(x) (((x) >> S_TVSENSE_RATIO) & M_TVSENSE_RATIO) + +#define A_DBG_CUST_EFUSE_OUT_EN 0x60ac +#define A_DBG_CUST_EFUSE_SEL1_EN 0x60b0 +#define A_DBG_CUST_EFUSE_SEL2_EN 0x60b4 + +#define S_DBG_FEENABLE 29 +#define V_DBG_FEENABLE(x) ((x) << S_DBG_FEENABLE) +#define F_DBG_FEENABLE V_DBG_FEENABLE(1U) + +#define S_DBG_FEF 23 +#define M_DBG_FEF 0x3fU +#define V_DBG_FEF(x) ((x) << S_DBG_FEF) +#define G_DBG_FEF(x) (((x) >> S_DBG_FEF) & M_DBG_FEF) + +#define S_DBG_FEMIMICN 22 +#define V_DBG_FEMIMICN(x) ((x) << S_DBG_FEMIMICN) +#define F_DBG_FEMIMICN V_DBG_FEMIMICN(1U) + +#define S_DBG_FEGATEC 21 +#define V_DBG_FEGATEC(x) ((x) << S_DBG_FEGATEC) +#define F_DBG_FEGATEC V_DBG_FEGATEC(1U) + +#define S_DBG_FEPROGP 20 +#define V_DBG_FEPROGP(x) ((x) << S_DBG_FEPROGP) +#define F_DBG_FEPROGP V_DBG_FEPROGP(1U) + +#define S_DBG_FEREADCLK 19 +#define V_DBG_FEREADCLK(x) ((x) << S_DBG_FEREADCLK) +#define F_DBG_FEREADCLK V_DBG_FEREADCLK(1U) + +#define S_DBG_FERSEL 3 +#define M_DBG_FERSEL 0xffffU +#define V_DBG_FERSEL(x) ((x) << S_DBG_FERSEL) +#define G_DBG_FERSEL(x) (((x) >> S_DBG_FERSEL) & M_DBG_FERSEL) + +#define S_DBG_FETIME 0 +#define M_DBG_FETIME 0x7U +#define V_DBG_FETIME(x) ((x) << S_DBG_FETIME) +#define G_DBG_FETIME(x) (((x) >> S_DBG_FETIME) & M_DBG_FETIME) + +#define A_DBG_T5_STATIC_M_PLL_CONF1 0x60b8 + +#define S_T5_STATIC_M_PLL_MULTFRAC 8 +#define M_T5_STATIC_M_PLL_MULTFRAC 0xffffffU +#define V_T5_STATIC_M_PLL_MULTFRAC(x) ((x) << S_T5_STATIC_M_PLL_MULTFRAC) +#define G_T5_STATIC_M_PLL_MULTFRAC(x) (((x) >> S_T5_STATIC_M_PLL_MULTFRAC) & M_T5_STATIC_M_PLL_MULTFRAC) + +#define S_T5_STATIC_M_PLL_FFSLEWRATE 0 +#define M_T5_STATIC_M_PLL_FFSLEWRATE 0xffU +#define V_T5_STATIC_M_PLL_FFSLEWRATE(x) ((x) << S_T5_STATIC_M_PLL_FFSLEWRATE) +#define G_T5_STATIC_M_PLL_FFSLEWRATE(x) (((x) >> S_T5_STATIC_M_PLL_FFSLEWRATE) & M_T5_STATIC_M_PLL_FFSLEWRATE) + +#define A_DBG_T5_STATIC_M_PLL_CONF2 0x60bc + +#define S_T5_STATIC_M_PLL_DCO_BYPASS 23 +#define V_T5_STATIC_M_PLL_DCO_BYPASS(x) ((x) << S_T5_STATIC_M_PLL_DCO_BYPASS) +#define F_T5_STATIC_M_PLL_DCO_BYPASS V_T5_STATIC_M_PLL_DCO_BYPASS(1U) + +#define S_T5_STATIC_M_PLL_SDORDER 21 +#define M_T5_STATIC_M_PLL_SDORDER 0x3U +#define V_T5_STATIC_M_PLL_SDORDER(x) ((x) << S_T5_STATIC_M_PLL_SDORDER) +#define G_T5_STATIC_M_PLL_SDORDER(x) (((x) >> S_T5_STATIC_M_PLL_SDORDER) & M_T5_STATIC_M_PLL_SDORDER) + +#define S_T5_STATIC_M_PLL_FFENABLE 20 +#define V_T5_STATIC_M_PLL_FFENABLE(x) ((x) << S_T5_STATIC_M_PLL_FFENABLE) +#define F_T5_STATIC_M_PLL_FFENABLE V_T5_STATIC_M_PLL_FFENABLE(1U) + +#define S_T5_STATIC_M_PLL_STOPCLKB 19 +#define V_T5_STATIC_M_PLL_STOPCLKB(x) ((x) << S_T5_STATIC_M_PLL_STOPCLKB) +#define F_T5_STATIC_M_PLL_STOPCLKB V_T5_STATIC_M_PLL_STOPCLKB(1U) + +#define S_T5_STATIC_M_PLL_STOPCLKA 18 +#define V_T5_STATIC_M_PLL_STOPCLKA(x) ((x) << S_T5_STATIC_M_PLL_STOPCLKA) +#define F_T5_STATIC_M_PLL_STOPCLKA V_T5_STATIC_M_PLL_STOPCLKA(1U) + +#define S_T5_STATIC_M_PLL_SLEEP 17 +#define V_T5_STATIC_M_PLL_SLEEP(x) ((x) << S_T5_STATIC_M_PLL_SLEEP) +#define F_T5_STATIC_M_PLL_SLEEP V_T5_STATIC_M_PLL_SLEEP(1U) + +#define S_T5_STATIC_M_PLL_BYPASS 16 +#define V_T5_STATIC_M_PLL_BYPASS(x) ((x) << S_T5_STATIC_M_PLL_BYPASS) +#define F_T5_STATIC_M_PLL_BYPASS V_T5_STATIC_M_PLL_BYPASS(1U) + +#define S_T5_STATIC_M_PLL_LOCKTUNE 0 +#define M_T5_STATIC_M_PLL_LOCKTUNE 0xffffU +#define V_T5_STATIC_M_PLL_LOCKTUNE(x) ((x) << S_T5_STATIC_M_PLL_LOCKTUNE) +#define G_T5_STATIC_M_PLL_LOCKTUNE(x) (((x) >> S_T5_STATIC_M_PLL_LOCKTUNE) & M_T5_STATIC_M_PLL_LOCKTUNE) + +#define A_DBG_T5_STATIC_M_PLL_CONF3 0x60c0 + +#define S_T5_STATIC_M_PLL_MULTPRE 30 +#define M_T5_STATIC_M_PLL_MULTPRE 0x3U +#define V_T5_STATIC_M_PLL_MULTPRE(x) ((x) << S_T5_STATIC_M_PLL_MULTPRE) +#define G_T5_STATIC_M_PLL_MULTPRE(x) (((x) >> S_T5_STATIC_M_PLL_MULTPRE) & M_T5_STATIC_M_PLL_MULTPRE) + +#define S_T5_STATIC_M_PLL_LOCKSEL 28 +#define M_T5_STATIC_M_PLL_LOCKSEL 0x3U +#define V_T5_STATIC_M_PLL_LOCKSEL(x) ((x) << S_T5_STATIC_M_PLL_LOCKSEL) +#define G_T5_STATIC_M_PLL_LOCKSEL(x) (((x) >> S_T5_STATIC_M_PLL_LOCKSEL) & M_T5_STATIC_M_PLL_LOCKSEL) + +#define S_T5_STATIC_M_PLL_FFTUNE 12 +#define M_T5_STATIC_M_PLL_FFTUNE 0xffffU +#define V_T5_STATIC_M_PLL_FFTUNE(x) ((x) << S_T5_STATIC_M_PLL_FFTUNE) +#define G_T5_STATIC_M_PLL_FFTUNE(x) (((x) >> S_T5_STATIC_M_PLL_FFTUNE) & M_T5_STATIC_M_PLL_FFTUNE) + +#define S_T5_STATIC_M_PLL_RANGEPRE 10 +#define M_T5_STATIC_M_PLL_RANGEPRE 0x3U +#define V_T5_STATIC_M_PLL_RANGEPRE(x) ((x) << S_T5_STATIC_M_PLL_RANGEPRE) +#define G_T5_STATIC_M_PLL_RANGEPRE(x) (((x) >> S_T5_STATIC_M_PLL_RANGEPRE) & M_T5_STATIC_M_PLL_RANGEPRE) + +#define S_T5_STATIC_M_PLL_RANGEB 5 +#define M_T5_STATIC_M_PLL_RANGEB 0x1fU +#define V_T5_STATIC_M_PLL_RANGEB(x) ((x) << S_T5_STATIC_M_PLL_RANGEB) +#define G_T5_STATIC_M_PLL_RANGEB(x) (((x) >> S_T5_STATIC_M_PLL_RANGEB) & M_T5_STATIC_M_PLL_RANGEB) + +#define S_T5_STATIC_M_PLL_RANGEA 0 +#define M_T5_STATIC_M_PLL_RANGEA 0x1fU +#define V_T5_STATIC_M_PLL_RANGEA(x) ((x) << S_T5_STATIC_M_PLL_RANGEA) +#define G_T5_STATIC_M_PLL_RANGEA(x) (((x) >> S_T5_STATIC_M_PLL_RANGEA) & M_T5_STATIC_M_PLL_RANGEA) + +#define A_DBG_T5_STATIC_M_PLL_CONF4 0x60c4 +#define A_DBG_T5_STATIC_M_PLL_CONF5 0x60c8 + +#define S_T5_STATIC_M_PLL_VCVTUNE 24 +#define M_T5_STATIC_M_PLL_VCVTUNE 0x7U +#define V_T5_STATIC_M_PLL_VCVTUNE(x) ((x) << S_T5_STATIC_M_PLL_VCVTUNE) +#define G_T5_STATIC_M_PLL_VCVTUNE(x) (((x) >> S_T5_STATIC_M_PLL_VCVTUNE) & M_T5_STATIC_M_PLL_VCVTUNE) + +#define S_T5_STATIC_M_PLL_RESET 23 +#define V_T5_STATIC_M_PLL_RESET(x) ((x) << S_T5_STATIC_M_PLL_RESET) +#define F_T5_STATIC_M_PLL_RESET V_T5_STATIC_M_PLL_RESET(1U) + +#define S_T5_STATIC_MPLL_REFCLK_SEL 22 +#define V_T5_STATIC_MPLL_REFCLK_SEL(x) ((x) << S_T5_STATIC_MPLL_REFCLK_SEL) +#define F_T5_STATIC_MPLL_REFCLK_SEL V_T5_STATIC_MPLL_REFCLK_SEL(1U) + +#define S_T5_STATIC_M_PLL_LFTUNE_32_40 13 +#define M_T5_STATIC_M_PLL_LFTUNE_32_40 0x1ffU +#define V_T5_STATIC_M_PLL_LFTUNE_32_40(x) ((x) << S_T5_STATIC_M_PLL_LFTUNE_32_40) +#define G_T5_STATIC_M_PLL_LFTUNE_32_40(x) (((x) >> S_T5_STATIC_M_PLL_LFTUNE_32_40) & M_T5_STATIC_M_PLL_LFTUNE_32_40) + +#define S_T5_STATIC_M_PLL_PREDIV 8 +#define M_T5_STATIC_M_PLL_PREDIV 0x1fU +#define V_T5_STATIC_M_PLL_PREDIV(x) ((x) << S_T5_STATIC_M_PLL_PREDIV) +#define G_T5_STATIC_M_PLL_PREDIV(x) (((x) >> S_T5_STATIC_M_PLL_PREDIV) & M_T5_STATIC_M_PLL_PREDIV) + +#define S_T5_STATIC_M_PLL_MULT 0 +#define M_T5_STATIC_M_PLL_MULT 0xffU +#define V_T5_STATIC_M_PLL_MULT(x) ((x) << S_T5_STATIC_M_PLL_MULT) +#define G_T5_STATIC_M_PLL_MULT(x) (((x) >> S_T5_STATIC_M_PLL_MULT) & M_T5_STATIC_M_PLL_MULT) + +#define A_DBG_T5_STATIC_M_PLL_CONF6 0x60cc + +#define S_T5_STATIC_PHY0RECRST_ 5 +#define V_T5_STATIC_PHY0RECRST_(x) ((x) << S_T5_STATIC_PHY0RECRST_) +#define F_T5_STATIC_PHY0RECRST_ V_T5_STATIC_PHY0RECRST_(1U) + +#define S_T5_STATIC_PHY1RECRST_ 4 +#define V_T5_STATIC_PHY1RECRST_(x) ((x) << S_T5_STATIC_PHY1RECRST_) +#define F_T5_STATIC_PHY1RECRST_ V_T5_STATIC_PHY1RECRST_(1U) + +#define S_T5_STATIC_SWMC0RST_ 3 +#define V_T5_STATIC_SWMC0RST_(x) ((x) << S_T5_STATIC_SWMC0RST_) +#define F_T5_STATIC_SWMC0RST_ V_T5_STATIC_SWMC0RST_(1U) + +#define S_T5_STATIC_SWMC0CFGRST_ 2 +#define V_T5_STATIC_SWMC0CFGRST_(x) ((x) << S_T5_STATIC_SWMC0CFGRST_) +#define F_T5_STATIC_SWMC0CFGRST_ V_T5_STATIC_SWMC0CFGRST_(1U) + +#define S_T5_STATIC_SWMC1RST_ 1 +#define V_T5_STATIC_SWMC1RST_(x) ((x) << S_T5_STATIC_SWMC1RST_) +#define F_T5_STATIC_SWMC1RST_ V_T5_STATIC_SWMC1RST_(1U) + +#define S_T5_STATIC_SWMC1CFGRST_ 0 +#define V_T5_STATIC_SWMC1CFGRST_(x) ((x) << S_T5_STATIC_SWMC1CFGRST_) +#define F_T5_STATIC_SWMC1CFGRST_ V_T5_STATIC_SWMC1CFGRST_(1U) + +#define A_DBG_T5_STATIC_C_PLL_CONF1 0x60d0 + +#define S_T5_STATIC_C_PLL_MULTFRAC 8 +#define M_T5_STATIC_C_PLL_MULTFRAC 0xffffffU +#define V_T5_STATIC_C_PLL_MULTFRAC(x) ((x) << S_T5_STATIC_C_PLL_MULTFRAC) +#define G_T5_STATIC_C_PLL_MULTFRAC(x) (((x) >> S_T5_STATIC_C_PLL_MULTFRAC) & M_T5_STATIC_C_PLL_MULTFRAC) + +#define S_T5_STATIC_C_PLL_FFSLEWRATE 0 +#define M_T5_STATIC_C_PLL_FFSLEWRATE 0xffU +#define V_T5_STATIC_C_PLL_FFSLEWRATE(x) ((x) << S_T5_STATIC_C_PLL_FFSLEWRATE) +#define G_T5_STATIC_C_PLL_FFSLEWRATE(x) (((x) >> S_T5_STATIC_C_PLL_FFSLEWRATE) & M_T5_STATIC_C_PLL_FFSLEWRATE) + +#define A_DBG_T5_STATIC_C_PLL_CONF2 0x60d4 + +#define S_T5_STATIC_C_PLL_DCO_BYPASS 23 +#define V_T5_STATIC_C_PLL_DCO_BYPASS(x) ((x) << S_T5_STATIC_C_PLL_DCO_BYPASS) +#define F_T5_STATIC_C_PLL_DCO_BYPASS V_T5_STATIC_C_PLL_DCO_BYPASS(1U) + +#define S_T5_STATIC_C_PLL_SDORDER 21 +#define M_T5_STATIC_C_PLL_SDORDER 0x3U +#define V_T5_STATIC_C_PLL_SDORDER(x) ((x) << S_T5_STATIC_C_PLL_SDORDER) +#define G_T5_STATIC_C_PLL_SDORDER(x) (((x) >> S_T5_STATIC_C_PLL_SDORDER) & M_T5_STATIC_C_PLL_SDORDER) + +#define S_T5_STATIC_C_PLL_FFENABLE 20 +#define V_T5_STATIC_C_PLL_FFENABLE(x) ((x) << S_T5_STATIC_C_PLL_FFENABLE) +#define F_T5_STATIC_C_PLL_FFENABLE V_T5_STATIC_C_PLL_FFENABLE(1U) + +#define S_T5_STATIC_C_PLL_STOPCLKB 19 +#define V_T5_STATIC_C_PLL_STOPCLKB(x) ((x) << S_T5_STATIC_C_PLL_STOPCLKB) +#define F_T5_STATIC_C_PLL_STOPCLKB V_T5_STATIC_C_PLL_STOPCLKB(1U) + +#define S_T5_STATIC_C_PLL_STOPCLKA 18 +#define V_T5_STATIC_C_PLL_STOPCLKA(x) ((x) << S_T5_STATIC_C_PLL_STOPCLKA) +#define F_T5_STATIC_C_PLL_STOPCLKA V_T5_STATIC_C_PLL_STOPCLKA(1U) + +#define S_T5_STATIC_C_PLL_SLEEP 17 +#define V_T5_STATIC_C_PLL_SLEEP(x) ((x) << S_T5_STATIC_C_PLL_SLEEP) +#define F_T5_STATIC_C_PLL_SLEEP V_T5_STATIC_C_PLL_SLEEP(1U) + +#define S_T5_STATIC_C_PLL_BYPASS 16 +#define V_T5_STATIC_C_PLL_BYPASS(x) ((x) << S_T5_STATIC_C_PLL_BYPASS) +#define F_T5_STATIC_C_PLL_BYPASS V_T5_STATIC_C_PLL_BYPASS(1U) + +#define S_T5_STATIC_C_PLL_LOCKTUNE 0 +#define M_T5_STATIC_C_PLL_LOCKTUNE 0xffffU +#define V_T5_STATIC_C_PLL_LOCKTUNE(x) ((x) << S_T5_STATIC_C_PLL_LOCKTUNE) +#define G_T5_STATIC_C_PLL_LOCKTUNE(x) (((x) >> S_T5_STATIC_C_PLL_LOCKTUNE) & M_T5_STATIC_C_PLL_LOCKTUNE) + +#define A_DBG_T5_STATIC_C_PLL_CONF3 0x60d8 + +#define S_T5_STATIC_C_PLL_MULTPRE 30 +#define M_T5_STATIC_C_PLL_MULTPRE 0x3U +#define V_T5_STATIC_C_PLL_MULTPRE(x) ((x) << S_T5_STATIC_C_PLL_MULTPRE) +#define G_T5_STATIC_C_PLL_MULTPRE(x) (((x) >> S_T5_STATIC_C_PLL_MULTPRE) & M_T5_STATIC_C_PLL_MULTPRE) + +#define S_T5_STATIC_C_PLL_LOCKSEL 28 +#define M_T5_STATIC_C_PLL_LOCKSEL 0x3U +#define V_T5_STATIC_C_PLL_LOCKSEL(x) ((x) << S_T5_STATIC_C_PLL_LOCKSEL) +#define G_T5_STATIC_C_PLL_LOCKSEL(x) (((x) >> S_T5_STATIC_C_PLL_LOCKSEL) & M_T5_STATIC_C_PLL_LOCKSEL) + +#define S_T5_STATIC_C_PLL_FFTUNE 12 +#define M_T5_STATIC_C_PLL_FFTUNE 0xffffU +#define V_T5_STATIC_C_PLL_FFTUNE(x) ((x) << S_T5_STATIC_C_PLL_FFTUNE) +#define G_T5_STATIC_C_PLL_FFTUNE(x) (((x) >> S_T5_STATIC_C_PLL_FFTUNE) & M_T5_STATIC_C_PLL_FFTUNE) + +#define S_T5_STATIC_C_PLL_RANGEPRE 10 +#define M_T5_STATIC_C_PLL_RANGEPRE 0x3U +#define V_T5_STATIC_C_PLL_RANGEPRE(x) ((x) << S_T5_STATIC_C_PLL_RANGEPRE) +#define G_T5_STATIC_C_PLL_RANGEPRE(x) (((x) >> S_T5_STATIC_C_PLL_RANGEPRE) & M_T5_STATIC_C_PLL_RANGEPRE) + +#define S_T5_STATIC_C_PLL_RANGEB 5 +#define M_T5_STATIC_C_PLL_RANGEB 0x1fU +#define V_T5_STATIC_C_PLL_RANGEB(x) ((x) << S_T5_STATIC_C_PLL_RANGEB) +#define G_T5_STATIC_C_PLL_RANGEB(x) (((x) >> S_T5_STATIC_C_PLL_RANGEB) & M_T5_STATIC_C_PLL_RANGEB) + +#define S_T5_STATIC_C_PLL_RANGEA 0 +#define M_T5_STATIC_C_PLL_RANGEA 0x1fU +#define V_T5_STATIC_C_PLL_RANGEA(x) ((x) << S_T5_STATIC_C_PLL_RANGEA) +#define G_T5_STATIC_C_PLL_RANGEA(x) (((x) >> S_T5_STATIC_C_PLL_RANGEA) & M_T5_STATIC_C_PLL_RANGEA) + +#define A_DBG_T5_STATIC_C_PLL_CONF4 0x60dc +#define A_DBG_T5_STATIC_C_PLL_CONF5 0x60e0 + +#define S_T5_STATIC_C_PLL_VCVTUNE 22 +#define M_T5_STATIC_C_PLL_VCVTUNE 0x7U +#define V_T5_STATIC_C_PLL_VCVTUNE(x) ((x) << S_T5_STATIC_C_PLL_VCVTUNE) +#define G_T5_STATIC_C_PLL_VCVTUNE(x) (((x) >> S_T5_STATIC_C_PLL_VCVTUNE) & M_T5_STATIC_C_PLL_VCVTUNE) + +#define S_T5_STATIC_C_PLL_LFTUNE_32_40 13 +#define M_T5_STATIC_C_PLL_LFTUNE_32_40 0x1ffU +#define V_T5_STATIC_C_PLL_LFTUNE_32_40(x) ((x) << S_T5_STATIC_C_PLL_LFTUNE_32_40) +#define G_T5_STATIC_C_PLL_LFTUNE_32_40(x) (((x) >> S_T5_STATIC_C_PLL_LFTUNE_32_40) & M_T5_STATIC_C_PLL_LFTUNE_32_40) + +#define S_T5_STATIC_C_PLL_PREDIV 8 +#define M_T5_STATIC_C_PLL_PREDIV 0x1fU +#define V_T5_STATIC_C_PLL_PREDIV(x) ((x) << S_T5_STATIC_C_PLL_PREDIV) +#define G_T5_STATIC_C_PLL_PREDIV(x) (((x) >> S_T5_STATIC_C_PLL_PREDIV) & M_T5_STATIC_C_PLL_PREDIV) + +#define S_T5_STATIC_C_PLL_MULT 0 +#define M_T5_STATIC_C_PLL_MULT 0xffU +#define V_T5_STATIC_C_PLL_MULT(x) ((x) << S_T5_STATIC_C_PLL_MULT) +#define G_T5_STATIC_C_PLL_MULT(x) (((x) >> S_T5_STATIC_C_PLL_MULT) & M_T5_STATIC_C_PLL_MULT) + +#define A_DBG_T5_STATIC_U_PLL_CONF1 0x60e4 + +#define S_T5_STATIC_U_PLL_MULTFRAC 8 +#define M_T5_STATIC_U_PLL_MULTFRAC 0xffffffU +#define V_T5_STATIC_U_PLL_MULTFRAC(x) ((x) << S_T5_STATIC_U_PLL_MULTFRAC) +#define G_T5_STATIC_U_PLL_MULTFRAC(x) (((x) >> S_T5_STATIC_U_PLL_MULTFRAC) & M_T5_STATIC_U_PLL_MULTFRAC) + +#define S_T5_STATIC_U_PLL_FFSLEWRATE 0 +#define M_T5_STATIC_U_PLL_FFSLEWRATE 0xffU +#define V_T5_STATIC_U_PLL_FFSLEWRATE(x) ((x) << S_T5_STATIC_U_PLL_FFSLEWRATE) +#define G_T5_STATIC_U_PLL_FFSLEWRATE(x) (((x) >> S_T5_STATIC_U_PLL_FFSLEWRATE) & M_T5_STATIC_U_PLL_FFSLEWRATE) + +#define A_DBG_T5_STATIC_U_PLL_CONF2 0x60e8 + +#define S_T5_STATIC_U_PLL_DCO_BYPASS 23 +#define V_T5_STATIC_U_PLL_DCO_BYPASS(x) ((x) << S_T5_STATIC_U_PLL_DCO_BYPASS) +#define F_T5_STATIC_U_PLL_DCO_BYPASS V_T5_STATIC_U_PLL_DCO_BYPASS(1U) + +#define S_T5_STATIC_U_PLL_SDORDER 21 +#define M_T5_STATIC_U_PLL_SDORDER 0x3U +#define V_T5_STATIC_U_PLL_SDORDER(x) ((x) << S_T5_STATIC_U_PLL_SDORDER) +#define G_T5_STATIC_U_PLL_SDORDER(x) (((x) >> S_T5_STATIC_U_PLL_SDORDER) & M_T5_STATIC_U_PLL_SDORDER) + +#define S_T5_STATIC_U_PLL_FFENABLE 20 +#define V_T5_STATIC_U_PLL_FFENABLE(x) ((x) << S_T5_STATIC_U_PLL_FFENABLE) +#define F_T5_STATIC_U_PLL_FFENABLE V_T5_STATIC_U_PLL_FFENABLE(1U) + +#define S_T5_STATIC_U_PLL_STOPCLKB 19 +#define V_T5_STATIC_U_PLL_STOPCLKB(x) ((x) << S_T5_STATIC_U_PLL_STOPCLKB) +#define F_T5_STATIC_U_PLL_STOPCLKB V_T5_STATIC_U_PLL_STOPCLKB(1U) + +#define S_T5_STATIC_U_PLL_STOPCLKA 18 +#define V_T5_STATIC_U_PLL_STOPCLKA(x) ((x) << S_T5_STATIC_U_PLL_STOPCLKA) +#define F_T5_STATIC_U_PLL_STOPCLKA V_T5_STATIC_U_PLL_STOPCLKA(1U) + +#define S_T5_STATIC_U_PLL_SLEEP 17 +#define V_T5_STATIC_U_PLL_SLEEP(x) ((x) << S_T5_STATIC_U_PLL_SLEEP) +#define F_T5_STATIC_U_PLL_SLEEP V_T5_STATIC_U_PLL_SLEEP(1U) + +#define S_T5_STATIC_U_PLL_BYPASS 16 +#define V_T5_STATIC_U_PLL_BYPASS(x) ((x) << S_T5_STATIC_U_PLL_BYPASS) +#define F_T5_STATIC_U_PLL_BYPASS V_T5_STATIC_U_PLL_BYPASS(1U) + +#define S_T5_STATIC_U_PLL_LOCKTUNE 0 +#define M_T5_STATIC_U_PLL_LOCKTUNE 0xffffU +#define V_T5_STATIC_U_PLL_LOCKTUNE(x) ((x) << S_T5_STATIC_U_PLL_LOCKTUNE) +#define G_T5_STATIC_U_PLL_LOCKTUNE(x) (((x) >> S_T5_STATIC_U_PLL_LOCKTUNE) & M_T5_STATIC_U_PLL_LOCKTUNE) + +#define A_DBG_T5_STATIC_U_PLL_CONF3 0x60ec + +#define S_T5_STATIC_U_PLL_MULTPRE 30 +#define M_T5_STATIC_U_PLL_MULTPRE 0x3U +#define V_T5_STATIC_U_PLL_MULTPRE(x) ((x) << S_T5_STATIC_U_PLL_MULTPRE) +#define G_T5_STATIC_U_PLL_MULTPRE(x) (((x) >> S_T5_STATIC_U_PLL_MULTPRE) & M_T5_STATIC_U_PLL_MULTPRE) + +#define S_T5_STATIC_U_PLL_LOCKSEL 28 +#define M_T5_STATIC_U_PLL_LOCKSEL 0x3U +#define V_T5_STATIC_U_PLL_LOCKSEL(x) ((x) << S_T5_STATIC_U_PLL_LOCKSEL) +#define G_T5_STATIC_U_PLL_LOCKSEL(x) (((x) >> S_T5_STATIC_U_PLL_LOCKSEL) & M_T5_STATIC_U_PLL_LOCKSEL) + +#define S_T5_STATIC_U_PLL_FFTUNE 12 +#define M_T5_STATIC_U_PLL_FFTUNE 0xffffU +#define V_T5_STATIC_U_PLL_FFTUNE(x) ((x) << S_T5_STATIC_U_PLL_FFTUNE) +#define G_T5_STATIC_U_PLL_FFTUNE(x) (((x) >> S_T5_STATIC_U_PLL_FFTUNE) & M_T5_STATIC_U_PLL_FFTUNE) + +#define S_T5_STATIC_U_PLL_RANGEPRE 10 +#define M_T5_STATIC_U_PLL_RANGEPRE 0x3U +#define V_T5_STATIC_U_PLL_RANGEPRE(x) ((x) << S_T5_STATIC_U_PLL_RANGEPRE) +#define G_T5_STATIC_U_PLL_RANGEPRE(x) (((x) >> S_T5_STATIC_U_PLL_RANGEPRE) & M_T5_STATIC_U_PLL_RANGEPRE) + +#define S_T5_STATIC_U_PLL_RANGEB 5 +#define M_T5_STATIC_U_PLL_RANGEB 0x1fU +#define V_T5_STATIC_U_PLL_RANGEB(x) ((x) << S_T5_STATIC_U_PLL_RANGEB) +#define G_T5_STATIC_U_PLL_RANGEB(x) (((x) >> S_T5_STATIC_U_PLL_RANGEB) & M_T5_STATIC_U_PLL_RANGEB) + +#define S_T5_STATIC_U_PLL_RANGEA 0 +#define M_T5_STATIC_U_PLL_RANGEA 0x1fU +#define V_T5_STATIC_U_PLL_RANGEA(x) ((x) << S_T5_STATIC_U_PLL_RANGEA) +#define G_T5_STATIC_U_PLL_RANGEA(x) (((x) >> S_T5_STATIC_U_PLL_RANGEA) & M_T5_STATIC_U_PLL_RANGEA) + +#define A_DBG_T5_STATIC_U_PLL_CONF4 0x60f0 +#define A_DBG_T5_STATIC_U_PLL_CONF5 0x60f4 + +#define S_T5_STATIC_U_PLL_VCVTUNE 22 +#define M_T5_STATIC_U_PLL_VCVTUNE 0x7U +#define V_T5_STATIC_U_PLL_VCVTUNE(x) ((x) << S_T5_STATIC_U_PLL_VCVTUNE) +#define G_T5_STATIC_U_PLL_VCVTUNE(x) (((x) >> S_T5_STATIC_U_PLL_VCVTUNE) & M_T5_STATIC_U_PLL_VCVTUNE) + +#define S_T5_STATIC_U_PLL_LFTUNE_32_40 13 +#define M_T5_STATIC_U_PLL_LFTUNE_32_40 0x1ffU +#define V_T5_STATIC_U_PLL_LFTUNE_32_40(x) ((x) << S_T5_STATIC_U_PLL_LFTUNE_32_40) +#define G_T5_STATIC_U_PLL_LFTUNE_32_40(x) (((x) >> S_T5_STATIC_U_PLL_LFTUNE_32_40) & M_T5_STATIC_U_PLL_LFTUNE_32_40) + +#define S_T5_STATIC_U_PLL_PREDIV 8 +#define M_T5_STATIC_U_PLL_PREDIV 0x1fU +#define V_T5_STATIC_U_PLL_PREDIV(x) ((x) << S_T5_STATIC_U_PLL_PREDIV) +#define G_T5_STATIC_U_PLL_PREDIV(x) (((x) >> S_T5_STATIC_U_PLL_PREDIV) & M_T5_STATIC_U_PLL_PREDIV) + +#define S_T5_STATIC_U_PLL_MULT 0 +#define M_T5_STATIC_U_PLL_MULT 0xffU +#define V_T5_STATIC_U_PLL_MULT(x) ((x) << S_T5_STATIC_U_PLL_MULT) +#define G_T5_STATIC_U_PLL_MULT(x) (((x) >> S_T5_STATIC_U_PLL_MULT) & M_T5_STATIC_U_PLL_MULT) + +#define A_DBG_T5_STATIC_KR_PLL_CONF1 0x60f8 + +#define S_T5_STATIC_KR_PLL_BYPASS 30 +#define V_T5_STATIC_KR_PLL_BYPASS(x) ((x) << S_T5_STATIC_KR_PLL_BYPASS) +#define F_T5_STATIC_KR_PLL_BYPASS V_T5_STATIC_KR_PLL_BYPASS(1U) + +#define S_T5_STATIC_KR_PLL_VBOOSTDIV 27 +#define M_T5_STATIC_KR_PLL_VBOOSTDIV 0x7U +#define V_T5_STATIC_KR_PLL_VBOOSTDIV(x) ((x) << S_T5_STATIC_KR_PLL_VBOOSTDIV) +#define G_T5_STATIC_KR_PLL_VBOOSTDIV(x) (((x) >> S_T5_STATIC_KR_PLL_VBOOSTDIV) & M_T5_STATIC_KR_PLL_VBOOSTDIV) + +#define S_T5_STATIC_KR_PLL_CPISEL 24 +#define M_T5_STATIC_KR_PLL_CPISEL 0x7U +#define V_T5_STATIC_KR_PLL_CPISEL(x) ((x) << S_T5_STATIC_KR_PLL_CPISEL) +#define G_T5_STATIC_KR_PLL_CPISEL(x) (((x) >> S_T5_STATIC_KR_PLL_CPISEL) & M_T5_STATIC_KR_PLL_CPISEL) + +#define S_T5_STATIC_KR_PLL_CCALMETHOD 23 +#define V_T5_STATIC_KR_PLL_CCALMETHOD(x) ((x) << S_T5_STATIC_KR_PLL_CCALMETHOD) +#define F_T5_STATIC_KR_PLL_CCALMETHOD V_T5_STATIC_KR_PLL_CCALMETHOD(1U) + +#define S_T5_STATIC_KR_PLL_CCALLOAD 22 +#define V_T5_STATIC_KR_PLL_CCALLOAD(x) ((x) << S_T5_STATIC_KR_PLL_CCALLOAD) +#define F_T5_STATIC_KR_PLL_CCALLOAD V_T5_STATIC_KR_PLL_CCALLOAD(1U) + +#define S_T5_STATIC_KR_PLL_CCALFMIN 21 +#define V_T5_STATIC_KR_PLL_CCALFMIN(x) ((x) << S_T5_STATIC_KR_PLL_CCALFMIN) +#define F_T5_STATIC_KR_PLL_CCALFMIN V_T5_STATIC_KR_PLL_CCALFMIN(1U) + +#define S_T5_STATIC_KR_PLL_CCALFMAX 20 +#define V_T5_STATIC_KR_PLL_CCALFMAX(x) ((x) << S_T5_STATIC_KR_PLL_CCALFMAX) +#define F_T5_STATIC_KR_PLL_CCALFMAX V_T5_STATIC_KR_PLL_CCALFMAX(1U) + +#define S_T5_STATIC_KR_PLL_CCALCVHOLD 19 +#define V_T5_STATIC_KR_PLL_CCALCVHOLD(x) ((x) << S_T5_STATIC_KR_PLL_CCALCVHOLD) +#define F_T5_STATIC_KR_PLL_CCALCVHOLD V_T5_STATIC_KR_PLL_CCALCVHOLD(1U) + +#define S_T5_STATIC_KR_PLL_CCALBANDSEL 15 +#define M_T5_STATIC_KR_PLL_CCALBANDSEL 0xfU +#define V_T5_STATIC_KR_PLL_CCALBANDSEL(x) ((x) << S_T5_STATIC_KR_PLL_CCALBANDSEL) +#define G_T5_STATIC_KR_PLL_CCALBANDSEL(x) (((x) >> S_T5_STATIC_KR_PLL_CCALBANDSEL) & M_T5_STATIC_KR_PLL_CCALBANDSEL) + +#define S_T5_STATIC_KR_PLL_BGOFFSET 11 +#define M_T5_STATIC_KR_PLL_BGOFFSET 0xfU +#define V_T5_STATIC_KR_PLL_BGOFFSET(x) ((x) << S_T5_STATIC_KR_PLL_BGOFFSET) +#define G_T5_STATIC_KR_PLL_BGOFFSET(x) (((x) >> S_T5_STATIC_KR_PLL_BGOFFSET) & M_T5_STATIC_KR_PLL_BGOFFSET) + +#define S_T5_STATIC_KR_PLL_P 8 +#define M_T5_STATIC_KR_PLL_P 0x7U +#define V_T5_STATIC_KR_PLL_P(x) ((x) << S_T5_STATIC_KR_PLL_P) +#define G_T5_STATIC_KR_PLL_P(x) (((x) >> S_T5_STATIC_KR_PLL_P) & M_T5_STATIC_KR_PLL_P) + +#define S_T5_STATIC_KR_PLL_N2 4 +#define M_T5_STATIC_KR_PLL_N2 0xfU +#define V_T5_STATIC_KR_PLL_N2(x) ((x) << S_T5_STATIC_KR_PLL_N2) +#define G_T5_STATIC_KR_PLL_N2(x) (((x) >> S_T5_STATIC_KR_PLL_N2) & M_T5_STATIC_KR_PLL_N2) + +#define S_T5_STATIC_KR_PLL_N1 0 +#define M_T5_STATIC_KR_PLL_N1 0xfU +#define V_T5_STATIC_KR_PLL_N1(x) ((x) << S_T5_STATIC_KR_PLL_N1) +#define G_T5_STATIC_KR_PLL_N1(x) (((x) >> S_T5_STATIC_KR_PLL_N1) & M_T5_STATIC_KR_PLL_N1) + +#define A_DBG_T5_STATIC_KR_PLL_CONF2 0x60fc + +#define S_T5_STATIC_KR_PLL_M 11 +#define M_T5_STATIC_KR_PLL_M 0x1ffU +#define V_T5_STATIC_KR_PLL_M(x) ((x) << S_T5_STATIC_KR_PLL_M) +#define G_T5_STATIC_KR_PLL_M(x) (((x) >> S_T5_STATIC_KR_PLL_M) & M_T5_STATIC_KR_PLL_M) + +#define S_T5_STATIC_KR_PLL_ANALOGTUNE 0 +#define M_T5_STATIC_KR_PLL_ANALOGTUNE 0x7ffU +#define V_T5_STATIC_KR_PLL_ANALOGTUNE(x) ((x) << S_T5_STATIC_KR_PLL_ANALOGTUNE) +#define G_T5_STATIC_KR_PLL_ANALOGTUNE(x) (((x) >> S_T5_STATIC_KR_PLL_ANALOGTUNE) & M_T5_STATIC_KR_PLL_ANALOGTUNE) + +#define A_DBG_PVT_REG_CALIBRATE_CTL 0x6100 + +#define S_HALT_CALIBRATE 1 +#define V_HALT_CALIBRATE(x) ((x) << S_HALT_CALIBRATE) +#define F_HALT_CALIBRATE V_HALT_CALIBRATE(1U) + +#define S_RESET_CALIBRATE 0 +#define V_RESET_CALIBRATE(x) ((x) << S_RESET_CALIBRATE) +#define F_RESET_CALIBRATE V_RESET_CALIBRATE(1U) + +#define A_DBG_GPIO_EN_NEW 0x6100 + +#define S_GPIO16_OEN 7 +#define V_GPIO16_OEN(x) ((x) << S_GPIO16_OEN) +#define F_GPIO16_OEN V_GPIO16_OEN(1U) + +#define S_GPIO17_OEN 6 +#define V_GPIO17_OEN(x) ((x) << S_GPIO17_OEN) +#define F_GPIO17_OEN V_GPIO17_OEN(1U) + +#define S_GPIO18_OEN 5 +#define V_GPIO18_OEN(x) ((x) << S_GPIO18_OEN) +#define F_GPIO18_OEN V_GPIO18_OEN(1U) + +#define S_GPIO19_OEN 4 +#define V_GPIO19_OEN(x) ((x) << S_GPIO19_OEN) +#define F_GPIO19_OEN V_GPIO19_OEN(1U) + +#define S_GPIO16_OUT_VAL 3 +#define V_GPIO16_OUT_VAL(x) ((x) << S_GPIO16_OUT_VAL) +#define F_GPIO16_OUT_VAL V_GPIO16_OUT_VAL(1U) + +#define S_GPIO17_OUT_VAL 2 +#define V_GPIO17_OUT_VAL(x) ((x) << S_GPIO17_OUT_VAL) +#define F_GPIO17_OUT_VAL V_GPIO17_OUT_VAL(1U) + +#define S_GPIO18_OUT_VAL 1 +#define V_GPIO18_OUT_VAL(x) ((x) << S_GPIO18_OUT_VAL) +#define F_GPIO18_OUT_VAL V_GPIO18_OUT_VAL(1U) + +#define S_GPIO19_OUT_VAL 0 +#define V_GPIO19_OUT_VAL(x) ((x) << S_GPIO19_OUT_VAL) +#define F_GPIO19_OUT_VAL V_GPIO19_OUT_VAL(1U) + +#define A_DBG_PVT_REG_UPDATE_CTL 0x6104 + +#define S_FAST_UPDATE 8 +#define V_FAST_UPDATE(x) ((x) << S_FAST_UPDATE) +#define F_FAST_UPDATE V_FAST_UPDATE(1U) + +#define S_FORCE_REG_IN_VALUE 2 +#define V_FORCE_REG_IN_VALUE(x) ((x) << S_FORCE_REG_IN_VALUE) +#define F_FORCE_REG_IN_VALUE V_FORCE_REG_IN_VALUE(1U) + +#define S_HALT_UPDATE 1 +#define V_HALT_UPDATE(x) ((x) << S_HALT_UPDATE) +#define F_HALT_UPDATE V_HALT_UPDATE(1U) + +#define A_DBG_GPIO_IN_NEW 0x6104 + +#define S_GPIO16_CHG_DET 7 +#define V_GPIO16_CHG_DET(x) ((x) << S_GPIO16_CHG_DET) +#define F_GPIO16_CHG_DET V_GPIO16_CHG_DET(1U) + +#define S_GPIO17_CHG_DET 6 +#define V_GPIO17_CHG_DET(x) ((x) << S_GPIO17_CHG_DET) +#define F_GPIO17_CHG_DET V_GPIO17_CHG_DET(1U) + +#define S_GPIO18_CHG_DET 5 +#define V_GPIO18_CHG_DET(x) ((x) << S_GPIO18_CHG_DET) +#define F_GPIO18_CHG_DET V_GPIO18_CHG_DET(1U) + +#define S_GPIO19_CHG_DET 4 +#define V_GPIO19_CHG_DET(x) ((x) << S_GPIO19_CHG_DET) +#define F_GPIO19_CHG_DET V_GPIO19_CHG_DET(1U) + +#define S_GPIO16_IN 3 +#define V_GPIO16_IN(x) ((x) << S_GPIO16_IN) +#define F_GPIO16_IN V_GPIO16_IN(1U) + +#define S_GPIO17_IN 2 +#define V_GPIO17_IN(x) ((x) << S_GPIO17_IN) +#define F_GPIO17_IN V_GPIO17_IN(1U) + +#define S_GPIO18_IN 1 +#define V_GPIO18_IN(x) ((x) << S_GPIO18_IN) +#define F_GPIO18_IN V_GPIO18_IN(1U) + +#define S_GPIO19_IN 0 +#define V_GPIO19_IN(x) ((x) << S_GPIO19_IN) +#define F_GPIO19_IN V_GPIO19_IN(1U) + +#define A_DBG_PVT_REG_LAST_MEASUREMENT 0x6108 + +#define S_LAST_MEASUREMENT_SELECT 8 +#define M_LAST_MEASUREMENT_SELECT 0x3U +#define V_LAST_MEASUREMENT_SELECT(x) ((x) << S_LAST_MEASUREMENT_SELECT) +#define G_LAST_MEASUREMENT_SELECT(x) (((x) >> S_LAST_MEASUREMENT_SELECT) & M_LAST_MEASUREMENT_SELECT) + +#define S_LAST_MEASUREMENT_RESULT_BANK_B 4 +#define M_LAST_MEASUREMENT_RESULT_BANK_B 0xfU +#define V_LAST_MEASUREMENT_RESULT_BANK_B(x) ((x) << S_LAST_MEASUREMENT_RESULT_BANK_B) +#define G_LAST_MEASUREMENT_RESULT_BANK_B(x) (((x) >> S_LAST_MEASUREMENT_RESULT_BANK_B) & M_LAST_MEASUREMENT_RESULT_BANK_B) + +#define S_LAST_MEASUREMENT_RESULT_BANK_A 0 +#define M_LAST_MEASUREMENT_RESULT_BANK_A 0xfU +#define V_LAST_MEASUREMENT_RESULT_BANK_A(x) ((x) << S_LAST_MEASUREMENT_RESULT_BANK_A) +#define G_LAST_MEASUREMENT_RESULT_BANK_A(x) (((x) >> S_LAST_MEASUREMENT_RESULT_BANK_A) & M_LAST_MEASUREMENT_RESULT_BANK_A) + +#define A_DBG_T5_STATIC_KX_PLL_CONF1 0x6108 + +#define S_T5_STATIC_KX_PLL_BYPASS 30 +#define V_T5_STATIC_KX_PLL_BYPASS(x) ((x) << S_T5_STATIC_KX_PLL_BYPASS) +#define F_T5_STATIC_KX_PLL_BYPASS V_T5_STATIC_KX_PLL_BYPASS(1U) + +#define S_T5_STATIC_KX_PLL_VBOOSTDIV 27 +#define M_T5_STATIC_KX_PLL_VBOOSTDIV 0x7U +#define V_T5_STATIC_KX_PLL_VBOOSTDIV(x) ((x) << S_T5_STATIC_KX_PLL_VBOOSTDIV) +#define G_T5_STATIC_KX_PLL_VBOOSTDIV(x) (((x) >> S_T5_STATIC_KX_PLL_VBOOSTDIV) & M_T5_STATIC_KX_PLL_VBOOSTDIV) + +#define S_T5_STATIC_KX_PLL_CPISEL 24 +#define M_T5_STATIC_KX_PLL_CPISEL 0x7U +#define V_T5_STATIC_KX_PLL_CPISEL(x) ((x) << S_T5_STATIC_KX_PLL_CPISEL) +#define G_T5_STATIC_KX_PLL_CPISEL(x) (((x) >> S_T5_STATIC_KX_PLL_CPISEL) & M_T5_STATIC_KX_PLL_CPISEL) + +#define S_T5_STATIC_KX_PLL_CCALMETHOD 23 +#define V_T5_STATIC_KX_PLL_CCALMETHOD(x) ((x) << S_T5_STATIC_KX_PLL_CCALMETHOD) +#define F_T5_STATIC_KX_PLL_CCALMETHOD V_T5_STATIC_KX_PLL_CCALMETHOD(1U) + +#define S_T5_STATIC_KX_PLL_CCALLOAD 22 +#define V_T5_STATIC_KX_PLL_CCALLOAD(x) ((x) << S_T5_STATIC_KX_PLL_CCALLOAD) +#define F_T5_STATIC_KX_PLL_CCALLOAD V_T5_STATIC_KX_PLL_CCALLOAD(1U) + +#define S_T5_STATIC_KX_PLL_CCALFMIN 21 +#define V_T5_STATIC_KX_PLL_CCALFMIN(x) ((x) << S_T5_STATIC_KX_PLL_CCALFMIN) +#define F_T5_STATIC_KX_PLL_CCALFMIN V_T5_STATIC_KX_PLL_CCALFMIN(1U) + +#define S_T5_STATIC_KX_PLL_CCALFMAX 20 +#define V_T5_STATIC_KX_PLL_CCALFMAX(x) ((x) << S_T5_STATIC_KX_PLL_CCALFMAX) +#define F_T5_STATIC_KX_PLL_CCALFMAX V_T5_STATIC_KX_PLL_CCALFMAX(1U) + +#define S_T5_STATIC_KX_PLL_CCALCVHOLD 19 +#define V_T5_STATIC_KX_PLL_CCALCVHOLD(x) ((x) << S_T5_STATIC_KX_PLL_CCALCVHOLD) +#define F_T5_STATIC_KX_PLL_CCALCVHOLD V_T5_STATIC_KX_PLL_CCALCVHOLD(1U) + +#define S_T5_STATIC_KX_PLL_CCALBANDSEL 15 +#define M_T5_STATIC_KX_PLL_CCALBANDSEL 0xfU +#define V_T5_STATIC_KX_PLL_CCALBANDSEL(x) ((x) << S_T5_STATIC_KX_PLL_CCALBANDSEL) +#define G_T5_STATIC_KX_PLL_CCALBANDSEL(x) (((x) >> S_T5_STATIC_KX_PLL_CCALBANDSEL) & M_T5_STATIC_KX_PLL_CCALBANDSEL) + +#define S_T5_STATIC_KX_PLL_BGOFFSET 11 +#define M_T5_STATIC_KX_PLL_BGOFFSET 0xfU +#define V_T5_STATIC_KX_PLL_BGOFFSET(x) ((x) << S_T5_STATIC_KX_PLL_BGOFFSET) +#define G_T5_STATIC_KX_PLL_BGOFFSET(x) (((x) >> S_T5_STATIC_KX_PLL_BGOFFSET) & M_T5_STATIC_KX_PLL_BGOFFSET) + +#define S_T5_STATIC_KX_PLL_P 8 +#define M_T5_STATIC_KX_PLL_P 0x7U +#define V_T5_STATIC_KX_PLL_P(x) ((x) << S_T5_STATIC_KX_PLL_P) +#define G_T5_STATIC_KX_PLL_P(x) (((x) >> S_T5_STATIC_KX_PLL_P) & M_T5_STATIC_KX_PLL_P) + +#define S_T5_STATIC_KX_PLL_N2 4 +#define M_T5_STATIC_KX_PLL_N2 0xfU +#define V_T5_STATIC_KX_PLL_N2(x) ((x) << S_T5_STATIC_KX_PLL_N2) +#define G_T5_STATIC_KX_PLL_N2(x) (((x) >> S_T5_STATIC_KX_PLL_N2) & M_T5_STATIC_KX_PLL_N2) + +#define S_T5_STATIC_KX_PLL_N1 0 +#define M_T5_STATIC_KX_PLL_N1 0xfU +#define V_T5_STATIC_KX_PLL_N1(x) ((x) << S_T5_STATIC_KX_PLL_N1) +#define G_T5_STATIC_KX_PLL_N1(x) (((x) >> S_T5_STATIC_KX_PLL_N1) & M_T5_STATIC_KX_PLL_N1) + +#define A_DBG_PVT_REG_DRVN 0x610c + +#define S_PVT_REG_DRVN_EN 8 +#define V_PVT_REG_DRVN_EN(x) ((x) << S_PVT_REG_DRVN_EN) +#define F_PVT_REG_DRVN_EN V_PVT_REG_DRVN_EN(1U) + +#define S_PVT_REG_DRVN_B 4 +#define M_PVT_REG_DRVN_B 0xfU +#define V_PVT_REG_DRVN_B(x) ((x) << S_PVT_REG_DRVN_B) +#define G_PVT_REG_DRVN_B(x) (((x) >> S_PVT_REG_DRVN_B) & M_PVT_REG_DRVN_B) + +#define S_PVT_REG_DRVN_A 0 +#define M_PVT_REG_DRVN_A 0xfU +#define V_PVT_REG_DRVN_A(x) ((x) << S_PVT_REG_DRVN_A) +#define G_PVT_REG_DRVN_A(x) (((x) >> S_PVT_REG_DRVN_A) & M_PVT_REG_DRVN_A) + +#define A_DBG_T5_STATIC_KX_PLL_CONF2 0x610c + +#define S_T5_STATIC_KX_PLL_M 11 +#define M_T5_STATIC_KX_PLL_M 0x1ffU +#define V_T5_STATIC_KX_PLL_M(x) ((x) << S_T5_STATIC_KX_PLL_M) +#define G_T5_STATIC_KX_PLL_M(x) (((x) >> S_T5_STATIC_KX_PLL_M) & M_T5_STATIC_KX_PLL_M) + +#define S_T5_STATIC_KX_PLL_ANALOGTUNE 0 +#define M_T5_STATIC_KX_PLL_ANALOGTUNE 0x7ffU +#define V_T5_STATIC_KX_PLL_ANALOGTUNE(x) ((x) << S_T5_STATIC_KX_PLL_ANALOGTUNE) +#define G_T5_STATIC_KX_PLL_ANALOGTUNE(x) (((x) >> S_T5_STATIC_KX_PLL_ANALOGTUNE) & M_T5_STATIC_KX_PLL_ANALOGTUNE) + +#define A_DBG_PVT_REG_DRVP 0x6110 + +#define S_PVT_REG_DRVP_EN 8 +#define V_PVT_REG_DRVP_EN(x) ((x) << S_PVT_REG_DRVP_EN) +#define F_PVT_REG_DRVP_EN V_PVT_REG_DRVP_EN(1U) + +#define S_PVT_REG_DRVP_B 4 +#define M_PVT_REG_DRVP_B 0xfU +#define V_PVT_REG_DRVP_B(x) ((x) << S_PVT_REG_DRVP_B) +#define G_PVT_REG_DRVP_B(x) (((x) >> S_PVT_REG_DRVP_B) & M_PVT_REG_DRVP_B) + +#define S_PVT_REG_DRVP_A 0 +#define M_PVT_REG_DRVP_A 0xfU +#define V_PVT_REG_DRVP_A(x) ((x) << S_PVT_REG_DRVP_A) +#define G_PVT_REG_DRVP_A(x) (((x) >> S_PVT_REG_DRVP_A) & M_PVT_REG_DRVP_A) + +#define A_DBG_T5_STATIC_C_DFS_CONF 0x6110 + +#define S_STATIC_C_DFS_RANGEA 8 +#define M_STATIC_C_DFS_RANGEA 0x1fU +#define V_STATIC_C_DFS_RANGEA(x) ((x) << S_STATIC_C_DFS_RANGEA) +#define G_STATIC_C_DFS_RANGEA(x) (((x) >> S_STATIC_C_DFS_RANGEA) & M_STATIC_C_DFS_RANGEA) + +#define S_STATIC_C_DFS_RANGEB 3 +#define M_STATIC_C_DFS_RANGEB 0x1fU +#define V_STATIC_C_DFS_RANGEB(x) ((x) << S_STATIC_C_DFS_RANGEB) +#define G_STATIC_C_DFS_RANGEB(x) (((x) >> S_STATIC_C_DFS_RANGEB) & M_STATIC_C_DFS_RANGEB) + +#define S_STATIC_C_DFS_FFTUNE4 2 +#define V_STATIC_C_DFS_FFTUNE4(x) ((x) << S_STATIC_C_DFS_FFTUNE4) +#define F_STATIC_C_DFS_FFTUNE4 V_STATIC_C_DFS_FFTUNE4(1U) + +#define S_STATIC_C_DFS_FFTUNE5 1 +#define V_STATIC_C_DFS_FFTUNE5(x) ((x) << S_STATIC_C_DFS_FFTUNE5) +#define F_STATIC_C_DFS_FFTUNE5 V_STATIC_C_DFS_FFTUNE5(1U) + +#define S_STATIC_C_DFS_ENABLE 0 +#define V_STATIC_C_DFS_ENABLE(x) ((x) << S_STATIC_C_DFS_ENABLE) +#define F_STATIC_C_DFS_ENABLE V_STATIC_C_DFS_ENABLE(1U) + +#define A_DBG_PVT_REG_TERMN 0x6114 + +#define S_PVT_REG_TERMN_EN 8 +#define V_PVT_REG_TERMN_EN(x) ((x) << S_PVT_REG_TERMN_EN) +#define F_PVT_REG_TERMN_EN V_PVT_REG_TERMN_EN(1U) + +#define S_PVT_REG_TERMN_B 4 +#define M_PVT_REG_TERMN_B 0xfU +#define V_PVT_REG_TERMN_B(x) ((x) << S_PVT_REG_TERMN_B) +#define G_PVT_REG_TERMN_B(x) (((x) >> S_PVT_REG_TERMN_B) & M_PVT_REG_TERMN_B) + +#define S_PVT_REG_TERMN_A 0 +#define M_PVT_REG_TERMN_A 0xfU +#define V_PVT_REG_TERMN_A(x) ((x) << S_PVT_REG_TERMN_A) +#define G_PVT_REG_TERMN_A(x) (((x) >> S_PVT_REG_TERMN_A) & M_PVT_REG_TERMN_A) + +#define A_DBG_T5_STATIC_U_DFS_CONF 0x6114 + +#define S_STATIC_U_DFS_RANGEA 8 +#define M_STATIC_U_DFS_RANGEA 0x1fU +#define V_STATIC_U_DFS_RANGEA(x) ((x) << S_STATIC_U_DFS_RANGEA) +#define G_STATIC_U_DFS_RANGEA(x) (((x) >> S_STATIC_U_DFS_RANGEA) & M_STATIC_U_DFS_RANGEA) + +#define S_STATIC_U_DFS_RANGEB 3 +#define M_STATIC_U_DFS_RANGEB 0x1fU +#define V_STATIC_U_DFS_RANGEB(x) ((x) << S_STATIC_U_DFS_RANGEB) +#define G_STATIC_U_DFS_RANGEB(x) (((x) >> S_STATIC_U_DFS_RANGEB) & M_STATIC_U_DFS_RANGEB) + +#define S_STATIC_U_DFS_FFTUNE4 2 +#define V_STATIC_U_DFS_FFTUNE4(x) ((x) << S_STATIC_U_DFS_FFTUNE4) +#define F_STATIC_U_DFS_FFTUNE4 V_STATIC_U_DFS_FFTUNE4(1U) + +#define S_STATIC_U_DFS_FFTUNE5 1 +#define V_STATIC_U_DFS_FFTUNE5(x) ((x) << S_STATIC_U_DFS_FFTUNE5) +#define F_STATIC_U_DFS_FFTUNE5 V_STATIC_U_DFS_FFTUNE5(1U) + +#define S_STATIC_U_DFS_ENABLE 0 +#define V_STATIC_U_DFS_ENABLE(x) ((x) << S_STATIC_U_DFS_ENABLE) +#define F_STATIC_U_DFS_ENABLE V_STATIC_U_DFS_ENABLE(1U) + +#define A_DBG_PVT_REG_TERMP 0x6118 + +#define S_PVT_REG_TERMP_EN 8 +#define V_PVT_REG_TERMP_EN(x) ((x) << S_PVT_REG_TERMP_EN) +#define F_PVT_REG_TERMP_EN V_PVT_REG_TERMP_EN(1U) + +#define S_PVT_REG_TERMP_B 4 +#define M_PVT_REG_TERMP_B 0xfU +#define V_PVT_REG_TERMP_B(x) ((x) << S_PVT_REG_TERMP_B) +#define G_PVT_REG_TERMP_B(x) (((x) >> S_PVT_REG_TERMP_B) & M_PVT_REG_TERMP_B) + +#define S_PVT_REG_TERMP_A 0 +#define M_PVT_REG_TERMP_A 0xfU +#define V_PVT_REG_TERMP_A(x) ((x) << S_PVT_REG_TERMP_A) +#define G_PVT_REG_TERMP_A(x) (((x) >> S_PVT_REG_TERMP_A) & M_PVT_REG_TERMP_A) + +#define A_DBG_GPIO_PE_EN 0x6118 + +#define S_GPIO19_PE_EN 19 +#define V_GPIO19_PE_EN(x) ((x) << S_GPIO19_PE_EN) +#define F_GPIO19_PE_EN V_GPIO19_PE_EN(1U) + +#define S_GPIO18_PE_EN 18 +#define V_GPIO18_PE_EN(x) ((x) << S_GPIO18_PE_EN) +#define F_GPIO18_PE_EN V_GPIO18_PE_EN(1U) + +#define S_GPIO17_PE_EN 17 +#define V_GPIO17_PE_EN(x) ((x) << S_GPIO17_PE_EN) +#define F_GPIO17_PE_EN V_GPIO17_PE_EN(1U) + +#define S_GPIO16_PE_EN 16 +#define V_GPIO16_PE_EN(x) ((x) << S_GPIO16_PE_EN) +#define F_GPIO16_PE_EN V_GPIO16_PE_EN(1U) + +#define S_GPIO15_PE_EN 15 +#define V_GPIO15_PE_EN(x) ((x) << S_GPIO15_PE_EN) +#define F_GPIO15_PE_EN V_GPIO15_PE_EN(1U) + +#define S_GPIO14_PE_EN 14 +#define V_GPIO14_PE_EN(x) ((x) << S_GPIO14_PE_EN) +#define F_GPIO14_PE_EN V_GPIO14_PE_EN(1U) + +#define S_GPIO13_PE_EN 13 +#define V_GPIO13_PE_EN(x) ((x) << S_GPIO13_PE_EN) +#define F_GPIO13_PE_EN V_GPIO13_PE_EN(1U) + +#define S_GPIO12_PE_EN 12 +#define V_GPIO12_PE_EN(x) ((x) << S_GPIO12_PE_EN) +#define F_GPIO12_PE_EN V_GPIO12_PE_EN(1U) + +#define S_GPIO11_PE_EN 11 +#define V_GPIO11_PE_EN(x) ((x) << S_GPIO11_PE_EN) +#define F_GPIO11_PE_EN V_GPIO11_PE_EN(1U) + +#define S_GPIO10_PE_EN 10 +#define V_GPIO10_PE_EN(x) ((x) << S_GPIO10_PE_EN) +#define F_GPIO10_PE_EN V_GPIO10_PE_EN(1U) + +#define S_GPIO9_PE_EN 9 +#define V_GPIO9_PE_EN(x) ((x) << S_GPIO9_PE_EN) +#define F_GPIO9_PE_EN V_GPIO9_PE_EN(1U) + +#define S_GPIO8_PE_EN 8 +#define V_GPIO8_PE_EN(x) ((x) << S_GPIO8_PE_EN) +#define F_GPIO8_PE_EN V_GPIO8_PE_EN(1U) + +#define S_GPIO7_PE_EN 7 +#define V_GPIO7_PE_EN(x) ((x) << S_GPIO7_PE_EN) +#define F_GPIO7_PE_EN V_GPIO7_PE_EN(1U) + +#define S_GPIO6_PE_EN 6 +#define V_GPIO6_PE_EN(x) ((x) << S_GPIO6_PE_EN) +#define F_GPIO6_PE_EN V_GPIO6_PE_EN(1U) + +#define S_GPIO5_PE_EN 5 +#define V_GPIO5_PE_EN(x) ((x) << S_GPIO5_PE_EN) +#define F_GPIO5_PE_EN V_GPIO5_PE_EN(1U) + +#define S_GPIO4_PE_EN 4 +#define V_GPIO4_PE_EN(x) ((x) << S_GPIO4_PE_EN) +#define F_GPIO4_PE_EN V_GPIO4_PE_EN(1U) + +#define S_GPIO3_PE_EN 3 +#define V_GPIO3_PE_EN(x) ((x) << S_GPIO3_PE_EN) +#define F_GPIO3_PE_EN V_GPIO3_PE_EN(1U) + +#define S_GPIO2_PE_EN 2 +#define V_GPIO2_PE_EN(x) ((x) << S_GPIO2_PE_EN) +#define F_GPIO2_PE_EN V_GPIO2_PE_EN(1U) + +#define S_GPIO1_PE_EN 1 +#define V_GPIO1_PE_EN(x) ((x) << S_GPIO1_PE_EN) +#define F_GPIO1_PE_EN V_GPIO1_PE_EN(1U) + +#define S_GPIO0_PE_EN 0 +#define V_GPIO0_PE_EN(x) ((x) << S_GPIO0_PE_EN) +#define F_GPIO0_PE_EN V_GPIO0_PE_EN(1U) + +#define A_DBG_PVT_REG_THRESHOLD 0x611c + +#define S_PVT_CALIBRATION_DONE 8 +#define V_PVT_CALIBRATION_DONE(x) ((x) << S_PVT_CALIBRATION_DONE) +#define F_PVT_CALIBRATION_DONE V_PVT_CALIBRATION_DONE(1U) + +#define S_THRESHOLD_TERMP_MAX_SYNC 7 +#define V_THRESHOLD_TERMP_MAX_SYNC(x) ((x) << S_THRESHOLD_TERMP_MAX_SYNC) +#define F_THRESHOLD_TERMP_MAX_SYNC V_THRESHOLD_TERMP_MAX_SYNC(1U) + +#define S_THRESHOLD_TERMP_MIN_SYNC 6 +#define V_THRESHOLD_TERMP_MIN_SYNC(x) ((x) << S_THRESHOLD_TERMP_MIN_SYNC) +#define F_THRESHOLD_TERMP_MIN_SYNC V_THRESHOLD_TERMP_MIN_SYNC(1U) + +#define S_THRESHOLD_TERMN_MAX_SYNC 5 +#define V_THRESHOLD_TERMN_MAX_SYNC(x) ((x) << S_THRESHOLD_TERMN_MAX_SYNC) +#define F_THRESHOLD_TERMN_MAX_SYNC V_THRESHOLD_TERMN_MAX_SYNC(1U) + +#define S_THRESHOLD_TERMN_MIN_SYNC 4 +#define V_THRESHOLD_TERMN_MIN_SYNC(x) ((x) << S_THRESHOLD_TERMN_MIN_SYNC) +#define F_THRESHOLD_TERMN_MIN_SYNC V_THRESHOLD_TERMN_MIN_SYNC(1U) + +#define S_THRESHOLD_DRVP_MAX_SYNC 3 +#define V_THRESHOLD_DRVP_MAX_SYNC(x) ((x) << S_THRESHOLD_DRVP_MAX_SYNC) +#define F_THRESHOLD_DRVP_MAX_SYNC V_THRESHOLD_DRVP_MAX_SYNC(1U) + +#define S_THRESHOLD_DRVP_MIN_SYNC 2 +#define V_THRESHOLD_DRVP_MIN_SYNC(x) ((x) << S_THRESHOLD_DRVP_MIN_SYNC) +#define F_THRESHOLD_DRVP_MIN_SYNC V_THRESHOLD_DRVP_MIN_SYNC(1U) + +#define S_THRESHOLD_DRVN_MAX_SYNC 1 +#define V_THRESHOLD_DRVN_MAX_SYNC(x) ((x) << S_THRESHOLD_DRVN_MAX_SYNC) +#define F_THRESHOLD_DRVN_MAX_SYNC V_THRESHOLD_DRVN_MAX_SYNC(1U) + +#define S_THRESHOLD_DRVN_MIN_SYNC 0 +#define V_THRESHOLD_DRVN_MIN_SYNC(x) ((x) << S_THRESHOLD_DRVN_MIN_SYNC) +#define F_THRESHOLD_DRVN_MIN_SYNC V_THRESHOLD_DRVN_MIN_SYNC(1U) + +#define A_DBG_GPIO_PS_EN 0x611c + +#define S_GPIO19_PS_EN 19 +#define V_GPIO19_PS_EN(x) ((x) << S_GPIO19_PS_EN) +#define F_GPIO19_PS_EN V_GPIO19_PS_EN(1U) + +#define S_GPIO18_PS_EN 18 +#define V_GPIO18_PS_EN(x) ((x) << S_GPIO18_PS_EN) +#define F_GPIO18_PS_EN V_GPIO18_PS_EN(1U) + +#define S_GPIO17_PS_EN 17 +#define V_GPIO17_PS_EN(x) ((x) << S_GPIO17_PS_EN) +#define F_GPIO17_PS_EN V_GPIO17_PS_EN(1U) + +#define S_GPIO16_PS_EN 16 +#define V_GPIO16_PS_EN(x) ((x) << S_GPIO16_PS_EN) +#define F_GPIO16_PS_EN V_GPIO16_PS_EN(1U) + +#define S_GPIO15_PS_EN 15 +#define V_GPIO15_PS_EN(x) ((x) << S_GPIO15_PS_EN) +#define F_GPIO15_PS_EN V_GPIO15_PS_EN(1U) + +#define S_GPIO14_PS_EN 14 +#define V_GPIO14_PS_EN(x) ((x) << S_GPIO14_PS_EN) +#define F_GPIO14_PS_EN V_GPIO14_PS_EN(1U) + +#define S_GPIO13_PS_EN 13 +#define V_GPIO13_PS_EN(x) ((x) << S_GPIO13_PS_EN) +#define F_GPIO13_PS_EN V_GPIO13_PS_EN(1U) + +#define S_GPIO12_PS_EN 12 +#define V_GPIO12_PS_EN(x) ((x) << S_GPIO12_PS_EN) +#define F_GPIO12_PS_EN V_GPIO12_PS_EN(1U) + +#define S_GPIO11_PS_EN 11 +#define V_GPIO11_PS_EN(x) ((x) << S_GPIO11_PS_EN) +#define F_GPIO11_PS_EN V_GPIO11_PS_EN(1U) + +#define S_GPIO10_PS_EN 10 +#define V_GPIO10_PS_EN(x) ((x) << S_GPIO10_PS_EN) +#define F_GPIO10_PS_EN V_GPIO10_PS_EN(1U) + +#define S_GPIO9_PS_EN 9 +#define V_GPIO9_PS_EN(x) ((x) << S_GPIO9_PS_EN) +#define F_GPIO9_PS_EN V_GPIO9_PS_EN(1U) + +#define S_GPIO8_PS_EN 8 +#define V_GPIO8_PS_EN(x) ((x) << S_GPIO8_PS_EN) +#define F_GPIO8_PS_EN V_GPIO8_PS_EN(1U) + +#define S_GPIO7_PS_EN 7 +#define V_GPIO7_PS_EN(x) ((x) << S_GPIO7_PS_EN) +#define F_GPIO7_PS_EN V_GPIO7_PS_EN(1U) + +#define S_GPIO6_PS_EN 6 +#define V_GPIO6_PS_EN(x) ((x) << S_GPIO6_PS_EN) +#define F_GPIO6_PS_EN V_GPIO6_PS_EN(1U) + +#define S_GPIO5_PS_EN 5 +#define V_GPIO5_PS_EN(x) ((x) << S_GPIO5_PS_EN) +#define F_GPIO5_PS_EN V_GPIO5_PS_EN(1U) + +#define S_GPIO4_PS_EN 4 +#define V_GPIO4_PS_EN(x) ((x) << S_GPIO4_PS_EN) +#define F_GPIO4_PS_EN V_GPIO4_PS_EN(1U) + +#define S_GPIO3_PS_EN 3 +#define V_GPIO3_PS_EN(x) ((x) << S_GPIO3_PS_EN) +#define F_GPIO3_PS_EN V_GPIO3_PS_EN(1U) + +#define S_GPIO2_PS_EN 2 +#define V_GPIO2_PS_EN(x) ((x) << S_GPIO2_PS_EN) +#define F_GPIO2_PS_EN V_GPIO2_PS_EN(1U) + +#define S_GPIO1_PS_EN 1 +#define V_GPIO1_PS_EN(x) ((x) << S_GPIO1_PS_EN) +#define F_GPIO1_PS_EN V_GPIO1_PS_EN(1U) + +#define S_GPIO0_PS_EN 0 +#define V_GPIO0_PS_EN(x) ((x) << S_GPIO0_PS_EN) +#define F_GPIO0_PS_EN V_GPIO0_PS_EN(1U) + +#define A_DBG_PVT_REG_IN_TERMP 0x6120 + +#define S_REG_IN_TERMP_B 4 +#define M_REG_IN_TERMP_B 0xfU +#define V_REG_IN_TERMP_B(x) ((x) << S_REG_IN_TERMP_B) +#define G_REG_IN_TERMP_B(x) (((x) >> S_REG_IN_TERMP_B) & M_REG_IN_TERMP_B) + +#define S_REG_IN_TERMP_A 0 +#define M_REG_IN_TERMP_A 0xfU +#define V_REG_IN_TERMP_A(x) ((x) << S_REG_IN_TERMP_A) +#define G_REG_IN_TERMP_A(x) (((x) >> S_REG_IN_TERMP_A) & M_REG_IN_TERMP_A) + +#define A_DBG_EFUSE_BYTE16_19 0x6120 +#define A_DBG_PVT_REG_IN_TERMN 0x6124 + +#define S_REG_IN_TERMN_B 4 +#define M_REG_IN_TERMN_B 0xfU +#define V_REG_IN_TERMN_B(x) ((x) << S_REG_IN_TERMN_B) +#define G_REG_IN_TERMN_B(x) (((x) >> S_REG_IN_TERMN_B) & M_REG_IN_TERMN_B) + +#define S_REG_IN_TERMN_A 0 +#define M_REG_IN_TERMN_A 0xfU +#define V_REG_IN_TERMN_A(x) ((x) << S_REG_IN_TERMN_A) +#define G_REG_IN_TERMN_A(x) (((x) >> S_REG_IN_TERMN_A) & M_REG_IN_TERMN_A) + +#define A_DBG_EFUSE_BYTE20_23 0x6124 +#define A_DBG_PVT_REG_IN_DRVP 0x6128 + +#define S_REG_IN_DRVP_B 4 +#define M_REG_IN_DRVP_B 0xfU +#define V_REG_IN_DRVP_B(x) ((x) << S_REG_IN_DRVP_B) +#define G_REG_IN_DRVP_B(x) (((x) >> S_REG_IN_DRVP_B) & M_REG_IN_DRVP_B) + +#define S_REG_IN_DRVP_A 0 +#define M_REG_IN_DRVP_A 0xfU +#define V_REG_IN_DRVP_A(x) ((x) << S_REG_IN_DRVP_A) +#define G_REG_IN_DRVP_A(x) (((x) >> S_REG_IN_DRVP_A) & M_REG_IN_DRVP_A) + +#define A_DBG_EFUSE_BYTE24_27 0x6128 +#define A_DBG_PVT_REG_IN_DRVN 0x612c + +#define S_REG_IN_DRVN_B 4 +#define M_REG_IN_DRVN_B 0xfU +#define V_REG_IN_DRVN_B(x) ((x) << S_REG_IN_DRVN_B) +#define G_REG_IN_DRVN_B(x) (((x) >> S_REG_IN_DRVN_B) & M_REG_IN_DRVN_B) + +#define S_REG_IN_DRVN_A 0 +#define M_REG_IN_DRVN_A 0xfU +#define V_REG_IN_DRVN_A(x) ((x) << S_REG_IN_DRVN_A) +#define G_REG_IN_DRVN_A(x) (((x) >> S_REG_IN_DRVN_A) & M_REG_IN_DRVN_A) + +#define A_DBG_EFUSE_BYTE28_31 0x612c +#define A_DBG_PVT_REG_OUT_TERMP 0x6130 + +#define S_REG_OUT_TERMP_B 4 +#define M_REG_OUT_TERMP_B 0xfU +#define V_REG_OUT_TERMP_B(x) ((x) << S_REG_OUT_TERMP_B) +#define G_REG_OUT_TERMP_B(x) (((x) >> S_REG_OUT_TERMP_B) & M_REG_OUT_TERMP_B) + +#define S_REG_OUT_TERMP_A 0 +#define M_REG_OUT_TERMP_A 0xfU +#define V_REG_OUT_TERMP_A(x) ((x) << S_REG_OUT_TERMP_A) +#define G_REG_OUT_TERMP_A(x) (((x) >> S_REG_OUT_TERMP_A) & M_REG_OUT_TERMP_A) + +#define A_DBG_EFUSE_BYTE32_35 0x6130 +#define A_DBG_PVT_REG_OUT_TERMN 0x6134 + +#define S_REG_OUT_TERMN_B 4 +#define M_REG_OUT_TERMN_B 0xfU +#define V_REG_OUT_TERMN_B(x) ((x) << S_REG_OUT_TERMN_B) +#define G_REG_OUT_TERMN_B(x) (((x) >> S_REG_OUT_TERMN_B) & M_REG_OUT_TERMN_B) + +#define S_REG_OUT_TERMN_A 0 +#define M_REG_OUT_TERMN_A 0xfU +#define V_REG_OUT_TERMN_A(x) ((x) << S_REG_OUT_TERMN_A) +#define G_REG_OUT_TERMN_A(x) (((x) >> S_REG_OUT_TERMN_A) & M_REG_OUT_TERMN_A) + +#define A_DBG_EFUSE_BYTE36_39 0x6134 +#define A_DBG_PVT_REG_OUT_DRVP 0x6138 + +#define S_REG_OUT_DRVP_B 4 +#define M_REG_OUT_DRVP_B 0xfU +#define V_REG_OUT_DRVP_B(x) ((x) << S_REG_OUT_DRVP_B) +#define G_REG_OUT_DRVP_B(x) (((x) >> S_REG_OUT_DRVP_B) & M_REG_OUT_DRVP_B) + +#define S_REG_OUT_DRVP_A 0 +#define M_REG_OUT_DRVP_A 0xfU +#define V_REG_OUT_DRVP_A(x) ((x) << S_REG_OUT_DRVP_A) +#define G_REG_OUT_DRVP_A(x) (((x) >> S_REG_OUT_DRVP_A) & M_REG_OUT_DRVP_A) + +#define A_DBG_EFUSE_BYTE40_43 0x6138 +#define A_DBG_PVT_REG_OUT_DRVN 0x613c + +#define S_REG_OUT_DRVN_B 4 +#define M_REG_OUT_DRVN_B 0xfU +#define V_REG_OUT_DRVN_B(x) ((x) << S_REG_OUT_DRVN_B) +#define G_REG_OUT_DRVN_B(x) (((x) >> S_REG_OUT_DRVN_B) & M_REG_OUT_DRVN_B) + +#define S_REG_OUT_DRVN_A 0 +#define M_REG_OUT_DRVN_A 0xfU +#define V_REG_OUT_DRVN_A(x) ((x) << S_REG_OUT_DRVN_A) +#define G_REG_OUT_DRVN_A(x) (((x) >> S_REG_OUT_DRVN_A) & M_REG_OUT_DRVN_A) + +#define A_DBG_EFUSE_BYTE44_47 0x613c +#define A_DBG_PVT_REG_HISTORY_TERMP 0x6140 + +#define S_TERMP_B_HISTORY 4 +#define M_TERMP_B_HISTORY 0xfU +#define V_TERMP_B_HISTORY(x) ((x) << S_TERMP_B_HISTORY) +#define G_TERMP_B_HISTORY(x) (((x) >> S_TERMP_B_HISTORY) & M_TERMP_B_HISTORY) + +#define S_TERMP_A_HISTORY 0 +#define M_TERMP_A_HISTORY 0xfU +#define V_TERMP_A_HISTORY(x) ((x) << S_TERMP_A_HISTORY) +#define G_TERMP_A_HISTORY(x) (((x) >> S_TERMP_A_HISTORY) & M_TERMP_A_HISTORY) + +#define A_DBG_EFUSE_BYTE48_51 0x6140 +#define A_DBG_PVT_REG_HISTORY_TERMN 0x6144 + +#define S_TERMN_B_HISTORY 4 +#define M_TERMN_B_HISTORY 0xfU +#define V_TERMN_B_HISTORY(x) ((x) << S_TERMN_B_HISTORY) +#define G_TERMN_B_HISTORY(x) (((x) >> S_TERMN_B_HISTORY) & M_TERMN_B_HISTORY) + +#define S_TERMN_A_HISTORY 0 +#define M_TERMN_A_HISTORY 0xfU +#define V_TERMN_A_HISTORY(x) ((x) << S_TERMN_A_HISTORY) +#define G_TERMN_A_HISTORY(x) (((x) >> S_TERMN_A_HISTORY) & M_TERMN_A_HISTORY) + +#define A_DBG_EFUSE_BYTE52_55 0x6144 +#define A_DBG_PVT_REG_HISTORY_DRVP 0x6148 + +#define S_DRVP_B_HISTORY 4 +#define M_DRVP_B_HISTORY 0xfU +#define V_DRVP_B_HISTORY(x) ((x) << S_DRVP_B_HISTORY) +#define G_DRVP_B_HISTORY(x) (((x) >> S_DRVP_B_HISTORY) & M_DRVP_B_HISTORY) + +#define S_DRVP_A_HISTORY 0 +#define M_DRVP_A_HISTORY 0xfU +#define V_DRVP_A_HISTORY(x) ((x) << S_DRVP_A_HISTORY) +#define G_DRVP_A_HISTORY(x) (((x) >> S_DRVP_A_HISTORY) & M_DRVP_A_HISTORY) + +#define A_DBG_EFUSE_BYTE56_59 0x6148 +#define A_DBG_PVT_REG_HISTORY_DRVN 0x614c + +#define S_DRVN_B_HISTORY 4 +#define M_DRVN_B_HISTORY 0xfU +#define V_DRVN_B_HISTORY(x) ((x) << S_DRVN_B_HISTORY) +#define G_DRVN_B_HISTORY(x) (((x) >> S_DRVN_B_HISTORY) & M_DRVN_B_HISTORY) + +#define S_DRVN_A_HISTORY 0 +#define M_DRVN_A_HISTORY 0xfU +#define V_DRVN_A_HISTORY(x) ((x) << S_DRVN_A_HISTORY) +#define G_DRVN_A_HISTORY(x) (((x) >> S_DRVN_A_HISTORY) & M_DRVN_A_HISTORY) + +#define A_DBG_EFUSE_BYTE60_63 0x614c +#define A_DBG_PVT_REG_SAMPLE_WAIT_CLKS 0x6150 + +#define S_SAMPLE_WAIT_CLKS 0 +#define M_SAMPLE_WAIT_CLKS 0x1fU +#define V_SAMPLE_WAIT_CLKS(x) ((x) << S_SAMPLE_WAIT_CLKS) +#define G_SAMPLE_WAIT_CLKS(x) (((x) >> S_SAMPLE_WAIT_CLKS) & M_SAMPLE_WAIT_CLKS) + +/* registers for module MC */ +#define MC_BASE_ADDR 0x6200 + +#define A_MC_PCTL_SCFG 0x6200 + +#define S_RKINF_EN 5 +#define V_RKINF_EN(x) ((x) << S_RKINF_EN) +#define F_RKINF_EN V_RKINF_EN(1U) + +#define S_DUAL_PCTL_EN 4 +#define V_DUAL_PCTL_EN(x) ((x) << S_DUAL_PCTL_EN) +#define F_DUAL_PCTL_EN V_DUAL_PCTL_EN(1U) + +#define S_SLAVE_MODE 3 +#define V_SLAVE_MODE(x) ((x) << S_SLAVE_MODE) +#define F_SLAVE_MODE V_SLAVE_MODE(1U) + +#define S_LOOPBACK_EN 1 +#define V_LOOPBACK_EN(x) ((x) << S_LOOPBACK_EN) +#define F_LOOPBACK_EN V_LOOPBACK_EN(1U) + +#define S_HW_LOW_POWER_EN 0 +#define V_HW_LOW_POWER_EN(x) ((x) << S_HW_LOW_POWER_EN) +#define F_HW_LOW_POWER_EN V_HW_LOW_POWER_EN(1U) + +#define A_MC_PCTL_SCTL 0x6204 + +#define S_STATE_CMD 0 +#define M_STATE_CMD 0x7U +#define V_STATE_CMD(x) ((x) << S_STATE_CMD) +#define G_STATE_CMD(x) (((x) >> S_STATE_CMD) & M_STATE_CMD) + +#define A_MC_PCTL_STAT 0x6208 + +#define S_CTL_STAT 0 +#define M_CTL_STAT 0x7U +#define V_CTL_STAT(x) ((x) << S_CTL_STAT) +#define G_CTL_STAT(x) (((x) >> S_CTL_STAT) & M_CTL_STAT) + +#define A_MC_PCTL_MCMD 0x6240 + +#define S_START_CMD 31 +#define V_START_CMD(x) ((x) << S_START_CMD) +#define F_START_CMD V_START_CMD(1U) + +#define S_CMD_ADD_DEL 24 +#define M_CMD_ADD_DEL 0xfU +#define V_CMD_ADD_DEL(x) ((x) << S_CMD_ADD_DEL) +#define G_CMD_ADD_DEL(x) (((x) >> S_CMD_ADD_DEL) & M_CMD_ADD_DEL) + +#define S_RANK_SEL 20 +#define M_RANK_SEL 0xfU +#define V_RANK_SEL(x) ((x) << S_RANK_SEL) +#define G_RANK_SEL(x) (((x) >> S_RANK_SEL) & M_RANK_SEL) + +#define S_BANK_ADDR 17 +#define M_BANK_ADDR 0x7U +#define V_BANK_ADDR(x) ((x) << S_BANK_ADDR) +#define G_BANK_ADDR(x) (((x) >> S_BANK_ADDR) & M_BANK_ADDR) + +#define S_CMD_ADDR 4 +#define M_CMD_ADDR 0x1fffU +#define V_CMD_ADDR(x) ((x) << S_CMD_ADDR) +#define G_CMD_ADDR(x) (((x) >> S_CMD_ADDR) & M_CMD_ADDR) + +#define S_CMD_OPCODE 0 +#define M_CMD_OPCODE 0x7U +#define V_CMD_OPCODE(x) ((x) << S_CMD_OPCODE) +#define G_CMD_OPCODE(x) (((x) >> S_CMD_OPCODE) & M_CMD_OPCODE) + +#define A_MC_PCTL_POWCTL 0x6244 + +#define S_POWER_UP_START 0 +#define V_POWER_UP_START(x) ((x) << S_POWER_UP_START) +#define F_POWER_UP_START V_POWER_UP_START(1U) + +#define A_MC_PCTL_POWSTAT 0x6248 + +#define S_PHY_CALIBDONE 1 +#define V_PHY_CALIBDONE(x) ((x) << S_PHY_CALIBDONE) +#define F_PHY_CALIBDONE V_PHY_CALIBDONE(1U) + +#define S_POWER_UP_DONE 0 +#define V_POWER_UP_DONE(x) ((x) << S_POWER_UP_DONE) +#define F_POWER_UP_DONE V_POWER_UP_DONE(1U) + +#define A_MC_PCTL_MCFG 0x6280 + +#define S_TFAW_CFG 18 +#define M_TFAW_CFG 0x3U +#define V_TFAW_CFG(x) ((x) << S_TFAW_CFG) +#define G_TFAW_CFG(x) (((x) >> S_TFAW_CFG) & M_TFAW_CFG) + +#define S_PD_EXIT_MODE 17 +#define V_PD_EXIT_MODE(x) ((x) << S_PD_EXIT_MODE) +#define F_PD_EXIT_MODE V_PD_EXIT_MODE(1U) + +#define S_PD_TYPE 16 +#define V_PD_TYPE(x) ((x) << S_PD_TYPE) +#define F_PD_TYPE V_PD_TYPE(1U) + +#define S_PD_IDLE 8 +#define M_PD_IDLE 0xffU +#define V_PD_IDLE(x) ((x) << S_PD_IDLE) +#define G_PD_IDLE(x) (((x) >> S_PD_IDLE) & M_PD_IDLE) + +#define S_PAGE_POLICY 6 +#define M_PAGE_POLICY 0x3U +#define V_PAGE_POLICY(x) ((x) << S_PAGE_POLICY) +#define G_PAGE_POLICY(x) (((x) >> S_PAGE_POLICY) & M_PAGE_POLICY) + +#define S_DDR3_EN 5 +#define V_DDR3_EN(x) ((x) << S_DDR3_EN) +#define F_DDR3_EN V_DDR3_EN(1U) + +#define S_TWO_T_EN 3 +#define V_TWO_T_EN(x) ((x) << S_TWO_T_EN) +#define F_TWO_T_EN V_TWO_T_EN(1U) + +#define S_BL8INT_EN 2 +#define V_BL8INT_EN(x) ((x) << S_BL8INT_EN) +#define F_BL8INT_EN V_BL8INT_EN(1U) + +#define S_MEM_BL 0 +#define V_MEM_BL(x) ((x) << S_MEM_BL) +#define F_MEM_BL V_MEM_BL(1U) + +#define A_MC_PCTL_PPCFG 0x6284 + +#define S_RPMEM_DIS 1 +#define M_RPMEM_DIS 0xffU +#define V_RPMEM_DIS(x) ((x) << S_RPMEM_DIS) +#define G_RPMEM_DIS(x) (((x) >> S_RPMEM_DIS) & M_RPMEM_DIS) + +#define S_PPMEM_EN 0 +#define V_PPMEM_EN(x) ((x) << S_PPMEM_EN) +#define F_PPMEM_EN V_PPMEM_EN(1U) + +#define A_MC_PCTL_MSTAT 0x6288 + +#define S_POWER_DOWN 0 +#define V_POWER_DOWN(x) ((x) << S_POWER_DOWN) +#define F_POWER_DOWN V_POWER_DOWN(1U) + +#define A_MC_PCTL_ODTCFG 0x628c + +#define S_RANK3_ODT_DEFAULT 28 +#define V_RANK3_ODT_DEFAULT(x) ((x) << S_RANK3_ODT_DEFAULT) +#define F_RANK3_ODT_DEFAULT V_RANK3_ODT_DEFAULT(1U) + +#define S_RANK3_ODT_WRITE_SEL 27 +#define V_RANK3_ODT_WRITE_SEL(x) ((x) << S_RANK3_ODT_WRITE_SEL) +#define F_RANK3_ODT_WRITE_SEL V_RANK3_ODT_WRITE_SEL(1U) + +#define S_RANK3_ODT_WRITE_NSE 26 +#define V_RANK3_ODT_WRITE_NSE(x) ((x) << S_RANK3_ODT_WRITE_NSE) +#define F_RANK3_ODT_WRITE_NSE V_RANK3_ODT_WRITE_NSE(1U) + +#define S_RANK3_ODT_READ_SEL 25 +#define V_RANK3_ODT_READ_SEL(x) ((x) << S_RANK3_ODT_READ_SEL) +#define F_RANK3_ODT_READ_SEL V_RANK3_ODT_READ_SEL(1U) + +#define S_RANK3_ODT_READ_NSEL 24 +#define V_RANK3_ODT_READ_NSEL(x) ((x) << S_RANK3_ODT_READ_NSEL) +#define F_RANK3_ODT_READ_NSEL V_RANK3_ODT_READ_NSEL(1U) + +#define S_RANK2_ODT_DEFAULT 20 +#define V_RANK2_ODT_DEFAULT(x) ((x) << S_RANK2_ODT_DEFAULT) +#define F_RANK2_ODT_DEFAULT V_RANK2_ODT_DEFAULT(1U) + +#define S_RANK2_ODT_WRITE_SEL 19 +#define V_RANK2_ODT_WRITE_SEL(x) ((x) << S_RANK2_ODT_WRITE_SEL) +#define F_RANK2_ODT_WRITE_SEL V_RANK2_ODT_WRITE_SEL(1U) + +#define S_RANK2_ODT_WRITE_NSEL 18 +#define V_RANK2_ODT_WRITE_NSEL(x) ((x) << S_RANK2_ODT_WRITE_NSEL) +#define F_RANK2_ODT_WRITE_NSEL V_RANK2_ODT_WRITE_NSEL(1U) + +#define S_RANK2_ODT_READ_SEL 17 +#define V_RANK2_ODT_READ_SEL(x) ((x) << S_RANK2_ODT_READ_SEL) +#define F_RANK2_ODT_READ_SEL V_RANK2_ODT_READ_SEL(1U) + +#define S_RANK2_ODT_READ_NSEL 16 +#define V_RANK2_ODT_READ_NSEL(x) ((x) << S_RANK2_ODT_READ_NSEL) +#define F_RANK2_ODT_READ_NSEL V_RANK2_ODT_READ_NSEL(1U) + +#define S_RANK1_ODT_DEFAULT 12 +#define V_RANK1_ODT_DEFAULT(x) ((x) << S_RANK1_ODT_DEFAULT) +#define F_RANK1_ODT_DEFAULT V_RANK1_ODT_DEFAULT(1U) + +#define S_RANK1_ODT_WRITE_SEL 11 +#define V_RANK1_ODT_WRITE_SEL(x) ((x) << S_RANK1_ODT_WRITE_SEL) +#define F_RANK1_ODT_WRITE_SEL V_RANK1_ODT_WRITE_SEL(1U) + +#define S_RANK1_ODT_WRITE_NSEL 10 +#define V_RANK1_ODT_WRITE_NSEL(x) ((x) << S_RANK1_ODT_WRITE_NSEL) +#define F_RANK1_ODT_WRITE_NSEL V_RANK1_ODT_WRITE_NSEL(1U) + +#define S_RANK1_ODT_READ_SEL 9 +#define V_RANK1_ODT_READ_SEL(x) ((x) << S_RANK1_ODT_READ_SEL) +#define F_RANK1_ODT_READ_SEL V_RANK1_ODT_READ_SEL(1U) + +#define S_RANK1_ODT_READ_NSEL 8 +#define V_RANK1_ODT_READ_NSEL(x) ((x) << S_RANK1_ODT_READ_NSEL) +#define F_RANK1_ODT_READ_NSEL V_RANK1_ODT_READ_NSEL(1U) + +#define S_RANK0_ODT_DEFAULT 4 +#define V_RANK0_ODT_DEFAULT(x) ((x) << S_RANK0_ODT_DEFAULT) +#define F_RANK0_ODT_DEFAULT V_RANK0_ODT_DEFAULT(1U) + +#define S_RANK0_ODT_WRITE_SEL 3 +#define V_RANK0_ODT_WRITE_SEL(x) ((x) << S_RANK0_ODT_WRITE_SEL) +#define F_RANK0_ODT_WRITE_SEL V_RANK0_ODT_WRITE_SEL(1U) + +#define S_RANK0_ODT_WRITE_NSEL 2 +#define V_RANK0_ODT_WRITE_NSEL(x) ((x) << S_RANK0_ODT_WRITE_NSEL) +#define F_RANK0_ODT_WRITE_NSEL V_RANK0_ODT_WRITE_NSEL(1U) + +#define S_RANK0_ODT_READ_SEL 1 +#define V_RANK0_ODT_READ_SEL(x) ((x) << S_RANK0_ODT_READ_SEL) +#define F_RANK0_ODT_READ_SEL V_RANK0_ODT_READ_SEL(1U) + +#define S_RANK0_ODT_READ_NSEL 0 +#define V_RANK0_ODT_READ_NSEL(x) ((x) << S_RANK0_ODT_READ_NSEL) +#define F_RANK0_ODT_READ_NSEL V_RANK0_ODT_READ_NSEL(1U) + +#define A_MC_PCTL_DQSECFG 0x6290 + +#define S_DV_ALAT 20 +#define M_DV_ALAT 0xfU +#define V_DV_ALAT(x) ((x) << S_DV_ALAT) +#define G_DV_ALAT(x) (((x) >> S_DV_ALAT) & M_DV_ALAT) + +#define S_DV_ALEN 16 +#define M_DV_ALEN 0x3U +#define V_DV_ALEN(x) ((x) << S_DV_ALEN) +#define G_DV_ALEN(x) (((x) >> S_DV_ALEN) & M_DV_ALEN) + +#define S_DSE_ALAT 12 +#define M_DSE_ALAT 0xfU +#define V_DSE_ALAT(x) ((x) << S_DSE_ALAT) +#define G_DSE_ALAT(x) (((x) >> S_DSE_ALAT) & M_DSE_ALAT) + +#define S_DSE_ALEN 8 +#define M_DSE_ALEN 0x3U +#define V_DSE_ALEN(x) ((x) << S_DSE_ALEN) +#define G_DSE_ALEN(x) (((x) >> S_DSE_ALEN) & M_DSE_ALEN) + +#define S_QSE_ALAT 4 +#define M_QSE_ALAT 0xfU +#define V_QSE_ALAT(x) ((x) << S_QSE_ALAT) +#define G_QSE_ALAT(x) (((x) >> S_QSE_ALAT) & M_QSE_ALAT) + +#define S_QSE_ALEN 0 +#define M_QSE_ALEN 0x3U +#define V_QSE_ALEN(x) ((x) << S_QSE_ALEN) +#define G_QSE_ALEN(x) (((x) >> S_QSE_ALEN) & M_QSE_ALEN) + +#define A_MC_PCTL_DTUPDES 0x6294 + +#define S_DTU_RD_MISSING 13 +#define V_DTU_RD_MISSING(x) ((x) << S_DTU_RD_MISSING) +#define F_DTU_RD_MISSING V_DTU_RD_MISSING(1U) + +#define S_DTU_EAFFL 9 +#define M_DTU_EAFFL 0xfU +#define V_DTU_EAFFL(x) ((x) << S_DTU_EAFFL) +#define G_DTU_EAFFL(x) (((x) >> S_DTU_EAFFL) & M_DTU_EAFFL) + +#define S_DTU_RANDOM_ERROR 8 +#define V_DTU_RANDOM_ERROR(x) ((x) << S_DTU_RANDOM_ERROR) +#define F_DTU_RANDOM_ERROR V_DTU_RANDOM_ERROR(1U) + +#define S_DTU_ERROR_B7 7 +#define V_DTU_ERROR_B7(x) ((x) << S_DTU_ERROR_B7) +#define F_DTU_ERROR_B7 V_DTU_ERROR_B7(1U) + +#define S_DTU_ERR_B6 6 +#define V_DTU_ERR_B6(x) ((x) << S_DTU_ERR_B6) +#define F_DTU_ERR_B6 V_DTU_ERR_B6(1U) + +#define S_DTU_ERR_B5 5 +#define V_DTU_ERR_B5(x) ((x) << S_DTU_ERR_B5) +#define F_DTU_ERR_B5 V_DTU_ERR_B5(1U) + +#define S_DTU_ERR_B4 4 +#define V_DTU_ERR_B4(x) ((x) << S_DTU_ERR_B4) +#define F_DTU_ERR_B4 V_DTU_ERR_B4(1U) + +#define S_DTU_ERR_B3 3 +#define V_DTU_ERR_B3(x) ((x) << S_DTU_ERR_B3) +#define F_DTU_ERR_B3 V_DTU_ERR_B3(1U) + +#define S_DTU_ERR_B2 2 +#define V_DTU_ERR_B2(x) ((x) << S_DTU_ERR_B2) +#define F_DTU_ERR_B2 V_DTU_ERR_B2(1U) + +#define S_DTU_ERR_B1 1 +#define V_DTU_ERR_B1(x) ((x) << S_DTU_ERR_B1) +#define F_DTU_ERR_B1 V_DTU_ERR_B1(1U) + +#define S_DTU_ERR_B0 0 +#define V_DTU_ERR_B0(x) ((x) << S_DTU_ERR_B0) +#define F_DTU_ERR_B0 V_DTU_ERR_B0(1U) + +#define A_MC_PCTL_DTUNA 0x6298 +#define A_MC_PCTL_DTUNE 0x629c +#define A_MC_PCTL_DTUPRDO 0x62a0 + +#define S_DTU_ALLBITS_1 16 +#define M_DTU_ALLBITS_1 0xffffU +#define V_DTU_ALLBITS_1(x) ((x) << S_DTU_ALLBITS_1) +#define G_DTU_ALLBITS_1(x) (((x) >> S_DTU_ALLBITS_1) & M_DTU_ALLBITS_1) + +#define S_DTU_ALLBITS_0 0 +#define M_DTU_ALLBITS_0 0xffffU +#define V_DTU_ALLBITS_0(x) ((x) << S_DTU_ALLBITS_0) +#define G_DTU_ALLBITS_0(x) (((x) >> S_DTU_ALLBITS_0) & M_DTU_ALLBITS_0) + +#define A_MC_PCTL_DTUPRD1 0x62a4 + +#define S_DTU_ALLBITS_3 16 +#define M_DTU_ALLBITS_3 0xffffU +#define V_DTU_ALLBITS_3(x) ((x) << S_DTU_ALLBITS_3) +#define G_DTU_ALLBITS_3(x) (((x) >> S_DTU_ALLBITS_3) & M_DTU_ALLBITS_3) + +#define S_DTU_ALLBITS_2 0 +#define M_DTU_ALLBITS_2 0xffffU +#define V_DTU_ALLBITS_2(x) ((x) << S_DTU_ALLBITS_2) +#define G_DTU_ALLBITS_2(x) (((x) >> S_DTU_ALLBITS_2) & M_DTU_ALLBITS_2) + +#define A_MC_PCTL_DTUPRD2 0x62a8 + +#define S_DTU_ALLBITS_5 16 +#define M_DTU_ALLBITS_5 0xffffU +#define V_DTU_ALLBITS_5(x) ((x) << S_DTU_ALLBITS_5) +#define G_DTU_ALLBITS_5(x) (((x) >> S_DTU_ALLBITS_5) & M_DTU_ALLBITS_5) + +#define S_DTU_ALLBITS_4 0 +#define M_DTU_ALLBITS_4 0xffffU +#define V_DTU_ALLBITS_4(x) ((x) << S_DTU_ALLBITS_4) +#define G_DTU_ALLBITS_4(x) (((x) >> S_DTU_ALLBITS_4) & M_DTU_ALLBITS_4) + +#define A_MC_PCTL_DTUPRD3 0x62ac + +#define S_DTU_ALLBITS_7 16 +#define M_DTU_ALLBITS_7 0xffffU +#define V_DTU_ALLBITS_7(x) ((x) << S_DTU_ALLBITS_7) +#define G_DTU_ALLBITS_7(x) (((x) >> S_DTU_ALLBITS_7) & M_DTU_ALLBITS_7) + +#define S_DTU_ALLBITS_6 0 +#define M_DTU_ALLBITS_6 0xffffU +#define V_DTU_ALLBITS_6(x) ((x) << S_DTU_ALLBITS_6) +#define G_DTU_ALLBITS_6(x) (((x) >> S_DTU_ALLBITS_6) & M_DTU_ALLBITS_6) + +#define A_MC_PCTL_DTUAWDT 0x62b0 + +#define S_NUMBER_RANKS 9 +#define M_NUMBER_RANKS 0x3U +#define V_NUMBER_RANKS(x) ((x) << S_NUMBER_RANKS) +#define G_NUMBER_RANKS(x) (((x) >> S_NUMBER_RANKS) & M_NUMBER_RANKS) + +#define S_ROW_ADDR_WIDTH 6 +#define M_ROW_ADDR_WIDTH 0x3U +#define V_ROW_ADDR_WIDTH(x) ((x) << S_ROW_ADDR_WIDTH) +#define G_ROW_ADDR_WIDTH(x) (((x) >> S_ROW_ADDR_WIDTH) & M_ROW_ADDR_WIDTH) + +#define S_BANK_ADDR_WIDTH 3 +#define M_BANK_ADDR_WIDTH 0x3U +#define V_BANK_ADDR_WIDTH(x) ((x) << S_BANK_ADDR_WIDTH) +#define G_BANK_ADDR_WIDTH(x) (((x) >> S_BANK_ADDR_WIDTH) & M_BANK_ADDR_WIDTH) + +#define S_COLUMN_ADDR_WIDTH 0 +#define M_COLUMN_ADDR_WIDTH 0x3U +#define V_COLUMN_ADDR_WIDTH(x) ((x) << S_COLUMN_ADDR_WIDTH) +#define G_COLUMN_ADDR_WIDTH(x) (((x) >> S_COLUMN_ADDR_WIDTH) & M_COLUMN_ADDR_WIDTH) + +#define A_MC_PCTL_TOGCNT1U 0x62c0 + +#define S_TOGGLE_COUNTER_1U 0 +#define M_TOGGLE_COUNTER_1U 0x3ffU +#define V_TOGGLE_COUNTER_1U(x) ((x) << S_TOGGLE_COUNTER_1U) +#define G_TOGGLE_COUNTER_1U(x) (((x) >> S_TOGGLE_COUNTER_1U) & M_TOGGLE_COUNTER_1U) + +#define A_MC_PCTL_TINIT 0x62c4 + +#define S_T_INIT 0 +#define M_T_INIT 0x1ffU +#define V_T_INIT(x) ((x) << S_T_INIT) +#define G_T_INIT(x) (((x) >> S_T_INIT) & M_T_INIT) + +#define A_MC_PCTL_TRSTH 0x62c8 + +#define S_T_RSTH 0 +#define M_T_RSTH 0x3ffU +#define V_T_RSTH(x) ((x) << S_T_RSTH) +#define G_T_RSTH(x) (((x) >> S_T_RSTH) & M_T_RSTH) + +#define A_MC_PCTL_TOGCNT100N 0x62cc + +#define S_TOGGLE_COUNTER_100N 0 +#define M_TOGGLE_COUNTER_100N 0x7fU +#define V_TOGGLE_COUNTER_100N(x) ((x) << S_TOGGLE_COUNTER_100N) +#define G_TOGGLE_COUNTER_100N(x) (((x) >> S_TOGGLE_COUNTER_100N) & M_TOGGLE_COUNTER_100N) + +#define A_MC_PCTL_TREFI 0x62d0 + +#define S_T_REFI 0 +#define M_T_REFI 0xffU +#define V_T_REFI(x) ((x) << S_T_REFI) +#define G_T_REFI(x) (((x) >> S_T_REFI) & M_T_REFI) + +#define A_MC_PCTL_TMRD 0x62d4 + +#define S_T_MRD 0 +#define M_T_MRD 0x7U +#define V_T_MRD(x) ((x) << S_T_MRD) +#define G_T_MRD(x) (((x) >> S_T_MRD) & M_T_MRD) + +#define A_MC_PCTL_TRFC 0x62d8 + +#define S_T_RFC 0 +#define M_T_RFC 0xffU +#define V_T_RFC(x) ((x) << S_T_RFC) +#define G_T_RFC(x) (((x) >> S_T_RFC) & M_T_RFC) + +#define A_MC_PCTL_TRP 0x62dc + +#define S_T_RP 0 +#define M_T_RP 0xfU +#define V_T_RP(x) ((x) << S_T_RP) +#define G_T_RP(x) (((x) >> S_T_RP) & M_T_RP) + +#define A_MC_PCTL_TRTW 0x62e0 + +#define S_T_RTW 0 +#define M_T_RTW 0x7U +#define V_T_RTW(x) ((x) << S_T_RTW) +#define G_T_RTW(x) (((x) >> S_T_RTW) & M_T_RTW) + +#define A_MC_PCTL_TAL 0x62e4 + +#define S_T_AL 0 +#define M_T_AL 0xfU +#define V_T_AL(x) ((x) << S_T_AL) +#define G_T_AL(x) (((x) >> S_T_AL) & M_T_AL) + +#define A_MC_PCTL_TCL 0x62e8 + +#define S_T_CL 0 +#define M_T_CL 0xfU +#define V_T_CL(x) ((x) << S_T_CL) +#define G_T_CL(x) (((x) >> S_T_CL) & M_T_CL) + +#define A_MC_PCTL_TCWL 0x62ec + +#define S_T_CWL 0 +#define M_T_CWL 0xfU +#define V_T_CWL(x) ((x) << S_T_CWL) +#define G_T_CWL(x) (((x) >> S_T_CWL) & M_T_CWL) + +#define A_MC_PCTL_TRAS 0x62f0 + +#define S_T_RAS 0 +#define M_T_RAS 0x3fU +#define V_T_RAS(x) ((x) << S_T_RAS) +#define G_T_RAS(x) (((x) >> S_T_RAS) & M_T_RAS) + +#define A_MC_PCTL_TRC 0x62f4 + +#define S_T_RC 0 +#define M_T_RC 0x3fU +#define V_T_RC(x) ((x) << S_T_RC) +#define G_T_RC(x) (((x) >> S_T_RC) & M_T_RC) + +#define A_MC_PCTL_TRCD 0x62f8 + +#define S_T_RCD 0 +#define M_T_RCD 0xfU +#define V_T_RCD(x) ((x) << S_T_RCD) +#define G_T_RCD(x) (((x) >> S_T_RCD) & M_T_RCD) + +#define A_MC_PCTL_TRRD 0x62fc + +#define S_T_RRD 0 +#define M_T_RRD 0xfU +#define V_T_RRD(x) ((x) << S_T_RRD) +#define G_T_RRD(x) (((x) >> S_T_RRD) & M_T_RRD) + +#define A_MC_PCTL_TRTP 0x6300 + +#define S_T_RTP 0 +#define M_T_RTP 0x7U +#define V_T_RTP(x) ((x) << S_T_RTP) +#define G_T_RTP(x) (((x) >> S_T_RTP) & M_T_RTP) + +#define A_MC_PCTL_TWR 0x6304 + +#define S_T_WR 0 +#define M_T_WR 0x7U +#define V_T_WR(x) ((x) << S_T_WR) +#define G_T_WR(x) (((x) >> S_T_WR) & M_T_WR) + +#define A_MC_PCTL_TWTR 0x6308 + +#define S_T_WTR 0 +#define M_T_WTR 0x7U +#define V_T_WTR(x) ((x) << S_T_WTR) +#define G_T_WTR(x) (((x) >> S_T_WTR) & M_T_WTR) + +#define A_MC_PCTL_TEXSR 0x630c + +#define S_T_EXSR 0 +#define M_T_EXSR 0x3ffU +#define V_T_EXSR(x) ((x) << S_T_EXSR) +#define G_T_EXSR(x) (((x) >> S_T_EXSR) & M_T_EXSR) + +#define A_MC_PCTL_TXP 0x6310 + +#define S_T_XP 0 +#define M_T_XP 0x7U +#define V_T_XP(x) ((x) << S_T_XP) +#define G_T_XP(x) (((x) >> S_T_XP) & M_T_XP) + +#define A_MC_PCTL_TXPDLL 0x6314 + +#define S_T_XPDLL 0 +#define M_T_XPDLL 0x3fU +#define V_T_XPDLL(x) ((x) << S_T_XPDLL) +#define G_T_XPDLL(x) (((x) >> S_T_XPDLL) & M_T_XPDLL) + +#define A_MC_PCTL_TZQCS 0x6318 + +#define S_T_ZQCS 0 +#define M_T_ZQCS 0x7fU +#define V_T_ZQCS(x) ((x) << S_T_ZQCS) +#define G_T_ZQCS(x) (((x) >> S_T_ZQCS) & M_T_ZQCS) + +#define A_MC_PCTL_TZQCSI 0x631c + +#define S_T_ZQCSI 0 +#define M_T_ZQCSI 0xfffU +#define V_T_ZQCSI(x) ((x) << S_T_ZQCSI) +#define G_T_ZQCSI(x) (((x) >> S_T_ZQCSI) & M_T_ZQCSI) + +#define A_MC_PCTL_TDQS 0x6320 + +#define S_T_DQS 0 +#define M_T_DQS 0x7U +#define V_T_DQS(x) ((x) << S_T_DQS) +#define G_T_DQS(x) (((x) >> S_T_DQS) & M_T_DQS) + +#define A_MC_PCTL_TCKSRE 0x6324 + +#define S_T_CKSRE 0 +#define M_T_CKSRE 0xfU +#define V_T_CKSRE(x) ((x) << S_T_CKSRE) +#define G_T_CKSRE(x) (((x) >> S_T_CKSRE) & M_T_CKSRE) + +#define A_MC_PCTL_TCKSRX 0x6328 + +#define S_T_CKSRX 0 +#define M_T_CKSRX 0xfU +#define V_T_CKSRX(x) ((x) << S_T_CKSRX) +#define G_T_CKSRX(x) (((x) >> S_T_CKSRX) & M_T_CKSRX) + +#define A_MC_PCTL_TCKE 0x632c + +#define S_T_CKE 0 +#define M_T_CKE 0x7U +#define V_T_CKE(x) ((x) << S_T_CKE) +#define G_T_CKE(x) (((x) >> S_T_CKE) & M_T_CKE) + +#define A_MC_PCTL_TMOD 0x6330 + +#define S_T_MOD 0 +#define M_T_MOD 0xfU +#define V_T_MOD(x) ((x) << S_T_MOD) +#define G_T_MOD(x) (((x) >> S_T_MOD) & M_T_MOD) + +#define A_MC_PCTL_TRSTL 0x6334 + +#define S_RSTHOLD 0 +#define M_RSTHOLD 0x7fU +#define V_RSTHOLD(x) ((x) << S_RSTHOLD) +#define G_RSTHOLD(x) (((x) >> S_RSTHOLD) & M_RSTHOLD) + +#define A_MC_PCTL_TZQCL 0x6338 + +#define S_T_ZQCL 0 +#define M_T_ZQCL 0x3ffU +#define V_T_ZQCL(x) ((x) << S_T_ZQCL) +#define G_T_ZQCL(x) (((x) >> S_T_ZQCL) & M_T_ZQCL) + +#define A_MC_PCTL_DWLCFG0 0x6370 + +#define S_T_ADWL_VEC 0 +#define M_T_ADWL_VEC 0x1ffU +#define V_T_ADWL_VEC(x) ((x) << S_T_ADWL_VEC) +#define G_T_ADWL_VEC(x) (((x) >> S_T_ADWL_VEC) & M_T_ADWL_VEC) + +#define A_MC_PCTL_DWLCFG1 0x6374 +#define A_MC_PCTL_DWLCFG2 0x6378 +#define A_MC_PCTL_DWLCFG3 0x637c +#define A_MC_PCTL_ECCCFG 0x6380 + +#define S_INLINE_SYN_EN 4 +#define V_INLINE_SYN_EN(x) ((x) << S_INLINE_SYN_EN) +#define F_INLINE_SYN_EN V_INLINE_SYN_EN(1U) + +#define S_ECC_EN 3 +#define V_ECC_EN(x) ((x) << S_ECC_EN) +#define F_ECC_EN V_ECC_EN(1U) + +#define S_ECC_INTR_EN 2 +#define V_ECC_INTR_EN(x) ((x) << S_ECC_INTR_EN) +#define F_ECC_INTR_EN V_ECC_INTR_EN(1U) + +#define A_MC_PCTL_ECCTST 0x6384 + +#define S_ECC_TEST_MASK 0 +#define M_ECC_TEST_MASK 0xffU +#define V_ECC_TEST_MASK(x) ((x) << S_ECC_TEST_MASK) +#define G_ECC_TEST_MASK(x) (((x) >> S_ECC_TEST_MASK) & M_ECC_TEST_MASK) + +#define A_MC_PCTL_ECCCLR 0x6388 + +#define S_CLR_ECC_LOG 1 +#define V_CLR_ECC_LOG(x) ((x) << S_CLR_ECC_LOG) +#define F_CLR_ECC_LOG V_CLR_ECC_LOG(1U) + +#define S_CLR_ECC_INTR 0 +#define V_CLR_ECC_INTR(x) ((x) << S_CLR_ECC_INTR) +#define F_CLR_ECC_INTR V_CLR_ECC_INTR(1U) + +#define A_MC_PCTL_ECCLOG 0x638c +#define A_MC_PCTL_DTUWACTL 0x6400 + +#define S_DTU_WR_RANK 30 +#define M_DTU_WR_RANK 0x3U +#define V_DTU_WR_RANK(x) ((x) << S_DTU_WR_RANK) +#define G_DTU_WR_RANK(x) (((x) >> S_DTU_WR_RANK) & M_DTU_WR_RANK) + +#define S_DTU_WR_ROW 13 +#define M_DTU_WR_ROW 0x1ffffU +#define V_DTU_WR_ROW(x) ((x) << S_DTU_WR_ROW) +#define G_DTU_WR_ROW(x) (((x) >> S_DTU_WR_ROW) & M_DTU_WR_ROW) + +#define S_DTU_WR_BANK 10 +#define M_DTU_WR_BANK 0x7U +#define V_DTU_WR_BANK(x) ((x) << S_DTU_WR_BANK) +#define G_DTU_WR_BANK(x) (((x) >> S_DTU_WR_BANK) & M_DTU_WR_BANK) + +#define S_DTU_WR_COL 0 +#define M_DTU_WR_COL 0x3ffU +#define V_DTU_WR_COL(x) ((x) << S_DTU_WR_COL) +#define G_DTU_WR_COL(x) (((x) >> S_DTU_WR_COL) & M_DTU_WR_COL) + +#define A_MC_PCTL_DTURACTL 0x6404 + +#define S_DTU_RD_RANK 30 +#define M_DTU_RD_RANK 0x3U +#define V_DTU_RD_RANK(x) ((x) << S_DTU_RD_RANK) +#define G_DTU_RD_RANK(x) (((x) >> S_DTU_RD_RANK) & M_DTU_RD_RANK) + +#define S_DTU_RD_ROW 13 +#define M_DTU_RD_ROW 0x1ffffU +#define V_DTU_RD_ROW(x) ((x) << S_DTU_RD_ROW) +#define G_DTU_RD_ROW(x) (((x) >> S_DTU_RD_ROW) & M_DTU_RD_ROW) + +#define S_DTU_RD_BANK 10 +#define M_DTU_RD_BANK 0x7U +#define V_DTU_RD_BANK(x) ((x) << S_DTU_RD_BANK) +#define G_DTU_RD_BANK(x) (((x) >> S_DTU_RD_BANK) & M_DTU_RD_BANK) + +#define S_DTU_RD_COL 0 +#define M_DTU_RD_COL 0x3ffU +#define V_DTU_RD_COL(x) ((x) << S_DTU_RD_COL) +#define G_DTU_RD_COL(x) (((x) >> S_DTU_RD_COL) & M_DTU_RD_COL) + +#define A_MC_PCTL_DTUCFG 0x6408 + +#define S_DTU_ROW_INCREMENTS 16 +#define M_DTU_ROW_INCREMENTS 0x7fU +#define V_DTU_ROW_INCREMENTS(x) ((x) << S_DTU_ROW_INCREMENTS) +#define G_DTU_ROW_INCREMENTS(x) (((x) >> S_DTU_ROW_INCREMENTS) & M_DTU_ROW_INCREMENTS) + +#define S_DTU_WR_MULTI_RD 15 +#define V_DTU_WR_MULTI_RD(x) ((x) << S_DTU_WR_MULTI_RD) +#define F_DTU_WR_MULTI_RD V_DTU_WR_MULTI_RD(1U) + +#define S_DTU_DATA_MASK_EN 14 +#define V_DTU_DATA_MASK_EN(x) ((x) << S_DTU_DATA_MASK_EN) +#define F_DTU_DATA_MASK_EN V_DTU_DATA_MASK_EN(1U) + +#define S_DTU_TARGET_LANE 10 +#define M_DTU_TARGET_LANE 0xfU +#define V_DTU_TARGET_LANE(x) ((x) << S_DTU_TARGET_LANE) +#define G_DTU_TARGET_LANE(x) (((x) >> S_DTU_TARGET_LANE) & M_DTU_TARGET_LANE) + +#define S_DTU_GENERATE_RANDOM 9 +#define V_DTU_GENERATE_RANDOM(x) ((x) << S_DTU_GENERATE_RANDOM) +#define F_DTU_GENERATE_RANDOM V_DTU_GENERATE_RANDOM(1U) + +#define S_DTU_INCR_BANKS 8 +#define V_DTU_INCR_BANKS(x) ((x) << S_DTU_INCR_BANKS) +#define F_DTU_INCR_BANKS V_DTU_INCR_BANKS(1U) + +#define S_DTU_INCR_COLS 7 +#define V_DTU_INCR_COLS(x) ((x) << S_DTU_INCR_COLS) +#define F_DTU_INCR_COLS V_DTU_INCR_COLS(1U) + +#define S_DTU_NALEN 1 +#define M_DTU_NALEN 0x3fU +#define V_DTU_NALEN(x) ((x) << S_DTU_NALEN) +#define G_DTU_NALEN(x) (((x) >> S_DTU_NALEN) & M_DTU_NALEN) + +#define S_DTU_ENABLE 0 +#define V_DTU_ENABLE(x) ((x) << S_DTU_ENABLE) +#define F_DTU_ENABLE V_DTU_ENABLE(1U) + +#define A_MC_PCTL_DTUECTL 0x640c + +#define S_WR_MULTI_RD_RST 2 +#define V_WR_MULTI_RD_RST(x) ((x) << S_WR_MULTI_RD_RST) +#define F_WR_MULTI_RD_RST V_WR_MULTI_RD_RST(1U) + +#define S_RUN_ERROR_REPORTS 1 +#define V_RUN_ERROR_REPORTS(x) ((x) << S_RUN_ERROR_REPORTS) +#define F_RUN_ERROR_REPORTS V_RUN_ERROR_REPORTS(1U) + +#define S_RUN_DTU 0 +#define V_RUN_DTU(x) ((x) << S_RUN_DTU) +#define F_RUN_DTU V_RUN_DTU(1U) + +#define A_MC_PCTL_DTUWD0 0x6410 + +#define S_DTU_WR_BYTE3 24 +#define M_DTU_WR_BYTE3 0xffU +#define V_DTU_WR_BYTE3(x) ((x) << S_DTU_WR_BYTE3) +#define G_DTU_WR_BYTE3(x) (((x) >> S_DTU_WR_BYTE3) & M_DTU_WR_BYTE3) + +#define S_DTU_WR_BYTE2 16 +#define M_DTU_WR_BYTE2 0xffU +#define V_DTU_WR_BYTE2(x) ((x) << S_DTU_WR_BYTE2) +#define G_DTU_WR_BYTE2(x) (((x) >> S_DTU_WR_BYTE2) & M_DTU_WR_BYTE2) + +#define S_DTU_WR_BYTE1 8 +#define M_DTU_WR_BYTE1 0xffU +#define V_DTU_WR_BYTE1(x) ((x) << S_DTU_WR_BYTE1) +#define G_DTU_WR_BYTE1(x) (((x) >> S_DTU_WR_BYTE1) & M_DTU_WR_BYTE1) + +#define S_DTU_WR_BYTE0 0 +#define M_DTU_WR_BYTE0 0xffU +#define V_DTU_WR_BYTE0(x) ((x) << S_DTU_WR_BYTE0) +#define G_DTU_WR_BYTE0(x) (((x) >> S_DTU_WR_BYTE0) & M_DTU_WR_BYTE0) + +#define A_MC_PCTL_DTUWD1 0x6414 + +#define S_DTU_WR_BYTE7 24 +#define M_DTU_WR_BYTE7 0xffU +#define V_DTU_WR_BYTE7(x) ((x) << S_DTU_WR_BYTE7) +#define G_DTU_WR_BYTE7(x) (((x) >> S_DTU_WR_BYTE7) & M_DTU_WR_BYTE7) + +#define S_DTU_WR_BYTE6 16 +#define M_DTU_WR_BYTE6 0xffU +#define V_DTU_WR_BYTE6(x) ((x) << S_DTU_WR_BYTE6) +#define G_DTU_WR_BYTE6(x) (((x) >> S_DTU_WR_BYTE6) & M_DTU_WR_BYTE6) + +#define S_DTU_WR_BYTE5 8 +#define M_DTU_WR_BYTE5 0xffU +#define V_DTU_WR_BYTE5(x) ((x) << S_DTU_WR_BYTE5) +#define G_DTU_WR_BYTE5(x) (((x) >> S_DTU_WR_BYTE5) & M_DTU_WR_BYTE5) + +#define S_DTU_WR_BYTE4 0 +#define M_DTU_WR_BYTE4 0xffU +#define V_DTU_WR_BYTE4(x) ((x) << S_DTU_WR_BYTE4) +#define G_DTU_WR_BYTE4(x) (((x) >> S_DTU_WR_BYTE4) & M_DTU_WR_BYTE4) + +#define A_MC_PCTL_DTUWD2 0x6418 + +#define S_DTU_WR_BYTE11 24 +#define M_DTU_WR_BYTE11 0xffU +#define V_DTU_WR_BYTE11(x) ((x) << S_DTU_WR_BYTE11) +#define G_DTU_WR_BYTE11(x) (((x) >> S_DTU_WR_BYTE11) & M_DTU_WR_BYTE11) + +#define S_DTU_WR_BYTE10 16 +#define M_DTU_WR_BYTE10 0xffU +#define V_DTU_WR_BYTE10(x) ((x) << S_DTU_WR_BYTE10) +#define G_DTU_WR_BYTE10(x) (((x) >> S_DTU_WR_BYTE10) & M_DTU_WR_BYTE10) + +#define S_DTU_WR_BYTE9 8 +#define M_DTU_WR_BYTE9 0xffU +#define V_DTU_WR_BYTE9(x) ((x) << S_DTU_WR_BYTE9) +#define G_DTU_WR_BYTE9(x) (((x) >> S_DTU_WR_BYTE9) & M_DTU_WR_BYTE9) + +#define S_DTU_WR_BYTE8 0 +#define M_DTU_WR_BYTE8 0xffU +#define V_DTU_WR_BYTE8(x) ((x) << S_DTU_WR_BYTE8) +#define G_DTU_WR_BYTE8(x) (((x) >> S_DTU_WR_BYTE8) & M_DTU_WR_BYTE8) + +#define A_MC_PCTL_DTUWD3 0x641c + +#define S_DTU_WR_BYTE15 24 +#define M_DTU_WR_BYTE15 0xffU +#define V_DTU_WR_BYTE15(x) ((x) << S_DTU_WR_BYTE15) +#define G_DTU_WR_BYTE15(x) (((x) >> S_DTU_WR_BYTE15) & M_DTU_WR_BYTE15) + +#define S_DTU_WR_BYTE14 16 +#define M_DTU_WR_BYTE14 0xffU +#define V_DTU_WR_BYTE14(x) ((x) << S_DTU_WR_BYTE14) +#define G_DTU_WR_BYTE14(x) (((x) >> S_DTU_WR_BYTE14) & M_DTU_WR_BYTE14) + +#define S_DTU_WR_BYTE13 8 +#define M_DTU_WR_BYTE13 0xffU +#define V_DTU_WR_BYTE13(x) ((x) << S_DTU_WR_BYTE13) +#define G_DTU_WR_BYTE13(x) (((x) >> S_DTU_WR_BYTE13) & M_DTU_WR_BYTE13) + +#define S_DTU_WR_BYTE12 0 +#define M_DTU_WR_BYTE12 0xffU +#define V_DTU_WR_BYTE12(x) ((x) << S_DTU_WR_BYTE12) +#define G_DTU_WR_BYTE12(x) (((x) >> S_DTU_WR_BYTE12) & M_DTU_WR_BYTE12) + +#define A_MC_PCTL_DTUWDM 0x6420 + +#define S_DM_WR_BYTE0 0 +#define M_DM_WR_BYTE0 0xffffU +#define V_DM_WR_BYTE0(x) ((x) << S_DM_WR_BYTE0) +#define G_DM_WR_BYTE0(x) (((x) >> S_DM_WR_BYTE0) & M_DM_WR_BYTE0) + +#define A_MC_PCTL_DTURD0 0x6424 + +#define S_DTU_RD_BYTE3 24 +#define M_DTU_RD_BYTE3 0xffU +#define V_DTU_RD_BYTE3(x) ((x) << S_DTU_RD_BYTE3) +#define G_DTU_RD_BYTE3(x) (((x) >> S_DTU_RD_BYTE3) & M_DTU_RD_BYTE3) + +#define S_DTU_RD_BYTE2 16 +#define M_DTU_RD_BYTE2 0xffU +#define V_DTU_RD_BYTE2(x) ((x) << S_DTU_RD_BYTE2) +#define G_DTU_RD_BYTE2(x) (((x) >> S_DTU_RD_BYTE2) & M_DTU_RD_BYTE2) + +#define S_DTU_RD_BYTE1 8 +#define M_DTU_RD_BYTE1 0xffU +#define V_DTU_RD_BYTE1(x) ((x) << S_DTU_RD_BYTE1) +#define G_DTU_RD_BYTE1(x) (((x) >> S_DTU_RD_BYTE1) & M_DTU_RD_BYTE1) + +#define S_DTU_RD_BYTE0 0 +#define M_DTU_RD_BYTE0 0xffU +#define V_DTU_RD_BYTE0(x) ((x) << S_DTU_RD_BYTE0) +#define G_DTU_RD_BYTE0(x) (((x) >> S_DTU_RD_BYTE0) & M_DTU_RD_BYTE0) + +#define A_MC_PCTL_DTURD1 0x6428 + +#define S_DTU_RD_BYTE7 24 +#define M_DTU_RD_BYTE7 0xffU +#define V_DTU_RD_BYTE7(x) ((x) << S_DTU_RD_BYTE7) +#define G_DTU_RD_BYTE7(x) (((x) >> S_DTU_RD_BYTE7) & M_DTU_RD_BYTE7) + +#define S_DTU_RD_BYTE6 16 +#define M_DTU_RD_BYTE6 0xffU +#define V_DTU_RD_BYTE6(x) ((x) << S_DTU_RD_BYTE6) +#define G_DTU_RD_BYTE6(x) (((x) >> S_DTU_RD_BYTE6) & M_DTU_RD_BYTE6) + +#define S_DTU_RD_BYTE5 8 +#define M_DTU_RD_BYTE5 0xffU +#define V_DTU_RD_BYTE5(x) ((x) << S_DTU_RD_BYTE5) +#define G_DTU_RD_BYTE5(x) (((x) >> S_DTU_RD_BYTE5) & M_DTU_RD_BYTE5) + +#define S_DTU_RD_BYTE4 0 +#define M_DTU_RD_BYTE4 0xffU +#define V_DTU_RD_BYTE4(x) ((x) << S_DTU_RD_BYTE4) +#define G_DTU_RD_BYTE4(x) (((x) >> S_DTU_RD_BYTE4) & M_DTU_RD_BYTE4) + +#define A_MC_PCTL_DTURD2 0x642c + +#define S_DTU_RD_BYTE11 24 +#define M_DTU_RD_BYTE11 0xffU +#define V_DTU_RD_BYTE11(x) ((x) << S_DTU_RD_BYTE11) +#define G_DTU_RD_BYTE11(x) (((x) >> S_DTU_RD_BYTE11) & M_DTU_RD_BYTE11) + +#define S_DTU_RD_BYTE10 16 +#define M_DTU_RD_BYTE10 0xffU +#define V_DTU_RD_BYTE10(x) ((x) << S_DTU_RD_BYTE10) +#define G_DTU_RD_BYTE10(x) (((x) >> S_DTU_RD_BYTE10) & M_DTU_RD_BYTE10) + +#define S_DTU_RD_BYTE9 8 +#define M_DTU_RD_BYTE9 0xffU +#define V_DTU_RD_BYTE9(x) ((x) << S_DTU_RD_BYTE9) +#define G_DTU_RD_BYTE9(x) (((x) >> S_DTU_RD_BYTE9) & M_DTU_RD_BYTE9) + +#define S_DTU_RD_BYTE8 0 +#define M_DTU_RD_BYTE8 0xffU +#define V_DTU_RD_BYTE8(x) ((x) << S_DTU_RD_BYTE8) +#define G_DTU_RD_BYTE8(x) (((x) >> S_DTU_RD_BYTE8) & M_DTU_RD_BYTE8) + +#define A_MC_PCTL_DTURD3 0x6430 + +#define S_DTU_RD_BYTE15 24 +#define M_DTU_RD_BYTE15 0xffU +#define V_DTU_RD_BYTE15(x) ((x) << S_DTU_RD_BYTE15) +#define G_DTU_RD_BYTE15(x) (((x) >> S_DTU_RD_BYTE15) & M_DTU_RD_BYTE15) + +#define S_DTU_RD_BYTE14 16 +#define M_DTU_RD_BYTE14 0xffU +#define V_DTU_RD_BYTE14(x) ((x) << S_DTU_RD_BYTE14) +#define G_DTU_RD_BYTE14(x) (((x) >> S_DTU_RD_BYTE14) & M_DTU_RD_BYTE14) + +#define S_DTU_RD_BYTE13 8 +#define M_DTU_RD_BYTE13 0xffU +#define V_DTU_RD_BYTE13(x) ((x) << S_DTU_RD_BYTE13) +#define G_DTU_RD_BYTE13(x) (((x) >> S_DTU_RD_BYTE13) & M_DTU_RD_BYTE13) + +#define S_DTU_RD_BYTE12 0 +#define M_DTU_RD_BYTE12 0xffU +#define V_DTU_RD_BYTE12(x) ((x) << S_DTU_RD_BYTE12) +#define G_DTU_RD_BYTE12(x) (((x) >> S_DTU_RD_BYTE12) & M_DTU_RD_BYTE12) + +#define A_MC_DTULFSRWD 0x6434 +#define A_MC_PCTL_DTULFSRRD 0x6438 +#define A_MC_PCTL_DTUEAF 0x643c + +#define S_EA_RANK 30 +#define M_EA_RANK 0x3U +#define V_EA_RANK(x) ((x) << S_EA_RANK) +#define G_EA_RANK(x) (((x) >> S_EA_RANK) & M_EA_RANK) + +#define S_EA_ROW 13 +#define M_EA_ROW 0x1ffffU +#define V_EA_ROW(x) ((x) << S_EA_ROW) +#define G_EA_ROW(x) (((x) >> S_EA_ROW) & M_EA_ROW) + +#define S_EA_BANK 10 +#define M_EA_BANK 0x7U +#define V_EA_BANK(x) ((x) << S_EA_BANK) +#define G_EA_BANK(x) (((x) >> S_EA_BANK) & M_EA_BANK) + +#define S_EA_COLUMN 0 +#define M_EA_COLUMN 0x3ffU +#define V_EA_COLUMN(x) ((x) << S_EA_COLUMN) +#define G_EA_COLUMN(x) (((x) >> S_EA_COLUMN) & M_EA_COLUMN) + +#define A_MC_PCTL_PHYPVTCFG 0x6500 + +#define S_PVT_UPD_REQ_EN 15 +#define V_PVT_UPD_REQ_EN(x) ((x) << S_PVT_UPD_REQ_EN) +#define F_PVT_UPD_REQ_EN V_PVT_UPD_REQ_EN(1U) + +#define S_PVT_UPD_TRIG_POL 14 +#define V_PVT_UPD_TRIG_POL(x) ((x) << S_PVT_UPD_TRIG_POL) +#define F_PVT_UPD_TRIG_POL V_PVT_UPD_TRIG_POL(1U) + +#define S_PVT_UPD_TRIG_TYPE 12 +#define V_PVT_UPD_TRIG_TYPE(x) ((x) << S_PVT_UPD_TRIG_TYPE) +#define F_PVT_UPD_TRIG_TYPE V_PVT_UPD_TRIG_TYPE(1U) + +#define S_PVT_UPD_DONE_POL 10 +#define V_PVT_UPD_DONE_POL(x) ((x) << S_PVT_UPD_DONE_POL) +#define F_PVT_UPD_DONE_POL V_PVT_UPD_DONE_POL(1U) + +#define S_PVT_UPD_DONE_TYPE 8 +#define M_PVT_UPD_DONE_TYPE 0x3U +#define V_PVT_UPD_DONE_TYPE(x) ((x) << S_PVT_UPD_DONE_TYPE) +#define G_PVT_UPD_DONE_TYPE(x) (((x) >> S_PVT_UPD_DONE_TYPE) & M_PVT_UPD_DONE_TYPE) + +#define S_PHY_UPD_REQ_EN 7 +#define V_PHY_UPD_REQ_EN(x) ((x) << S_PHY_UPD_REQ_EN) +#define F_PHY_UPD_REQ_EN V_PHY_UPD_REQ_EN(1U) + +#define S_PHY_UPD_TRIG_POL 6 +#define V_PHY_UPD_TRIG_POL(x) ((x) << S_PHY_UPD_TRIG_POL) +#define F_PHY_UPD_TRIG_POL V_PHY_UPD_TRIG_POL(1U) + +#define S_PHY_UPD_TRIG_TYPE 4 +#define V_PHY_UPD_TRIG_TYPE(x) ((x) << S_PHY_UPD_TRIG_TYPE) +#define F_PHY_UPD_TRIG_TYPE V_PHY_UPD_TRIG_TYPE(1U) + +#define S_PHY_UPD_DONE_POL 2 +#define V_PHY_UPD_DONE_POL(x) ((x) << S_PHY_UPD_DONE_POL) +#define F_PHY_UPD_DONE_POL V_PHY_UPD_DONE_POL(1U) + +#define S_PHY_UPD_DONE_TYPE 0 +#define M_PHY_UPD_DONE_TYPE 0x3U +#define V_PHY_UPD_DONE_TYPE(x) ((x) << S_PHY_UPD_DONE_TYPE) +#define G_PHY_UPD_DONE_TYPE(x) (((x) >> S_PHY_UPD_DONE_TYPE) & M_PHY_UPD_DONE_TYPE) + +#define A_MC_PCTL_PHYPVTSTAT 0x6504 + +#define S_I_PVT_UPD_TRIG 5 +#define V_I_PVT_UPD_TRIG(x) ((x) << S_I_PVT_UPD_TRIG) +#define F_I_PVT_UPD_TRIG V_I_PVT_UPD_TRIG(1U) + +#define S_I_PVT_UPD_DONE 4 +#define V_I_PVT_UPD_DONE(x) ((x) << S_I_PVT_UPD_DONE) +#define F_I_PVT_UPD_DONE V_I_PVT_UPD_DONE(1U) + +#define S_I_PHY_UPD_TRIG 1 +#define V_I_PHY_UPD_TRIG(x) ((x) << S_I_PHY_UPD_TRIG) +#define F_I_PHY_UPD_TRIG V_I_PHY_UPD_TRIG(1U) + +#define S_I_PHY_UPD_DONE 0 +#define V_I_PHY_UPD_DONE(x) ((x) << S_I_PHY_UPD_DONE) +#define F_I_PHY_UPD_DONE V_I_PHY_UPD_DONE(1U) + +#define A_MC_PCTL_PHYTUPDON 0x6508 + +#define S_PHY_T_UPDON 0 +#define M_PHY_T_UPDON 0xffU +#define V_PHY_T_UPDON(x) ((x) << S_PHY_T_UPDON) +#define G_PHY_T_UPDON(x) (((x) >> S_PHY_T_UPDON) & M_PHY_T_UPDON) + +#define A_MC_PCTL_PHYTUPDDLY 0x650c + +#define S_PHY_T_UPDDLY 0 +#define M_PHY_T_UPDDLY 0xfU +#define V_PHY_T_UPDDLY(x) ((x) << S_PHY_T_UPDDLY) +#define G_PHY_T_UPDDLY(x) (((x) >> S_PHY_T_UPDDLY) & M_PHY_T_UPDDLY) + +#define A_MC_PCTL_PVTTUPON 0x6510 + +#define S_PVT_T_UPDON 0 +#define M_PVT_T_UPDON 0xffU +#define V_PVT_T_UPDON(x) ((x) << S_PVT_T_UPDON) +#define G_PVT_T_UPDON(x) (((x) >> S_PVT_T_UPDON) & M_PVT_T_UPDON) + +#define A_MC_PCTL_PVTTUPDDLY 0x6514 + +#define S_PVT_T_UPDDLY 0 +#define M_PVT_T_UPDDLY 0xfU +#define V_PVT_T_UPDDLY(x) ((x) << S_PVT_T_UPDDLY) +#define G_PVT_T_UPDDLY(x) (((x) >> S_PVT_T_UPDDLY) & M_PVT_T_UPDDLY) + +#define A_MC_PCTL_PHYPVTUPDI 0x6518 + +#define S_PHYPVT_T_UPDI 0 +#define M_PHYPVT_T_UPDI 0xffU +#define V_PHYPVT_T_UPDI(x) ((x) << S_PHYPVT_T_UPDI) +#define G_PHYPVT_T_UPDI(x) (((x) >> S_PHYPVT_T_UPDI) & M_PHYPVT_T_UPDI) + +#define A_MC_PCTL_PHYIOCRV1 0x651c + +#define S_BYTE_OE_CTL 16 +#define M_BYTE_OE_CTL 0x3U +#define V_BYTE_OE_CTL(x) ((x) << S_BYTE_OE_CTL) +#define G_BYTE_OE_CTL(x) (((x) >> S_BYTE_OE_CTL) & M_BYTE_OE_CTL) + +#define S_DYN_SOC_ODT_ALAT 12 +#define M_DYN_SOC_ODT_ALAT 0xfU +#define V_DYN_SOC_ODT_ALAT(x) ((x) << S_DYN_SOC_ODT_ALAT) +#define G_DYN_SOC_ODT_ALAT(x) (((x) >> S_DYN_SOC_ODT_ALAT) & M_DYN_SOC_ODT_ALAT) + +#define S_DYN_SOC_ODT_ATEN 8 +#define M_DYN_SOC_ODT_ATEN 0x3U +#define V_DYN_SOC_ODT_ATEN(x) ((x) << S_DYN_SOC_ODT_ATEN) +#define G_DYN_SOC_ODT_ATEN(x) (((x) >> S_DYN_SOC_ODT_ATEN) & M_DYN_SOC_ODT_ATEN) + +#define S_DYN_SOC_ODT 2 +#define V_DYN_SOC_ODT(x) ((x) << S_DYN_SOC_ODT) +#define F_DYN_SOC_ODT V_DYN_SOC_ODT(1U) + +#define S_SOC_ODT_EN 0 +#define V_SOC_ODT_EN(x) ((x) << S_SOC_ODT_EN) +#define F_SOC_ODT_EN V_SOC_ODT_EN(1U) + +#define A_MC_PCTL_PHYTUPDWAIT 0x6520 + +#define S_PHY_T_UPDWAIT 0 +#define M_PHY_T_UPDWAIT 0x3fU +#define V_PHY_T_UPDWAIT(x) ((x) << S_PHY_T_UPDWAIT) +#define G_PHY_T_UPDWAIT(x) (((x) >> S_PHY_T_UPDWAIT) & M_PHY_T_UPDWAIT) + +#define A_MC_PCTL_PVTTUPDWAIT 0x6524 + +#define S_PVT_T_UPDWAIT 0 +#define M_PVT_T_UPDWAIT 0x3fU +#define V_PVT_T_UPDWAIT(x) ((x) << S_PVT_T_UPDWAIT) +#define G_PVT_T_UPDWAIT(x) (((x) >> S_PVT_T_UPDWAIT) & M_PVT_T_UPDWAIT) + +#define A_MC_DDR3PHYAC_GCR 0x6a00 + +#define S_WLRANK 8 +#define M_WLRANK 0x3U +#define V_WLRANK(x) ((x) << S_WLRANK) +#define G_WLRANK(x) (((x) >> S_WLRANK) & M_WLRANK) + +#define S_FDEPTH 6 +#define M_FDEPTH 0x3U +#define V_FDEPTH(x) ((x) << S_FDEPTH) +#define G_FDEPTH(x) (((x) >> S_FDEPTH) & M_FDEPTH) + +#define S_LPFDEPTH 4 +#define M_LPFDEPTH 0x3U +#define V_LPFDEPTH(x) ((x) << S_LPFDEPTH) +#define G_LPFDEPTH(x) (((x) >> S_LPFDEPTH) & M_LPFDEPTH) + +#define S_LPFEN 3 +#define V_LPFEN(x) ((x) << S_LPFEN) +#define F_LPFEN V_LPFEN(1U) + +#define S_WL 2 +#define V_WL(x) ((x) << S_WL) +#define F_WL V_WL(1U) + +#define S_CAL 1 +#define V_CAL(x) ((x) << S_CAL) +#define F_CAL V_CAL(1U) + +#define S_MDLEN 0 +#define V_MDLEN(x) ((x) << S_MDLEN) +#define F_MDLEN V_MDLEN(1U) + +#define A_MC_DDR3PHYAC_RCR0 0x6a04 + +#define S_OCPONR 8 +#define V_OCPONR(x) ((x) << S_OCPONR) +#define F_OCPONR V_OCPONR(1U) + +#define S_OCPOND 7 +#define V_OCPOND(x) ((x) << S_OCPOND) +#define F_OCPOND V_OCPOND(1U) + +#define S_OCOEN 6 +#define V_OCOEN(x) ((x) << S_OCOEN) +#define F_OCOEN V_OCOEN(1U) + +#define S_CKEPONR 5 +#define V_CKEPONR(x) ((x) << S_CKEPONR) +#define F_CKEPONR V_CKEPONR(1U) + +#define S_CKEPOND 4 +#define V_CKEPOND(x) ((x) << S_CKEPOND) +#define F_CKEPOND V_CKEPOND(1U) + +#define S_CKEOEN 3 +#define V_CKEOEN(x) ((x) << S_CKEOEN) +#define F_CKEOEN V_CKEOEN(1U) + +#define S_CKPONR 2 +#define V_CKPONR(x) ((x) << S_CKPONR) +#define F_CKPONR V_CKPONR(1U) + +#define S_CKPOND 1 +#define V_CKPOND(x) ((x) << S_CKPOND) +#define F_CKPOND V_CKPOND(1U) + +#define S_CKOEN 0 +#define V_CKOEN(x) ((x) << S_CKOEN) +#define F_CKOEN V_CKOEN(1U) + +#define A_MC_DDR3PHYAC_ACCR 0x6a14 + +#define S_ACPONR 8 +#define V_ACPONR(x) ((x) << S_ACPONR) +#define F_ACPONR V_ACPONR(1U) + +#define S_ACPOND 7 +#define V_ACPOND(x) ((x) << S_ACPOND) +#define F_ACPOND V_ACPOND(1U) + +#define S_ACOEN 6 +#define V_ACOEN(x) ((x) << S_ACOEN) +#define F_ACOEN V_ACOEN(1U) + +#define S_CK5PONR 5 +#define V_CK5PONR(x) ((x) << S_CK5PONR) +#define F_CK5PONR V_CK5PONR(1U) + +#define S_CK5POND 4 +#define V_CK5POND(x) ((x) << S_CK5POND) +#define F_CK5POND V_CK5POND(1U) + +#define S_CK5OEN 3 +#define V_CK5OEN(x) ((x) << S_CK5OEN) +#define F_CK5OEN V_CK5OEN(1U) + +#define S_CK4PONR 2 +#define V_CK4PONR(x) ((x) << S_CK4PONR) +#define F_CK4PONR V_CK4PONR(1U) + +#define S_CK4POND 1 +#define V_CK4POND(x) ((x) << S_CK4POND) +#define F_CK4POND V_CK4POND(1U) + +#define S_CK4OEN 0 +#define V_CK4OEN(x) ((x) << S_CK4OEN) +#define F_CK4OEN V_CK4OEN(1U) + +#define A_MC_DDR3PHYAC_GSR 0x6a18 + +#define S_WLERR 4 +#define V_WLERR(x) ((x) << S_WLERR) +#define F_WLERR V_WLERR(1U) + +#define S_INIT 3 +#define V_INIT(x) ((x) << S_INIT) +#define F_INIT V_INIT(1U) + +#define S_ACCAL 0 +#define V_ACCAL(x) ((x) << S_ACCAL) +#define F_ACCAL V_ACCAL(1U) + +#define A_MC_DDR3PHYAC_ECSR 0x6a1c + +#define S_WLDEC 1 +#define V_WLDEC(x) ((x) << S_WLDEC) +#define F_WLDEC V_WLDEC(1U) + +#define S_WLINC 0 +#define V_WLINC(x) ((x) << S_WLINC) +#define F_WLINC V_WLINC(1U) + +#define A_MC_DDR3PHYAC_OCSR 0x6a20 +#define A_MC_DDR3PHYAC_MDIPR 0x6a24 + +#define S_PRD 0 +#define M_PRD 0x3ffU +#define V_PRD(x) ((x) << S_PRD) +#define G_PRD(x) (((x) >> S_PRD) & M_PRD) + +#define A_MC_DDR3PHYAC_MDTPR 0x6a28 +#define A_MC_DDR3PHYAC_MDPPR0 0x6a2c +#define A_MC_DDR3PHYAC_MDPPR1 0x6a30 +#define A_MC_DDR3PHYAC_PMBDR0 0x6a34 + +#define S_DFLTDLY 0 +#define M_DFLTDLY 0x7fU +#define V_DFLTDLY(x) ((x) << S_DFLTDLY) +#define G_DFLTDLY(x) (((x) >> S_DFLTDLY) & M_DFLTDLY) + +#define A_MC_DDR3PHYAC_PMBDR1 0x6a38 +#define A_MC_DDR3PHYAC_ACR 0x6a60 + +#define S_TSEL 9 +#define V_TSEL(x) ((x) << S_TSEL) +#define F_TSEL V_TSEL(1U) + +#define S_ISEL 7 +#define M_ISEL 0x3U +#define V_ISEL(x) ((x) << S_ISEL) +#define G_ISEL(x) (((x) >> S_ISEL) & M_ISEL) + +#define S_CALBYP 2 +#define V_CALBYP(x) ((x) << S_CALBYP) +#define F_CALBYP V_CALBYP(1U) + +#define S_SDRSELINV 1 +#define V_SDRSELINV(x) ((x) << S_SDRSELINV) +#define F_SDRSELINV V_SDRSELINV(1U) + +#define S_CKINV 0 +#define V_CKINV(x) ((x) << S_CKINV) +#define F_CKINV V_CKINV(1U) + +#define A_MC_DDR3PHYAC_PSCR 0x6a64 + +#define S_PSCALE 0 +#define M_PSCALE 0x3ffU +#define V_PSCALE(x) ((x) << S_PSCALE) +#define G_PSCALE(x) (((x) >> S_PSCALE) & M_PSCALE) + +#define A_MC_DDR3PHYAC_PRCR 0x6a68 + +#define S_PHYINIT 9 +#define V_PHYINIT(x) ((x) << S_PHYINIT) +#define F_PHYINIT V_PHYINIT(1U) + +#define S_PHYHRST 7 +#define V_PHYHRST(x) ((x) << S_PHYHRST) +#define F_PHYHRST V_PHYHRST(1U) + +#define S_RSTCLKS 3 +#define M_RSTCLKS 0xfU +#define V_RSTCLKS(x) ((x) << S_RSTCLKS) +#define G_RSTCLKS(x) (((x) >> S_RSTCLKS) & M_RSTCLKS) + +#define S_PLLPD 2 +#define V_PLLPD(x) ((x) << S_PLLPD) +#define F_PLLPD V_PLLPD(1U) + +#define S_PLLRST 1 +#define V_PLLRST(x) ((x) << S_PLLRST) +#define F_PLLRST V_PLLRST(1U) + +#define S_PHYRST 0 +#define V_PHYRST(x) ((x) << S_PHYRST) +#define F_PHYRST V_PHYRST(1U) + +#define A_MC_DDR3PHYAC_PLLCR0 0x6a6c + +#define S_RSTCXKS 4 +#define M_RSTCXKS 0x1fU +#define V_RSTCXKS(x) ((x) << S_RSTCXKS) +#define G_RSTCXKS(x) (((x) >> S_RSTCXKS) & M_RSTCXKS) + +#define S_ICPSEL 3 +#define V_ICPSEL(x) ((x) << S_ICPSEL) +#define F_ICPSEL V_ICPSEL(1U) + +#define S_TESTA 0 +#define M_TESTA 0x7U +#define V_TESTA(x) ((x) << S_TESTA) +#define G_TESTA(x) (((x) >> S_TESTA) & M_TESTA) + +#define A_MC_DDR3PHYAC_PLLCR1 0x6a70 + +#define S_BYPASS 9 +#define V_BYPASS(x) ((x) << S_BYPASS) +#define F_BYPASS V_BYPASS(1U) + +#define S_BDIV 3 +#define M_BDIV 0x3U +#define V_BDIV(x) ((x) << S_BDIV) +#define G_BDIV(x) (((x) >> S_BDIV) & M_BDIV) + +#define S_TESTD 0 +#define M_TESTD 0x7U +#define V_TESTD(x) ((x) << S_TESTD) +#define G_TESTD(x) (((x) >> S_TESTD) & M_TESTD) + +#define A_MC_DDR3PHYAC_CLKENR 0x6a78 + +#define S_CKCLKEN 3 +#define M_CKCLKEN 0x3fU +#define V_CKCLKEN(x) ((x) << S_CKCLKEN) +#define G_CKCLKEN(x) (((x) >> S_CKCLKEN) & M_CKCLKEN) + +#define S_HDRCLKEN 2 +#define V_HDRCLKEN(x) ((x) << S_HDRCLKEN) +#define F_HDRCLKEN V_HDRCLKEN(1U) + +#define S_SDRCLKEN 1 +#define V_SDRCLKEN(x) ((x) << S_SDRCLKEN) +#define F_SDRCLKEN V_SDRCLKEN(1U) + +#define S_DDRCLKEN 0 +#define V_DDRCLKEN(x) ((x) << S_DDRCLKEN) +#define F_DDRCLKEN V_DDRCLKEN(1U) + +#define A_MC_DDR3PHYDATX8_GCR 0x6b00 + +#define S_PONR 6 +#define V_PONR(x) ((x) << S_PONR) +#define F_PONR V_PONR(1U) + +#define S_POND 5 +#define V_POND(x) ((x) << S_POND) +#define F_POND V_POND(1U) + +#define S_RDBDVT 4 +#define V_RDBDVT(x) ((x) << S_RDBDVT) +#define F_RDBDVT V_RDBDVT(1U) + +#define S_WDBDVT 3 +#define V_WDBDVT(x) ((x) << S_WDBDVT) +#define F_WDBDVT V_WDBDVT(1U) + +#define S_RDSDVT 2 +#define V_RDSDVT(x) ((x) << S_RDSDVT) +#define F_RDSDVT V_RDSDVT(1U) + +#define S_WDSDVT 1 +#define V_WDSDVT(x) ((x) << S_WDSDVT) +#define F_WDSDVT V_WDSDVT(1U) + +#define S_WLSDVT 0 +#define V_WLSDVT(x) ((x) << S_WLSDVT) +#define F_WLSDVT V_WLSDVT(1U) + +#define A_MC_DDR3PHYDATX8_WDSDR 0x6b04 + +#define S_WDSDR_DLY 0 +#define M_WDSDR_DLY 0x3ffU +#define V_WDSDR_DLY(x) ((x) << S_WDSDR_DLY) +#define G_WDSDR_DLY(x) (((x) >> S_WDSDR_DLY) & M_WDSDR_DLY) + +#define A_MC_DDR3PHYDATX8_WLDPR 0x6b08 +#define A_MC_DDR3PHYDATX8_WLDR 0x6b0c + +#define S_WL_DLY 0 +#define M_WL_DLY 0x3ffU +#define V_WL_DLY(x) ((x) << S_WL_DLY) +#define G_WL_DLY(x) (((x) >> S_WL_DLY) & M_WL_DLY) + +#define A_MC_DDR3PHYDATX8_WDBDR0 0x6b1c + +#define S_DLY 0 +#define M_DLY 0x7fU +#define V_DLY(x) ((x) << S_DLY) +#define G_DLY(x) (((x) >> S_DLY) & M_DLY) + +#define A_MC_DDR3PHYDATX8_WDBDR1 0x6b20 +#define A_MC_DDR3PHYDATX8_WDBDR2 0x6b24 +#define A_MC_DDR3PHYDATX8_WDBDR3 0x6b28 +#define A_MC_DDR3PHYDATX8_WDBDR4 0x6b2c +#define A_MC_DDR3PHYDATX8_WDBDR5 0x6b30 +#define A_MC_DDR3PHYDATX8_WDBDR6 0x6b34 +#define A_MC_DDR3PHYDATX8_WDBDR7 0x6b38 +#define A_MC_DDR3PHYDATX8_WDBDR8 0x6b3c +#define A_MC_DDR3PHYDATX8_WDBDMR 0x6b40 + +#define S_MAXDLY 0 +#define M_MAXDLY 0x7fU +#define V_MAXDLY(x) ((x) << S_MAXDLY) +#define G_MAXDLY(x) (((x) >> S_MAXDLY) & M_MAXDLY) + +#define A_MC_DDR3PHYDATX8_RDSDR 0x6b44 + +#define S_RDSDR_DLY 0 +#define M_RDSDR_DLY 0x3ffU +#define V_RDSDR_DLY(x) ((x) << S_RDSDR_DLY) +#define G_RDSDR_DLY(x) (((x) >> S_RDSDR_DLY) & M_RDSDR_DLY) + +#define A_MC_DDR3PHYDATX8_RDBDR0 0x6b48 +#define A_MC_DDR3PHYDATX8_RDBDR1 0x6b4c +#define A_MC_DDR3PHYDATX8_RDBDR2 0x6b50 +#define A_MC_DDR3PHYDATX8_RDBDR3 0x6b54 +#define A_MC_DDR3PHYDATX8_RDBDR4 0x6b58 +#define A_MC_DDR3PHYDATX8_RDBDR5 0x6b5c +#define A_MC_DDR3PHYDATX8_RDBDR6 0x6b60 +#define A_MC_DDR3PHYDATX8_RDBDR7 0x6b64 +#define A_MC_DDR3PHYDATX8_RDBDMR 0x6b68 +#define A_MC_DDR3PHYDATX8_PMBDR0 0x6b6c +#define A_MC_DDR3PHYDATX8_PMBDR1 0x6b70 +#define A_MC_DDR3PHYDATX8_PMBDR2 0x6b74 +#define A_MC_DDR3PHYDATX8_PMBDR3 0x6b78 +#define A_MC_DDR3PHYDATX8_WDBDPR 0x6b7c + +#define S_DP_DLY 0 +#define M_DP_DLY 0x1ffU +#define V_DP_DLY(x) ((x) << S_DP_DLY) +#define G_DP_DLY(x) (((x) >> S_DP_DLY) & M_DP_DLY) + +#define A_MC_DDR3PHYDATX8_RDBDPR 0x6b80 +#define A_MC_DDR3PHYDATX8_GSR 0x6b84 + +#define S_WLDONE 3 +#define V_WLDONE(x) ((x) << S_WLDONE) +#define F_WLDONE V_WLDONE(1U) + +#define S_WLCAL 2 +#define V_WLCAL(x) ((x) << S_WLCAL) +#define F_WLCAL V_WLCAL(1U) + +#define S_READ 1 +#define V_READ(x) ((x) << S_READ) +#define F_READ V_READ(1U) + +#define S_RDQSCAL 0 +#define V_RDQSCAL(x) ((x) << S_RDQSCAL) +#define F_RDQSCAL V_RDQSCAL(1U) + +#define A_MC_DDR3PHYDATX8_ACR 0x6bf0 + +#define S_PHYHSRST 9 +#define V_PHYHSRST(x) ((x) << S_PHYHSRST) +#define F_PHYHSRST V_PHYHSRST(1U) + +#define S_WLSTEP 8 +#define V_WLSTEP(x) ((x) << S_WLSTEP) +#define F_WLSTEP V_WLSTEP(1U) + +#define S_SDR_SEL_INV 2 +#define V_SDR_SEL_INV(x) ((x) << S_SDR_SEL_INV) +#define F_SDR_SEL_INV V_SDR_SEL_INV(1U) + +#define S_DDRSELINV 1 +#define V_DDRSELINV(x) ((x) << S_DDRSELINV) +#define F_DDRSELINV V_DDRSELINV(1U) + +#define S_DSINV 0 +#define V_DSINV(x) ((x) << S_DSINV) +#define F_DSINV V_DSINV(1U) + +#define A_MC_DDR3PHYDATX8_RSR 0x6bf4 + +#define S_WLRANKSEL 9 +#define V_WLRANKSEL(x) ((x) << S_WLRANKSEL) +#define F_WLRANKSEL V_WLRANKSEL(1U) + +#define S_RANK 0 +#define M_RANK 0x3U +#define V_RANK(x) ((x) << S_RANK) +#define G_RANK(x) (((x) >> S_RANK) & M_RANK) + +#define A_MC_DDR3PHYDATX8_CLKENR 0x6bf8 + +#define S_DTOSEL 8 +#define M_DTOSEL 0x3U +#define V_DTOSEL(x) ((x) << S_DTOSEL) +#define G_DTOSEL(x) (((x) >> S_DTOSEL) & M_DTOSEL) + +#define A_MC_PVT_REG_CALIBRATE_CTL 0x7400 +#define A_MC_PVT_REG_UPDATE_CTL 0x7404 +#define A_MC_PVT_REG_LAST_MEASUREMENT 0x7408 +#define A_MC_PVT_REG_DRVN 0x740c +#define A_MC_PVT_REG_DRVP 0x7410 +#define A_MC_PVT_REG_TERMN 0x7414 +#define A_MC_PVT_REG_TERMP 0x7418 +#define A_MC_PVT_REG_THRESHOLD 0x741c +#define A_MC_PVT_REG_IN_TERMP 0x7420 +#define A_MC_PVT_REG_IN_TERMN 0x7424 +#define A_MC_PVT_REG_IN_DRVP 0x7428 +#define A_MC_PVT_REG_IN_DRVN 0x742c +#define A_MC_PVT_REG_OUT_TERMP 0x7430 +#define A_MC_PVT_REG_OUT_TERMN 0x7434 +#define A_MC_PVT_REG_OUT_DRVP 0x7438 +#define A_MC_PVT_REG_OUT_DRVN 0x743c +#define A_MC_PVT_REG_HISTORY_TERMP 0x7440 +#define A_MC_PVT_REG_HISTORY_TERMN 0x7444 +#define A_MC_PVT_REG_HISTORY_DRVP 0x7448 +#define A_MC_PVT_REG_HISTORY_DRVN 0x744c +#define A_MC_PVT_REG_SAMPLE_WAIT_CLKS 0x7450 +#define A_MC_DDRPHY_RST_CTRL 0x7500 + +#define S_DDRIO_ENABLE 1 +#define V_DDRIO_ENABLE(x) ((x) << S_DDRIO_ENABLE) +#define F_DDRIO_ENABLE V_DDRIO_ENABLE(1U) + +#define S_PHY_RST_N 0 +#define V_PHY_RST_N(x) ((x) << S_PHY_RST_N) +#define F_PHY_RST_N V_PHY_RST_N(1U) + +#define A_MC_PERFORMANCE_CTRL 0x7504 + +#define S_STALL_CHK_BIT 2 +#define V_STALL_CHK_BIT(x) ((x) << S_STALL_CHK_BIT) +#define F_STALL_CHK_BIT V_STALL_CHK_BIT(1U) + +#define S_DDR3_BRC_MODE 1 +#define V_DDR3_BRC_MODE(x) ((x) << S_DDR3_BRC_MODE) +#define F_DDR3_BRC_MODE V_DDR3_BRC_MODE(1U) + +#define S_RMW_PERF_CTRL 0 +#define V_RMW_PERF_CTRL(x) ((x) << S_RMW_PERF_CTRL) +#define F_RMW_PERF_CTRL V_RMW_PERF_CTRL(1U) + +#define A_MC_ECC_CTRL 0x7508 + +#define S_ECC_BYPASS_BIST 1 +#define V_ECC_BYPASS_BIST(x) ((x) << S_ECC_BYPASS_BIST) +#define F_ECC_BYPASS_BIST V_ECC_BYPASS_BIST(1U) + +#define S_ECC_DISABLE 0 +#define V_ECC_DISABLE(x) ((x) << S_ECC_DISABLE) +#define F_ECC_DISABLE V_ECC_DISABLE(1U) + +#define A_MC_PAR_ENABLE 0x750c + +#define S_ECC_UE_PAR_ENABLE 3 +#define V_ECC_UE_PAR_ENABLE(x) ((x) << S_ECC_UE_PAR_ENABLE) +#define F_ECC_UE_PAR_ENABLE V_ECC_UE_PAR_ENABLE(1U) + +#define S_ECC_CE_PAR_ENABLE 2 +#define V_ECC_CE_PAR_ENABLE(x) ((x) << S_ECC_CE_PAR_ENABLE) +#define F_ECC_CE_PAR_ENABLE V_ECC_CE_PAR_ENABLE(1U) + +#define S_PERR_REG_INT_ENABLE 1 +#define V_PERR_REG_INT_ENABLE(x) ((x) << S_PERR_REG_INT_ENABLE) +#define F_PERR_REG_INT_ENABLE V_PERR_REG_INT_ENABLE(1U) + +#define S_PERR_BLK_INT_ENABLE 0 +#define V_PERR_BLK_INT_ENABLE(x) ((x) << S_PERR_BLK_INT_ENABLE) +#define F_PERR_BLK_INT_ENABLE V_PERR_BLK_INT_ENABLE(1U) + +#define A_MC_PAR_CAUSE 0x7510 + +#define S_ECC_UE_PAR_CAUSE 3 +#define V_ECC_UE_PAR_CAUSE(x) ((x) << S_ECC_UE_PAR_CAUSE) +#define F_ECC_UE_PAR_CAUSE V_ECC_UE_PAR_CAUSE(1U) + +#define S_ECC_CE_PAR_CAUSE 2 +#define V_ECC_CE_PAR_CAUSE(x) ((x) << S_ECC_CE_PAR_CAUSE) +#define F_ECC_CE_PAR_CAUSE V_ECC_CE_PAR_CAUSE(1U) + +#define S_FIFOR_PAR_CAUSE 1 +#define V_FIFOR_PAR_CAUSE(x) ((x) << S_FIFOR_PAR_CAUSE) +#define F_FIFOR_PAR_CAUSE V_FIFOR_PAR_CAUSE(1U) + +#define S_RDATA_FIFOR_PAR_CAUSE 0 +#define V_RDATA_FIFOR_PAR_CAUSE(x) ((x) << S_RDATA_FIFOR_PAR_CAUSE) +#define F_RDATA_FIFOR_PAR_CAUSE V_RDATA_FIFOR_PAR_CAUSE(1U) + +#define A_MC_INT_ENABLE 0x7514 + +#define S_ECC_UE_INT_ENABLE 2 +#define V_ECC_UE_INT_ENABLE(x) ((x) << S_ECC_UE_INT_ENABLE) +#define F_ECC_UE_INT_ENABLE V_ECC_UE_INT_ENABLE(1U) + +#define S_ECC_CE_INT_ENABLE 1 +#define V_ECC_CE_INT_ENABLE(x) ((x) << S_ECC_CE_INT_ENABLE) +#define F_ECC_CE_INT_ENABLE V_ECC_CE_INT_ENABLE(1U) + +#define S_PERR_INT_ENABLE 0 +#define V_PERR_INT_ENABLE(x) ((x) << S_PERR_INT_ENABLE) +#define F_PERR_INT_ENABLE V_PERR_INT_ENABLE(1U) + +#define A_MC_INT_CAUSE 0x7518 + +#define S_ECC_UE_INT_CAUSE 2 +#define V_ECC_UE_INT_CAUSE(x) ((x) << S_ECC_UE_INT_CAUSE) +#define F_ECC_UE_INT_CAUSE V_ECC_UE_INT_CAUSE(1U) + +#define S_ECC_CE_INT_CAUSE 1 +#define V_ECC_CE_INT_CAUSE(x) ((x) << S_ECC_CE_INT_CAUSE) +#define F_ECC_CE_INT_CAUSE V_ECC_CE_INT_CAUSE(1U) + +#define S_PERR_INT_CAUSE 0 +#define V_PERR_INT_CAUSE(x) ((x) << S_PERR_INT_CAUSE) +#define F_PERR_INT_CAUSE V_PERR_INT_CAUSE(1U) + +#define A_MC_ECC_STATUS 0x751c + +#define S_ECC_CECNT 16 +#define M_ECC_CECNT 0xffffU +#define V_ECC_CECNT(x) ((x) << S_ECC_CECNT) +#define G_ECC_CECNT(x) (((x) >> S_ECC_CECNT) & M_ECC_CECNT) + +#define S_ECC_UECNT 0 +#define M_ECC_UECNT 0xffffU +#define V_ECC_UECNT(x) ((x) << S_ECC_UECNT) +#define G_ECC_UECNT(x) (((x) >> S_ECC_UECNT) & M_ECC_UECNT) + +#define A_MC_PHY_CTRL 0x7520 + +#define S_CTLPHYRR 0 +#define V_CTLPHYRR(x) ((x) << S_CTLPHYRR) +#define F_CTLPHYRR V_CTLPHYRR(1U) + +#define A_MC_STATIC_CFG_STATUS 0x7524 + +#define S_STATIC_MODE 9 +#define V_STATIC_MODE(x) ((x) << S_STATIC_MODE) +#define F_STATIC_MODE V_STATIC_MODE(1U) + +#define S_STATIC_DEN 6 +#define M_STATIC_DEN 0x7U +#define V_STATIC_DEN(x) ((x) << S_STATIC_DEN) +#define G_STATIC_DEN(x) (((x) >> S_STATIC_DEN) & M_STATIC_DEN) + +#define S_STATIC_ORG 5 +#define V_STATIC_ORG(x) ((x) << S_STATIC_ORG) +#define F_STATIC_ORG V_STATIC_ORG(1U) + +#define S_STATIC_RKS 4 +#define V_STATIC_RKS(x) ((x) << S_STATIC_RKS) +#define F_STATIC_RKS V_STATIC_RKS(1U) + +#define S_STATIC_WIDTH 1 +#define M_STATIC_WIDTH 0x7U +#define V_STATIC_WIDTH(x) ((x) << S_STATIC_WIDTH) +#define G_STATIC_WIDTH(x) (((x) >> S_STATIC_WIDTH) & M_STATIC_WIDTH) + +#define S_STATIC_SLOW 0 +#define V_STATIC_SLOW(x) ((x) << S_STATIC_SLOW) +#define F_STATIC_SLOW V_STATIC_SLOW(1U) + +#define A_MC_CORE_PCTL_STAT 0x7528 + +#define S_PCTL_ACCESS_STAT 0 +#define M_PCTL_ACCESS_STAT 0x7U +#define V_PCTL_ACCESS_STAT(x) ((x) << S_PCTL_ACCESS_STAT) +#define G_PCTL_ACCESS_STAT(x) (((x) >> S_PCTL_ACCESS_STAT) & M_PCTL_ACCESS_STAT) + +#define A_MC_DEBUG_CNT 0x752c + +#define S_WDATA_OCNT 8 +#define M_WDATA_OCNT 0x1fU +#define V_WDATA_OCNT(x) ((x) << S_WDATA_OCNT) +#define G_WDATA_OCNT(x) (((x) >> S_WDATA_OCNT) & M_WDATA_OCNT) + +#define S_RDATA_OCNT 0 +#define M_RDATA_OCNT 0x1fU +#define V_RDATA_OCNT(x) ((x) << S_RDATA_OCNT) +#define G_RDATA_OCNT(x) (((x) >> S_RDATA_OCNT) & M_RDATA_OCNT) + +#define A_MC_BONUS 0x7530 +#define A_MC_BIST_CMD 0x7600 + +#define S_START_BIST 31 +#define V_START_BIST(x) ((x) << S_START_BIST) +#define F_START_BIST V_START_BIST(1U) + +#define S_BIST_CMD_GAP 8 +#define M_BIST_CMD_GAP 0xffU +#define V_BIST_CMD_GAP(x) ((x) << S_BIST_CMD_GAP) +#define G_BIST_CMD_GAP(x) (((x) >> S_BIST_CMD_GAP) & M_BIST_CMD_GAP) + +#define S_BIST_OPCODE 0 +#define M_BIST_OPCODE 0x3U +#define V_BIST_OPCODE(x) ((x) << S_BIST_OPCODE) +#define G_BIST_OPCODE(x) (((x) >> S_BIST_OPCODE) & M_BIST_OPCODE) + +#define A_MC_BIST_CMD_ADDR 0x7604 +#define A_MC_BIST_CMD_LEN 0x7608 +#define A_MC_BIST_DATA_PATTERN 0x760c + +#define S_BIST_DATA_TYPE 0 +#define M_BIST_DATA_TYPE 0xfU +#define V_BIST_DATA_TYPE(x) ((x) << S_BIST_DATA_TYPE) +#define G_BIST_DATA_TYPE(x) (((x) >> S_BIST_DATA_TYPE) & M_BIST_DATA_TYPE) + +#define A_MC_BIST_USER_WDATA0 0x7614 +#define A_MC_BIST_USER_WDATA1 0x7618 +#define A_MC_BIST_USER_WDATA2 0x761c + +#define S_USER_DATA2 0 +#define M_USER_DATA2 0xffU +#define V_USER_DATA2(x) ((x) << S_USER_DATA2) +#define G_USER_DATA2(x) (((x) >> S_USER_DATA2) & M_USER_DATA2) + +#define A_MC_BIST_NUM_ERR 0x7680 +#define A_MC_BIST_ERR_FIRST_ADDR 0x7684 +#define A_MC_BIST_STATUS_RDATA 0x7688 + +/* registers for module MA */ +#define MA_BASE_ADDR 0x7700 + +#define A_MA_CLIENT0_RD_LATENCY_THRESHOLD 0x7700 + +#define S_THRESHOLD1 17 +#define M_THRESHOLD1 0x7fffU +#define V_THRESHOLD1(x) ((x) << S_THRESHOLD1) +#define G_THRESHOLD1(x) (((x) >> S_THRESHOLD1) & M_THRESHOLD1) + +#define S_THRESHOLD1_EN 16 +#define V_THRESHOLD1_EN(x) ((x) << S_THRESHOLD1_EN) +#define F_THRESHOLD1_EN V_THRESHOLD1_EN(1U) + +#define S_THRESHOLD0 1 +#define M_THRESHOLD0 0x7fffU +#define V_THRESHOLD0(x) ((x) << S_THRESHOLD0) +#define G_THRESHOLD0(x) (((x) >> S_THRESHOLD0) & M_THRESHOLD0) + +#define S_THRESHOLD0_EN 0 +#define V_THRESHOLD0_EN(x) ((x) << S_THRESHOLD0_EN) +#define F_THRESHOLD0_EN V_THRESHOLD0_EN(1U) + +#define A_MA_CLIENT0_WR_LATENCY_THRESHOLD 0x7704 +#define A_MA_CLIENT1_RD_LATENCY_THRESHOLD 0x7708 +#define A_MA_CLIENT1_WR_LATENCY_THRESHOLD 0x770c +#define A_MA_CLIENT2_RD_LATENCY_THRESHOLD 0x7710 +#define A_MA_CLIENT2_WR_LATENCY_THRESHOLD 0x7714 +#define A_MA_CLIENT3_RD_LATENCY_THRESHOLD 0x7718 +#define A_MA_CLIENT3_WR_LATENCY_THRESHOLD 0x771c +#define A_MA_CLIENT4_RD_LATENCY_THRESHOLD 0x7720 +#define A_MA_CLIENT4_WR_LATENCY_THRESHOLD 0x7724 +#define A_MA_CLIENT5_RD_LATENCY_THRESHOLD 0x7728 +#define A_MA_CLIENT5_WR_LATENCY_THRESHOLD 0x772c +#define A_MA_CLIENT6_RD_LATENCY_THRESHOLD 0x7730 +#define A_MA_CLIENT6_WR_LATENCY_THRESHOLD 0x7734 +#define A_MA_CLIENT7_RD_LATENCY_THRESHOLD 0x7738 +#define A_MA_CLIENT7_WR_LATENCY_THRESHOLD 0x773c +#define A_MA_CLIENT8_RD_LATENCY_THRESHOLD 0x7740 +#define A_MA_CLIENT8_WR_LATENCY_THRESHOLD 0x7744 +#define A_MA_CLIENT9_RD_LATENCY_THRESHOLD 0x7748 +#define A_MA_CLIENT9_WR_LATENCY_THRESHOLD 0x774c +#define A_MA_CLIENT10_RD_LATENCY_THRESHOLD 0x7750 +#define A_MA_CLIENT10_WR_LATENCY_THRESHOLD 0x7754 +#define A_MA_CLIENT11_RD_LATENCY_THRESHOLD 0x7758 +#define A_MA_CLIENT11_WR_LATENCY_THRESHOLD 0x775c +#define A_MA_CLIENT12_RD_LATENCY_THRESHOLD 0x7760 +#define A_MA_CLIENT12_WR_LATENCY_THRESHOLD 0x7764 +#define A_MA_SGE_TH0_DEBUG_CNT 0x7768 + +#define S_DBG_READ_DATA_CNT 24 +#define M_DBG_READ_DATA_CNT 0xffU +#define V_DBG_READ_DATA_CNT(x) ((x) << S_DBG_READ_DATA_CNT) +#define G_DBG_READ_DATA_CNT(x) (((x) >> S_DBG_READ_DATA_CNT) & M_DBG_READ_DATA_CNT) + +#define S_DBG_READ_REQ_CNT 16 +#define M_DBG_READ_REQ_CNT 0xffU +#define V_DBG_READ_REQ_CNT(x) ((x) << S_DBG_READ_REQ_CNT) +#define G_DBG_READ_REQ_CNT(x) (((x) >> S_DBG_READ_REQ_CNT) & M_DBG_READ_REQ_CNT) + +#define S_DBG_WRITE_DATA_CNT 8 +#define M_DBG_WRITE_DATA_CNT 0xffU +#define V_DBG_WRITE_DATA_CNT(x) ((x) << S_DBG_WRITE_DATA_CNT) +#define G_DBG_WRITE_DATA_CNT(x) (((x) >> S_DBG_WRITE_DATA_CNT) & M_DBG_WRITE_DATA_CNT) + +#define S_DBG_WRITE_REQ_CNT 0 +#define M_DBG_WRITE_REQ_CNT 0xffU +#define V_DBG_WRITE_REQ_CNT(x) ((x) << S_DBG_WRITE_REQ_CNT) +#define G_DBG_WRITE_REQ_CNT(x) (((x) >> S_DBG_WRITE_REQ_CNT) & M_DBG_WRITE_REQ_CNT) + +#define A_MA_SGE_TH1_DEBUG_CNT 0x776c +#define A_MA_ULPTX_DEBUG_CNT 0x7770 +#define A_MA_ULPRX_DEBUG_CNT 0x7774 +#define A_MA_ULPTXRX_DEBUG_CNT 0x7778 +#define A_MA_TP_TH0_DEBUG_CNT 0x777c +#define A_MA_TP_TH1_DEBUG_CNT 0x7780 +#define A_MA_LE_DEBUG_CNT 0x7784 +#define A_MA_CIM_DEBUG_CNT 0x7788 +#define A_MA_PCIE_DEBUG_CNT 0x778c +#define A_MA_PMTX_DEBUG_CNT 0x7790 +#define A_MA_PMRX_DEBUG_CNT 0x7794 +#define A_MA_HMA_DEBUG_CNT 0x7798 +#define A_MA_EDRAM0_BAR 0x77c0 + +#define S_EDRAM0_BASE 16 +#define M_EDRAM0_BASE 0xfffU +#define V_EDRAM0_BASE(x) ((x) << S_EDRAM0_BASE) +#define G_EDRAM0_BASE(x) (((x) >> S_EDRAM0_BASE) & M_EDRAM0_BASE) + +#define S_EDRAM0_SIZE 0 +#define M_EDRAM0_SIZE 0xfffU +#define V_EDRAM0_SIZE(x) ((x) << S_EDRAM0_SIZE) +#define G_EDRAM0_SIZE(x) (((x) >> S_EDRAM0_SIZE) & M_EDRAM0_SIZE) + +#define A_MA_EDRAM1_BAR 0x77c4 + +#define S_EDRAM1_BASE 16 +#define M_EDRAM1_BASE 0xfffU +#define V_EDRAM1_BASE(x) ((x) << S_EDRAM1_BASE) +#define G_EDRAM1_BASE(x) (((x) >> S_EDRAM1_BASE) & M_EDRAM1_BASE) + +#define S_EDRAM1_SIZE 0 +#define M_EDRAM1_SIZE 0xfffU +#define V_EDRAM1_SIZE(x) ((x) << S_EDRAM1_SIZE) +#define G_EDRAM1_SIZE(x) (((x) >> S_EDRAM1_SIZE) & M_EDRAM1_SIZE) + +#define A_MA_EXT_MEMORY_BAR 0x77c8 + +#define S_EXT_MEM_BASE 16 +#define M_EXT_MEM_BASE 0xfffU +#define V_EXT_MEM_BASE(x) ((x) << S_EXT_MEM_BASE) +#define G_EXT_MEM_BASE(x) (((x) >> S_EXT_MEM_BASE) & M_EXT_MEM_BASE) + +#define S_EXT_MEM_SIZE 0 +#define M_EXT_MEM_SIZE 0xfffU +#define V_EXT_MEM_SIZE(x) ((x) << S_EXT_MEM_SIZE) +#define G_EXT_MEM_SIZE(x) (((x) >> S_EXT_MEM_SIZE) & M_EXT_MEM_SIZE) + +#define A_MA_EXT_MEMORY0_BAR 0x77c8 + +#define S_EXT_MEM0_BASE 16 +#define M_EXT_MEM0_BASE 0xfffU +#define V_EXT_MEM0_BASE(x) ((x) << S_EXT_MEM0_BASE) +#define G_EXT_MEM0_BASE(x) (((x) >> S_EXT_MEM0_BASE) & M_EXT_MEM0_BASE) + +#define S_EXT_MEM0_SIZE 0 +#define M_EXT_MEM0_SIZE 0xfffU +#define V_EXT_MEM0_SIZE(x) ((x) << S_EXT_MEM0_SIZE) +#define G_EXT_MEM0_SIZE(x) (((x) >> S_EXT_MEM0_SIZE) & M_EXT_MEM0_SIZE) + +#define A_MA_HOST_MEMORY_BAR 0x77cc + +#define S_HMA_BASE 16 +#define M_HMA_BASE 0xfffU +#define V_HMA_BASE(x) ((x) << S_HMA_BASE) +#define G_HMA_BASE(x) (((x) >> S_HMA_BASE) & M_HMA_BASE) + +#define S_HMA_SIZE 0 +#define M_HMA_SIZE 0xfffU +#define V_HMA_SIZE(x) ((x) << S_HMA_SIZE) +#define G_HMA_SIZE(x) (((x) >> S_HMA_SIZE) & M_HMA_SIZE) + +#define A_MA_EXT_MEM_PAGE_SIZE 0x77d0 + +#define S_BRC_MODE 2 +#define V_BRC_MODE(x) ((x) << S_BRC_MODE) +#define F_BRC_MODE V_BRC_MODE(1U) + +#define S_EXT_MEM_PAGE_SIZE 0 +#define M_EXT_MEM_PAGE_SIZE 0x3U +#define V_EXT_MEM_PAGE_SIZE(x) ((x) << S_EXT_MEM_PAGE_SIZE) +#define G_EXT_MEM_PAGE_SIZE(x) (((x) >> S_EXT_MEM_PAGE_SIZE) & M_EXT_MEM_PAGE_SIZE) + +#define S_BRC_MODE1 6 +#define V_BRC_MODE1(x) ((x) << S_BRC_MODE1) +#define F_BRC_MODE1 V_BRC_MODE1(1U) + +#define S_EXT_MEM_PAGE_SIZE1 4 +#define M_EXT_MEM_PAGE_SIZE1 0x3U +#define V_EXT_MEM_PAGE_SIZE1(x) ((x) << S_EXT_MEM_PAGE_SIZE1) +#define G_EXT_MEM_PAGE_SIZE1(x) (((x) >> S_EXT_MEM_PAGE_SIZE1) & M_EXT_MEM_PAGE_SIZE1) + +#define A_MA_ARB_CTRL 0x77d4 + +#define S_DIS_PAGE_HINT 1 +#define V_DIS_PAGE_HINT(x) ((x) << S_DIS_PAGE_HINT) +#define F_DIS_PAGE_HINT V_DIS_PAGE_HINT(1U) + +#define S_DIS_ADV_ARB 0 +#define V_DIS_ADV_ARB(x) ((x) << S_DIS_ADV_ARB) +#define F_DIS_ADV_ARB V_DIS_ADV_ARB(1U) + +#define S_DIS_BANK_FAIR 2 +#define V_DIS_BANK_FAIR(x) ((x) << S_DIS_BANK_FAIR) +#define F_DIS_BANK_FAIR V_DIS_BANK_FAIR(1U) + +#define A_MA_TARGET_MEM_ENABLE 0x77d8 + +#define S_HMA_ENABLE 3 +#define V_HMA_ENABLE(x) ((x) << S_HMA_ENABLE) +#define F_HMA_ENABLE V_HMA_ENABLE(1U) + +#define S_EXT_MEM_ENABLE 2 +#define V_EXT_MEM_ENABLE(x) ((x) << S_EXT_MEM_ENABLE) +#define F_EXT_MEM_ENABLE V_EXT_MEM_ENABLE(1U) + +#define S_EDRAM1_ENABLE 1 +#define V_EDRAM1_ENABLE(x) ((x) << S_EDRAM1_ENABLE) +#define F_EDRAM1_ENABLE V_EDRAM1_ENABLE(1U) + +#define S_EDRAM0_ENABLE 0 +#define V_EDRAM0_ENABLE(x) ((x) << S_EDRAM0_ENABLE) +#define F_EDRAM0_ENABLE V_EDRAM0_ENABLE(1U) + +#define S_HMA_MUX 5 +#define V_HMA_MUX(x) ((x) << S_HMA_MUX) +#define F_HMA_MUX V_HMA_MUX(1U) + +#define S_EXT_MEM1_ENABLE 4 +#define V_EXT_MEM1_ENABLE(x) ((x) << S_EXT_MEM1_ENABLE) +#define F_EXT_MEM1_ENABLE V_EXT_MEM1_ENABLE(1U) + +#define S_EXT_MEM0_ENABLE 2 +#define V_EXT_MEM0_ENABLE(x) ((x) << S_EXT_MEM0_ENABLE) +#define F_EXT_MEM0_ENABLE V_EXT_MEM0_ENABLE(1U) + +#define A_MA_INT_ENABLE 0x77dc + +#define S_MEM_PERR_INT_ENABLE 1 +#define V_MEM_PERR_INT_ENABLE(x) ((x) << S_MEM_PERR_INT_ENABLE) +#define F_MEM_PERR_INT_ENABLE V_MEM_PERR_INT_ENABLE(1U) + +#define S_MEM_WRAP_INT_ENABLE 0 +#define V_MEM_WRAP_INT_ENABLE(x) ((x) << S_MEM_WRAP_INT_ENABLE) +#define F_MEM_WRAP_INT_ENABLE V_MEM_WRAP_INT_ENABLE(1U) + +#define S_MEM_TO_INT_ENABLE 2 +#define V_MEM_TO_INT_ENABLE(x) ((x) << S_MEM_TO_INT_ENABLE) +#define F_MEM_TO_INT_ENABLE V_MEM_TO_INT_ENABLE(1U) + +#define A_MA_INT_CAUSE 0x77e0 + +#define S_MEM_PERR_INT_CAUSE 1 +#define V_MEM_PERR_INT_CAUSE(x) ((x) << S_MEM_PERR_INT_CAUSE) +#define F_MEM_PERR_INT_CAUSE V_MEM_PERR_INT_CAUSE(1U) + +#define S_MEM_WRAP_INT_CAUSE 0 +#define V_MEM_WRAP_INT_CAUSE(x) ((x) << S_MEM_WRAP_INT_CAUSE) +#define F_MEM_WRAP_INT_CAUSE V_MEM_WRAP_INT_CAUSE(1U) + +#define S_MEM_TO_INT_CAUSE 2 +#define V_MEM_TO_INT_CAUSE(x) ((x) << S_MEM_TO_INT_CAUSE) +#define F_MEM_TO_INT_CAUSE V_MEM_TO_INT_CAUSE(1U) + +#define A_MA_INT_WRAP_STATUS 0x77e4 + +#define S_MEM_WRAP_ADDRESS 4 +#define M_MEM_WRAP_ADDRESS 0xfffffffU +#define V_MEM_WRAP_ADDRESS(x) ((x) << S_MEM_WRAP_ADDRESS) +#define G_MEM_WRAP_ADDRESS(x) (((x) >> S_MEM_WRAP_ADDRESS) & M_MEM_WRAP_ADDRESS) + +#define S_MEM_WRAP_CLIENT_NUM 0 +#define M_MEM_WRAP_CLIENT_NUM 0xfU +#define V_MEM_WRAP_CLIENT_NUM(x) ((x) << S_MEM_WRAP_CLIENT_NUM) +#define G_MEM_WRAP_CLIENT_NUM(x) (((x) >> S_MEM_WRAP_CLIENT_NUM) & M_MEM_WRAP_CLIENT_NUM) + +#define A_MA_TP_THREAD1_MAPPER 0x77e8 + +#define S_TP_THREAD1_EN 0 +#define M_TP_THREAD1_EN 0xffU +#define V_TP_THREAD1_EN(x) ((x) << S_TP_THREAD1_EN) +#define G_TP_THREAD1_EN(x) (((x) >> S_TP_THREAD1_EN) & M_TP_THREAD1_EN) + +#define A_MA_SGE_THREAD1_MAPPER 0x77ec + +#define S_SGE_THREAD1_EN 0 +#define M_SGE_THREAD1_EN 0xffU +#define V_SGE_THREAD1_EN(x) ((x) << S_SGE_THREAD1_EN) +#define G_SGE_THREAD1_EN(x) (((x) >> S_SGE_THREAD1_EN) & M_SGE_THREAD1_EN) + +#define A_MA_PARITY_ERROR_ENABLE 0x77f0 + +#define S_TP_DMARBT_PAR_ERROR_EN 31 +#define V_TP_DMARBT_PAR_ERROR_EN(x) ((x) << S_TP_DMARBT_PAR_ERROR_EN) +#define F_TP_DMARBT_PAR_ERROR_EN V_TP_DMARBT_PAR_ERROR_EN(1U) + +#define S_LOGIC_FIFO_PAR_ERROR_EN 30 +#define V_LOGIC_FIFO_PAR_ERROR_EN(x) ((x) << S_LOGIC_FIFO_PAR_ERROR_EN) +#define F_LOGIC_FIFO_PAR_ERROR_EN V_LOGIC_FIFO_PAR_ERROR_EN(1U) + +#define S_ARB3_PAR_WRQUEUE_ERROR_EN 29 +#define V_ARB3_PAR_WRQUEUE_ERROR_EN(x) ((x) << S_ARB3_PAR_WRQUEUE_ERROR_EN) +#define F_ARB3_PAR_WRQUEUE_ERROR_EN V_ARB3_PAR_WRQUEUE_ERROR_EN(1U) + +#define S_ARB2_PAR_WRQUEUE_ERROR_EN 28 +#define V_ARB2_PAR_WRQUEUE_ERROR_EN(x) ((x) << S_ARB2_PAR_WRQUEUE_ERROR_EN) +#define F_ARB2_PAR_WRQUEUE_ERROR_EN V_ARB2_PAR_WRQUEUE_ERROR_EN(1U) + +#define S_ARB1_PAR_WRQUEUE_ERROR_EN 27 +#define V_ARB1_PAR_WRQUEUE_ERROR_EN(x) ((x) << S_ARB1_PAR_WRQUEUE_ERROR_EN) +#define F_ARB1_PAR_WRQUEUE_ERROR_EN V_ARB1_PAR_WRQUEUE_ERROR_EN(1U) + +#define S_ARB0_PAR_WRQUEUE_ERROR_EN 26 +#define V_ARB0_PAR_WRQUEUE_ERROR_EN(x) ((x) << S_ARB0_PAR_WRQUEUE_ERROR_EN) +#define F_ARB0_PAR_WRQUEUE_ERROR_EN V_ARB0_PAR_WRQUEUE_ERROR_EN(1U) + +#define S_ARB3_PAR_RDQUEUE_ERROR_EN 25 +#define V_ARB3_PAR_RDQUEUE_ERROR_EN(x) ((x) << S_ARB3_PAR_RDQUEUE_ERROR_EN) +#define F_ARB3_PAR_RDQUEUE_ERROR_EN V_ARB3_PAR_RDQUEUE_ERROR_EN(1U) + +#define S_ARB2_PAR_RDQUEUE_ERROR_EN 24 +#define V_ARB2_PAR_RDQUEUE_ERROR_EN(x) ((x) << S_ARB2_PAR_RDQUEUE_ERROR_EN) +#define F_ARB2_PAR_RDQUEUE_ERROR_EN V_ARB2_PAR_RDQUEUE_ERROR_EN(1U) + +#define S_ARB1_PAR_RDQUEUE_ERROR_EN 23 +#define V_ARB1_PAR_RDQUEUE_ERROR_EN(x) ((x) << S_ARB1_PAR_RDQUEUE_ERROR_EN) +#define F_ARB1_PAR_RDQUEUE_ERROR_EN V_ARB1_PAR_RDQUEUE_ERROR_EN(1U) + +#define S_ARB0_PAR_RDQUEUE_ERROR_EN 22 +#define V_ARB0_PAR_RDQUEUE_ERROR_EN(x) ((x) << S_ARB0_PAR_RDQUEUE_ERROR_EN) +#define F_ARB0_PAR_RDQUEUE_ERROR_EN V_ARB0_PAR_RDQUEUE_ERROR_EN(1U) + +#define S_CL10_PAR_WRQUEUE_ERROR_EN 21 +#define V_CL10_PAR_WRQUEUE_ERROR_EN(x) ((x) << S_CL10_PAR_WRQUEUE_ERROR_EN) +#define F_CL10_PAR_WRQUEUE_ERROR_EN V_CL10_PAR_WRQUEUE_ERROR_EN(1U) + +#define S_CL9_PAR_WRQUEUE_ERROR_EN 20 +#define V_CL9_PAR_WRQUEUE_ERROR_EN(x) ((x) << S_CL9_PAR_WRQUEUE_ERROR_EN) +#define F_CL9_PAR_WRQUEUE_ERROR_EN V_CL9_PAR_WRQUEUE_ERROR_EN(1U) + +#define S_CL8_PAR_WRQUEUE_ERROR_EN 19 +#define V_CL8_PAR_WRQUEUE_ERROR_EN(x) ((x) << S_CL8_PAR_WRQUEUE_ERROR_EN) +#define F_CL8_PAR_WRQUEUE_ERROR_EN V_CL8_PAR_WRQUEUE_ERROR_EN(1U) + +#define S_CL7_PAR_WRQUEUE_ERROR_EN 18 +#define V_CL7_PAR_WRQUEUE_ERROR_EN(x) ((x) << S_CL7_PAR_WRQUEUE_ERROR_EN) +#define F_CL7_PAR_WRQUEUE_ERROR_EN V_CL7_PAR_WRQUEUE_ERROR_EN(1U) + +#define S_CL6_PAR_WRQUEUE_ERROR_EN 17 +#define V_CL6_PAR_WRQUEUE_ERROR_EN(x) ((x) << S_CL6_PAR_WRQUEUE_ERROR_EN) +#define F_CL6_PAR_WRQUEUE_ERROR_EN V_CL6_PAR_WRQUEUE_ERROR_EN(1U) + +#define S_CL5_PAR_WRQUEUE_ERROR_EN 16 +#define V_CL5_PAR_WRQUEUE_ERROR_EN(x) ((x) << S_CL5_PAR_WRQUEUE_ERROR_EN) +#define F_CL5_PAR_WRQUEUE_ERROR_EN V_CL5_PAR_WRQUEUE_ERROR_EN(1U) + +#define S_CL4_PAR_WRQUEUE_ERROR_EN 15 +#define V_CL4_PAR_WRQUEUE_ERROR_EN(x) ((x) << S_CL4_PAR_WRQUEUE_ERROR_EN) +#define F_CL4_PAR_WRQUEUE_ERROR_EN V_CL4_PAR_WRQUEUE_ERROR_EN(1U) + +#define S_CL3_PAR_WRQUEUE_ERROR_EN 14 +#define V_CL3_PAR_WRQUEUE_ERROR_EN(x) ((x) << S_CL3_PAR_WRQUEUE_ERROR_EN) +#define F_CL3_PAR_WRQUEUE_ERROR_EN V_CL3_PAR_WRQUEUE_ERROR_EN(1U) + +#define S_CL2_PAR_WRQUEUE_ERROR_EN 13 +#define V_CL2_PAR_WRQUEUE_ERROR_EN(x) ((x) << S_CL2_PAR_WRQUEUE_ERROR_EN) +#define F_CL2_PAR_WRQUEUE_ERROR_EN V_CL2_PAR_WRQUEUE_ERROR_EN(1U) + +#define S_CL1_PAR_WRQUEUE_ERROR_EN 12 +#define V_CL1_PAR_WRQUEUE_ERROR_EN(x) ((x) << S_CL1_PAR_WRQUEUE_ERROR_EN) +#define F_CL1_PAR_WRQUEUE_ERROR_EN V_CL1_PAR_WRQUEUE_ERROR_EN(1U) + +#define S_CL0_PAR_WRQUEUE_ERROR_EN 11 +#define V_CL0_PAR_WRQUEUE_ERROR_EN(x) ((x) << S_CL0_PAR_WRQUEUE_ERROR_EN) +#define F_CL0_PAR_WRQUEUE_ERROR_EN V_CL0_PAR_WRQUEUE_ERROR_EN(1U) + +#define S_CL10_PAR_RDQUEUE_ERROR_EN 10 +#define V_CL10_PAR_RDQUEUE_ERROR_EN(x) ((x) << S_CL10_PAR_RDQUEUE_ERROR_EN) +#define F_CL10_PAR_RDQUEUE_ERROR_EN V_CL10_PAR_RDQUEUE_ERROR_EN(1U) + +#define S_CL9_PAR_RDQUEUE_ERROR_EN 9 +#define V_CL9_PAR_RDQUEUE_ERROR_EN(x) ((x) << S_CL9_PAR_RDQUEUE_ERROR_EN) +#define F_CL9_PAR_RDQUEUE_ERROR_EN V_CL9_PAR_RDQUEUE_ERROR_EN(1U) + +#define S_CL8_PAR_RDQUEUE_ERROR_EN 8 +#define V_CL8_PAR_RDQUEUE_ERROR_EN(x) ((x) << S_CL8_PAR_RDQUEUE_ERROR_EN) +#define F_CL8_PAR_RDQUEUE_ERROR_EN V_CL8_PAR_RDQUEUE_ERROR_EN(1U) + +#define S_CL7_PAR_RDQUEUE_ERROR_EN 7 +#define V_CL7_PAR_RDQUEUE_ERROR_EN(x) ((x) << S_CL7_PAR_RDQUEUE_ERROR_EN) +#define F_CL7_PAR_RDQUEUE_ERROR_EN V_CL7_PAR_RDQUEUE_ERROR_EN(1U) + +#define S_CL6_PAR_RDQUEUE_ERROR_EN 6 +#define V_CL6_PAR_RDQUEUE_ERROR_EN(x) ((x) << S_CL6_PAR_RDQUEUE_ERROR_EN) +#define F_CL6_PAR_RDQUEUE_ERROR_EN V_CL6_PAR_RDQUEUE_ERROR_EN(1U) + +#define S_CL5_PAR_RDQUEUE_ERROR_EN 5 +#define V_CL5_PAR_RDQUEUE_ERROR_EN(x) ((x) << S_CL5_PAR_RDQUEUE_ERROR_EN) +#define F_CL5_PAR_RDQUEUE_ERROR_EN V_CL5_PAR_RDQUEUE_ERROR_EN(1U) + +#define S_CL4_PAR_RDQUEUE_ERROR_EN 4 +#define V_CL4_PAR_RDQUEUE_ERROR_EN(x) ((x) << S_CL4_PAR_RDQUEUE_ERROR_EN) +#define F_CL4_PAR_RDQUEUE_ERROR_EN V_CL4_PAR_RDQUEUE_ERROR_EN(1U) + +#define S_CL3_PAR_RDQUEUE_ERROR_EN 3 +#define V_CL3_PAR_RDQUEUE_ERROR_EN(x) ((x) << S_CL3_PAR_RDQUEUE_ERROR_EN) +#define F_CL3_PAR_RDQUEUE_ERROR_EN V_CL3_PAR_RDQUEUE_ERROR_EN(1U) + +#define S_CL2_PAR_RDQUEUE_ERROR_EN 2 +#define V_CL2_PAR_RDQUEUE_ERROR_EN(x) ((x) << S_CL2_PAR_RDQUEUE_ERROR_EN) +#define F_CL2_PAR_RDQUEUE_ERROR_EN V_CL2_PAR_RDQUEUE_ERROR_EN(1U) + +#define S_CL1_PAR_RDQUEUE_ERROR_EN 1 +#define V_CL1_PAR_RDQUEUE_ERROR_EN(x) ((x) << S_CL1_PAR_RDQUEUE_ERROR_EN) +#define F_CL1_PAR_RDQUEUE_ERROR_EN V_CL1_PAR_RDQUEUE_ERROR_EN(1U) + +#define S_CL0_PAR_RDQUEUE_ERROR_EN 0 +#define V_CL0_PAR_RDQUEUE_ERROR_EN(x) ((x) << S_CL0_PAR_RDQUEUE_ERROR_EN) +#define F_CL0_PAR_RDQUEUE_ERROR_EN V_CL0_PAR_RDQUEUE_ERROR_EN(1U) + +#define A_MA_PARITY_ERROR_ENABLE1 0x77f0 +#define A_MA_PARITY_ERROR_STATUS 0x77f4 + +#define S_TP_DMARBT_PAR_ERROR 31 +#define V_TP_DMARBT_PAR_ERROR(x) ((x) << S_TP_DMARBT_PAR_ERROR) +#define F_TP_DMARBT_PAR_ERROR V_TP_DMARBT_PAR_ERROR(1U) + +#define S_LOGIC_FIFO_PAR_ERROR 30 +#define V_LOGIC_FIFO_PAR_ERROR(x) ((x) << S_LOGIC_FIFO_PAR_ERROR) +#define F_LOGIC_FIFO_PAR_ERROR V_LOGIC_FIFO_PAR_ERROR(1U) + +#define S_ARB3_PAR_WRQUEUE_ERROR 29 +#define V_ARB3_PAR_WRQUEUE_ERROR(x) ((x) << S_ARB3_PAR_WRQUEUE_ERROR) +#define F_ARB3_PAR_WRQUEUE_ERROR V_ARB3_PAR_WRQUEUE_ERROR(1U) + +#define S_ARB2_PAR_WRQUEUE_ERROR 28 +#define V_ARB2_PAR_WRQUEUE_ERROR(x) ((x) << S_ARB2_PAR_WRQUEUE_ERROR) +#define F_ARB2_PAR_WRQUEUE_ERROR V_ARB2_PAR_WRQUEUE_ERROR(1U) + +#define S_ARB1_PAR_WRQUEUE_ERROR 27 +#define V_ARB1_PAR_WRQUEUE_ERROR(x) ((x) << S_ARB1_PAR_WRQUEUE_ERROR) +#define F_ARB1_PAR_WRQUEUE_ERROR V_ARB1_PAR_WRQUEUE_ERROR(1U) + +#define S_ARB0_PAR_WRQUEUE_ERROR 26 +#define V_ARB0_PAR_WRQUEUE_ERROR(x) ((x) << S_ARB0_PAR_WRQUEUE_ERROR) +#define F_ARB0_PAR_WRQUEUE_ERROR V_ARB0_PAR_WRQUEUE_ERROR(1U) + +#define S_ARB3_PAR_RDQUEUE_ERROR 25 +#define V_ARB3_PAR_RDQUEUE_ERROR(x) ((x) << S_ARB3_PAR_RDQUEUE_ERROR) +#define F_ARB3_PAR_RDQUEUE_ERROR V_ARB3_PAR_RDQUEUE_ERROR(1U) + +#define S_ARB2_PAR_RDQUEUE_ERROR 24 +#define V_ARB2_PAR_RDQUEUE_ERROR(x) ((x) << S_ARB2_PAR_RDQUEUE_ERROR) +#define F_ARB2_PAR_RDQUEUE_ERROR V_ARB2_PAR_RDQUEUE_ERROR(1U) + +#define S_ARB1_PAR_RDQUEUE_ERROR 23 +#define V_ARB1_PAR_RDQUEUE_ERROR(x) ((x) << S_ARB1_PAR_RDQUEUE_ERROR) +#define F_ARB1_PAR_RDQUEUE_ERROR V_ARB1_PAR_RDQUEUE_ERROR(1U) + +#define S_ARB0_PAR_RDQUEUE_ERROR 22 +#define V_ARB0_PAR_RDQUEUE_ERROR(x) ((x) << S_ARB0_PAR_RDQUEUE_ERROR) +#define F_ARB0_PAR_RDQUEUE_ERROR V_ARB0_PAR_RDQUEUE_ERROR(1U) + +#define S_CL10_PAR_WRQUEUE_ERROR 21 +#define V_CL10_PAR_WRQUEUE_ERROR(x) ((x) << S_CL10_PAR_WRQUEUE_ERROR) +#define F_CL10_PAR_WRQUEUE_ERROR V_CL10_PAR_WRQUEUE_ERROR(1U) + +#define S_CL9_PAR_WRQUEUE_ERROR 20 +#define V_CL9_PAR_WRQUEUE_ERROR(x) ((x) << S_CL9_PAR_WRQUEUE_ERROR) +#define F_CL9_PAR_WRQUEUE_ERROR V_CL9_PAR_WRQUEUE_ERROR(1U) + +#define S_CL8_PAR_WRQUEUE_ERROR 19 +#define V_CL8_PAR_WRQUEUE_ERROR(x) ((x) << S_CL8_PAR_WRQUEUE_ERROR) +#define F_CL8_PAR_WRQUEUE_ERROR V_CL8_PAR_WRQUEUE_ERROR(1U) + +#define S_CL7_PAR_WRQUEUE_ERROR 18 +#define V_CL7_PAR_WRQUEUE_ERROR(x) ((x) << S_CL7_PAR_WRQUEUE_ERROR) +#define F_CL7_PAR_WRQUEUE_ERROR V_CL7_PAR_WRQUEUE_ERROR(1U) + +#define S_CL6_PAR_WRQUEUE_ERROR 17 +#define V_CL6_PAR_WRQUEUE_ERROR(x) ((x) << S_CL6_PAR_WRQUEUE_ERROR) +#define F_CL6_PAR_WRQUEUE_ERROR V_CL6_PAR_WRQUEUE_ERROR(1U) + +#define S_CL5_PAR_WRQUEUE_ERROR 16 +#define V_CL5_PAR_WRQUEUE_ERROR(x) ((x) << S_CL5_PAR_WRQUEUE_ERROR) +#define F_CL5_PAR_WRQUEUE_ERROR V_CL5_PAR_WRQUEUE_ERROR(1U) + +#define S_CL4_PAR_WRQUEUE_ERROR 15 +#define V_CL4_PAR_WRQUEUE_ERROR(x) ((x) << S_CL4_PAR_WRQUEUE_ERROR) +#define F_CL4_PAR_WRQUEUE_ERROR V_CL4_PAR_WRQUEUE_ERROR(1U) + +#define S_CL3_PAR_WRQUEUE_ERROR 14 +#define V_CL3_PAR_WRQUEUE_ERROR(x) ((x) << S_CL3_PAR_WRQUEUE_ERROR) +#define F_CL3_PAR_WRQUEUE_ERROR V_CL3_PAR_WRQUEUE_ERROR(1U) + +#define S_CL2_PAR_WRQUEUE_ERROR 13 +#define V_CL2_PAR_WRQUEUE_ERROR(x) ((x) << S_CL2_PAR_WRQUEUE_ERROR) +#define F_CL2_PAR_WRQUEUE_ERROR V_CL2_PAR_WRQUEUE_ERROR(1U) + +#define S_CL1_PAR_WRQUEUE_ERROR 12 +#define V_CL1_PAR_WRQUEUE_ERROR(x) ((x) << S_CL1_PAR_WRQUEUE_ERROR) +#define F_CL1_PAR_WRQUEUE_ERROR V_CL1_PAR_WRQUEUE_ERROR(1U) + +#define S_CL0_PAR_WRQUEUE_ERROR 11 +#define V_CL0_PAR_WRQUEUE_ERROR(x) ((x) << S_CL0_PAR_WRQUEUE_ERROR) +#define F_CL0_PAR_WRQUEUE_ERROR V_CL0_PAR_WRQUEUE_ERROR(1U) + +#define S_CL10_PAR_RDQUEUE_ERROR 10 +#define V_CL10_PAR_RDQUEUE_ERROR(x) ((x) << S_CL10_PAR_RDQUEUE_ERROR) +#define F_CL10_PAR_RDQUEUE_ERROR V_CL10_PAR_RDQUEUE_ERROR(1U) + +#define S_CL9_PAR_RDQUEUE_ERROR 9 +#define V_CL9_PAR_RDQUEUE_ERROR(x) ((x) << S_CL9_PAR_RDQUEUE_ERROR) +#define F_CL9_PAR_RDQUEUE_ERROR V_CL9_PAR_RDQUEUE_ERROR(1U) + +#define S_CL8_PAR_RDQUEUE_ERROR 8 +#define V_CL8_PAR_RDQUEUE_ERROR(x) ((x) << S_CL8_PAR_RDQUEUE_ERROR) +#define F_CL8_PAR_RDQUEUE_ERROR V_CL8_PAR_RDQUEUE_ERROR(1U) + +#define S_CL7_PAR_RDQUEUE_ERROR 7 +#define V_CL7_PAR_RDQUEUE_ERROR(x) ((x) << S_CL7_PAR_RDQUEUE_ERROR) +#define F_CL7_PAR_RDQUEUE_ERROR V_CL7_PAR_RDQUEUE_ERROR(1U) + +#define S_CL6_PAR_RDQUEUE_ERROR 6 +#define V_CL6_PAR_RDQUEUE_ERROR(x) ((x) << S_CL6_PAR_RDQUEUE_ERROR) +#define F_CL6_PAR_RDQUEUE_ERROR V_CL6_PAR_RDQUEUE_ERROR(1U) + +#define S_CL5_PAR_RDQUEUE_ERROR 5 +#define V_CL5_PAR_RDQUEUE_ERROR(x) ((x) << S_CL5_PAR_RDQUEUE_ERROR) +#define F_CL5_PAR_RDQUEUE_ERROR V_CL5_PAR_RDQUEUE_ERROR(1U) + +#define S_CL4_PAR_RDQUEUE_ERROR 4 +#define V_CL4_PAR_RDQUEUE_ERROR(x) ((x) << S_CL4_PAR_RDQUEUE_ERROR) +#define F_CL4_PAR_RDQUEUE_ERROR V_CL4_PAR_RDQUEUE_ERROR(1U) + +#define S_CL3_PAR_RDQUEUE_ERROR 3 +#define V_CL3_PAR_RDQUEUE_ERROR(x) ((x) << S_CL3_PAR_RDQUEUE_ERROR) +#define F_CL3_PAR_RDQUEUE_ERROR V_CL3_PAR_RDQUEUE_ERROR(1U) + +#define S_CL2_PAR_RDQUEUE_ERROR 2 +#define V_CL2_PAR_RDQUEUE_ERROR(x) ((x) << S_CL2_PAR_RDQUEUE_ERROR) +#define F_CL2_PAR_RDQUEUE_ERROR V_CL2_PAR_RDQUEUE_ERROR(1U) + +#define S_CL1_PAR_RDQUEUE_ERROR 1 +#define V_CL1_PAR_RDQUEUE_ERROR(x) ((x) << S_CL1_PAR_RDQUEUE_ERROR) +#define F_CL1_PAR_RDQUEUE_ERROR V_CL1_PAR_RDQUEUE_ERROR(1U) + +#define S_CL0_PAR_RDQUEUE_ERROR 0 +#define V_CL0_PAR_RDQUEUE_ERROR(x) ((x) << S_CL0_PAR_RDQUEUE_ERROR) +#define F_CL0_PAR_RDQUEUE_ERROR V_CL0_PAR_RDQUEUE_ERROR(1U) + +#define A_MA_PARITY_ERROR_STATUS1 0x77f4 +#define A_MA_SGE_PCIE_COHERANCY_CTRL 0x77f8 + +#define S_BONUS_REG 6 +#define M_BONUS_REG 0x3ffffffU +#define V_BONUS_REG(x) ((x) << S_BONUS_REG) +#define G_BONUS_REG(x) (((x) >> S_BONUS_REG) & M_BONUS_REG) + +#define S_COHERANCY_CMD_TYPE 4 +#define M_COHERANCY_CMD_TYPE 0x3U +#define V_COHERANCY_CMD_TYPE(x) ((x) << S_COHERANCY_CMD_TYPE) +#define G_COHERANCY_CMD_TYPE(x) (((x) >> S_COHERANCY_CMD_TYPE) & M_COHERANCY_CMD_TYPE) + +#define S_COHERANCY_THREAD_NUM 1 +#define M_COHERANCY_THREAD_NUM 0x7U +#define V_COHERANCY_THREAD_NUM(x) ((x) << S_COHERANCY_THREAD_NUM) +#define G_COHERANCY_THREAD_NUM(x) (((x) >> S_COHERANCY_THREAD_NUM) & M_COHERANCY_THREAD_NUM) + +#define S_COHERANCY_ENABLE 0 +#define V_COHERANCY_ENABLE(x) ((x) << S_COHERANCY_ENABLE) +#define F_COHERANCY_ENABLE V_COHERANCY_ENABLE(1U) + +#define A_MA_ERROR_ENABLE 0x77fc + +#define S_UE_ENABLE 0 +#define V_UE_ENABLE(x) ((x) << S_UE_ENABLE) +#define F_UE_ENABLE V_UE_ENABLE(1U) + +#define S_FUTURE_EXPANSION 1 +#define M_FUTURE_EXPANSION 0x7fffffffU +#define V_FUTURE_EXPANSION(x) ((x) << S_FUTURE_EXPANSION) +#define G_FUTURE_EXPANSION(x) (((x) >> S_FUTURE_EXPANSION) & M_FUTURE_EXPANSION) + +#define A_MA_PARITY_ERROR_ENABLE2 0x7800 + +#define S_ARB4_PAR_WRQUEUE_ERROR_EN 1 +#define V_ARB4_PAR_WRQUEUE_ERROR_EN(x) ((x) << S_ARB4_PAR_WRQUEUE_ERROR_EN) +#define F_ARB4_PAR_WRQUEUE_ERROR_EN V_ARB4_PAR_WRQUEUE_ERROR_EN(1U) + +#define S_ARB4_PAR_RDQUEUE_ERROR_EN 0 +#define V_ARB4_PAR_RDQUEUE_ERROR_EN(x) ((x) << S_ARB4_PAR_RDQUEUE_ERROR_EN) +#define F_ARB4_PAR_RDQUEUE_ERROR_EN V_ARB4_PAR_RDQUEUE_ERROR_EN(1U) + +#define A_MA_PARITY_ERROR_STATUS2 0x7804 + +#define S_ARB4_PAR_WRQUEUE_ERROR 1 +#define V_ARB4_PAR_WRQUEUE_ERROR(x) ((x) << S_ARB4_PAR_WRQUEUE_ERROR) +#define F_ARB4_PAR_WRQUEUE_ERROR V_ARB4_PAR_WRQUEUE_ERROR(1U) + +#define S_ARB4_PAR_RDQUEUE_ERROR 0 +#define V_ARB4_PAR_RDQUEUE_ERROR(x) ((x) << S_ARB4_PAR_RDQUEUE_ERROR) +#define F_ARB4_PAR_RDQUEUE_ERROR V_ARB4_PAR_RDQUEUE_ERROR(1U) + +#define A_MA_EXT_MEMORY1_BAR 0x7808 + +#define S_EXT_MEM1_BASE 16 +#define M_EXT_MEM1_BASE 0xfffU +#define V_EXT_MEM1_BASE(x) ((x) << S_EXT_MEM1_BASE) +#define G_EXT_MEM1_BASE(x) (((x) >> S_EXT_MEM1_BASE) & M_EXT_MEM1_BASE) + +#define S_EXT_MEM1_SIZE 0 +#define M_EXT_MEM1_SIZE 0xfffU +#define V_EXT_MEM1_SIZE(x) ((x) << S_EXT_MEM1_SIZE) +#define G_EXT_MEM1_SIZE(x) (((x) >> S_EXT_MEM1_SIZE) & M_EXT_MEM1_SIZE) + +#define A_MA_PMTX_THROTTLE 0x780c + +#define S_FL_ENABLE 31 +#define V_FL_ENABLE(x) ((x) << S_FL_ENABLE) +#define F_FL_ENABLE V_FL_ENABLE(1U) + +#define S_FL_LIMIT 0 +#define M_FL_LIMIT 0xffU +#define V_FL_LIMIT(x) ((x) << S_FL_LIMIT) +#define G_FL_LIMIT(x) (((x) >> S_FL_LIMIT) & M_FL_LIMIT) + +#define A_MA_PMRX_THROTTLE 0x7810 +#define A_MA_SGE_TH0_WRDATA_CNT 0x7814 +#define A_MA_SGE_TH1_WRDATA_CNT 0x7818 +#define A_MA_ULPTX_WRDATA_CNT 0x781c +#define A_MA_ULPRX_WRDATA_CNT 0x7820 +#define A_MA_ULPTXRX_WRDATA_CNT 0x7824 +#define A_MA_TP_TH0_WRDATA_CNT 0x7828 +#define A_MA_TP_TH1_WRDATA_CNT 0x782c +#define A_MA_LE_WRDATA_CNT 0x7830 +#define A_MA_CIM_WRDATA_CNT 0x7834 +#define A_MA_PCIE_WRDATA_CNT 0x7838 +#define A_MA_PMTX_WRDATA_CNT 0x783c +#define A_MA_PMRX_WRDATA_CNT 0x7840 +#define A_MA_HMA_WRDATA_CNT 0x7844 +#define A_MA_SGE_TH0_RDDATA_CNT 0x7848 +#define A_MA_SGE_TH1_RDDATA_CNT 0x784c +#define A_MA_ULPTX_RDDATA_CNT 0x7850 +#define A_MA_ULPRX_RDDATA_CNT 0x7854 +#define A_MA_ULPTXRX_RDDATA_CNT 0x7858 +#define A_MA_TP_TH0_RDDATA_CNT 0x785c +#define A_MA_TP_TH1_RDDATA_CNT 0x7860 +#define A_MA_LE_RDDATA_CNT 0x7864 +#define A_MA_CIM_RDDATA_CNT 0x7868 +#define A_MA_PCIE_RDDATA_CNT 0x786c +#define A_MA_PMTX_RDDATA_CNT 0x7870 +#define A_MA_PMRX_RDDATA_CNT 0x7874 +#define A_MA_HMA_RDDATA_CNT 0x7878 +#define A_MA_EDRAM0_WRDATA_CNT1 0x787c +#define A_MA_EDRAM0_WRDATA_CNT0 0x7880 +#define A_MA_EDRAM1_WRDATA_CNT1 0x7884 +#define A_MA_EDRAM1_WRDATA_CNT0 0x7888 +#define A_MA_EXT_MEMORY0_WRDATA_CNT1 0x788c +#define A_MA_EXT_MEMORY0_WRDATA_CNT0 0x7890 +#define A_MA_HOST_MEMORY_WRDATA_CNT1 0x7894 +#define A_MA_HOST_MEMORY_WRDATA_CNT0 0x7898 +#define A_MA_EXT_MEMORY1_WRDATA_CNT1 0x789c +#define A_MA_EXT_MEMORY1_WRDATA_CNT0 0x78a0 +#define A_MA_EDRAM0_RDDATA_CNT1 0x78a4 +#define A_MA_EDRAM0_RDDATA_CNT0 0x78a8 +#define A_MA_EDRAM1_RDDATA_CNT1 0x78ac +#define A_MA_EDRAM1_RDDATA_CNT0 0x78b0 +#define A_MA_EXT_MEMORY0_RDDATA_CNT1 0x78b4 +#define A_MA_EXT_MEMORY0_RDDATA_CNT0 0x78b8 +#define A_MA_HOST_MEMORY_RDDATA_CNT1 0x78bc +#define A_MA_HOST_MEMORY_RDDATA_CNT0 0x78c0 +#define A_MA_EXT_MEMORY1_RDDATA_CNT1 0x78c4 +#define A_MA_EXT_MEMORY1_RDDATA_CNT0 0x78c8 +#define A_MA_TIMEOUT_CFG 0x78cc + +#define S_CLR 31 +#define V_CLR(x) ((x) << S_CLR) +#define F_CLR V_CLR(1U) + +#define S_CNT_LOCK 30 +#define V_CNT_LOCK(x) ((x) << S_CNT_LOCK) +#define F_CNT_LOCK V_CNT_LOCK(1U) + +#define S_WRN 24 +#define V_WRN(x) ((x) << S_WRN) +#define F_WRN V_WRN(1U) + +#define S_DIR 23 +#define V_DIR(x) ((x) << S_DIR) +#define F_DIR V_DIR(1U) + +#define S_TO_BUS 22 +#define V_TO_BUS(x) ((x) << S_TO_BUS) +#define F_TO_BUS V_TO_BUS(1U) + +#define S_CLIENT 16 +#define M_CLIENT 0xfU +#define V_CLIENT(x) ((x) << S_CLIENT) +#define G_CLIENT(x) (((x) >> S_CLIENT) & M_CLIENT) + +#define S_DELAY 0 +#define M_DELAY 0xffffU +#define V_DELAY(x) ((x) << S_DELAY) +#define G_DELAY(x) (((x) >> S_DELAY) & M_DELAY) + +#define A_MA_TIMEOUT_CNT 0x78d0 + +#define S_CNT_VAL 0 +#define M_CNT_VAL 0xffffU +#define V_CNT_VAL(x) ((x) << S_CNT_VAL) +#define G_CNT_VAL(x) (((x) >> S_CNT_VAL) & M_CNT_VAL) + +#define A_MA_WRITE_TIMEOUT_ERROR_ENABLE 0x78d4 + +#define S_FUTURE_CEXPANSION 29 +#define M_FUTURE_CEXPANSION 0x7U +#define V_FUTURE_CEXPANSION(x) ((x) << S_FUTURE_CEXPANSION) +#define G_FUTURE_CEXPANSION(x) (((x) >> S_FUTURE_CEXPANSION) & M_FUTURE_CEXPANSION) + +#define S_CL12_WR_CMD_TO_EN 28 +#define V_CL12_WR_CMD_TO_EN(x) ((x) << S_CL12_WR_CMD_TO_EN) +#define F_CL12_WR_CMD_TO_EN V_CL12_WR_CMD_TO_EN(1U) + +#define S_CL11_WR_CMD_TO_EN 27 +#define V_CL11_WR_CMD_TO_EN(x) ((x) << S_CL11_WR_CMD_TO_EN) +#define F_CL11_WR_CMD_TO_EN V_CL11_WR_CMD_TO_EN(1U) + +#define S_CL10_WR_CMD_TO_EN 26 +#define V_CL10_WR_CMD_TO_EN(x) ((x) << S_CL10_WR_CMD_TO_EN) +#define F_CL10_WR_CMD_TO_EN V_CL10_WR_CMD_TO_EN(1U) + +#define S_CL9_WR_CMD_TO_EN 25 +#define V_CL9_WR_CMD_TO_EN(x) ((x) << S_CL9_WR_CMD_TO_EN) +#define F_CL9_WR_CMD_TO_EN V_CL9_WR_CMD_TO_EN(1U) + +#define S_CL8_WR_CMD_TO_EN 24 +#define V_CL8_WR_CMD_TO_EN(x) ((x) << S_CL8_WR_CMD_TO_EN) +#define F_CL8_WR_CMD_TO_EN V_CL8_WR_CMD_TO_EN(1U) + +#define S_CL7_WR_CMD_TO_EN 23 +#define V_CL7_WR_CMD_TO_EN(x) ((x) << S_CL7_WR_CMD_TO_EN) +#define F_CL7_WR_CMD_TO_EN V_CL7_WR_CMD_TO_EN(1U) + +#define S_CL6_WR_CMD_TO_EN 22 +#define V_CL6_WR_CMD_TO_EN(x) ((x) << S_CL6_WR_CMD_TO_EN) +#define F_CL6_WR_CMD_TO_EN V_CL6_WR_CMD_TO_EN(1U) + +#define S_CL5_WR_CMD_TO_EN 21 +#define V_CL5_WR_CMD_TO_EN(x) ((x) << S_CL5_WR_CMD_TO_EN) +#define F_CL5_WR_CMD_TO_EN V_CL5_WR_CMD_TO_EN(1U) + +#define S_CL4_WR_CMD_TO_EN 20 +#define V_CL4_WR_CMD_TO_EN(x) ((x) << S_CL4_WR_CMD_TO_EN) +#define F_CL4_WR_CMD_TO_EN V_CL4_WR_CMD_TO_EN(1U) + +#define S_CL3_WR_CMD_TO_EN 19 +#define V_CL3_WR_CMD_TO_EN(x) ((x) << S_CL3_WR_CMD_TO_EN) +#define F_CL3_WR_CMD_TO_EN V_CL3_WR_CMD_TO_EN(1U) + +#define S_CL2_WR_CMD_TO_EN 18 +#define V_CL2_WR_CMD_TO_EN(x) ((x) << S_CL2_WR_CMD_TO_EN) +#define F_CL2_WR_CMD_TO_EN V_CL2_WR_CMD_TO_EN(1U) + +#define S_CL1_WR_CMD_TO_EN 17 +#define V_CL1_WR_CMD_TO_EN(x) ((x) << S_CL1_WR_CMD_TO_EN) +#define F_CL1_WR_CMD_TO_EN V_CL1_WR_CMD_TO_EN(1U) + +#define S_CL0_WR_CMD_TO_EN 16 +#define V_CL0_WR_CMD_TO_EN(x) ((x) << S_CL0_WR_CMD_TO_EN) +#define F_CL0_WR_CMD_TO_EN V_CL0_WR_CMD_TO_EN(1U) + +#define S_FUTURE_DEXPANSION 13 +#define M_FUTURE_DEXPANSION 0x7U +#define V_FUTURE_DEXPANSION(x) ((x) << S_FUTURE_DEXPANSION) +#define G_FUTURE_DEXPANSION(x) (((x) >> S_FUTURE_DEXPANSION) & M_FUTURE_DEXPANSION) + +#define S_CL12_WR_DATA_TO_EN 12 +#define V_CL12_WR_DATA_TO_EN(x) ((x) << S_CL12_WR_DATA_TO_EN) +#define F_CL12_WR_DATA_TO_EN V_CL12_WR_DATA_TO_EN(1U) + +#define S_CL11_WR_DATA_TO_EN 11 +#define V_CL11_WR_DATA_TO_EN(x) ((x) << S_CL11_WR_DATA_TO_EN) +#define F_CL11_WR_DATA_TO_EN V_CL11_WR_DATA_TO_EN(1U) + +#define S_CL10_WR_DATA_TO_EN 10 +#define V_CL10_WR_DATA_TO_EN(x) ((x) << S_CL10_WR_DATA_TO_EN) +#define F_CL10_WR_DATA_TO_EN V_CL10_WR_DATA_TO_EN(1U) + +#define S_CL9_WR_DATA_TO_EN 9 +#define V_CL9_WR_DATA_TO_EN(x) ((x) << S_CL9_WR_DATA_TO_EN) +#define F_CL9_WR_DATA_TO_EN V_CL9_WR_DATA_TO_EN(1U) + +#define S_CL8_WR_DATA_TO_EN 8 +#define V_CL8_WR_DATA_TO_EN(x) ((x) << S_CL8_WR_DATA_TO_EN) +#define F_CL8_WR_DATA_TO_EN V_CL8_WR_DATA_TO_EN(1U) + +#define S_CL7_WR_DATA_TO_EN 7 +#define V_CL7_WR_DATA_TO_EN(x) ((x) << S_CL7_WR_DATA_TO_EN) +#define F_CL7_WR_DATA_TO_EN V_CL7_WR_DATA_TO_EN(1U) + +#define S_CL6_WR_DATA_TO_EN 6 +#define V_CL6_WR_DATA_TO_EN(x) ((x) << S_CL6_WR_DATA_TO_EN) +#define F_CL6_WR_DATA_TO_EN V_CL6_WR_DATA_TO_EN(1U) + +#define S_CL5_WR_DATA_TO_EN 5 +#define V_CL5_WR_DATA_TO_EN(x) ((x) << S_CL5_WR_DATA_TO_EN) +#define F_CL5_WR_DATA_TO_EN V_CL5_WR_DATA_TO_EN(1U) + +#define S_CL4_WR_DATA_TO_EN 4 +#define V_CL4_WR_DATA_TO_EN(x) ((x) << S_CL4_WR_DATA_TO_EN) +#define F_CL4_WR_DATA_TO_EN V_CL4_WR_DATA_TO_EN(1U) + +#define S_CL3_WR_DATA_TO_EN 3 +#define V_CL3_WR_DATA_TO_EN(x) ((x) << S_CL3_WR_DATA_TO_EN) +#define F_CL3_WR_DATA_TO_EN V_CL3_WR_DATA_TO_EN(1U) + +#define S_CL2_WR_DATA_TO_EN 2 +#define V_CL2_WR_DATA_TO_EN(x) ((x) << S_CL2_WR_DATA_TO_EN) +#define F_CL2_WR_DATA_TO_EN V_CL2_WR_DATA_TO_EN(1U) + +#define S_CL1_WR_DATA_TO_EN 1 +#define V_CL1_WR_DATA_TO_EN(x) ((x) << S_CL1_WR_DATA_TO_EN) +#define F_CL1_WR_DATA_TO_EN V_CL1_WR_DATA_TO_EN(1U) + +#define S_CL0_WR_DATA_TO_EN 0 +#define V_CL0_WR_DATA_TO_EN(x) ((x) << S_CL0_WR_DATA_TO_EN) +#define F_CL0_WR_DATA_TO_EN V_CL0_WR_DATA_TO_EN(1U) + +#define A_MA_WRITE_TIMEOUT_ERROR_STATUS 0x78d8 + +#define S_CL12_WR_CMD_TO_ERROR 28 +#define V_CL12_WR_CMD_TO_ERROR(x) ((x) << S_CL12_WR_CMD_TO_ERROR) +#define F_CL12_WR_CMD_TO_ERROR V_CL12_WR_CMD_TO_ERROR(1U) + +#define S_CL11_WR_CMD_TO_ERROR 27 +#define V_CL11_WR_CMD_TO_ERROR(x) ((x) << S_CL11_WR_CMD_TO_ERROR) +#define F_CL11_WR_CMD_TO_ERROR V_CL11_WR_CMD_TO_ERROR(1U) + +#define S_CL10_WR_CMD_TO_ERROR 26 +#define V_CL10_WR_CMD_TO_ERROR(x) ((x) << S_CL10_WR_CMD_TO_ERROR) +#define F_CL10_WR_CMD_TO_ERROR V_CL10_WR_CMD_TO_ERROR(1U) + +#define S_CL9_WR_CMD_TO_ERROR 25 +#define V_CL9_WR_CMD_TO_ERROR(x) ((x) << S_CL9_WR_CMD_TO_ERROR) +#define F_CL9_WR_CMD_TO_ERROR V_CL9_WR_CMD_TO_ERROR(1U) + +#define S_CL8_WR_CMD_TO_ERROR 24 +#define V_CL8_WR_CMD_TO_ERROR(x) ((x) << S_CL8_WR_CMD_TO_ERROR) +#define F_CL8_WR_CMD_TO_ERROR V_CL8_WR_CMD_TO_ERROR(1U) + +#define S_CL7_WR_CMD_TO_ERROR 23 +#define V_CL7_WR_CMD_TO_ERROR(x) ((x) << S_CL7_WR_CMD_TO_ERROR) +#define F_CL7_WR_CMD_TO_ERROR V_CL7_WR_CMD_TO_ERROR(1U) + +#define S_CL6_WR_CMD_TO_ERROR 22 +#define V_CL6_WR_CMD_TO_ERROR(x) ((x) << S_CL6_WR_CMD_TO_ERROR) +#define F_CL6_WR_CMD_TO_ERROR V_CL6_WR_CMD_TO_ERROR(1U) + +#define S_CL5_WR_CMD_TO_ERROR 21 +#define V_CL5_WR_CMD_TO_ERROR(x) ((x) << S_CL5_WR_CMD_TO_ERROR) +#define F_CL5_WR_CMD_TO_ERROR V_CL5_WR_CMD_TO_ERROR(1U) + +#define S_CL4_WR_CMD_TO_ERROR 20 +#define V_CL4_WR_CMD_TO_ERROR(x) ((x) << S_CL4_WR_CMD_TO_ERROR) +#define F_CL4_WR_CMD_TO_ERROR V_CL4_WR_CMD_TO_ERROR(1U) + +#define S_CL3_WR_CMD_TO_ERROR 19 +#define V_CL3_WR_CMD_TO_ERROR(x) ((x) << S_CL3_WR_CMD_TO_ERROR) +#define F_CL3_WR_CMD_TO_ERROR V_CL3_WR_CMD_TO_ERROR(1U) + +#define S_CL2_WR_CMD_TO_ERROR 18 +#define V_CL2_WR_CMD_TO_ERROR(x) ((x) << S_CL2_WR_CMD_TO_ERROR) +#define F_CL2_WR_CMD_TO_ERROR V_CL2_WR_CMD_TO_ERROR(1U) + +#define S_CL1_WR_CMD_TO_ERROR 17 +#define V_CL1_WR_CMD_TO_ERROR(x) ((x) << S_CL1_WR_CMD_TO_ERROR) +#define F_CL1_WR_CMD_TO_ERROR V_CL1_WR_CMD_TO_ERROR(1U) + +#define S_CL0_WR_CMD_TO_ERROR 16 +#define V_CL0_WR_CMD_TO_ERROR(x) ((x) << S_CL0_WR_CMD_TO_ERROR) +#define F_CL0_WR_CMD_TO_ERROR V_CL0_WR_CMD_TO_ERROR(1U) + +#define S_CL12_WR_DATA_TO_ERROR 12 +#define V_CL12_WR_DATA_TO_ERROR(x) ((x) << S_CL12_WR_DATA_TO_ERROR) +#define F_CL12_WR_DATA_TO_ERROR V_CL12_WR_DATA_TO_ERROR(1U) + +#define S_CL11_WR_DATA_TO_ERROR 11 +#define V_CL11_WR_DATA_TO_ERROR(x) ((x) << S_CL11_WR_DATA_TO_ERROR) +#define F_CL11_WR_DATA_TO_ERROR V_CL11_WR_DATA_TO_ERROR(1U) + +#define S_CL10_WR_DATA_TO_ERROR 10 +#define V_CL10_WR_DATA_TO_ERROR(x) ((x) << S_CL10_WR_DATA_TO_ERROR) +#define F_CL10_WR_DATA_TO_ERROR V_CL10_WR_DATA_TO_ERROR(1U) + +#define S_CL9_WR_DATA_TO_ERROR 9 +#define V_CL9_WR_DATA_TO_ERROR(x) ((x) << S_CL9_WR_DATA_TO_ERROR) +#define F_CL9_WR_DATA_TO_ERROR V_CL9_WR_DATA_TO_ERROR(1U) + +#define S_CL8_WR_DATA_TO_ERROR 8 +#define V_CL8_WR_DATA_TO_ERROR(x) ((x) << S_CL8_WR_DATA_TO_ERROR) +#define F_CL8_WR_DATA_TO_ERROR V_CL8_WR_DATA_TO_ERROR(1U) + +#define S_CL7_WR_DATA_TO_ERROR 7 +#define V_CL7_WR_DATA_TO_ERROR(x) ((x) << S_CL7_WR_DATA_TO_ERROR) +#define F_CL7_WR_DATA_TO_ERROR V_CL7_WR_DATA_TO_ERROR(1U) + +#define S_CL6_WR_DATA_TO_ERROR 6 +#define V_CL6_WR_DATA_TO_ERROR(x) ((x) << S_CL6_WR_DATA_TO_ERROR) +#define F_CL6_WR_DATA_TO_ERROR V_CL6_WR_DATA_TO_ERROR(1U) + +#define S_CL5_WR_DATA_TO_ERROR 5 +#define V_CL5_WR_DATA_TO_ERROR(x) ((x) << S_CL5_WR_DATA_TO_ERROR) +#define F_CL5_WR_DATA_TO_ERROR V_CL5_WR_DATA_TO_ERROR(1U) + +#define S_CL4_WR_DATA_TO_ERROR 4 +#define V_CL4_WR_DATA_TO_ERROR(x) ((x) << S_CL4_WR_DATA_TO_ERROR) +#define F_CL4_WR_DATA_TO_ERROR V_CL4_WR_DATA_TO_ERROR(1U) + +#define S_CL3_WR_DATA_TO_ERROR 3 +#define V_CL3_WR_DATA_TO_ERROR(x) ((x) << S_CL3_WR_DATA_TO_ERROR) +#define F_CL3_WR_DATA_TO_ERROR V_CL3_WR_DATA_TO_ERROR(1U) + +#define S_CL2_WR_DATA_TO_ERROR 2 +#define V_CL2_WR_DATA_TO_ERROR(x) ((x) << S_CL2_WR_DATA_TO_ERROR) +#define F_CL2_WR_DATA_TO_ERROR V_CL2_WR_DATA_TO_ERROR(1U) + +#define S_CL1_WR_DATA_TO_ERROR 1 +#define V_CL1_WR_DATA_TO_ERROR(x) ((x) << S_CL1_WR_DATA_TO_ERROR) +#define F_CL1_WR_DATA_TO_ERROR V_CL1_WR_DATA_TO_ERROR(1U) + +#define S_CL0_WR_DATA_TO_ERROR 0 +#define V_CL0_WR_DATA_TO_ERROR(x) ((x) << S_CL0_WR_DATA_TO_ERROR) +#define F_CL0_WR_DATA_TO_ERROR V_CL0_WR_DATA_TO_ERROR(1U) + +#define A_MA_READ_TIMEOUT_ERROR_ENABLE 0x78dc + +#define S_CL12_RD_CMD_TO_EN 28 +#define V_CL12_RD_CMD_TO_EN(x) ((x) << S_CL12_RD_CMD_TO_EN) +#define F_CL12_RD_CMD_TO_EN V_CL12_RD_CMD_TO_EN(1U) + +#define S_CL11_RD_CMD_TO_EN 27 +#define V_CL11_RD_CMD_TO_EN(x) ((x) << S_CL11_RD_CMD_TO_EN) +#define F_CL11_RD_CMD_TO_EN V_CL11_RD_CMD_TO_EN(1U) + +#define S_CL10_RD_CMD_TO_EN 26 +#define V_CL10_RD_CMD_TO_EN(x) ((x) << S_CL10_RD_CMD_TO_EN) +#define F_CL10_RD_CMD_TO_EN V_CL10_RD_CMD_TO_EN(1U) + +#define S_CL9_RD_CMD_TO_EN 25 +#define V_CL9_RD_CMD_TO_EN(x) ((x) << S_CL9_RD_CMD_TO_EN) +#define F_CL9_RD_CMD_TO_EN V_CL9_RD_CMD_TO_EN(1U) + +#define S_CL8_RD_CMD_TO_EN 24 +#define V_CL8_RD_CMD_TO_EN(x) ((x) << S_CL8_RD_CMD_TO_EN) +#define F_CL8_RD_CMD_TO_EN V_CL8_RD_CMD_TO_EN(1U) + +#define S_CL7_RD_CMD_TO_EN 23 +#define V_CL7_RD_CMD_TO_EN(x) ((x) << S_CL7_RD_CMD_TO_EN) +#define F_CL7_RD_CMD_TO_EN V_CL7_RD_CMD_TO_EN(1U) + +#define S_CL6_RD_CMD_TO_EN 22 +#define V_CL6_RD_CMD_TO_EN(x) ((x) << S_CL6_RD_CMD_TO_EN) +#define F_CL6_RD_CMD_TO_EN V_CL6_RD_CMD_TO_EN(1U) + +#define S_CL5_RD_CMD_TO_EN 21 +#define V_CL5_RD_CMD_TO_EN(x) ((x) << S_CL5_RD_CMD_TO_EN) +#define F_CL5_RD_CMD_TO_EN V_CL5_RD_CMD_TO_EN(1U) + +#define S_CL4_RD_CMD_TO_EN 20 +#define V_CL4_RD_CMD_TO_EN(x) ((x) << S_CL4_RD_CMD_TO_EN) +#define F_CL4_RD_CMD_TO_EN V_CL4_RD_CMD_TO_EN(1U) + +#define S_CL3_RD_CMD_TO_EN 19 +#define V_CL3_RD_CMD_TO_EN(x) ((x) << S_CL3_RD_CMD_TO_EN) +#define F_CL3_RD_CMD_TO_EN V_CL3_RD_CMD_TO_EN(1U) + +#define S_CL2_RD_CMD_TO_EN 18 +#define V_CL2_RD_CMD_TO_EN(x) ((x) << S_CL2_RD_CMD_TO_EN) +#define F_CL2_RD_CMD_TO_EN V_CL2_RD_CMD_TO_EN(1U) + +#define S_CL1_RD_CMD_TO_EN 17 +#define V_CL1_RD_CMD_TO_EN(x) ((x) << S_CL1_RD_CMD_TO_EN) +#define F_CL1_RD_CMD_TO_EN V_CL1_RD_CMD_TO_EN(1U) + +#define S_CL0_RD_CMD_TO_EN 16 +#define V_CL0_RD_CMD_TO_EN(x) ((x) << S_CL0_RD_CMD_TO_EN) +#define F_CL0_RD_CMD_TO_EN V_CL0_RD_CMD_TO_EN(1U) + +#define S_CL12_RD_DATA_TO_EN 12 +#define V_CL12_RD_DATA_TO_EN(x) ((x) << S_CL12_RD_DATA_TO_EN) +#define F_CL12_RD_DATA_TO_EN V_CL12_RD_DATA_TO_EN(1U) + +#define S_CL11_RD_DATA_TO_EN 11 +#define V_CL11_RD_DATA_TO_EN(x) ((x) << S_CL11_RD_DATA_TO_EN) +#define F_CL11_RD_DATA_TO_EN V_CL11_RD_DATA_TO_EN(1U) + +#define S_CL10_RD_DATA_TO_EN 10 +#define V_CL10_RD_DATA_TO_EN(x) ((x) << S_CL10_RD_DATA_TO_EN) +#define F_CL10_RD_DATA_TO_EN V_CL10_RD_DATA_TO_EN(1U) + +#define S_CL9_RD_DATA_TO_EN 9 +#define V_CL9_RD_DATA_TO_EN(x) ((x) << S_CL9_RD_DATA_TO_EN) +#define F_CL9_RD_DATA_TO_EN V_CL9_RD_DATA_TO_EN(1U) + +#define S_CL8_RD_DATA_TO_EN 8 +#define V_CL8_RD_DATA_TO_EN(x) ((x) << S_CL8_RD_DATA_TO_EN) +#define F_CL8_RD_DATA_TO_EN V_CL8_RD_DATA_TO_EN(1U) + +#define S_CL7_RD_DATA_TO_EN 7 +#define V_CL7_RD_DATA_TO_EN(x) ((x) << S_CL7_RD_DATA_TO_EN) +#define F_CL7_RD_DATA_TO_EN V_CL7_RD_DATA_TO_EN(1U) + +#define S_CL6_RD_DATA_TO_EN 6 +#define V_CL6_RD_DATA_TO_EN(x) ((x) << S_CL6_RD_DATA_TO_EN) +#define F_CL6_RD_DATA_TO_EN V_CL6_RD_DATA_TO_EN(1U) + +#define S_CL5_RD_DATA_TO_EN 5 +#define V_CL5_RD_DATA_TO_EN(x) ((x) << S_CL5_RD_DATA_TO_EN) +#define F_CL5_RD_DATA_TO_EN V_CL5_RD_DATA_TO_EN(1U) + +#define S_CL4_RD_DATA_TO_EN 4 +#define V_CL4_RD_DATA_TO_EN(x) ((x) << S_CL4_RD_DATA_TO_EN) +#define F_CL4_RD_DATA_TO_EN V_CL4_RD_DATA_TO_EN(1U) + +#define S_CL3_RD_DATA_TO_EN 3 +#define V_CL3_RD_DATA_TO_EN(x) ((x) << S_CL3_RD_DATA_TO_EN) +#define F_CL3_RD_DATA_TO_EN V_CL3_RD_DATA_TO_EN(1U) + +#define S_CL2_RD_DATA_TO_EN 2 +#define V_CL2_RD_DATA_TO_EN(x) ((x) << S_CL2_RD_DATA_TO_EN) +#define F_CL2_RD_DATA_TO_EN V_CL2_RD_DATA_TO_EN(1U) + +#define S_CL1_RD_DATA_TO_EN 1 +#define V_CL1_RD_DATA_TO_EN(x) ((x) << S_CL1_RD_DATA_TO_EN) +#define F_CL1_RD_DATA_TO_EN V_CL1_RD_DATA_TO_EN(1U) + +#define S_CL0_RD_DATA_TO_EN 0 +#define V_CL0_RD_DATA_TO_EN(x) ((x) << S_CL0_RD_DATA_TO_EN) +#define F_CL0_RD_DATA_TO_EN V_CL0_RD_DATA_TO_EN(1U) + +#define A_MA_READ_TIMEOUT_ERROR_STATUS 0x78e0 + +#define S_CL12_RD_CMD_TO_ERROR 28 +#define V_CL12_RD_CMD_TO_ERROR(x) ((x) << S_CL12_RD_CMD_TO_ERROR) +#define F_CL12_RD_CMD_TO_ERROR V_CL12_RD_CMD_TO_ERROR(1U) + +#define S_CL11_RD_CMD_TO_ERROR 27 +#define V_CL11_RD_CMD_TO_ERROR(x) ((x) << S_CL11_RD_CMD_TO_ERROR) +#define F_CL11_RD_CMD_TO_ERROR V_CL11_RD_CMD_TO_ERROR(1U) + +#define S_CL10_RD_CMD_TO_ERROR 26 +#define V_CL10_RD_CMD_TO_ERROR(x) ((x) << S_CL10_RD_CMD_TO_ERROR) +#define F_CL10_RD_CMD_TO_ERROR V_CL10_RD_CMD_TO_ERROR(1U) + +#define S_CL9_RD_CMD_TO_ERROR 25 +#define V_CL9_RD_CMD_TO_ERROR(x) ((x) << S_CL9_RD_CMD_TO_ERROR) +#define F_CL9_RD_CMD_TO_ERROR V_CL9_RD_CMD_TO_ERROR(1U) + +#define S_CL8_RD_CMD_TO_ERROR 24 +#define V_CL8_RD_CMD_TO_ERROR(x) ((x) << S_CL8_RD_CMD_TO_ERROR) +#define F_CL8_RD_CMD_TO_ERROR V_CL8_RD_CMD_TO_ERROR(1U) + +#define S_CL7_RD_CMD_TO_ERROR 23 +#define V_CL7_RD_CMD_TO_ERROR(x) ((x) << S_CL7_RD_CMD_TO_ERROR) +#define F_CL7_RD_CMD_TO_ERROR V_CL7_RD_CMD_TO_ERROR(1U) + +#define S_CL6_RD_CMD_TO_ERROR 22 +#define V_CL6_RD_CMD_TO_ERROR(x) ((x) << S_CL6_RD_CMD_TO_ERROR) +#define F_CL6_RD_CMD_TO_ERROR V_CL6_RD_CMD_TO_ERROR(1U) + +#define S_CL5_RD_CMD_TO_ERROR 21 +#define V_CL5_RD_CMD_TO_ERROR(x) ((x) << S_CL5_RD_CMD_TO_ERROR) +#define F_CL5_RD_CMD_TO_ERROR V_CL5_RD_CMD_TO_ERROR(1U) + +#define S_CL4_RD_CMD_TO_ERROR 20 +#define V_CL4_RD_CMD_TO_ERROR(x) ((x) << S_CL4_RD_CMD_TO_ERROR) +#define F_CL4_RD_CMD_TO_ERROR V_CL4_RD_CMD_TO_ERROR(1U) + +#define S_CL3_RD_CMD_TO_ERROR 19 +#define V_CL3_RD_CMD_TO_ERROR(x) ((x) << S_CL3_RD_CMD_TO_ERROR) +#define F_CL3_RD_CMD_TO_ERROR V_CL3_RD_CMD_TO_ERROR(1U) + +#define S_CL2_RD_CMD_TO_ERROR 18 +#define V_CL2_RD_CMD_TO_ERROR(x) ((x) << S_CL2_RD_CMD_TO_ERROR) +#define F_CL2_RD_CMD_TO_ERROR V_CL2_RD_CMD_TO_ERROR(1U) + +#define S_CL1_RD_CMD_TO_ERROR 17 +#define V_CL1_RD_CMD_TO_ERROR(x) ((x) << S_CL1_RD_CMD_TO_ERROR) +#define F_CL1_RD_CMD_TO_ERROR V_CL1_RD_CMD_TO_ERROR(1U) + +#define S_CL0_RD_CMD_TO_ERROR 16 +#define V_CL0_RD_CMD_TO_ERROR(x) ((x) << S_CL0_RD_CMD_TO_ERROR) +#define F_CL0_RD_CMD_TO_ERROR V_CL0_RD_CMD_TO_ERROR(1U) + +#define S_CL12_RD_DATA_TO_ERROR 12 +#define V_CL12_RD_DATA_TO_ERROR(x) ((x) << S_CL12_RD_DATA_TO_ERROR) +#define F_CL12_RD_DATA_TO_ERROR V_CL12_RD_DATA_TO_ERROR(1U) + +#define S_CL11_RD_DATA_TO_ERROR 11 +#define V_CL11_RD_DATA_TO_ERROR(x) ((x) << S_CL11_RD_DATA_TO_ERROR) +#define F_CL11_RD_DATA_TO_ERROR V_CL11_RD_DATA_TO_ERROR(1U) + +#define S_CL10_RD_DATA_TO_ERROR 10 +#define V_CL10_RD_DATA_TO_ERROR(x) ((x) << S_CL10_RD_DATA_TO_ERROR) +#define F_CL10_RD_DATA_TO_ERROR V_CL10_RD_DATA_TO_ERROR(1U) + +#define S_CL9_RD_DATA_TO_ERROR 9 +#define V_CL9_RD_DATA_TO_ERROR(x) ((x) << S_CL9_RD_DATA_TO_ERROR) +#define F_CL9_RD_DATA_TO_ERROR V_CL9_RD_DATA_TO_ERROR(1U) + +#define S_CL8_RD_DATA_TO_ERROR 8 +#define V_CL8_RD_DATA_TO_ERROR(x) ((x) << S_CL8_RD_DATA_TO_ERROR) +#define F_CL8_RD_DATA_TO_ERROR V_CL8_RD_DATA_TO_ERROR(1U) + +#define S_CL7_RD_DATA_TO_ERROR 7 +#define V_CL7_RD_DATA_TO_ERROR(x) ((x) << S_CL7_RD_DATA_TO_ERROR) +#define F_CL7_RD_DATA_TO_ERROR V_CL7_RD_DATA_TO_ERROR(1U) + +#define S_CL6_RD_DATA_TO_ERROR 6 +#define V_CL6_RD_DATA_TO_ERROR(x) ((x) << S_CL6_RD_DATA_TO_ERROR) +#define F_CL6_RD_DATA_TO_ERROR V_CL6_RD_DATA_TO_ERROR(1U) + +#define S_CL5_RD_DATA_TO_ERROR 5 +#define V_CL5_RD_DATA_TO_ERROR(x) ((x) << S_CL5_RD_DATA_TO_ERROR) +#define F_CL5_RD_DATA_TO_ERROR V_CL5_RD_DATA_TO_ERROR(1U) + +#define S_CL4_RD_DATA_TO_ERROR 4 +#define V_CL4_RD_DATA_TO_ERROR(x) ((x) << S_CL4_RD_DATA_TO_ERROR) +#define F_CL4_RD_DATA_TO_ERROR V_CL4_RD_DATA_TO_ERROR(1U) + +#define S_CL3_RD_DATA_TO_ERROR 3 +#define V_CL3_RD_DATA_TO_ERROR(x) ((x) << S_CL3_RD_DATA_TO_ERROR) +#define F_CL3_RD_DATA_TO_ERROR V_CL3_RD_DATA_TO_ERROR(1U) + +#define S_CL2_RD_DATA_TO_ERROR 2 +#define V_CL2_RD_DATA_TO_ERROR(x) ((x) << S_CL2_RD_DATA_TO_ERROR) +#define F_CL2_RD_DATA_TO_ERROR V_CL2_RD_DATA_TO_ERROR(1U) + +#define S_CL1_RD_DATA_TO_ERROR 1 +#define V_CL1_RD_DATA_TO_ERROR(x) ((x) << S_CL1_RD_DATA_TO_ERROR) +#define F_CL1_RD_DATA_TO_ERROR V_CL1_RD_DATA_TO_ERROR(1U) + +#define S_CL0_RD_DATA_TO_ERROR 0 +#define V_CL0_RD_DATA_TO_ERROR(x) ((x) << S_CL0_RD_DATA_TO_ERROR) +#define F_CL0_RD_DATA_TO_ERROR V_CL0_RD_DATA_TO_ERROR(1U) + +#define A_MA_BKP_CNT_SEL 0x78e4 + +#define S_BKP_CNT_TYPE 30 +#define M_BKP_CNT_TYPE 0x3U +#define V_BKP_CNT_TYPE(x) ((x) << S_BKP_CNT_TYPE) +#define G_BKP_CNT_TYPE(x) (((x) >> S_BKP_CNT_TYPE) & M_BKP_CNT_TYPE) + +#define S_BKP_CLIENT 24 +#define M_BKP_CLIENT 0xfU +#define V_BKP_CLIENT(x) ((x) << S_BKP_CLIENT) +#define G_BKP_CLIENT(x) (((x) >> S_BKP_CLIENT) & M_BKP_CLIENT) + +#define A_MA_BKP_CNT 0x78e8 +#define A_MA_WRT_ARB 0x78ec + +#define S_WRT_EN 31 +#define V_WRT_EN(x) ((x) << S_WRT_EN) +#define F_WRT_EN V_WRT_EN(1U) + +#define S_WR_TIM 16 +#define M_WR_TIM 0xffU +#define V_WR_TIM(x) ((x) << S_WR_TIM) +#define G_WR_TIM(x) (((x) >> S_WR_TIM) & M_WR_TIM) + +#define S_RD_WIN 8 +#define M_RD_WIN 0xffU +#define V_RD_WIN(x) ((x) << S_RD_WIN) +#define G_RD_WIN(x) (((x) >> S_RD_WIN) & M_RD_WIN) + +#define S_WR_WIN 0 +#define M_WR_WIN 0xffU +#define V_WR_WIN(x) ((x) << S_WR_WIN) +#define G_WR_WIN(x) (((x) >> S_WR_WIN) & M_WR_WIN) + +#define A_MA_IF_PARITY_ERROR_ENABLE 0x78f0 + +#define S_CL12_IF_PAR_EN 12 +#define V_CL12_IF_PAR_EN(x) ((x) << S_CL12_IF_PAR_EN) +#define F_CL12_IF_PAR_EN V_CL12_IF_PAR_EN(1U) + +#define S_CL11_IF_PAR_EN 11 +#define V_CL11_IF_PAR_EN(x) ((x) << S_CL11_IF_PAR_EN) +#define F_CL11_IF_PAR_EN V_CL11_IF_PAR_EN(1U) + +#define S_CL10_IF_PAR_EN 10 +#define V_CL10_IF_PAR_EN(x) ((x) << S_CL10_IF_PAR_EN) +#define F_CL10_IF_PAR_EN V_CL10_IF_PAR_EN(1U) + +#define S_CL9_IF_PAR_EN 9 +#define V_CL9_IF_PAR_EN(x) ((x) << S_CL9_IF_PAR_EN) +#define F_CL9_IF_PAR_EN V_CL9_IF_PAR_EN(1U) + +#define S_CL8_IF_PAR_EN 8 +#define V_CL8_IF_PAR_EN(x) ((x) << S_CL8_IF_PAR_EN) +#define F_CL8_IF_PAR_EN V_CL8_IF_PAR_EN(1U) + +#define S_CL7_IF_PAR_EN 7 +#define V_CL7_IF_PAR_EN(x) ((x) << S_CL7_IF_PAR_EN) +#define F_CL7_IF_PAR_EN V_CL7_IF_PAR_EN(1U) + +#define S_CL6_IF_PAR_EN 6 +#define V_CL6_IF_PAR_EN(x) ((x) << S_CL6_IF_PAR_EN) +#define F_CL6_IF_PAR_EN V_CL6_IF_PAR_EN(1U) + +#define S_CL5_IF_PAR_EN 5 +#define V_CL5_IF_PAR_EN(x) ((x) << S_CL5_IF_PAR_EN) +#define F_CL5_IF_PAR_EN V_CL5_IF_PAR_EN(1U) + +#define S_CL4_IF_PAR_EN 4 +#define V_CL4_IF_PAR_EN(x) ((x) << S_CL4_IF_PAR_EN) +#define F_CL4_IF_PAR_EN V_CL4_IF_PAR_EN(1U) + +#define S_CL3_IF_PAR_EN 3 +#define V_CL3_IF_PAR_EN(x) ((x) << S_CL3_IF_PAR_EN) +#define F_CL3_IF_PAR_EN V_CL3_IF_PAR_EN(1U) + +#define S_CL2_IF_PAR_EN 2 +#define V_CL2_IF_PAR_EN(x) ((x) << S_CL2_IF_PAR_EN) +#define F_CL2_IF_PAR_EN V_CL2_IF_PAR_EN(1U) + +#define S_CL1_IF_PAR_EN 1 +#define V_CL1_IF_PAR_EN(x) ((x) << S_CL1_IF_PAR_EN) +#define F_CL1_IF_PAR_EN V_CL1_IF_PAR_EN(1U) + +#define S_CL0_IF_PAR_EN 0 +#define V_CL0_IF_PAR_EN(x) ((x) << S_CL0_IF_PAR_EN) +#define F_CL0_IF_PAR_EN V_CL0_IF_PAR_EN(1U) + +#define A_MA_IF_PARITY_ERROR_STATUS 0x78f4 + +#define S_CL12_IF_PAR_ERROR 12 +#define V_CL12_IF_PAR_ERROR(x) ((x) << S_CL12_IF_PAR_ERROR) +#define F_CL12_IF_PAR_ERROR V_CL12_IF_PAR_ERROR(1U) + +#define S_CL11_IF_PAR_ERROR 11 +#define V_CL11_IF_PAR_ERROR(x) ((x) << S_CL11_IF_PAR_ERROR) +#define F_CL11_IF_PAR_ERROR V_CL11_IF_PAR_ERROR(1U) + +#define S_CL10_IF_PAR_ERROR 10 +#define V_CL10_IF_PAR_ERROR(x) ((x) << S_CL10_IF_PAR_ERROR) +#define F_CL10_IF_PAR_ERROR V_CL10_IF_PAR_ERROR(1U) + +#define S_CL9_IF_PAR_ERROR 9 +#define V_CL9_IF_PAR_ERROR(x) ((x) << S_CL9_IF_PAR_ERROR) +#define F_CL9_IF_PAR_ERROR V_CL9_IF_PAR_ERROR(1U) + +#define S_CL8_IF_PAR_ERROR 8 +#define V_CL8_IF_PAR_ERROR(x) ((x) << S_CL8_IF_PAR_ERROR) +#define F_CL8_IF_PAR_ERROR V_CL8_IF_PAR_ERROR(1U) + +#define S_CL7_IF_PAR_ERROR 7 +#define V_CL7_IF_PAR_ERROR(x) ((x) << S_CL7_IF_PAR_ERROR) +#define F_CL7_IF_PAR_ERROR V_CL7_IF_PAR_ERROR(1U) + +#define S_CL6_IF_PAR_ERROR 6 +#define V_CL6_IF_PAR_ERROR(x) ((x) << S_CL6_IF_PAR_ERROR) +#define F_CL6_IF_PAR_ERROR V_CL6_IF_PAR_ERROR(1U) + +#define S_CL5_IF_PAR_ERROR 5 +#define V_CL5_IF_PAR_ERROR(x) ((x) << S_CL5_IF_PAR_ERROR) +#define F_CL5_IF_PAR_ERROR V_CL5_IF_PAR_ERROR(1U) + +#define S_CL4_IF_PAR_ERROR 4 +#define V_CL4_IF_PAR_ERROR(x) ((x) << S_CL4_IF_PAR_ERROR) +#define F_CL4_IF_PAR_ERROR V_CL4_IF_PAR_ERROR(1U) + +#define S_CL3_IF_PAR_ERROR 3 +#define V_CL3_IF_PAR_ERROR(x) ((x) << S_CL3_IF_PAR_ERROR) +#define F_CL3_IF_PAR_ERROR V_CL3_IF_PAR_ERROR(1U) + +#define S_CL2_IF_PAR_ERROR 2 +#define V_CL2_IF_PAR_ERROR(x) ((x) << S_CL2_IF_PAR_ERROR) +#define F_CL2_IF_PAR_ERROR V_CL2_IF_PAR_ERROR(1U) + +#define S_CL1_IF_PAR_ERROR 1 +#define V_CL1_IF_PAR_ERROR(x) ((x) << S_CL1_IF_PAR_ERROR) +#define F_CL1_IF_PAR_ERROR V_CL1_IF_PAR_ERROR(1U) + +#define S_CL0_IF_PAR_ERROR 0 +#define V_CL0_IF_PAR_ERROR(x) ((x) << S_CL0_IF_PAR_ERROR) +#define F_CL0_IF_PAR_ERROR V_CL0_IF_PAR_ERROR(1U) + +#define A_MA_LOCAL_DEBUG_CFG 0x78f8 + +#define S_DEBUG_OR 15 +#define V_DEBUG_OR(x) ((x) << S_DEBUG_OR) +#define F_DEBUG_OR V_DEBUG_OR(1U) + +#define S_DEBUG_HI 14 +#define V_DEBUG_HI(x) ((x) << S_DEBUG_HI) +#define F_DEBUG_HI V_DEBUG_HI(1U) + +#define S_DEBUG_RPT 13 +#define V_DEBUG_RPT(x) ((x) << S_DEBUG_RPT) +#define F_DEBUG_RPT V_DEBUG_RPT(1U) + +#define S_DEBUGPAGE 10 +#define M_DEBUGPAGE 0x7U +#define V_DEBUGPAGE(x) ((x) << S_DEBUGPAGE) +#define G_DEBUGPAGE(x) (((x) >> S_DEBUGPAGE) & M_DEBUGPAGE) + +#define A_MA_LOCAL_DEBUG_RPT 0x78fc + +/* registers for module EDC_0 */ +#define EDC_0_BASE_ADDR 0x7900 + +#define A_EDC_REF 0x7900 + +#define S_EDC_INST_NUM 18 +#define V_EDC_INST_NUM(x) ((x) << S_EDC_INST_NUM) +#define F_EDC_INST_NUM V_EDC_INST_NUM(1U) + +#define S_ENABLE_PERF 17 +#define V_ENABLE_PERF(x) ((x) << S_ENABLE_PERF) +#define F_ENABLE_PERF V_ENABLE_PERF(1U) + +#define S_ECC_BYPASS 16 +#define V_ECC_BYPASS(x) ((x) << S_ECC_BYPASS) +#define F_ECC_BYPASS V_ECC_BYPASS(1U) + +#define S_REFFREQ 0 +#define M_REFFREQ 0xffffU +#define V_REFFREQ(x) ((x) << S_REFFREQ) +#define G_REFFREQ(x) (((x) >> S_REFFREQ) & M_REFFREQ) + +#define A_EDC_BIST_CMD 0x7904 +#define A_EDC_BIST_CMD_ADDR 0x7908 +#define A_EDC_BIST_CMD_LEN 0x790c +#define A_EDC_BIST_DATA_PATTERN 0x7910 +#define A_EDC_BIST_USER_WDATA0 0x7914 +#define A_EDC_BIST_USER_WDATA1 0x7918 +#define A_EDC_BIST_USER_WDATA2 0x791c +#define A_EDC_BIST_NUM_ERR 0x7920 +#define A_EDC_BIST_ERR_FIRST_ADDR 0x7924 +#define A_EDC_BIST_STATUS_RDATA 0x7928 +#define A_EDC_PAR_ENABLE 0x7970 + +#define S_ECC_UE 2 +#define V_ECC_UE(x) ((x) << S_ECC_UE) +#define F_ECC_UE V_ECC_UE(1U) + +#define S_ECC_CE 1 +#define V_ECC_CE(x) ((x) << S_ECC_CE) +#define F_ECC_CE V_ECC_CE(1U) + +#define A_EDC_INT_ENABLE 0x7974 +#define A_EDC_INT_CAUSE 0x7978 + +#define S_ECC_UE_PAR 5 +#define V_ECC_UE_PAR(x) ((x) << S_ECC_UE_PAR) +#define F_ECC_UE_PAR V_ECC_UE_PAR(1U) + +#define S_ECC_CE_PAR 4 +#define V_ECC_CE_PAR(x) ((x) << S_ECC_CE_PAR) +#define F_ECC_CE_PAR V_ECC_CE_PAR(1U) + +#define S_PERR_PAR_CAUSE 3 +#define V_PERR_PAR_CAUSE(x) ((x) << S_PERR_PAR_CAUSE) +#define F_PERR_PAR_CAUSE V_PERR_PAR_CAUSE(1U) + +#define A_EDC_ECC_STATUS 0x797c + +/* registers for module EDC_1 */ +#define EDC_1_BASE_ADDR 0x7980 + +/* registers for module HMA */ +#define HMA_BASE_ADDR 0x7a00 + +/* registers for module CIM */ +#define CIM_BASE_ADDR 0x7b00 + +#define A_CIM_VF_EXT_MAILBOX_CTRL 0x0 + +#define S_VFMBGENERIC 4 +#define M_VFMBGENERIC 0xfU +#define V_VFMBGENERIC(x) ((x) << S_VFMBGENERIC) +#define G_VFMBGENERIC(x) (((x) >> S_VFMBGENERIC) & M_VFMBGENERIC) + +#define A_CIM_VF_EXT_MAILBOX_STATUS 0x4 + +#define S_MBVFREADY 0 +#define V_MBVFREADY(x) ((x) << S_MBVFREADY) +#define F_MBVFREADY V_MBVFREADY(1U) + +#define A_CIM_PF_MAILBOX_DATA 0x240 +#define A_CIM_PF_MAILBOX_CTRL 0x280 + +#define S_MBGENERIC 4 +#define M_MBGENERIC 0xfffffffU +#define V_MBGENERIC(x) ((x) << S_MBGENERIC) +#define G_MBGENERIC(x) (((x) >> S_MBGENERIC) & M_MBGENERIC) + +#define S_MBMSGVALID 3 +#define V_MBMSGVALID(x) ((x) << S_MBMSGVALID) +#define F_MBMSGVALID V_MBMSGVALID(1U) + +#define S_MBINTREQ 2 +#define V_MBINTREQ(x) ((x) << S_MBINTREQ) +#define F_MBINTREQ V_MBINTREQ(1U) + +#define S_MBOWNER 0 +#define M_MBOWNER 0x3U +#define V_MBOWNER(x) ((x) << S_MBOWNER) +#define G_MBOWNER(x) (((x) >> S_MBOWNER) & M_MBOWNER) + +#define A_CIM_PF_MAILBOX_ACC_STATUS 0x284 + +#define S_MBWRBUSY 31 +#define V_MBWRBUSY(x) ((x) << S_MBWRBUSY) +#define F_MBWRBUSY V_MBWRBUSY(1U) + +#define A_CIM_PF_HOST_INT_ENABLE 0x288 + +#define S_MBMSGRDYINTEN 19 +#define V_MBMSGRDYINTEN(x) ((x) << S_MBMSGRDYINTEN) +#define F_MBMSGRDYINTEN V_MBMSGRDYINTEN(1U) + +#define A_CIM_PF_HOST_INT_CAUSE 0x28c + +#define S_MBMSGRDYINT 19 +#define V_MBMSGRDYINT(x) ((x) << S_MBMSGRDYINT) +#define F_MBMSGRDYINT V_MBMSGRDYINT(1U) + +#define A_CIM_PF_MAILBOX_CTRL_SHADOW_COPY 0x290 +#define A_CIM_BOOT_CFG 0x7b00 + +#define S_BOOTADDR 8 +#define M_BOOTADDR 0xffffffU +#define V_BOOTADDR(x) ((x) << S_BOOTADDR) +#define G_BOOTADDR(x) (((x) >> S_BOOTADDR) & M_BOOTADDR) + +#define S_UPGEN 2 +#define M_UPGEN 0x3fU +#define V_UPGEN(x) ((x) << S_UPGEN) +#define G_UPGEN(x) (((x) >> S_UPGEN) & M_UPGEN) + +#define S_BOOTSDRAM 1 +#define V_BOOTSDRAM(x) ((x) << S_BOOTSDRAM) +#define F_BOOTSDRAM V_BOOTSDRAM(1U) + +#define S_UPCRST 0 +#define V_UPCRST(x) ((x) << S_UPCRST) +#define F_UPCRST V_UPCRST(1U) + +#define A_CIM_FLASH_BASE_ADDR 0x7b04 + +#define S_FLASHBASEADDR 6 +#define M_FLASHBASEADDR 0x3ffffU +#define V_FLASHBASEADDR(x) ((x) << S_FLASHBASEADDR) +#define G_FLASHBASEADDR(x) (((x) >> S_FLASHBASEADDR) & M_FLASHBASEADDR) + +#define A_CIM_FLASH_ADDR_SIZE 0x7b08 + +#define S_FLASHADDRSIZE 4 +#define M_FLASHADDRSIZE 0xfffffU +#define V_FLASHADDRSIZE(x) ((x) << S_FLASHADDRSIZE) +#define G_FLASHADDRSIZE(x) (((x) >> S_FLASHADDRSIZE) & M_FLASHADDRSIZE) + +#define A_CIM_EEPROM_BASE_ADDR 0x7b0c + +#define S_EEPROMBASEADDR 6 +#define M_EEPROMBASEADDR 0x3ffffU +#define V_EEPROMBASEADDR(x) ((x) << S_EEPROMBASEADDR) +#define G_EEPROMBASEADDR(x) (((x) >> S_EEPROMBASEADDR) & M_EEPROMBASEADDR) + +#define A_CIM_EEPROM_ADDR_SIZE 0x7b10 + +#define S_EEPROMADDRSIZE 4 +#define M_EEPROMADDRSIZE 0xfffffU +#define V_EEPROMADDRSIZE(x) ((x) << S_EEPROMADDRSIZE) +#define G_EEPROMADDRSIZE(x) (((x) >> S_EEPROMADDRSIZE) & M_EEPROMADDRSIZE) + +#define A_CIM_SDRAM_BASE_ADDR 0x7b14 + +#define S_SDRAMBASEADDR 6 +#define M_SDRAMBASEADDR 0x3ffffffU +#define V_SDRAMBASEADDR(x) ((x) << S_SDRAMBASEADDR) +#define G_SDRAMBASEADDR(x) (((x) >> S_SDRAMBASEADDR) & M_SDRAMBASEADDR) + +#define A_CIM_SDRAM_ADDR_SIZE 0x7b18 + +#define S_SDRAMADDRSIZE 4 +#define M_SDRAMADDRSIZE 0xfffffffU +#define V_SDRAMADDRSIZE(x) ((x) << S_SDRAMADDRSIZE) +#define G_SDRAMADDRSIZE(x) (((x) >> S_SDRAMADDRSIZE) & M_SDRAMADDRSIZE) + +#define A_CIM_EXTMEM2_BASE_ADDR 0x7b1c + +#define S_EXTMEM2BASEADDR 6 +#define M_EXTMEM2BASEADDR 0x3ffffffU +#define V_EXTMEM2BASEADDR(x) ((x) << S_EXTMEM2BASEADDR) +#define G_EXTMEM2BASEADDR(x) (((x) >> S_EXTMEM2BASEADDR) & M_EXTMEM2BASEADDR) + +#define A_CIM_EXTMEM2_ADDR_SIZE 0x7b20 + +#define S_EXTMEM2ADDRSIZE 4 +#define M_EXTMEM2ADDRSIZE 0xfffffffU +#define V_EXTMEM2ADDRSIZE(x) ((x) << S_EXTMEM2ADDRSIZE) +#define G_EXTMEM2ADDRSIZE(x) (((x) >> S_EXTMEM2ADDRSIZE) & M_EXTMEM2ADDRSIZE) + +#define A_CIM_UP_SPARE_INT 0x7b24 + +#define S_TDEBUGINT 4 +#define V_TDEBUGINT(x) ((x) << S_TDEBUGINT) +#define F_TDEBUGINT V_TDEBUGINT(1U) + +#define S_BOOTVECSEL 3 +#define V_BOOTVECSEL(x) ((x) << S_BOOTVECSEL) +#define F_BOOTVECSEL V_BOOTVECSEL(1U) + +#define S_UPSPAREINT 0 +#define M_UPSPAREINT 0x7U +#define V_UPSPAREINT(x) ((x) << S_UPSPAREINT) +#define G_UPSPAREINT(x) (((x) >> S_UPSPAREINT) & M_UPSPAREINT) + +#define A_CIM_HOST_INT_ENABLE 0x7b28 + +#define S_TIEQOUTPARERRINTEN 20 +#define V_TIEQOUTPARERRINTEN(x) ((x) << S_TIEQOUTPARERRINTEN) +#define F_TIEQOUTPARERRINTEN V_TIEQOUTPARERRINTEN(1U) + +#define S_TIEQINPARERRINTEN 19 +#define V_TIEQINPARERRINTEN(x) ((x) << S_TIEQINPARERRINTEN) +#define F_TIEQINPARERRINTEN V_TIEQINPARERRINTEN(1U) + +#define S_MBHOSTPARERR 18 +#define V_MBHOSTPARERR(x) ((x) << S_MBHOSTPARERR) +#define F_MBHOSTPARERR V_MBHOSTPARERR(1U) + +#define S_MBUPPARERR 17 +#define V_MBUPPARERR(x) ((x) << S_MBUPPARERR) +#define F_MBUPPARERR V_MBUPPARERR(1U) + +#define S_IBQTP0PARERR 16 +#define V_IBQTP0PARERR(x) ((x) << S_IBQTP0PARERR) +#define F_IBQTP0PARERR V_IBQTP0PARERR(1U) + +#define S_IBQTP1PARERR 15 +#define V_IBQTP1PARERR(x) ((x) << S_IBQTP1PARERR) +#define F_IBQTP1PARERR V_IBQTP1PARERR(1U) + +#define S_IBQULPPARERR 14 +#define V_IBQULPPARERR(x) ((x) << S_IBQULPPARERR) +#define F_IBQULPPARERR V_IBQULPPARERR(1U) + +#define S_IBQSGELOPARERR 13 +#define V_IBQSGELOPARERR(x) ((x) << S_IBQSGELOPARERR) +#define F_IBQSGELOPARERR V_IBQSGELOPARERR(1U) + +#define S_IBQSGEHIPARERR 12 +#define V_IBQSGEHIPARERR(x) ((x) << S_IBQSGEHIPARERR) +#define F_IBQSGEHIPARERR V_IBQSGEHIPARERR(1U) + +#define S_IBQNCSIPARERR 11 +#define V_IBQNCSIPARERR(x) ((x) << S_IBQNCSIPARERR) +#define F_IBQNCSIPARERR V_IBQNCSIPARERR(1U) + +#define S_OBQULP0PARERR 10 +#define V_OBQULP0PARERR(x) ((x) << S_OBQULP0PARERR) +#define F_OBQULP0PARERR V_OBQULP0PARERR(1U) + +#define S_OBQULP1PARERR 9 +#define V_OBQULP1PARERR(x) ((x) << S_OBQULP1PARERR) +#define F_OBQULP1PARERR V_OBQULP1PARERR(1U) + +#define S_OBQULP2PARERR 8 +#define V_OBQULP2PARERR(x) ((x) << S_OBQULP2PARERR) +#define F_OBQULP2PARERR V_OBQULP2PARERR(1U) + +#define S_OBQULP3PARERR 7 +#define V_OBQULP3PARERR(x) ((x) << S_OBQULP3PARERR) +#define F_OBQULP3PARERR V_OBQULP3PARERR(1U) + +#define S_OBQSGEPARERR 6 +#define V_OBQSGEPARERR(x) ((x) << S_OBQSGEPARERR) +#define F_OBQSGEPARERR V_OBQSGEPARERR(1U) + +#define S_OBQNCSIPARERR 5 +#define V_OBQNCSIPARERR(x) ((x) << S_OBQNCSIPARERR) +#define F_OBQNCSIPARERR V_OBQNCSIPARERR(1U) + +#define S_TIMER1INTEN 3 +#define V_TIMER1INTEN(x) ((x) << S_TIMER1INTEN) +#define F_TIMER1INTEN V_TIMER1INTEN(1U) + +#define S_TIMER0INTEN 2 +#define V_TIMER0INTEN(x) ((x) << S_TIMER0INTEN) +#define F_TIMER0INTEN V_TIMER0INTEN(1U) + +#define S_PREFDROPINTEN 1 +#define V_PREFDROPINTEN(x) ((x) << S_PREFDROPINTEN) +#define F_PREFDROPINTEN V_PREFDROPINTEN(1U) + +#define S_MA_CIM_INTFPERR 28 +#define V_MA_CIM_INTFPERR(x) ((x) << S_MA_CIM_INTFPERR) +#define F_MA_CIM_INTFPERR V_MA_CIM_INTFPERR(1U) + +#define S_PLCIM_MSTRSPDATAPARERR 27 +#define V_PLCIM_MSTRSPDATAPARERR(x) ((x) << S_PLCIM_MSTRSPDATAPARERR) +#define F_PLCIM_MSTRSPDATAPARERR V_PLCIM_MSTRSPDATAPARERR(1U) + +#define S_NCSI2CIMINTFPARERR 26 +#define V_NCSI2CIMINTFPARERR(x) ((x) << S_NCSI2CIMINTFPARERR) +#define F_NCSI2CIMINTFPARERR V_NCSI2CIMINTFPARERR(1U) + +#define S_SGE2CIMINTFPARERR 25 +#define V_SGE2CIMINTFPARERR(x) ((x) << S_SGE2CIMINTFPARERR) +#define F_SGE2CIMINTFPARERR V_SGE2CIMINTFPARERR(1U) + +#define S_ULP2CIMINTFPARERR 24 +#define V_ULP2CIMINTFPARERR(x) ((x) << S_ULP2CIMINTFPARERR) +#define F_ULP2CIMINTFPARERR V_ULP2CIMINTFPARERR(1U) + +#define S_TP2CIMINTFPARERR 23 +#define V_TP2CIMINTFPARERR(x) ((x) << S_TP2CIMINTFPARERR) +#define F_TP2CIMINTFPARERR V_TP2CIMINTFPARERR(1U) + +#define S_OBQSGERX1PARERR 22 +#define V_OBQSGERX1PARERR(x) ((x) << S_OBQSGERX1PARERR) +#define F_OBQSGERX1PARERR V_OBQSGERX1PARERR(1U) + +#define S_OBQSGERX0PARERR 21 +#define V_OBQSGERX0PARERR(x) ((x) << S_OBQSGERX0PARERR) +#define F_OBQSGERX0PARERR V_OBQSGERX0PARERR(1U) + +#define A_CIM_HOST_INT_CAUSE 0x7b2c + +#define S_TIEQOUTPARERRINT 20 +#define V_TIEQOUTPARERRINT(x) ((x) << S_TIEQOUTPARERRINT) +#define F_TIEQOUTPARERRINT V_TIEQOUTPARERRINT(1U) + +#define S_TIEQINPARERRINT 19 +#define V_TIEQINPARERRINT(x) ((x) << S_TIEQINPARERRINT) +#define F_TIEQINPARERRINT V_TIEQINPARERRINT(1U) + +#define S_TIMER1INT 3 +#define V_TIMER1INT(x) ((x) << S_TIMER1INT) +#define F_TIMER1INT V_TIMER1INT(1U) + +#define S_TIMER0INT 2 +#define V_TIMER0INT(x) ((x) << S_TIMER0INT) +#define F_TIMER0INT V_TIMER0INT(1U) + +#define S_PREFDROPINT 1 +#define V_PREFDROPINT(x) ((x) << S_PREFDROPINT) +#define F_PREFDROPINT V_PREFDROPINT(1U) + +#define S_UPACCNONZERO 0 +#define V_UPACCNONZERO(x) ((x) << S_UPACCNONZERO) +#define F_UPACCNONZERO V_UPACCNONZERO(1U) + +#define A_CIM_HOST_UPACC_INT_ENABLE 0x7b30 + +#define S_EEPROMWRINTEN 30 +#define V_EEPROMWRINTEN(x) ((x) << S_EEPROMWRINTEN) +#define F_EEPROMWRINTEN V_EEPROMWRINTEN(1U) + +#define S_TIMEOUTMAINTEN 29 +#define V_TIMEOUTMAINTEN(x) ((x) << S_TIMEOUTMAINTEN) +#define F_TIMEOUTMAINTEN V_TIMEOUTMAINTEN(1U) + +#define S_TIMEOUTINTEN 28 +#define V_TIMEOUTINTEN(x) ((x) << S_TIMEOUTINTEN) +#define F_TIMEOUTINTEN V_TIMEOUTINTEN(1U) + +#define S_RSPOVRLOOKUPINTEN 27 +#define V_RSPOVRLOOKUPINTEN(x) ((x) << S_RSPOVRLOOKUPINTEN) +#define F_RSPOVRLOOKUPINTEN V_RSPOVRLOOKUPINTEN(1U) + +#define S_REQOVRLOOKUPINTEN 26 +#define V_REQOVRLOOKUPINTEN(x) ((x) << S_REQOVRLOOKUPINTEN) +#define F_REQOVRLOOKUPINTEN V_REQOVRLOOKUPINTEN(1U) + +#define S_BLKWRPLINTEN 25 +#define V_BLKWRPLINTEN(x) ((x) << S_BLKWRPLINTEN) +#define F_BLKWRPLINTEN V_BLKWRPLINTEN(1U) + +#define S_BLKRDPLINTEN 24 +#define V_BLKRDPLINTEN(x) ((x) << S_BLKRDPLINTEN) +#define F_BLKRDPLINTEN V_BLKRDPLINTEN(1U) + +#define S_SGLWRPLINTEN 23 +#define V_SGLWRPLINTEN(x) ((x) << S_SGLWRPLINTEN) +#define F_SGLWRPLINTEN V_SGLWRPLINTEN(1U) + +#define S_SGLRDPLINTEN 22 +#define V_SGLRDPLINTEN(x) ((x) << S_SGLRDPLINTEN) +#define F_SGLRDPLINTEN V_SGLRDPLINTEN(1U) + +#define S_BLKWRCTLINTEN 21 +#define V_BLKWRCTLINTEN(x) ((x) << S_BLKWRCTLINTEN) +#define F_BLKWRCTLINTEN V_BLKWRCTLINTEN(1U) + +#define S_BLKRDCTLINTEN 20 +#define V_BLKRDCTLINTEN(x) ((x) << S_BLKRDCTLINTEN) +#define F_BLKRDCTLINTEN V_BLKRDCTLINTEN(1U) + +#define S_SGLWRCTLINTEN 19 +#define V_SGLWRCTLINTEN(x) ((x) << S_SGLWRCTLINTEN) +#define F_SGLWRCTLINTEN V_SGLWRCTLINTEN(1U) + +#define S_SGLRDCTLINTEN 18 +#define V_SGLRDCTLINTEN(x) ((x) << S_SGLRDCTLINTEN) +#define F_SGLRDCTLINTEN V_SGLRDCTLINTEN(1U) + +#define S_BLKWREEPROMINTEN 17 +#define V_BLKWREEPROMINTEN(x) ((x) << S_BLKWREEPROMINTEN) +#define F_BLKWREEPROMINTEN V_BLKWREEPROMINTEN(1U) + +#define S_BLKRDEEPROMINTEN 16 +#define V_BLKRDEEPROMINTEN(x) ((x) << S_BLKRDEEPROMINTEN) +#define F_BLKRDEEPROMINTEN V_BLKRDEEPROMINTEN(1U) + +#define S_SGLWREEPROMINTEN 15 +#define V_SGLWREEPROMINTEN(x) ((x) << S_SGLWREEPROMINTEN) +#define F_SGLWREEPROMINTEN V_SGLWREEPROMINTEN(1U) + +#define S_SGLRDEEPROMINTEN 14 +#define V_SGLRDEEPROMINTEN(x) ((x) << S_SGLRDEEPROMINTEN) +#define F_SGLRDEEPROMINTEN V_SGLRDEEPROMINTEN(1U) + +#define S_BLKWRFLASHINTEN 13 +#define V_BLKWRFLASHINTEN(x) ((x) << S_BLKWRFLASHINTEN) +#define F_BLKWRFLASHINTEN V_BLKWRFLASHINTEN(1U) + +#define S_BLKRDFLASHINTEN 12 +#define V_BLKRDFLASHINTEN(x) ((x) << S_BLKRDFLASHINTEN) +#define F_BLKRDFLASHINTEN V_BLKRDFLASHINTEN(1U) + +#define S_SGLWRFLASHINTEN 11 +#define V_SGLWRFLASHINTEN(x) ((x) << S_SGLWRFLASHINTEN) +#define F_SGLWRFLASHINTEN V_SGLWRFLASHINTEN(1U) + +#define S_SGLRDFLASHINTEN 10 +#define V_SGLRDFLASHINTEN(x) ((x) << S_SGLRDFLASHINTEN) +#define F_SGLRDFLASHINTEN V_SGLRDFLASHINTEN(1U) + +#define S_BLKWRBOOTINTEN 9 +#define V_BLKWRBOOTINTEN(x) ((x) << S_BLKWRBOOTINTEN) +#define F_BLKWRBOOTINTEN V_BLKWRBOOTINTEN(1U) + +#define S_BLKRDBOOTINTEN 8 +#define V_BLKRDBOOTINTEN(x) ((x) << S_BLKRDBOOTINTEN) +#define F_BLKRDBOOTINTEN V_BLKRDBOOTINTEN(1U) + +#define S_SGLWRBOOTINTEN 7 +#define V_SGLWRBOOTINTEN(x) ((x) << S_SGLWRBOOTINTEN) +#define F_SGLWRBOOTINTEN V_SGLWRBOOTINTEN(1U) + +#define S_SGLRDBOOTINTEN 6 +#define V_SGLRDBOOTINTEN(x) ((x) << S_SGLRDBOOTINTEN) +#define F_SGLRDBOOTINTEN V_SGLRDBOOTINTEN(1U) + +#define S_ILLWRBEINTEN 5 +#define V_ILLWRBEINTEN(x) ((x) << S_ILLWRBEINTEN) +#define F_ILLWRBEINTEN V_ILLWRBEINTEN(1U) + +#define S_ILLRDBEINTEN 4 +#define V_ILLRDBEINTEN(x) ((x) << S_ILLRDBEINTEN) +#define F_ILLRDBEINTEN V_ILLRDBEINTEN(1U) + +#define S_ILLRDINTEN 3 +#define V_ILLRDINTEN(x) ((x) << S_ILLRDINTEN) +#define F_ILLRDINTEN V_ILLRDINTEN(1U) + +#define S_ILLWRINTEN 2 +#define V_ILLWRINTEN(x) ((x) << S_ILLWRINTEN) +#define F_ILLWRINTEN V_ILLWRINTEN(1U) + +#define S_ILLTRANSINTEN 1 +#define V_ILLTRANSINTEN(x) ((x) << S_ILLTRANSINTEN) +#define F_ILLTRANSINTEN V_ILLTRANSINTEN(1U) + +#define S_RSVDSPACEINTEN 0 +#define V_RSVDSPACEINTEN(x) ((x) << S_RSVDSPACEINTEN) +#define F_RSVDSPACEINTEN V_RSVDSPACEINTEN(1U) + +#define A_CIM_HOST_UPACC_INT_CAUSE 0x7b34 + +#define S_EEPROMWRINT 30 +#define V_EEPROMWRINT(x) ((x) << S_EEPROMWRINT) +#define F_EEPROMWRINT V_EEPROMWRINT(1U) + +#define S_TIMEOUTMAINT 29 +#define V_TIMEOUTMAINT(x) ((x) << S_TIMEOUTMAINT) +#define F_TIMEOUTMAINT V_TIMEOUTMAINT(1U) + +#define S_TIMEOUTINT 28 +#define V_TIMEOUTINT(x) ((x) << S_TIMEOUTINT) +#define F_TIMEOUTINT V_TIMEOUTINT(1U) + +#define S_RSPOVRLOOKUPINT 27 +#define V_RSPOVRLOOKUPINT(x) ((x) << S_RSPOVRLOOKUPINT) +#define F_RSPOVRLOOKUPINT V_RSPOVRLOOKUPINT(1U) + +#define S_REQOVRLOOKUPINT 26 +#define V_REQOVRLOOKUPINT(x) ((x) << S_REQOVRLOOKUPINT) +#define F_REQOVRLOOKUPINT V_REQOVRLOOKUPINT(1U) + +#define S_BLKWRPLINT 25 +#define V_BLKWRPLINT(x) ((x) << S_BLKWRPLINT) +#define F_BLKWRPLINT V_BLKWRPLINT(1U) + +#define S_BLKRDPLINT 24 +#define V_BLKRDPLINT(x) ((x) << S_BLKRDPLINT) +#define F_BLKRDPLINT V_BLKRDPLINT(1U) + +#define S_SGLWRPLINT 23 +#define V_SGLWRPLINT(x) ((x) << S_SGLWRPLINT) +#define F_SGLWRPLINT V_SGLWRPLINT(1U) + +#define S_SGLRDPLINT 22 +#define V_SGLRDPLINT(x) ((x) << S_SGLRDPLINT) +#define F_SGLRDPLINT V_SGLRDPLINT(1U) + +#define S_BLKWRCTLINT 21 +#define V_BLKWRCTLINT(x) ((x) << S_BLKWRCTLINT) +#define F_BLKWRCTLINT V_BLKWRCTLINT(1U) + +#define S_BLKRDCTLINT 20 +#define V_BLKRDCTLINT(x) ((x) << S_BLKRDCTLINT) +#define F_BLKRDCTLINT V_BLKRDCTLINT(1U) + +#define S_SGLWRCTLINT 19 +#define V_SGLWRCTLINT(x) ((x) << S_SGLWRCTLINT) +#define F_SGLWRCTLINT V_SGLWRCTLINT(1U) + +#define S_SGLRDCTLINT 18 +#define V_SGLRDCTLINT(x) ((x) << S_SGLRDCTLINT) +#define F_SGLRDCTLINT V_SGLRDCTLINT(1U) + +#define S_BLKWREEPROMINT 17 +#define V_BLKWREEPROMINT(x) ((x) << S_BLKWREEPROMINT) +#define F_BLKWREEPROMINT V_BLKWREEPROMINT(1U) + +#define S_BLKRDEEPROMINT 16 +#define V_BLKRDEEPROMINT(x) ((x) << S_BLKRDEEPROMINT) +#define F_BLKRDEEPROMINT V_BLKRDEEPROMINT(1U) + +#define S_SGLWREEPROMINT 15 +#define V_SGLWREEPROMINT(x) ((x) << S_SGLWREEPROMINT) +#define F_SGLWREEPROMINT V_SGLWREEPROMINT(1U) + +#define S_SGLRDEEPROMINT 14 +#define V_SGLRDEEPROMINT(x) ((x) << S_SGLRDEEPROMINT) +#define F_SGLRDEEPROMINT V_SGLRDEEPROMINT(1U) + +#define S_BLKWRFLASHINT 13 +#define V_BLKWRFLASHINT(x) ((x) << S_BLKWRFLASHINT) +#define F_BLKWRFLASHINT V_BLKWRFLASHINT(1U) + +#define S_BLKRDFLASHINT 12 +#define V_BLKRDFLASHINT(x) ((x) << S_BLKRDFLASHINT) +#define F_BLKRDFLASHINT V_BLKRDFLASHINT(1U) + +#define S_SGLWRFLASHINT 11 +#define V_SGLWRFLASHINT(x) ((x) << S_SGLWRFLASHINT) +#define F_SGLWRFLASHINT V_SGLWRFLASHINT(1U) + +#define S_SGLRDFLASHINT 10 +#define V_SGLRDFLASHINT(x) ((x) << S_SGLRDFLASHINT) +#define F_SGLRDFLASHINT V_SGLRDFLASHINT(1U) + +#define S_BLKWRBOOTINT 9 +#define V_BLKWRBOOTINT(x) ((x) << S_BLKWRBOOTINT) +#define F_BLKWRBOOTINT V_BLKWRBOOTINT(1U) + +#define S_BLKRDBOOTINT 8 +#define V_BLKRDBOOTINT(x) ((x) << S_BLKRDBOOTINT) +#define F_BLKRDBOOTINT V_BLKRDBOOTINT(1U) + +#define S_SGLWRBOOTINT 7 +#define V_SGLWRBOOTINT(x) ((x) << S_SGLWRBOOTINT) +#define F_SGLWRBOOTINT V_SGLWRBOOTINT(1U) + +#define S_SGLRDBOOTINT 6 +#define V_SGLRDBOOTINT(x) ((x) << S_SGLRDBOOTINT) +#define F_SGLRDBOOTINT V_SGLRDBOOTINT(1U) + +#define S_ILLWRBEINT 5 +#define V_ILLWRBEINT(x) ((x) << S_ILLWRBEINT) +#define F_ILLWRBEINT V_ILLWRBEINT(1U) + +#define S_ILLRDBEINT 4 +#define V_ILLRDBEINT(x) ((x) << S_ILLRDBEINT) +#define F_ILLRDBEINT V_ILLRDBEINT(1U) + +#define S_ILLRDINT 3 +#define V_ILLRDINT(x) ((x) << S_ILLRDINT) +#define F_ILLRDINT V_ILLRDINT(1U) + +#define S_ILLWRINT 2 +#define V_ILLWRINT(x) ((x) << S_ILLWRINT) +#define F_ILLWRINT V_ILLWRINT(1U) + +#define S_ILLTRANSINT 1 +#define V_ILLTRANSINT(x) ((x) << S_ILLTRANSINT) +#define F_ILLTRANSINT V_ILLTRANSINT(1U) + +#define S_RSVDSPACEINT 0 +#define V_RSVDSPACEINT(x) ((x) << S_RSVDSPACEINT) +#define F_RSVDSPACEINT V_RSVDSPACEINT(1U) + +#define A_CIM_UP_INT_ENABLE 0x7b38 + +#define S_MSTPLINTEN 4 +#define V_MSTPLINTEN(x) ((x) << S_MSTPLINTEN) +#define F_MSTPLINTEN V_MSTPLINTEN(1U) + +#define A_CIM_UP_INT_CAUSE 0x7b3c + +#define S_MSTPLINT 4 +#define V_MSTPLINT(x) ((x) << S_MSTPLINT) +#define F_MSTPLINT V_MSTPLINT(1U) + +#define A_CIM_UP_ACC_INT_ENABLE 0x7b40 +#define A_CIM_UP_ACC_INT_CAUSE 0x7b44 +#define A_CIM_QUEUE_CONFIG_REF 0x7b48 + +#define S_OBQSELECT 4 +#define V_OBQSELECT(x) ((x) << S_OBQSELECT) +#define F_OBQSELECT V_OBQSELECT(1U) + +#define S_IBQSELECT 3 +#define V_IBQSELECT(x) ((x) << S_IBQSELECT) +#define F_IBQSELECT V_IBQSELECT(1U) + +#define S_QUENUMSELECT 0 +#define M_QUENUMSELECT 0x7U +#define V_QUENUMSELECT(x) ((x) << S_QUENUMSELECT) +#define G_QUENUMSELECT(x) (((x) >> S_QUENUMSELECT) & M_QUENUMSELECT) + +#define A_CIM_QUEUE_CONFIG_CTRL 0x7b4c + +#define S_CIMQSIZE 24 +#define M_CIMQSIZE 0x3fU +#define V_CIMQSIZE(x) ((x) << S_CIMQSIZE) +#define G_CIMQSIZE(x) (((x) >> S_CIMQSIZE) & M_CIMQSIZE) + +#define S_CIMQBASE 16 +#define M_CIMQBASE 0x3fU +#define V_CIMQBASE(x) ((x) << S_CIMQBASE) +#define G_CIMQBASE(x) (((x) >> S_CIMQBASE) & M_CIMQBASE) + +#define S_CIMQDBG8BEN 9 +#define V_CIMQDBG8BEN(x) ((x) << S_CIMQDBG8BEN) +#define F_CIMQDBG8BEN V_CIMQDBG8BEN(1U) + +#define S_QUEFULLTHRSH 0 +#define M_QUEFULLTHRSH 0x1ffU +#define V_QUEFULLTHRSH(x) ((x) << S_QUEFULLTHRSH) +#define G_QUEFULLTHRSH(x) (((x) >> S_QUEFULLTHRSH) & M_QUEFULLTHRSH) + +#define A_CIM_HOST_ACC_CTRL 0x7b50 + +#define S_HOSTBUSY 17 +#define V_HOSTBUSY(x) ((x) << S_HOSTBUSY) +#define F_HOSTBUSY V_HOSTBUSY(1U) + +#define S_HOSTWRITE 16 +#define V_HOSTWRITE(x) ((x) << S_HOSTWRITE) +#define F_HOSTWRITE V_HOSTWRITE(1U) + +#define S_HOSTADDR 0 +#define M_HOSTADDR 0xffffU +#define V_HOSTADDR(x) ((x) << S_HOSTADDR) +#define G_HOSTADDR(x) (((x) >> S_HOSTADDR) & M_HOSTADDR) + +#define A_CIM_HOST_ACC_DATA 0x7b54 +#define A_CIM_CDEBUGDATA 0x7b58 + +#define S_CDEBUGDATAH 16 +#define M_CDEBUGDATAH 0xffffU +#define V_CDEBUGDATAH(x) ((x) << S_CDEBUGDATAH) +#define G_CDEBUGDATAH(x) (((x) >> S_CDEBUGDATAH) & M_CDEBUGDATAH) + +#define S_CDEBUGDATAL 0 +#define M_CDEBUGDATAL 0xffffU +#define V_CDEBUGDATAL(x) ((x) << S_CDEBUGDATAL) +#define G_CDEBUGDATAL(x) (((x) >> S_CDEBUGDATAL) & M_CDEBUGDATAL) + +#define A_CIM_IBQ_DBG_CFG 0x7b60 + +#define S_IBQDBGADDR 16 +#define M_IBQDBGADDR 0xfffU +#define V_IBQDBGADDR(x) ((x) << S_IBQDBGADDR) +#define G_IBQDBGADDR(x) (((x) >> S_IBQDBGADDR) & M_IBQDBGADDR) + +#define S_IBQDBGWR 2 +#define V_IBQDBGWR(x) ((x) << S_IBQDBGWR) +#define F_IBQDBGWR V_IBQDBGWR(1U) + +#define S_IBQDBGBUSY 1 +#define V_IBQDBGBUSY(x) ((x) << S_IBQDBGBUSY) +#define F_IBQDBGBUSY V_IBQDBGBUSY(1U) + +#define S_IBQDBGEN 0 +#define V_IBQDBGEN(x) ((x) << S_IBQDBGEN) +#define F_IBQDBGEN V_IBQDBGEN(1U) + +#define A_CIM_OBQ_DBG_CFG 0x7b64 + +#define S_OBQDBGADDR 16 +#define M_OBQDBGADDR 0xfffU +#define V_OBQDBGADDR(x) ((x) << S_OBQDBGADDR) +#define G_OBQDBGADDR(x) (((x) >> S_OBQDBGADDR) & M_OBQDBGADDR) + +#define S_OBQDBGWR 2 +#define V_OBQDBGWR(x) ((x) << S_OBQDBGWR) +#define F_OBQDBGWR V_OBQDBGWR(1U) + +#define S_OBQDBGBUSY 1 +#define V_OBQDBGBUSY(x) ((x) << S_OBQDBGBUSY) +#define F_OBQDBGBUSY V_OBQDBGBUSY(1U) + +#define S_OBQDBGEN 0 +#define V_OBQDBGEN(x) ((x) << S_OBQDBGEN) +#define F_OBQDBGEN V_OBQDBGEN(1U) + +#define A_CIM_IBQ_DBG_DATA 0x7b68 +#define A_CIM_OBQ_DBG_DATA 0x7b6c +#define A_CIM_DEBUGCFG 0x7b70 + +#define S_POLADBGRDPTR 23 +#define M_POLADBGRDPTR 0x1ffU +#define V_POLADBGRDPTR(x) ((x) << S_POLADBGRDPTR) +#define G_POLADBGRDPTR(x) (((x) >> S_POLADBGRDPTR) & M_POLADBGRDPTR) + +#define S_PILADBGRDPTR 14 +#define M_PILADBGRDPTR 0x1ffU +#define V_PILADBGRDPTR(x) ((x) << S_PILADBGRDPTR) +#define G_PILADBGRDPTR(x) (((x) >> S_PILADBGRDPTR) & M_PILADBGRDPTR) + +#define S_LAMASKTRIG 13 +#define V_LAMASKTRIG(x) ((x) << S_LAMASKTRIG) +#define F_LAMASKTRIG V_LAMASKTRIG(1U) + +#define S_LADBGEN 12 +#define V_LADBGEN(x) ((x) << S_LADBGEN) +#define F_LADBGEN V_LADBGEN(1U) + +#define S_LAFILLONCE 11 +#define V_LAFILLONCE(x) ((x) << S_LAFILLONCE) +#define F_LAFILLONCE V_LAFILLONCE(1U) + +#define S_LAMASKSTOP 10 +#define V_LAMASKSTOP(x) ((x) << S_LAMASKSTOP) +#define F_LAMASKSTOP V_LAMASKSTOP(1U) + +#define S_DEBUGSELH 5 +#define M_DEBUGSELH 0x1fU +#define V_DEBUGSELH(x) ((x) << S_DEBUGSELH) +#define G_DEBUGSELH(x) (((x) >> S_DEBUGSELH) & M_DEBUGSELH) + +#define S_DEBUGSELL 0 +#define M_DEBUGSELL 0x1fU +#define V_DEBUGSELL(x) ((x) << S_DEBUGSELL) +#define G_DEBUGSELL(x) (((x) >> S_DEBUGSELL) & M_DEBUGSELL) + +#define A_CIM_DEBUGSTS 0x7b74 + +#define S_LARESET 31 +#define V_LARESET(x) ((x) << S_LARESET) +#define F_LARESET V_LARESET(1U) + +#define S_POLADBGWRPTR 16 +#define M_POLADBGWRPTR 0x1ffU +#define V_POLADBGWRPTR(x) ((x) << S_POLADBGWRPTR) +#define G_POLADBGWRPTR(x) (((x) >> S_POLADBGWRPTR) & M_POLADBGWRPTR) + +#define S_PILADBGWRPTR 0 +#define M_PILADBGWRPTR 0x1ffU +#define V_PILADBGWRPTR(x) ((x) << S_PILADBGWRPTR) +#define G_PILADBGWRPTR(x) (((x) >> S_PILADBGWRPTR) & M_PILADBGWRPTR) + +#define A_CIM_PO_LA_DEBUGDATA 0x7b78 +#define A_CIM_PI_LA_DEBUGDATA 0x7b7c +#define A_CIM_PO_LA_MADEBUGDATA 0x7b80 +#define A_CIM_PI_LA_MADEBUGDATA 0x7b84 +#define A_CIM_PO_LA_PIFSMDEBUGDATA 0x7b8c +#define A_CIM_MEM_ZONE0_VA 0x7b90 + +#define S_MEM_ZONE_VA 4 +#define M_MEM_ZONE_VA 0xfffffffU +#define V_MEM_ZONE_VA(x) ((x) << S_MEM_ZONE_VA) +#define G_MEM_ZONE_VA(x) (((x) >> S_MEM_ZONE_VA) & M_MEM_ZONE_VA) + +#define A_CIM_MEM_ZONE0_BA 0x7b94 + +#define S_MEM_ZONE_BA 6 +#define M_MEM_ZONE_BA 0x3ffffffU +#define V_MEM_ZONE_BA(x) ((x) << S_MEM_ZONE_BA) +#define G_MEM_ZONE_BA(x) (((x) >> S_MEM_ZONE_BA) & M_MEM_ZONE_BA) + +#define S_PBT_ENABLE 5 +#define V_PBT_ENABLE(x) ((x) << S_PBT_ENABLE) +#define F_PBT_ENABLE V_PBT_ENABLE(1U) + +#define S_ZONE_DST 0 +#define M_ZONE_DST 0x3U +#define V_ZONE_DST(x) ((x) << S_ZONE_DST) +#define G_ZONE_DST(x) (((x) >> S_ZONE_DST) & M_ZONE_DST) + +#define A_CIM_MEM_ZONE0_LEN 0x7b98 + +#define S_MEM_ZONE_LEN 4 +#define M_MEM_ZONE_LEN 0xfffffffU +#define V_MEM_ZONE_LEN(x) ((x) << S_MEM_ZONE_LEN) +#define G_MEM_ZONE_LEN(x) (((x) >> S_MEM_ZONE_LEN) & M_MEM_ZONE_LEN) + +#define A_CIM_MEM_ZONE1_VA 0x7b9c +#define A_CIM_MEM_ZONE1_BA 0x7ba0 +#define A_CIM_MEM_ZONE1_LEN 0x7ba4 +#define A_CIM_MEM_ZONE2_VA 0x7ba8 +#define A_CIM_MEM_ZONE2_BA 0x7bac +#define A_CIM_MEM_ZONE2_LEN 0x7bb0 +#define A_CIM_MEM_ZONE3_VA 0x7bb4 +#define A_CIM_MEM_ZONE3_BA 0x7bb8 +#define A_CIM_MEM_ZONE3_LEN 0x7bbc +#define A_CIM_MEM_ZONE4_VA 0x7bc0 +#define A_CIM_MEM_ZONE4_BA 0x7bc4 +#define A_CIM_MEM_ZONE4_LEN 0x7bc8 +#define A_CIM_MEM_ZONE5_VA 0x7bcc +#define A_CIM_MEM_ZONE5_BA 0x7bd0 +#define A_CIM_MEM_ZONE5_LEN 0x7bd4 +#define A_CIM_MEM_ZONE6_VA 0x7bd8 +#define A_CIM_MEM_ZONE6_BA 0x7bdc +#define A_CIM_MEM_ZONE6_LEN 0x7be0 +#define A_CIM_MEM_ZONE7_VA 0x7be4 +#define A_CIM_MEM_ZONE7_BA 0x7be8 +#define A_CIM_MEM_ZONE7_LEN 0x7bec +#define A_CIM_BOOT_LEN 0x7bf0 + +#define S_BOOTLEN 4 +#define M_BOOTLEN 0xfffffffU +#define V_BOOTLEN(x) ((x) << S_BOOTLEN) +#define G_BOOTLEN(x) (((x) >> S_BOOTLEN) & M_BOOTLEN) + +#define A_CIM_GLB_TIMER_CTL 0x7bf4 + +#define S_TIMER1EN 4 +#define V_TIMER1EN(x) ((x) << S_TIMER1EN) +#define F_TIMER1EN V_TIMER1EN(1U) + +#define S_TIMER0EN 3 +#define V_TIMER0EN(x) ((x) << S_TIMER0EN) +#define F_TIMER0EN V_TIMER0EN(1U) + +#define S_TIMEREN 1 +#define V_TIMEREN(x) ((x) << S_TIMEREN) +#define F_TIMEREN V_TIMEREN(1U) + +#define A_CIM_GLB_TIMER 0x7bf8 +#define A_CIM_GLB_TIMER_TICK 0x7bfc + +#define S_GLBLTTICK 0 +#define M_GLBLTTICK 0xffffU +#define V_GLBLTTICK(x) ((x) << S_GLBLTTICK) +#define G_GLBLTTICK(x) (((x) >> S_GLBLTTICK) & M_GLBLTTICK) + +#define A_CIM_TIMER0 0x7c00 +#define A_CIM_TIMER1 0x7c04 +#define A_CIM_DEBUG_ADDR_TIMEOUT 0x7c08 + +#define S_DADDRTIMEOUT 2 +#define M_DADDRTIMEOUT 0x3fffffffU +#define V_DADDRTIMEOUT(x) ((x) << S_DADDRTIMEOUT) +#define G_DADDRTIMEOUT(x) (((x) >> S_DADDRTIMEOUT) & M_DADDRTIMEOUT) + +#define A_CIM_DEBUG_ADDR_ILLEGAL 0x7c0c + +#define S_DADDRILLEGAL 2 +#define M_DADDRILLEGAL 0x3fffffffU +#define V_DADDRILLEGAL(x) ((x) << S_DADDRILLEGAL) +#define G_DADDRILLEGAL(x) (((x) >> S_DADDRILLEGAL) & M_DADDRILLEGAL) + +#define A_CIM_DEBUG_PIF_CAUSE_MASK 0x7c10 + +#define S_DPIFHOSTMASK 0 +#define M_DPIFHOSTMASK 0x1fffffU +#define V_DPIFHOSTMASK(x) ((x) << S_DPIFHOSTMASK) +#define G_DPIFHOSTMASK(x) (((x) >> S_DPIFHOSTMASK) & M_DPIFHOSTMASK) + +#define S_T5_DPIFHOSTMASK 0 +#define M_T5_DPIFHOSTMASK 0x1fffffffU +#define V_T5_DPIFHOSTMASK(x) ((x) << S_T5_DPIFHOSTMASK) +#define G_T5_DPIFHOSTMASK(x) (((x) >> S_T5_DPIFHOSTMASK) & M_T5_DPIFHOSTMASK) + +#define A_CIM_DEBUG_PIF_UPACC_CAUSE_MASK 0x7c14 + +#define S_DPIFHUPAMASK 0 +#define M_DPIFHUPAMASK 0x7fffffffU +#define V_DPIFHUPAMASK(x) ((x) << S_DPIFHUPAMASK) +#define G_DPIFHUPAMASK(x) (((x) >> S_DPIFHUPAMASK) & M_DPIFHUPAMASK) + +#define A_CIM_DEBUG_UP_CAUSE_MASK 0x7c18 + +#define S_DUPMASK 0 +#define M_DUPMASK 0x1fffffU +#define V_DUPMASK(x) ((x) << S_DUPMASK) +#define G_DUPMASK(x) (((x) >> S_DUPMASK) & M_DUPMASK) + +#define S_T5_DUPMASK 0 +#define M_T5_DUPMASK 0x1fffffffU +#define V_T5_DUPMASK(x) ((x) << S_T5_DUPMASK) +#define G_T5_DUPMASK(x) (((x) >> S_T5_DUPMASK) & M_T5_DUPMASK) + +#define A_CIM_DEBUG_UP_UPACC_CAUSE_MASK 0x7c1c + +#define S_DUPUACCMASK 0 +#define M_DUPUACCMASK 0x7fffffffU +#define V_DUPUACCMASK(x) ((x) << S_DUPUACCMASK) +#define G_DUPUACCMASK(x) (((x) >> S_DUPUACCMASK) & M_DUPUACCMASK) + +#define A_CIM_PERR_INJECT 0x7c20 +#define A_CIM_PERR_ENABLE 0x7c24 + +#define S_PERREN 0 +#define M_PERREN 0x1fffffU +#define V_PERREN(x) ((x) << S_PERREN) +#define G_PERREN(x) (((x) >> S_PERREN) & M_PERREN) + +#define S_T5_PERREN 0 +#define M_T5_PERREN 0x1fffffffU +#define V_T5_PERREN(x) ((x) << S_T5_PERREN) +#define G_T5_PERREN(x) (((x) >> S_T5_PERREN) & M_T5_PERREN) + +#define A_CIM_EEPROM_BUSY_BIT 0x7c28 + +#define S_EEPROMBUSY 0 +#define V_EEPROMBUSY(x) ((x) << S_EEPROMBUSY) +#define F_EEPROMBUSY V_EEPROMBUSY(1U) + +#define A_CIM_MA_TIMER_EN 0x7c2c + +#define S_MA_TIMER_ENABLE 0 +#define V_MA_TIMER_ENABLE(x) ((x) << S_MA_TIMER_ENABLE) +#define F_MA_TIMER_ENABLE V_MA_TIMER_ENABLE(1U) + +#define A_CIM_UP_PO_SINGLE_OUTSTANDING 0x7c30 + +#define S_UP_PO_SINGLE_OUTSTANDING 0 +#define V_UP_PO_SINGLE_OUTSTANDING(x) ((x) << S_UP_PO_SINGLE_OUTSTANDING) +#define F_UP_PO_SINGLE_OUTSTANDING V_UP_PO_SINGLE_OUTSTANDING(1U) + +#define A_CIM_CIM_DEBUG_SPARE 0x7c34 +#define A_CIM_UP_OPERATION_FREQ 0x7c38 +#define A_CIM_CIM_IBQ_ERR_CODE 0x7c3c + +#define S_CIM_ULP_TX_PKT_ERR_CODE 16 +#define M_CIM_ULP_TX_PKT_ERR_CODE 0xffU +#define V_CIM_ULP_TX_PKT_ERR_CODE(x) ((x) << S_CIM_ULP_TX_PKT_ERR_CODE) +#define G_CIM_ULP_TX_PKT_ERR_CODE(x) (((x) >> S_CIM_ULP_TX_PKT_ERR_CODE) & M_CIM_ULP_TX_PKT_ERR_CODE) + +#define S_CIM_SGE1_PKT_ERR_CODE 8 +#define M_CIM_SGE1_PKT_ERR_CODE 0xffU +#define V_CIM_SGE1_PKT_ERR_CODE(x) ((x) << S_CIM_SGE1_PKT_ERR_CODE) +#define G_CIM_SGE1_PKT_ERR_CODE(x) (((x) >> S_CIM_SGE1_PKT_ERR_CODE) & M_CIM_SGE1_PKT_ERR_CODE) + +#define S_CIM_SGE0_PKT_ERR_CODE 0 +#define M_CIM_SGE0_PKT_ERR_CODE 0xffU +#define V_CIM_SGE0_PKT_ERR_CODE(x) ((x) << S_CIM_SGE0_PKT_ERR_CODE) +#define G_CIM_SGE0_PKT_ERR_CODE(x) (((x) >> S_CIM_SGE0_PKT_ERR_CODE) & M_CIM_SGE0_PKT_ERR_CODE) + +#define A_CIM_IBQ_DBG_WAIT_COUNTER 0x7c40 +#define A_CIM_PIO_UP_MST_CFG_SEL 0x7c44 + +#define S_PIO_UP_MST_CFG_SEL 0 +#define V_PIO_UP_MST_CFG_SEL(x) ((x) << S_PIO_UP_MST_CFG_SEL) +#define F_PIO_UP_MST_CFG_SEL V_PIO_UP_MST_CFG_SEL(1U) + +#define A_CIM_CGEN 0x7c48 + +#define S_TSCH_CGEN 0 +#define V_TSCH_CGEN(x) ((x) << S_TSCH_CGEN) +#define F_TSCH_CGEN V_TSCH_CGEN(1U) + +#define A_CIM_QUEUE_FEATURE_DISABLE 0x7c4c + +#define S_OBQ_THROUTTLE_ON_EOP 4 +#define V_OBQ_THROUTTLE_ON_EOP(x) ((x) << S_OBQ_THROUTTLE_ON_EOP) +#define F_OBQ_THROUTTLE_ON_EOP V_OBQ_THROUTTLE_ON_EOP(1U) + +#define S_OBQ_READ_CTL_PERF_MODE_DISABLE 3 +#define V_OBQ_READ_CTL_PERF_MODE_DISABLE(x) ((x) << S_OBQ_READ_CTL_PERF_MODE_DISABLE) +#define F_OBQ_READ_CTL_PERF_MODE_DISABLE V_OBQ_READ_CTL_PERF_MODE_DISABLE(1U) + +#define S_OBQ_WAIT_FOR_EOP_FLUSH_DISABLE 2 +#define V_OBQ_WAIT_FOR_EOP_FLUSH_DISABLE(x) ((x) << S_OBQ_WAIT_FOR_EOP_FLUSH_DISABLE) +#define F_OBQ_WAIT_FOR_EOP_FLUSH_DISABLE V_OBQ_WAIT_FOR_EOP_FLUSH_DISABLE(1U) + +#define S_IBQ_RRA_DSBL 1 +#define V_IBQ_RRA_DSBL(x) ((x) << S_IBQ_RRA_DSBL) +#define F_IBQ_RRA_DSBL V_IBQ_RRA_DSBL(1U) + +#define S_IBQ_SKID_FIFO_EOP_FLSH_DSBL 0 +#define V_IBQ_SKID_FIFO_EOP_FLSH_DSBL(x) ((x) << S_IBQ_SKID_FIFO_EOP_FLSH_DSBL) +#define F_IBQ_SKID_FIFO_EOP_FLSH_DSBL V_IBQ_SKID_FIFO_EOP_FLSH_DSBL(1U) + +#define A_CIM_CGEN_GLOBAL 0x7c50 + +#define S_CGEN_GLOBAL 0 +#define V_CGEN_GLOBAL(x) ((x) << S_CGEN_GLOBAL) +#define F_CGEN_GLOBAL V_CGEN_GLOBAL(1U) + +#define A_CIM_DPSLP_EN 0x7c54 + +#define S_PIFDBGLA_DPSLP_EN 0 +#define V_PIFDBGLA_DPSLP_EN(x) ((x) << S_PIFDBGLA_DPSLP_EN) +#define F_PIFDBGLA_DPSLP_EN V_PIFDBGLA_DPSLP_EN(1U) + +/* registers for module TP */ +#define TP_BASE_ADDR 0x7d00 + +#define A_TP_IN_CONFIG 0x7d00 + +#define S_TCPOPTPARSERDISCH3 27 +#define V_TCPOPTPARSERDISCH3(x) ((x) << S_TCPOPTPARSERDISCH3) +#define F_TCPOPTPARSERDISCH3 V_TCPOPTPARSERDISCH3(1U) + +#define S_TCPOPTPARSERDISCH2 26 +#define V_TCPOPTPARSERDISCH2(x) ((x) << S_TCPOPTPARSERDISCH2) +#define F_TCPOPTPARSERDISCH2 V_TCPOPTPARSERDISCH2(1U) + +#define S_TCPOPTPARSERDISCH1 25 +#define V_TCPOPTPARSERDISCH1(x) ((x) << S_TCPOPTPARSERDISCH1) +#define F_TCPOPTPARSERDISCH1 V_TCPOPTPARSERDISCH1(1U) + +#define S_TCPOPTPARSERDISCH0 24 +#define V_TCPOPTPARSERDISCH0(x) ((x) << S_TCPOPTPARSERDISCH0) +#define F_TCPOPTPARSERDISCH0 V_TCPOPTPARSERDISCH0(1U) + +#define S_CRCPASSPRT3 23 +#define V_CRCPASSPRT3(x) ((x) << S_CRCPASSPRT3) +#define F_CRCPASSPRT3 V_CRCPASSPRT3(1U) + +#define S_CRCPASSPRT2 22 +#define V_CRCPASSPRT2(x) ((x) << S_CRCPASSPRT2) +#define F_CRCPASSPRT2 V_CRCPASSPRT2(1U) + +#define S_CRCPASSPRT1 21 +#define V_CRCPASSPRT1(x) ((x) << S_CRCPASSPRT1) +#define F_CRCPASSPRT1 V_CRCPASSPRT1(1U) + +#define S_CRCPASSPRT0 20 +#define V_CRCPASSPRT0(x) ((x) << S_CRCPASSPRT0) +#define F_CRCPASSPRT0 V_CRCPASSPRT0(1U) + +#define S_VEPAMODE 19 +#define V_VEPAMODE(x) ((x) << S_VEPAMODE) +#define F_VEPAMODE V_VEPAMODE(1U) + +#define S_FIPUPEN 18 +#define V_FIPUPEN(x) ((x) << S_FIPUPEN) +#define F_FIPUPEN V_FIPUPEN(1U) + +#define S_FCOEUPEN 17 +#define V_FCOEUPEN(x) ((x) << S_FCOEUPEN) +#define F_FCOEUPEN V_FCOEUPEN(1U) + +#define S_FCOEENABLE 16 +#define V_FCOEENABLE(x) ((x) << S_FCOEENABLE) +#define F_FCOEENABLE V_FCOEENABLE(1U) + +#define S_IPV6ENABLE 15 +#define V_IPV6ENABLE(x) ((x) << S_IPV6ENABLE) +#define F_IPV6ENABLE V_IPV6ENABLE(1U) + +#define S_NICMODE 14 +#define V_NICMODE(x) ((x) << S_NICMODE) +#define F_NICMODE V_NICMODE(1U) + +#define S_ECHECKSUMCHECKTCP 13 +#define V_ECHECKSUMCHECKTCP(x) ((x) << S_ECHECKSUMCHECKTCP) +#define F_ECHECKSUMCHECKTCP V_ECHECKSUMCHECKTCP(1U) + +#define S_ECHECKSUMCHECKIP 12 +#define V_ECHECKSUMCHECKIP(x) ((x) << S_ECHECKSUMCHECKIP) +#define F_ECHECKSUMCHECKIP V_ECHECKSUMCHECKIP(1U) + +#define S_EREPORTUDPHDRLEN 11 +#define V_EREPORTUDPHDRLEN(x) ((x) << S_EREPORTUDPHDRLEN) +#define F_EREPORTUDPHDRLEN V_EREPORTUDPHDRLEN(1U) + +#define S_IN_ECPL 10 +#define V_IN_ECPL(x) ((x) << S_IN_ECPL) +#define F_IN_ECPL V_IN_ECPL(1U) + +#define S_VNTAGENABLE 9 +#define V_VNTAGENABLE(x) ((x) << S_VNTAGENABLE) +#define F_VNTAGENABLE V_VNTAGENABLE(1U) + +#define S_IN_EETH 8 +#define V_IN_EETH(x) ((x) << S_IN_EETH) +#define F_IN_EETH V_IN_EETH(1U) + +#define S_CCHECKSUMCHECKTCP 6 +#define V_CCHECKSUMCHECKTCP(x) ((x) << S_CCHECKSUMCHECKTCP) +#define F_CCHECKSUMCHECKTCP V_CCHECKSUMCHECKTCP(1U) + +#define S_CCHECKSUMCHECKIP 5 +#define V_CCHECKSUMCHECKIP(x) ((x) << S_CCHECKSUMCHECKIP) +#define F_CCHECKSUMCHECKIP V_CCHECKSUMCHECKIP(1U) + +#define S_CTAG 4 +#define V_CTAG(x) ((x) << S_CTAG) +#define F_CTAG V_CTAG(1U) + +#define S_IN_CCPL 3 +#define V_IN_CCPL(x) ((x) << S_IN_CCPL) +#define F_IN_CCPL V_IN_CCPL(1U) + +#define S_IN_CETH 1 +#define V_IN_CETH(x) ((x) << S_IN_CETH) +#define F_IN_CETH V_IN_CETH(1U) + +#define S_CTUNNEL 0 +#define V_CTUNNEL(x) ((x) << S_CTUNNEL) +#define F_CTUNNEL V_CTUNNEL(1U) + +#define S_VLANEXTENPORT3 31 +#define V_VLANEXTENPORT3(x) ((x) << S_VLANEXTENPORT3) +#define F_VLANEXTENPORT3 V_VLANEXTENPORT3(1U) + +#define S_VLANEXTENPORT2 30 +#define V_VLANEXTENPORT2(x) ((x) << S_VLANEXTENPORT2) +#define F_VLANEXTENPORT2 V_VLANEXTENPORT2(1U) + +#define S_VLANEXTENPORT1 29 +#define V_VLANEXTENPORT1(x) ((x) << S_VLANEXTENPORT1) +#define F_VLANEXTENPORT1 V_VLANEXTENPORT1(1U) + +#define S_VLANEXTENPORT0 28 +#define V_VLANEXTENPORT0(x) ((x) << S_VLANEXTENPORT0) +#define F_VLANEXTENPORT0 V_VLANEXTENPORT0(1U) + +#define S_VNTAGDEFAULTVAL 13 +#define V_VNTAGDEFAULTVAL(x) ((x) << S_VNTAGDEFAULTVAL) +#define F_VNTAGDEFAULTVAL V_VNTAGDEFAULTVAL(1U) + +#define S_ECHECKUDPLEN 12 +#define V_ECHECKUDPLEN(x) ((x) << S_ECHECKUDPLEN) +#define F_ECHECKUDPLEN V_ECHECKUDPLEN(1U) + +#define S_FCOEFPMA 10 +#define V_FCOEFPMA(x) ((x) << S_FCOEFPMA) +#define F_FCOEFPMA V_FCOEFPMA(1U) + +#define S_VNTAGETHENABLE 8 +#define V_VNTAGETHENABLE(x) ((x) << S_VNTAGETHENABLE) +#define F_VNTAGETHENABLE V_VNTAGETHENABLE(1U) + +#define S_IP_CCSM 7 +#define V_IP_CCSM(x) ((x) << S_IP_CCSM) +#define F_IP_CCSM V_IP_CCSM(1U) + +#define S_CCHECKSUMCHECKUDP 6 +#define V_CCHECKSUMCHECKUDP(x) ((x) << S_CCHECKSUMCHECKUDP) +#define F_CCHECKSUMCHECKUDP V_CCHECKSUMCHECKUDP(1U) + +#define S_TCP_CCSM 5 +#define V_TCP_CCSM(x) ((x) << S_TCP_CCSM) +#define F_TCP_CCSM V_TCP_CCSM(1U) + +#define S_CDEMUX 3 +#define V_CDEMUX(x) ((x) << S_CDEMUX) +#define F_CDEMUX V_CDEMUX(1U) + +#define S_ETHUPEN 2 +#define V_ETHUPEN(x) ((x) << S_ETHUPEN) +#define F_ETHUPEN V_ETHUPEN(1U) + +#define A_TP_OUT_CONFIG 0x7d04 + +#define S_PORTQFCEN 28 +#define M_PORTQFCEN 0xfU +#define V_PORTQFCEN(x) ((x) << S_PORTQFCEN) +#define G_PORTQFCEN(x) (((x) >> S_PORTQFCEN) & M_PORTQFCEN) + +#define S_EPKTDISTCHN3 23 +#define V_EPKTDISTCHN3(x) ((x) << S_EPKTDISTCHN3) +#define F_EPKTDISTCHN3 V_EPKTDISTCHN3(1U) + +#define S_EPKTDISTCHN2 22 +#define V_EPKTDISTCHN2(x) ((x) << S_EPKTDISTCHN2) +#define F_EPKTDISTCHN2 V_EPKTDISTCHN2(1U) + +#define S_EPKTDISTCHN1 21 +#define V_EPKTDISTCHN1(x) ((x) << S_EPKTDISTCHN1) +#define F_EPKTDISTCHN1 V_EPKTDISTCHN1(1U) + +#define S_EPKTDISTCHN0 20 +#define V_EPKTDISTCHN0(x) ((x) << S_EPKTDISTCHN0) +#define F_EPKTDISTCHN0 V_EPKTDISTCHN0(1U) + +#define S_TTLMODE 19 +#define V_TTLMODE(x) ((x) << S_TTLMODE) +#define F_TTLMODE V_TTLMODE(1U) + +#define S_EQFCDMAC 18 +#define V_EQFCDMAC(x) ((x) << S_EQFCDMAC) +#define F_EQFCDMAC V_EQFCDMAC(1U) + +#define S_ELPBKINCMPSSTAT 17 +#define V_ELPBKINCMPSSTAT(x) ((x) << S_ELPBKINCMPSSTAT) +#define F_ELPBKINCMPSSTAT V_ELPBKINCMPSSTAT(1U) + +#define S_IPIDSPLITMODE 16 +#define V_IPIDSPLITMODE(x) ((x) << S_IPIDSPLITMODE) +#define F_IPIDSPLITMODE V_IPIDSPLITMODE(1U) + +#define S_VLANEXTENABLEPORT3 15 +#define V_VLANEXTENABLEPORT3(x) ((x) << S_VLANEXTENABLEPORT3) +#define F_VLANEXTENABLEPORT3 V_VLANEXTENABLEPORT3(1U) + +#define S_VLANEXTENABLEPORT2 14 +#define V_VLANEXTENABLEPORT2(x) ((x) << S_VLANEXTENABLEPORT2) +#define F_VLANEXTENABLEPORT2 V_VLANEXTENABLEPORT2(1U) + +#define S_VLANEXTENABLEPORT1 13 +#define V_VLANEXTENABLEPORT1(x) ((x) << S_VLANEXTENABLEPORT1) +#define F_VLANEXTENABLEPORT1 V_VLANEXTENABLEPORT1(1U) + +#define S_VLANEXTENABLEPORT0 12 +#define V_VLANEXTENABLEPORT0(x) ((x) << S_VLANEXTENABLEPORT0) +#define F_VLANEXTENABLEPORT0 V_VLANEXTENABLEPORT0(1U) + +#define S_ECHECKSUMINSERTTCP 11 +#define V_ECHECKSUMINSERTTCP(x) ((x) << S_ECHECKSUMINSERTTCP) +#define F_ECHECKSUMINSERTTCP V_ECHECKSUMINSERTTCP(1U) + +#define S_ECHECKSUMINSERTIP 10 +#define V_ECHECKSUMINSERTIP(x) ((x) << S_ECHECKSUMINSERTIP) +#define F_ECHECKSUMINSERTIP V_ECHECKSUMINSERTIP(1U) + +#define S_ECPL 8 +#define V_ECPL(x) ((x) << S_ECPL) +#define F_ECPL V_ECPL(1U) + +#define S_EPRIORITY 7 +#define V_EPRIORITY(x) ((x) << S_EPRIORITY) +#define F_EPRIORITY V_EPRIORITY(1U) + +#define S_EETHERNET 6 +#define V_EETHERNET(x) ((x) << S_EETHERNET) +#define F_EETHERNET V_EETHERNET(1U) + +#define S_CCHECKSUMINSERTTCP 5 +#define V_CCHECKSUMINSERTTCP(x) ((x) << S_CCHECKSUMINSERTTCP) +#define F_CCHECKSUMINSERTTCP V_CCHECKSUMINSERTTCP(1U) + +#define S_CCHECKSUMINSERTIP 4 +#define V_CCHECKSUMINSERTIP(x) ((x) << S_CCHECKSUMINSERTIP) +#define F_CCHECKSUMINSERTIP V_CCHECKSUMINSERTIP(1U) + +#define S_CCPL 2 +#define V_CCPL(x) ((x) << S_CCPL) +#define F_CCPL V_CCPL(1U) + +#define S_CETHERNET 0 +#define V_CETHERNET(x) ((x) << S_CETHERNET) +#define F_CETHERNET V_CETHERNET(1U) + +#define S_EVNTAGEN 9 +#define V_EVNTAGEN(x) ((x) << S_EVNTAGEN) +#define F_EVNTAGEN V_EVNTAGEN(1U) + +#define A_TP_GLOBAL_CONFIG 0x7d08 + +#define S_SYNCOOKIEPARAMS 26 +#define M_SYNCOOKIEPARAMS 0x3fU +#define V_SYNCOOKIEPARAMS(x) ((x) << S_SYNCOOKIEPARAMS) +#define G_SYNCOOKIEPARAMS(x) (((x) >> S_SYNCOOKIEPARAMS) & M_SYNCOOKIEPARAMS) + +#define S_RXFLOWCONTROLDISABLE 25 +#define V_RXFLOWCONTROLDISABLE(x) ((x) << S_RXFLOWCONTROLDISABLE) +#define F_RXFLOWCONTROLDISABLE V_RXFLOWCONTROLDISABLE(1U) + +#define S_TXPACINGENABLE 24 +#define V_TXPACINGENABLE(x) ((x) << S_TXPACINGENABLE) +#define F_TXPACINGENABLE V_TXPACINGENABLE(1U) + +#define S_ATTACKFILTERENABLE 23 +#define V_ATTACKFILTERENABLE(x) ((x) << S_ATTACKFILTERENABLE) +#define F_ATTACKFILTERENABLE V_ATTACKFILTERENABLE(1U) + +#define S_SYNCOOKIENOOPTIONS 22 +#define V_SYNCOOKIENOOPTIONS(x) ((x) << S_SYNCOOKIENOOPTIONS) +#define F_SYNCOOKIENOOPTIONS V_SYNCOOKIENOOPTIONS(1U) + +#define S_PROTECTEDMODE 21 +#define V_PROTECTEDMODE(x) ((x) << S_PROTECTEDMODE) +#define F_PROTECTEDMODE V_PROTECTEDMODE(1U) + +#define S_PINGDROP 20 +#define V_PINGDROP(x) ((x) << S_PINGDROP) +#define F_PINGDROP V_PINGDROP(1U) + +#define S_FRAGMENTDROP 19 +#define V_FRAGMENTDROP(x) ((x) << S_FRAGMENTDROP) +#define F_FRAGMENTDROP V_FRAGMENTDROP(1U) + +#define S_FIVETUPLELOOKUP 17 +#define M_FIVETUPLELOOKUP 0x3U +#define V_FIVETUPLELOOKUP(x) ((x) << S_FIVETUPLELOOKUP) +#define G_FIVETUPLELOOKUP(x) (((x) >> S_FIVETUPLELOOKUP) & M_FIVETUPLELOOKUP) + +#define S_OFDMPSSTATS 16 +#define V_OFDMPSSTATS(x) ((x) << S_OFDMPSSTATS) +#define F_OFDMPSSTATS V_OFDMPSSTATS(1U) + +#define S_DONTFRAGMENT 15 +#define V_DONTFRAGMENT(x) ((x) << S_DONTFRAGMENT) +#define F_DONTFRAGMENT V_DONTFRAGMENT(1U) + +#define S_IPIDENTSPLIT 14 +#define V_IPIDENTSPLIT(x) ((x) << S_IPIDENTSPLIT) +#define F_IPIDENTSPLIT V_IPIDENTSPLIT(1U) + +#define S_IPCHECKSUMOFFLOAD 13 +#define V_IPCHECKSUMOFFLOAD(x) ((x) << S_IPCHECKSUMOFFLOAD) +#define F_IPCHECKSUMOFFLOAD V_IPCHECKSUMOFFLOAD(1U) + +#define S_UDPCHECKSUMOFFLOAD 12 +#define V_UDPCHECKSUMOFFLOAD(x) ((x) << S_UDPCHECKSUMOFFLOAD) +#define F_UDPCHECKSUMOFFLOAD V_UDPCHECKSUMOFFLOAD(1U) + +#define S_TCPCHECKSUMOFFLOAD 11 +#define V_TCPCHECKSUMOFFLOAD(x) ((x) << S_TCPCHECKSUMOFFLOAD) +#define F_TCPCHECKSUMOFFLOAD V_TCPCHECKSUMOFFLOAD(1U) + +#define S_RSSLOOPBACKENABLE 10 +#define V_RSSLOOPBACKENABLE(x) ((x) << S_RSSLOOPBACKENABLE) +#define F_RSSLOOPBACKENABLE V_RSSLOOPBACKENABLE(1U) + +#define S_TCAMSERVERUSE 8 +#define M_TCAMSERVERUSE 0x3U +#define V_TCAMSERVERUSE(x) ((x) << S_TCAMSERVERUSE) +#define G_TCAMSERVERUSE(x) (((x) >> S_TCAMSERVERUSE) & M_TCAMSERVERUSE) + +#define S_IPTTL 0 +#define M_IPTTL 0xffU +#define V_IPTTL(x) ((x) << S_IPTTL) +#define G_IPTTL(x) (((x) >> S_IPTTL) & M_IPTTL) + +#define S_RSSSYNSTEERENABLE 12 +#define V_RSSSYNSTEERENABLE(x) ((x) << S_RSSSYNSTEERENABLE) +#define F_RSSSYNSTEERENABLE V_RSSSYNSTEERENABLE(1U) + +#define S_ISSFROMCPLENABLE 11 +#define V_ISSFROMCPLENABLE(x) ((x) << S_ISSFROMCPLENABLE) +#define F_ISSFROMCPLENABLE V_ISSFROMCPLENABLE(1U) + +#define A_TP_DB_CONFIG 0x7d0c + +#define S_DBMAXOPCNT 24 +#define M_DBMAXOPCNT 0xffU +#define V_DBMAXOPCNT(x) ((x) << S_DBMAXOPCNT) +#define G_DBMAXOPCNT(x) (((x) >> S_DBMAXOPCNT) & M_DBMAXOPCNT) + +#define S_CXMAXOPCNTDISABLE 23 +#define V_CXMAXOPCNTDISABLE(x) ((x) << S_CXMAXOPCNTDISABLE) +#define F_CXMAXOPCNTDISABLE V_CXMAXOPCNTDISABLE(1U) + +#define S_CXMAXOPCNT 16 +#define M_CXMAXOPCNT 0x7fU +#define V_CXMAXOPCNT(x) ((x) << S_CXMAXOPCNT) +#define G_CXMAXOPCNT(x) (((x) >> S_CXMAXOPCNT) & M_CXMAXOPCNT) + +#define S_TXMAXOPCNTDISABLE 15 +#define V_TXMAXOPCNTDISABLE(x) ((x) << S_TXMAXOPCNTDISABLE) +#define F_TXMAXOPCNTDISABLE V_TXMAXOPCNTDISABLE(1U) + +#define S_TXMAXOPCNT 8 +#define M_TXMAXOPCNT 0x7fU +#define V_TXMAXOPCNT(x) ((x) << S_TXMAXOPCNT) +#define G_TXMAXOPCNT(x) (((x) >> S_TXMAXOPCNT) & M_TXMAXOPCNT) + +#define S_RXMAXOPCNTDISABLE 7 +#define V_RXMAXOPCNTDISABLE(x) ((x) << S_RXMAXOPCNTDISABLE) +#define F_RXMAXOPCNTDISABLE V_RXMAXOPCNTDISABLE(1U) + +#define S_RXMAXOPCNT 0 +#define M_RXMAXOPCNT 0x7fU +#define V_RXMAXOPCNT(x) ((x) << S_RXMAXOPCNT) +#define G_RXMAXOPCNT(x) (((x) >> S_RXMAXOPCNT) & M_RXMAXOPCNT) + +#define A_TP_CMM_TCB_BASE 0x7d10 +#define A_TP_CMM_MM_BASE 0x7d14 +#define A_TP_CMM_TIMER_BASE 0x7d18 +#define A_TP_CMM_MM_FLST_SIZE 0x7d1c + +#define S_RXPOOLSIZE 16 +#define M_RXPOOLSIZE 0xffffU +#define V_RXPOOLSIZE(x) ((x) << S_RXPOOLSIZE) +#define G_RXPOOLSIZE(x) (((x) >> S_RXPOOLSIZE) & M_RXPOOLSIZE) + +#define S_TXPOOLSIZE 0 +#define M_TXPOOLSIZE 0xffffU +#define V_TXPOOLSIZE(x) ((x) << S_TXPOOLSIZE) +#define G_TXPOOLSIZE(x) (((x) >> S_TXPOOLSIZE) & M_TXPOOLSIZE) + +#define A_TP_PMM_TX_BASE 0x7d20 +#define A_TP_PMM_DEFRAG_BASE 0x7d24 +#define A_TP_PMM_RX_BASE 0x7d28 +#define A_TP_PMM_RX_PAGE_SIZE 0x7d2c +#define A_TP_PMM_RX_MAX_PAGE 0x7d30 + +#define S_PMRXNUMCHN 31 +#define V_PMRXNUMCHN(x) ((x) << S_PMRXNUMCHN) +#define F_PMRXNUMCHN V_PMRXNUMCHN(1U) + +#define S_PMRXMAXPAGE 0 +#define M_PMRXMAXPAGE 0x1fffffU +#define V_PMRXMAXPAGE(x) ((x) << S_PMRXMAXPAGE) +#define G_PMRXMAXPAGE(x) (((x) >> S_PMRXMAXPAGE) & M_PMRXMAXPAGE) + +#define A_TP_PMM_TX_PAGE_SIZE 0x7d34 +#define A_TP_PMM_TX_MAX_PAGE 0x7d38 + +#define S_PMTXNUMCHN 30 +#define M_PMTXNUMCHN 0x3U +#define V_PMTXNUMCHN(x) ((x) << S_PMTXNUMCHN) +#define G_PMTXNUMCHN(x) (((x) >> S_PMTXNUMCHN) & M_PMTXNUMCHN) + +#define S_PMTXMAXPAGE 0 +#define M_PMTXMAXPAGE 0x1fffffU +#define V_PMTXMAXPAGE(x) ((x) << S_PMTXMAXPAGE) +#define G_PMTXMAXPAGE(x) (((x) >> S_PMTXMAXPAGE) & M_PMTXMAXPAGE) + +#define A_TP_TCP_OPTIONS 0x7d40 + +#define S_MTUDEFAULT 16 +#define M_MTUDEFAULT 0xffffU +#define V_MTUDEFAULT(x) ((x) << S_MTUDEFAULT) +#define G_MTUDEFAULT(x) (((x) >> S_MTUDEFAULT) & M_MTUDEFAULT) + +#define S_MTUENABLE 10 +#define V_MTUENABLE(x) ((x) << S_MTUENABLE) +#define F_MTUENABLE V_MTUENABLE(1U) + +#define S_SACKTX 9 +#define V_SACKTX(x) ((x) << S_SACKTX) +#define F_SACKTX V_SACKTX(1U) + +#define S_SACKRX 8 +#define V_SACKRX(x) ((x) << S_SACKRX) +#define F_SACKRX V_SACKRX(1U) + +#define S_SACKMODE 4 +#define M_SACKMODE 0x3U +#define V_SACKMODE(x) ((x) << S_SACKMODE) +#define G_SACKMODE(x) (((x) >> S_SACKMODE) & M_SACKMODE) + +#define S_WINDOWSCALEMODE 2 +#define M_WINDOWSCALEMODE 0x3U +#define V_WINDOWSCALEMODE(x) ((x) << S_WINDOWSCALEMODE) +#define G_WINDOWSCALEMODE(x) (((x) >> S_WINDOWSCALEMODE) & M_WINDOWSCALEMODE) + +#define S_TIMESTAMPSMODE 0 +#define M_TIMESTAMPSMODE 0x3U +#define V_TIMESTAMPSMODE(x) ((x) << S_TIMESTAMPSMODE) +#define G_TIMESTAMPSMODE(x) (((x) >> S_TIMESTAMPSMODE) & M_TIMESTAMPSMODE) + +#define A_TP_DACK_CONFIG 0x7d44 + +#define S_AUTOSTATE3 30 +#define M_AUTOSTATE3 0x3U +#define V_AUTOSTATE3(x) ((x) << S_AUTOSTATE3) +#define G_AUTOSTATE3(x) (((x) >> S_AUTOSTATE3) & M_AUTOSTATE3) + +#define S_AUTOSTATE2 28 +#define M_AUTOSTATE2 0x3U +#define V_AUTOSTATE2(x) ((x) << S_AUTOSTATE2) +#define G_AUTOSTATE2(x) (((x) >> S_AUTOSTATE2) & M_AUTOSTATE2) + +#define S_AUTOSTATE1 26 +#define M_AUTOSTATE1 0x3U +#define V_AUTOSTATE1(x) ((x) << S_AUTOSTATE1) +#define G_AUTOSTATE1(x) (((x) >> S_AUTOSTATE1) & M_AUTOSTATE1) + +#define S_BYTETHRESHOLD 8 +#define M_BYTETHRESHOLD 0x3ffffU +#define V_BYTETHRESHOLD(x) ((x) << S_BYTETHRESHOLD) +#define G_BYTETHRESHOLD(x) (((x) >> S_BYTETHRESHOLD) & M_BYTETHRESHOLD) + +#define S_MSSTHRESHOLD 4 +#define M_MSSTHRESHOLD 0x7U +#define V_MSSTHRESHOLD(x) ((x) << S_MSSTHRESHOLD) +#define G_MSSTHRESHOLD(x) (((x) >> S_MSSTHRESHOLD) & M_MSSTHRESHOLD) + +#define S_AUTOCAREFUL 2 +#define V_AUTOCAREFUL(x) ((x) << S_AUTOCAREFUL) +#define F_AUTOCAREFUL V_AUTOCAREFUL(1U) + +#define S_AUTOENABLE 1 +#define V_AUTOENABLE(x) ((x) << S_AUTOENABLE) +#define F_AUTOENABLE V_AUTOENABLE(1U) + +#define S_MODE 0 +#define V_MODE(x) ((x) << S_MODE) +#define F_MODE V_MODE(1U) + +#define A_TP_PC_CONFIG 0x7d48 + +#define S_CMCACHEDISABLE 31 +#define V_CMCACHEDISABLE(x) ((x) << S_CMCACHEDISABLE) +#define F_CMCACHEDISABLE V_CMCACHEDISABLE(1U) + +#define S_ENABLEOCSPIFULL 30 +#define V_ENABLEOCSPIFULL(x) ((x) << S_ENABLEOCSPIFULL) +#define F_ENABLEOCSPIFULL V_ENABLEOCSPIFULL(1U) + +#define S_ENABLEFLMERRORDDP 29 +#define V_ENABLEFLMERRORDDP(x) ((x) << S_ENABLEFLMERRORDDP) +#define F_ENABLEFLMERRORDDP V_ENABLEFLMERRORDDP(1U) + +#define S_LOCKTID 28 +#define V_LOCKTID(x) ((x) << S_LOCKTID) +#define F_LOCKTID V_LOCKTID(1U) + +#define S_DISABLEINVPEND 27 +#define V_DISABLEINVPEND(x) ((x) << S_DISABLEINVPEND) +#define F_DISABLEINVPEND V_DISABLEINVPEND(1U) + +#define S_ENABLEFILTERCOUNT 26 +#define V_ENABLEFILTERCOUNT(x) ((x) << S_ENABLEFILTERCOUNT) +#define F_ENABLEFILTERCOUNT V_ENABLEFILTERCOUNT(1U) + +#define S_RDDPCONGEN 25 +#define V_RDDPCONGEN(x) ((x) << S_RDDPCONGEN) +#define F_RDDPCONGEN V_RDDPCONGEN(1U) + +#define S_ENABLEONFLYPDU 24 +#define V_ENABLEONFLYPDU(x) ((x) << S_ENABLEONFLYPDU) +#define F_ENABLEONFLYPDU V_ENABLEONFLYPDU(1U) + +#define S_ENABLEMINRCVWND 23 +#define V_ENABLEMINRCVWND(x) ((x) << S_ENABLEMINRCVWND) +#define F_ENABLEMINRCVWND V_ENABLEMINRCVWND(1U) + +#define S_ENABLEMAXRCVWND 22 +#define V_ENABLEMAXRCVWND(x) ((x) << S_ENABLEMAXRCVWND) +#define F_ENABLEMAXRCVWND V_ENABLEMAXRCVWND(1U) + +#define S_TXDATAACKRATEENABLE 21 +#define V_TXDATAACKRATEENABLE(x) ((x) << S_TXDATAACKRATEENABLE) +#define F_TXDATAACKRATEENABLE V_TXDATAACKRATEENABLE(1U) + +#define S_TXDEFERENABLE 20 +#define V_TXDEFERENABLE(x) ((x) << S_TXDEFERENABLE) +#define F_TXDEFERENABLE V_TXDEFERENABLE(1U) + +#define S_RXCONGESTIONMODE 19 +#define V_RXCONGESTIONMODE(x) ((x) << S_RXCONGESTIONMODE) +#define F_RXCONGESTIONMODE V_RXCONGESTIONMODE(1U) + +#define S_HEARBEATONCEDACK 18 +#define V_HEARBEATONCEDACK(x) ((x) << S_HEARBEATONCEDACK) +#define F_HEARBEATONCEDACK V_HEARBEATONCEDACK(1U) + +#define S_HEARBEATONCEHEAP 17 +#define V_HEARBEATONCEHEAP(x) ((x) << S_HEARBEATONCEHEAP) +#define F_HEARBEATONCEHEAP V_HEARBEATONCEHEAP(1U) + +#define S_HEARBEATDACK 16 +#define V_HEARBEATDACK(x) ((x) << S_HEARBEATDACK) +#define F_HEARBEATDACK V_HEARBEATDACK(1U) + +#define S_TXCONGESTIONMODE 15 +#define V_TXCONGESTIONMODE(x) ((x) << S_TXCONGESTIONMODE) +#define F_TXCONGESTIONMODE V_TXCONGESTIONMODE(1U) + +#define S_ACCEPTLATESTRCVADV 14 +#define V_ACCEPTLATESTRCVADV(x) ((x) << S_ACCEPTLATESTRCVADV) +#define F_ACCEPTLATESTRCVADV V_ACCEPTLATESTRCVADV(1U) + +#define S_DISABLESYNDATA 13 +#define V_DISABLESYNDATA(x) ((x) << S_DISABLESYNDATA) +#define F_DISABLESYNDATA V_DISABLESYNDATA(1U) + +#define S_DISABLEWINDOWPSH 12 +#define V_DISABLEWINDOWPSH(x) ((x) << S_DISABLEWINDOWPSH) +#define F_DISABLEWINDOWPSH V_DISABLEWINDOWPSH(1U) + +#define S_DISABLEFINOLDDATA 11 +#define V_DISABLEFINOLDDATA(x) ((x) << S_DISABLEFINOLDDATA) +#define F_DISABLEFINOLDDATA V_DISABLEFINOLDDATA(1U) + +#define S_ENABLEFLMERROR 10 +#define V_ENABLEFLMERROR(x) ((x) << S_ENABLEFLMERROR) +#define F_ENABLEFLMERROR V_ENABLEFLMERROR(1U) + +#define S_ENABLEOPTMTU 9 +#define V_ENABLEOPTMTU(x) ((x) << S_ENABLEOPTMTU) +#define F_ENABLEOPTMTU V_ENABLEOPTMTU(1U) + +#define S_FILTERPEERFIN 8 +#define V_FILTERPEERFIN(x) ((x) << S_FILTERPEERFIN) +#define F_FILTERPEERFIN V_FILTERPEERFIN(1U) + +#define S_ENABLEFEEDBACKSEND 7 +#define V_ENABLEFEEDBACKSEND(x) ((x) << S_ENABLEFEEDBACKSEND) +#define F_ENABLEFEEDBACKSEND V_ENABLEFEEDBACKSEND(1U) + +#define S_ENABLERDMAERROR 6 +#define V_ENABLERDMAERROR(x) ((x) << S_ENABLERDMAERROR) +#define F_ENABLERDMAERROR V_ENABLERDMAERROR(1U) + +#define S_ENABLEDDPFLOWCONTROL 5 +#define V_ENABLEDDPFLOWCONTROL(x) ((x) << S_ENABLEDDPFLOWCONTROL) +#define F_ENABLEDDPFLOWCONTROL V_ENABLEDDPFLOWCONTROL(1U) + +#define S_DISABLEHELDFIN 4 +#define V_DISABLEHELDFIN(x) ((x) << S_DISABLEHELDFIN) +#define F_DISABLEHELDFIN V_DISABLEHELDFIN(1U) + +#define S_ENABLEOFDOVLAN 3 +#define V_ENABLEOFDOVLAN(x) ((x) << S_ENABLEOFDOVLAN) +#define F_ENABLEOFDOVLAN V_ENABLEOFDOVLAN(1U) + +#define S_DISABLETIMEWAIT 2 +#define V_DISABLETIMEWAIT(x) ((x) << S_DISABLETIMEWAIT) +#define F_DISABLETIMEWAIT V_DISABLETIMEWAIT(1U) + +#define S_ENABLEVLANCHECK 1 +#define V_ENABLEVLANCHECK(x) ((x) << S_ENABLEVLANCHECK) +#define F_ENABLEVLANCHECK V_ENABLEVLANCHECK(1U) + +#define S_TXDATAACKPAGEENABLE 0 +#define V_TXDATAACKPAGEENABLE(x) ((x) << S_TXDATAACKPAGEENABLE) +#define F_TXDATAACKPAGEENABLE V_TXDATAACKPAGEENABLE(1U) + +#define S_ENABLEFILTERNAT 5 +#define V_ENABLEFILTERNAT(x) ((x) << S_ENABLEFILTERNAT) +#define F_ENABLEFILTERNAT V_ENABLEFILTERNAT(1U) + +#define A_TP_PC_CONFIG2 0x7d4c + +#define S_ENABLEMTUVFMODE 31 +#define V_ENABLEMTUVFMODE(x) ((x) << S_ENABLEMTUVFMODE) +#define F_ENABLEMTUVFMODE V_ENABLEMTUVFMODE(1U) + +#define S_ENABLEMIBVFMODE 30 +#define V_ENABLEMIBVFMODE(x) ((x) << S_ENABLEMIBVFMODE) +#define F_ENABLEMIBVFMODE V_ENABLEMIBVFMODE(1U) + +#define S_DISABLELBKCHECK 29 +#define V_DISABLELBKCHECK(x) ((x) << S_DISABLELBKCHECK) +#define F_DISABLELBKCHECK V_DISABLELBKCHECK(1U) + +#define S_ENABLEURGDDPOFF 28 +#define V_ENABLEURGDDPOFF(x) ((x) << S_ENABLEURGDDPOFF) +#define F_ENABLEURGDDPOFF V_ENABLEURGDDPOFF(1U) + +#define S_ENABLEFILTERLPBK 27 +#define V_ENABLEFILTERLPBK(x) ((x) << S_ENABLEFILTERLPBK) +#define F_ENABLEFILTERLPBK V_ENABLEFILTERLPBK(1U) + +#define S_DISABLETBLMMGR 26 +#define V_DISABLETBLMMGR(x) ((x) << S_DISABLETBLMMGR) +#define F_DISABLETBLMMGR V_DISABLETBLMMGR(1U) + +#define S_CNGRECSNDNXT 25 +#define V_CNGRECSNDNXT(x) ((x) << S_CNGRECSNDNXT) +#define F_CNGRECSNDNXT V_CNGRECSNDNXT(1U) + +#define S_ENABLELBKCHN 24 +#define V_ENABLELBKCHN(x) ((x) << S_ENABLELBKCHN) +#define F_ENABLELBKCHN V_ENABLELBKCHN(1U) + +#define S_ENABLELROECN 23 +#define V_ENABLELROECN(x) ((x) << S_ENABLELROECN) +#define F_ENABLELROECN V_ENABLELROECN(1U) + +#define S_ENABLEPCMDCHECK 22 +#define V_ENABLEPCMDCHECK(x) ((x) << S_ENABLEPCMDCHECK) +#define F_ENABLEPCMDCHECK V_ENABLEPCMDCHECK(1U) + +#define S_ENABLEELBKAFULL 21 +#define V_ENABLEELBKAFULL(x) ((x) << S_ENABLEELBKAFULL) +#define F_ENABLEELBKAFULL V_ENABLEELBKAFULL(1U) + +#define S_ENABLECLBKAFULL 20 +#define V_ENABLECLBKAFULL(x) ((x) << S_ENABLECLBKAFULL) +#define F_ENABLECLBKAFULL V_ENABLECLBKAFULL(1U) + +#define S_ENABLEOESPIFULL 19 +#define V_ENABLEOESPIFULL(x) ((x) << S_ENABLEOESPIFULL) +#define F_ENABLEOESPIFULL V_ENABLEOESPIFULL(1U) + +#define S_DISABLEHITCHECK 18 +#define V_DISABLEHITCHECK(x) ((x) << S_DISABLEHITCHECK) +#define F_DISABLEHITCHECK V_DISABLEHITCHECK(1U) + +#define S_ENABLERSSERRCHECK 17 +#define V_ENABLERSSERRCHECK(x) ((x) << S_ENABLERSSERRCHECK) +#define F_ENABLERSSERRCHECK V_ENABLERSSERRCHECK(1U) + +#define S_DISABLENEWPSHFLAG 16 +#define V_DISABLENEWPSHFLAG(x) ((x) << S_DISABLENEWPSHFLAG) +#define F_DISABLENEWPSHFLAG V_DISABLENEWPSHFLAG(1U) + +#define S_ENABLERDDPRCVADVCLR 15 +#define V_ENABLERDDPRCVADVCLR(x) ((x) << S_ENABLERDDPRCVADVCLR) +#define F_ENABLERDDPRCVADVCLR V_ENABLERDDPRCVADVCLR(1U) + +#define S_ENABLETXDATAARPMISS 14 +#define V_ENABLETXDATAARPMISS(x) ((x) << S_ENABLETXDATAARPMISS) +#define F_ENABLETXDATAARPMISS V_ENABLETXDATAARPMISS(1U) + +#define S_ENABLEARPMISS 13 +#define V_ENABLEARPMISS(x) ((x) << S_ENABLEARPMISS) +#define F_ENABLEARPMISS V_ENABLEARPMISS(1U) + +#define S_ENABLERSTPAWS 12 +#define V_ENABLERSTPAWS(x) ((x) << S_ENABLERSTPAWS) +#define F_ENABLERSTPAWS V_ENABLERSTPAWS(1U) + +#define S_ENABLEIPV6RSS 11 +#define V_ENABLEIPV6RSS(x) ((x) << S_ENABLEIPV6RSS) +#define F_ENABLEIPV6RSS V_ENABLEIPV6RSS(1U) + +#define S_ENABLENONOFDHYBRSS 10 +#define V_ENABLENONOFDHYBRSS(x) ((x) << S_ENABLENONOFDHYBRSS) +#define F_ENABLENONOFDHYBRSS V_ENABLENONOFDHYBRSS(1U) + +#define S_ENABLEUDP4TUPRSS 9 +#define V_ENABLEUDP4TUPRSS(x) ((x) << S_ENABLEUDP4TUPRSS) +#define F_ENABLEUDP4TUPRSS V_ENABLEUDP4TUPRSS(1U) + +#define S_ENABLERXPKTTMSTPRSS 8 +#define V_ENABLERXPKTTMSTPRSS(x) ((x) << S_ENABLERXPKTTMSTPRSS) +#define F_ENABLERXPKTTMSTPRSS V_ENABLERXPKTTMSTPRSS(1U) + +#define S_ENABLEEPCMDAFULL 7 +#define V_ENABLEEPCMDAFULL(x) ((x) << S_ENABLEEPCMDAFULL) +#define F_ENABLEEPCMDAFULL V_ENABLEEPCMDAFULL(1U) + +#define S_ENABLECPCMDAFULL 6 +#define V_ENABLECPCMDAFULL(x) ((x) << S_ENABLECPCMDAFULL) +#define F_ENABLECPCMDAFULL V_ENABLECPCMDAFULL(1U) + +#define S_ENABLEEHDRAFULL 5 +#define V_ENABLEEHDRAFULL(x) ((x) << S_ENABLEEHDRAFULL) +#define F_ENABLEEHDRAFULL V_ENABLEEHDRAFULL(1U) + +#define S_ENABLECHDRAFULL 4 +#define V_ENABLECHDRAFULL(x) ((x) << S_ENABLECHDRAFULL) +#define F_ENABLECHDRAFULL V_ENABLECHDRAFULL(1U) + +#define S_ENABLEEMACAFULL 3 +#define V_ENABLEEMACAFULL(x) ((x) << S_ENABLEEMACAFULL) +#define F_ENABLEEMACAFULL V_ENABLEEMACAFULL(1U) + +#define S_ENABLENONOFDTIDRSS 2 +#define V_ENABLENONOFDTIDRSS(x) ((x) << S_ENABLENONOFDTIDRSS) +#define F_ENABLENONOFDTIDRSS V_ENABLENONOFDTIDRSS(1U) + +#define S_ENABLENONOFDTCBRSS 1 +#define V_ENABLENONOFDTCBRSS(x) ((x) << S_ENABLENONOFDTCBRSS) +#define F_ENABLENONOFDTCBRSS V_ENABLENONOFDTCBRSS(1U) + +#define S_ENABLETNLOFDCLOSED 0 +#define V_ENABLETNLOFDCLOSED(x) ((x) << S_ENABLETNLOFDCLOSED) +#define F_ENABLETNLOFDCLOSED V_ENABLETNLOFDCLOSED(1U) + +#define S_ENABLEFINDDPOFF 14 +#define V_ENABLEFINDDPOFF(x) ((x) << S_ENABLEFINDDPOFF) +#define F_ENABLEFINDDPOFF V_ENABLEFINDDPOFF(1U) + +#define A_TP_TCP_BACKOFF_REG0 0x7d50 + +#define S_TIMERBACKOFFINDEX3 24 +#define M_TIMERBACKOFFINDEX3 0xffU +#define V_TIMERBACKOFFINDEX3(x) ((x) << S_TIMERBACKOFFINDEX3) +#define G_TIMERBACKOFFINDEX3(x) (((x) >> S_TIMERBACKOFFINDEX3) & M_TIMERBACKOFFINDEX3) + +#define S_TIMERBACKOFFINDEX2 16 +#define M_TIMERBACKOFFINDEX2 0xffU +#define V_TIMERBACKOFFINDEX2(x) ((x) << S_TIMERBACKOFFINDEX2) +#define G_TIMERBACKOFFINDEX2(x) (((x) >> S_TIMERBACKOFFINDEX2) & M_TIMERBACKOFFINDEX2) + +#define S_TIMERBACKOFFINDEX1 8 +#define M_TIMERBACKOFFINDEX1 0xffU +#define V_TIMERBACKOFFINDEX1(x) ((x) << S_TIMERBACKOFFINDEX1) +#define G_TIMERBACKOFFINDEX1(x) (((x) >> S_TIMERBACKOFFINDEX1) & M_TIMERBACKOFFINDEX1) + +#define S_TIMERBACKOFFINDEX0 0 +#define M_TIMERBACKOFFINDEX0 0xffU +#define V_TIMERBACKOFFINDEX0(x) ((x) << S_TIMERBACKOFFINDEX0) +#define G_TIMERBACKOFFINDEX0(x) (((x) >> S_TIMERBACKOFFINDEX0) & M_TIMERBACKOFFINDEX0) + +#define A_TP_TCP_BACKOFF_REG1 0x7d54 + +#define S_TIMERBACKOFFINDEX7 24 +#define M_TIMERBACKOFFINDEX7 0xffU +#define V_TIMERBACKOFFINDEX7(x) ((x) << S_TIMERBACKOFFINDEX7) +#define G_TIMERBACKOFFINDEX7(x) (((x) >> S_TIMERBACKOFFINDEX7) & M_TIMERBACKOFFINDEX7) + +#define S_TIMERBACKOFFINDEX6 16 +#define M_TIMERBACKOFFINDEX6 0xffU +#define V_TIMERBACKOFFINDEX6(x) ((x) << S_TIMERBACKOFFINDEX6) +#define G_TIMERBACKOFFINDEX6(x) (((x) >> S_TIMERBACKOFFINDEX6) & M_TIMERBACKOFFINDEX6) + +#define S_TIMERBACKOFFINDEX5 8 +#define M_TIMERBACKOFFINDEX5 0xffU +#define V_TIMERBACKOFFINDEX5(x) ((x) << S_TIMERBACKOFFINDEX5) +#define G_TIMERBACKOFFINDEX5(x) (((x) >> S_TIMERBACKOFFINDEX5) & M_TIMERBACKOFFINDEX5) + +#define S_TIMERBACKOFFINDEX4 0 +#define M_TIMERBACKOFFINDEX4 0xffU +#define V_TIMERBACKOFFINDEX4(x) ((x) << S_TIMERBACKOFFINDEX4) +#define G_TIMERBACKOFFINDEX4(x) (((x) >> S_TIMERBACKOFFINDEX4) & M_TIMERBACKOFFINDEX4) + +#define A_TP_TCP_BACKOFF_REG2 0x7d58 + +#define S_TIMERBACKOFFINDEX11 24 +#define M_TIMERBACKOFFINDEX11 0xffU +#define V_TIMERBACKOFFINDEX11(x) ((x) << S_TIMERBACKOFFINDEX11) +#define G_TIMERBACKOFFINDEX11(x) (((x) >> S_TIMERBACKOFFINDEX11) & M_TIMERBACKOFFINDEX11) + +#define S_TIMERBACKOFFINDEX10 16 +#define M_TIMERBACKOFFINDEX10 0xffU +#define V_TIMERBACKOFFINDEX10(x) ((x) << S_TIMERBACKOFFINDEX10) +#define G_TIMERBACKOFFINDEX10(x) (((x) >> S_TIMERBACKOFFINDEX10) & M_TIMERBACKOFFINDEX10) + +#define S_TIMERBACKOFFINDEX9 8 +#define M_TIMERBACKOFFINDEX9 0xffU +#define V_TIMERBACKOFFINDEX9(x) ((x) << S_TIMERBACKOFFINDEX9) +#define G_TIMERBACKOFFINDEX9(x) (((x) >> S_TIMERBACKOFFINDEX9) & M_TIMERBACKOFFINDEX9) + +#define S_TIMERBACKOFFINDEX8 0 +#define M_TIMERBACKOFFINDEX8 0xffU +#define V_TIMERBACKOFFINDEX8(x) ((x) << S_TIMERBACKOFFINDEX8) +#define G_TIMERBACKOFFINDEX8(x) (((x) >> S_TIMERBACKOFFINDEX8) & M_TIMERBACKOFFINDEX8) + +#define A_TP_TCP_BACKOFF_REG3 0x7d5c + +#define S_TIMERBACKOFFINDEX15 24 +#define M_TIMERBACKOFFINDEX15 0xffU +#define V_TIMERBACKOFFINDEX15(x) ((x) << S_TIMERBACKOFFINDEX15) +#define G_TIMERBACKOFFINDEX15(x) (((x) >> S_TIMERBACKOFFINDEX15) & M_TIMERBACKOFFINDEX15) + +#define S_TIMERBACKOFFINDEX14 16 +#define M_TIMERBACKOFFINDEX14 0xffU +#define V_TIMERBACKOFFINDEX14(x) ((x) << S_TIMERBACKOFFINDEX14) +#define G_TIMERBACKOFFINDEX14(x) (((x) >> S_TIMERBACKOFFINDEX14) & M_TIMERBACKOFFINDEX14) + +#define S_TIMERBACKOFFINDEX13 8 +#define M_TIMERBACKOFFINDEX13 0xffU +#define V_TIMERBACKOFFINDEX13(x) ((x) << S_TIMERBACKOFFINDEX13) +#define G_TIMERBACKOFFINDEX13(x) (((x) >> S_TIMERBACKOFFINDEX13) & M_TIMERBACKOFFINDEX13) + +#define S_TIMERBACKOFFINDEX12 0 +#define M_TIMERBACKOFFINDEX12 0xffU +#define V_TIMERBACKOFFINDEX12(x) ((x) << S_TIMERBACKOFFINDEX12) +#define G_TIMERBACKOFFINDEX12(x) (((x) >> S_TIMERBACKOFFINDEX12) & M_TIMERBACKOFFINDEX12) + +#define A_TP_PARA_REG0 0x7d60 + +#define S_INITCWNDIDLE 27 +#define V_INITCWNDIDLE(x) ((x) << S_INITCWNDIDLE) +#define F_INITCWNDIDLE V_INITCWNDIDLE(1U) + +#define S_INITCWND 24 +#define M_INITCWND 0x7U +#define V_INITCWND(x) ((x) << S_INITCWND) +#define G_INITCWND(x) (((x) >> S_INITCWND) & M_INITCWND) + +#define S_DUPACKTHRESH 20 +#define M_DUPACKTHRESH 0xfU +#define V_DUPACKTHRESH(x) ((x) << S_DUPACKTHRESH) +#define G_DUPACKTHRESH(x) (((x) >> S_DUPACKTHRESH) & M_DUPACKTHRESH) + +#define S_CPLERRENABLE 12 +#define V_CPLERRENABLE(x) ((x) << S_CPLERRENABLE) +#define F_CPLERRENABLE V_CPLERRENABLE(1U) + +#define S_FASTTNLCNT 11 +#define V_FASTTNLCNT(x) ((x) << S_FASTTNLCNT) +#define F_FASTTNLCNT V_FASTTNLCNT(1U) + +#define S_FASTTBLCNT 10 +#define V_FASTTBLCNT(x) ((x) << S_FASTTBLCNT) +#define F_FASTTBLCNT V_FASTTBLCNT(1U) + +#define S_TPTCAMKEY 9 +#define V_TPTCAMKEY(x) ((x) << S_TPTCAMKEY) +#define F_TPTCAMKEY V_TPTCAMKEY(1U) + +#define S_SWSMODE 8 +#define V_SWSMODE(x) ((x) << S_SWSMODE) +#define F_SWSMODE V_SWSMODE(1U) + +#define S_TSMPMODE 6 +#define M_TSMPMODE 0x3U +#define V_TSMPMODE(x) ((x) << S_TSMPMODE) +#define G_TSMPMODE(x) (((x) >> S_TSMPMODE) & M_TSMPMODE) + +#define S_BYTECOUNTLIMIT 4 +#define M_BYTECOUNTLIMIT 0x3U +#define V_BYTECOUNTLIMIT(x) ((x) << S_BYTECOUNTLIMIT) +#define G_BYTECOUNTLIMIT(x) (((x) >> S_BYTECOUNTLIMIT) & M_BYTECOUNTLIMIT) + +#define S_SWSSHOVE 3 +#define V_SWSSHOVE(x) ((x) << S_SWSSHOVE) +#define F_SWSSHOVE V_SWSSHOVE(1U) + +#define S_TBLTIMER 2 +#define V_TBLTIMER(x) ((x) << S_TBLTIMER) +#define F_TBLTIMER V_TBLTIMER(1U) + +#define S_RXTPACE 1 +#define V_RXTPACE(x) ((x) << S_RXTPACE) +#define F_RXTPACE V_RXTPACE(1U) + +#define S_SWSTIMER 0 +#define V_SWSTIMER(x) ((x) << S_SWSTIMER) +#define F_SWSTIMER V_SWSTIMER(1U) + +#define S_LIMTXTHRESH 28 +#define M_LIMTXTHRESH 0xfU +#define V_LIMTXTHRESH(x) ((x) << S_LIMTXTHRESH) +#define G_LIMTXTHRESH(x) (((x) >> S_LIMTXTHRESH) & M_LIMTXTHRESH) + +#define S_CHNERRENABLE 14 +#define V_CHNERRENABLE(x) ((x) << S_CHNERRENABLE) +#define F_CHNERRENABLE V_CHNERRENABLE(1U) + +#define S_SETTIMEENABLE 13 +#define V_SETTIMEENABLE(x) ((x) << S_SETTIMEENABLE) +#define F_SETTIMEENABLE V_SETTIMEENABLE(1U) + +#define A_TP_PARA_REG1 0x7d64 + +#define S_INITRWND 16 +#define M_INITRWND 0xffffU +#define V_INITRWND(x) ((x) << S_INITRWND) +#define G_INITRWND(x) (((x) >> S_INITRWND) & M_INITRWND) + +#define S_INITIALSSTHRESH 0 +#define M_INITIALSSTHRESH 0xffffU +#define V_INITIALSSTHRESH(x) ((x) << S_INITIALSSTHRESH) +#define G_INITIALSSTHRESH(x) (((x) >> S_INITIALSSTHRESH) & M_INITIALSSTHRESH) + +#define A_TP_PARA_REG2 0x7d68 + +#define S_MAXRXDATA 16 +#define M_MAXRXDATA 0xffffU +#define V_MAXRXDATA(x) ((x) << S_MAXRXDATA) +#define G_MAXRXDATA(x) (((x) >> S_MAXRXDATA) & M_MAXRXDATA) + +#define S_RXCOALESCESIZE 0 +#define M_RXCOALESCESIZE 0xffffU +#define V_RXCOALESCESIZE(x) ((x) << S_RXCOALESCESIZE) +#define G_RXCOALESCESIZE(x) (((x) >> S_RXCOALESCESIZE) & M_RXCOALESCESIZE) + +#define A_TP_PARA_REG3 0x7d6c + +#define S_ENABLETNLCNGLPBK 31 +#define V_ENABLETNLCNGLPBK(x) ((x) << S_ENABLETNLCNGLPBK) +#define F_ENABLETNLCNGLPBK V_ENABLETNLCNGLPBK(1U) + +#define S_ENABLETNLCNGFIFO 30 +#define V_ENABLETNLCNGFIFO(x) ((x) << S_ENABLETNLCNGFIFO) +#define F_ENABLETNLCNGFIFO V_ENABLETNLCNGFIFO(1U) + +#define S_ENABLETNLCNGHDR 29 +#define V_ENABLETNLCNGHDR(x) ((x) << S_ENABLETNLCNGHDR) +#define F_ENABLETNLCNGHDR V_ENABLETNLCNGHDR(1U) + +#define S_ENABLETNLCNGSGE 28 +#define V_ENABLETNLCNGSGE(x) ((x) << S_ENABLETNLCNGSGE) +#define F_ENABLETNLCNGSGE V_ENABLETNLCNGSGE(1U) + +#define S_RXMACCHECK 27 +#define V_RXMACCHECK(x) ((x) << S_RXMACCHECK) +#define F_RXMACCHECK V_RXMACCHECK(1U) + +#define S_RXSYNFILTER 26 +#define V_RXSYNFILTER(x) ((x) << S_RXSYNFILTER) +#define F_RXSYNFILTER V_RXSYNFILTER(1U) + +#define S_CNGCTRLECN 25 +#define V_CNGCTRLECN(x) ((x) << S_CNGCTRLECN) +#define F_CNGCTRLECN V_CNGCTRLECN(1U) + +#define S_RXDDPOFFINIT 24 +#define V_RXDDPOFFINIT(x) ((x) << S_RXDDPOFFINIT) +#define F_RXDDPOFFINIT V_RXDDPOFFINIT(1U) + +#define S_TUNNELCNGDROP3 23 +#define V_TUNNELCNGDROP3(x) ((x) << S_TUNNELCNGDROP3) +#define F_TUNNELCNGDROP3 V_TUNNELCNGDROP3(1U) + +#define S_TUNNELCNGDROP2 22 +#define V_TUNNELCNGDROP2(x) ((x) << S_TUNNELCNGDROP2) +#define F_TUNNELCNGDROP2 V_TUNNELCNGDROP2(1U) + +#define S_TUNNELCNGDROP1 21 +#define V_TUNNELCNGDROP1(x) ((x) << S_TUNNELCNGDROP1) +#define F_TUNNELCNGDROP1 V_TUNNELCNGDROP1(1U) + +#define S_TUNNELCNGDROP0 20 +#define V_TUNNELCNGDROP0(x) ((x) << S_TUNNELCNGDROP0) +#define F_TUNNELCNGDROP0 V_TUNNELCNGDROP0(1U) + +#define S_TXDATAACKIDX 16 +#define M_TXDATAACKIDX 0xfU +#define V_TXDATAACKIDX(x) ((x) << S_TXDATAACKIDX) +#define G_TXDATAACKIDX(x) (((x) >> S_TXDATAACKIDX) & M_TXDATAACKIDX) + +#define S_RXFRAGENABLE 12 +#define M_RXFRAGENABLE 0x7U +#define V_RXFRAGENABLE(x) ((x) << S_RXFRAGENABLE) +#define G_RXFRAGENABLE(x) (((x) >> S_RXFRAGENABLE) & M_RXFRAGENABLE) + +#define S_TXPACEFIXEDSTRICT 11 +#define V_TXPACEFIXEDSTRICT(x) ((x) << S_TXPACEFIXEDSTRICT) +#define F_TXPACEFIXEDSTRICT V_TXPACEFIXEDSTRICT(1U) + +#define S_TXPACEAUTOSTRICT 10 +#define V_TXPACEAUTOSTRICT(x) ((x) << S_TXPACEAUTOSTRICT) +#define F_TXPACEAUTOSTRICT V_TXPACEAUTOSTRICT(1U) + +#define S_TXPACEFIXED 9 +#define V_TXPACEFIXED(x) ((x) << S_TXPACEFIXED) +#define F_TXPACEFIXED V_TXPACEFIXED(1U) + +#define S_TXPACEAUTO 8 +#define V_TXPACEAUTO(x) ((x) << S_TXPACEAUTO) +#define F_TXPACEAUTO V_TXPACEAUTO(1U) + +#define S_RXCHNTUNNEL 7 +#define V_RXCHNTUNNEL(x) ((x) << S_RXCHNTUNNEL) +#define F_RXCHNTUNNEL V_RXCHNTUNNEL(1U) + +#define S_RXURGTUNNEL 6 +#define V_RXURGTUNNEL(x) ((x) << S_RXURGTUNNEL) +#define F_RXURGTUNNEL V_RXURGTUNNEL(1U) + +#define S_RXURGMODE 5 +#define V_RXURGMODE(x) ((x) << S_RXURGMODE) +#define F_RXURGMODE V_RXURGMODE(1U) + +#define S_TXURGMODE 4 +#define V_TXURGMODE(x) ((x) << S_TXURGMODE) +#define F_TXURGMODE V_TXURGMODE(1U) + +#define S_CNGCTRLMODE 2 +#define M_CNGCTRLMODE 0x3U +#define V_CNGCTRLMODE(x) ((x) << S_CNGCTRLMODE) +#define G_CNGCTRLMODE(x) (((x) >> S_CNGCTRLMODE) & M_CNGCTRLMODE) + +#define S_RXCOALESCEENABLE 1 +#define V_RXCOALESCEENABLE(x) ((x) << S_RXCOALESCEENABLE) +#define F_RXCOALESCEENABLE V_RXCOALESCEENABLE(1U) + +#define S_RXCOALESCEPSHEN 0 +#define V_RXCOALESCEPSHEN(x) ((x) << S_RXCOALESCEPSHEN) +#define F_RXCOALESCEPSHEN V_RXCOALESCEPSHEN(1U) + +#define A_TP_PARA_REG4 0x7d70 + +#define S_HIGHSPEEDCFG 24 +#define M_HIGHSPEEDCFG 0xffU +#define V_HIGHSPEEDCFG(x) ((x) << S_HIGHSPEEDCFG) +#define G_HIGHSPEEDCFG(x) (((x) >> S_HIGHSPEEDCFG) & M_HIGHSPEEDCFG) + +#define S_NEWRENOCFG 16 +#define M_NEWRENOCFG 0xffU +#define V_NEWRENOCFG(x) ((x) << S_NEWRENOCFG) +#define G_NEWRENOCFG(x) (((x) >> S_NEWRENOCFG) & M_NEWRENOCFG) + +#define S_TAHOECFG 8 +#define M_TAHOECFG 0xffU +#define V_TAHOECFG(x) ((x) << S_TAHOECFG) +#define G_TAHOECFG(x) (((x) >> S_TAHOECFG) & M_TAHOECFG) + +#define S_RENOCFG 0 +#define M_RENOCFG 0xffU +#define V_RENOCFG(x) ((x) << S_RENOCFG) +#define G_RENOCFG(x) (((x) >> S_RENOCFG) & M_RENOCFG) + +#define S_IDLECWNDHIGHSPEED 28 +#define V_IDLECWNDHIGHSPEED(x) ((x) << S_IDLECWNDHIGHSPEED) +#define F_IDLECWNDHIGHSPEED V_IDLECWNDHIGHSPEED(1U) + +#define S_RXMTCWNDHIGHSPEED 27 +#define V_RXMTCWNDHIGHSPEED(x) ((x) << S_RXMTCWNDHIGHSPEED) +#define F_RXMTCWNDHIGHSPEED V_RXMTCWNDHIGHSPEED(1U) + +#define S_OVERDRIVEHIGHSPEED 25 +#define M_OVERDRIVEHIGHSPEED 0x3U +#define V_OVERDRIVEHIGHSPEED(x) ((x) << S_OVERDRIVEHIGHSPEED) +#define G_OVERDRIVEHIGHSPEED(x) (((x) >> S_OVERDRIVEHIGHSPEED) & M_OVERDRIVEHIGHSPEED) + +#define S_BYTECOUNTHIGHSPEED 24 +#define V_BYTECOUNTHIGHSPEED(x) ((x) << S_BYTECOUNTHIGHSPEED) +#define F_BYTECOUNTHIGHSPEED V_BYTECOUNTHIGHSPEED(1U) + +#define S_IDLECWNDNEWRENO 20 +#define V_IDLECWNDNEWRENO(x) ((x) << S_IDLECWNDNEWRENO) +#define F_IDLECWNDNEWRENO V_IDLECWNDNEWRENO(1U) + +#define S_RXMTCWNDNEWRENO 19 +#define V_RXMTCWNDNEWRENO(x) ((x) << S_RXMTCWNDNEWRENO) +#define F_RXMTCWNDNEWRENO V_RXMTCWNDNEWRENO(1U) + +#define S_OVERDRIVENEWRENO 17 +#define M_OVERDRIVENEWRENO 0x3U +#define V_OVERDRIVENEWRENO(x) ((x) << S_OVERDRIVENEWRENO) +#define G_OVERDRIVENEWRENO(x) (((x) >> S_OVERDRIVENEWRENO) & M_OVERDRIVENEWRENO) + +#define S_BYTECOUNTNEWRENO 16 +#define V_BYTECOUNTNEWRENO(x) ((x) << S_BYTECOUNTNEWRENO) +#define F_BYTECOUNTNEWRENO V_BYTECOUNTNEWRENO(1U) + +#define S_IDLECWNDTAHOE 12 +#define V_IDLECWNDTAHOE(x) ((x) << S_IDLECWNDTAHOE) +#define F_IDLECWNDTAHOE V_IDLECWNDTAHOE(1U) + +#define S_RXMTCWNDTAHOE 11 +#define V_RXMTCWNDTAHOE(x) ((x) << S_RXMTCWNDTAHOE) +#define F_RXMTCWNDTAHOE V_RXMTCWNDTAHOE(1U) + +#define S_OVERDRIVETAHOE 9 +#define M_OVERDRIVETAHOE 0x3U +#define V_OVERDRIVETAHOE(x) ((x) << S_OVERDRIVETAHOE) +#define G_OVERDRIVETAHOE(x) (((x) >> S_OVERDRIVETAHOE) & M_OVERDRIVETAHOE) + +#define S_BYTECOUNTTAHOE 8 +#define V_BYTECOUNTTAHOE(x) ((x) << S_BYTECOUNTTAHOE) +#define F_BYTECOUNTTAHOE V_BYTECOUNTTAHOE(1U) + +#define S_IDLECWNDRENO 4 +#define V_IDLECWNDRENO(x) ((x) << S_IDLECWNDRENO) +#define F_IDLECWNDRENO V_IDLECWNDRENO(1U) + +#define S_RXMTCWNDRENO 3 +#define V_RXMTCWNDRENO(x) ((x) << S_RXMTCWNDRENO) +#define F_RXMTCWNDRENO V_RXMTCWNDRENO(1U) + +#define S_OVERDRIVERENO 1 +#define M_OVERDRIVERENO 0x3U +#define V_OVERDRIVERENO(x) ((x) << S_OVERDRIVERENO) +#define G_OVERDRIVERENO(x) (((x) >> S_OVERDRIVERENO) & M_OVERDRIVERENO) + +#define S_BYTECOUNTRENO 0 +#define V_BYTECOUNTRENO(x) ((x) << S_BYTECOUNTRENO) +#define F_BYTECOUNTRENO V_BYTECOUNTRENO(1U) + +#define A_TP_PARA_REG5 0x7d74 + +#define S_INDICATESIZE 16 +#define M_INDICATESIZE 0xffffU +#define V_INDICATESIZE(x) ((x) << S_INDICATESIZE) +#define G_INDICATESIZE(x) (((x) >> S_INDICATESIZE) & M_INDICATESIZE) + +#define S_MAXPROXYSIZE 12 +#define M_MAXPROXYSIZE 0xfU +#define V_MAXPROXYSIZE(x) ((x) << S_MAXPROXYSIZE) +#define G_MAXPROXYSIZE(x) (((x) >> S_MAXPROXYSIZE) & M_MAXPROXYSIZE) + +#define S_ENABLEREADPDU 11 +#define V_ENABLEREADPDU(x) ((x) << S_ENABLEREADPDU) +#define F_ENABLEREADPDU V_ENABLEREADPDU(1U) + +#define S_RXREADAHEAD 10 +#define V_RXREADAHEAD(x) ((x) << S_RXREADAHEAD) +#define F_RXREADAHEAD V_RXREADAHEAD(1U) + +#define S_EMPTYRQENABLE 9 +#define V_EMPTYRQENABLE(x) ((x) << S_EMPTYRQENABLE) +#define F_EMPTYRQENABLE V_EMPTYRQENABLE(1U) + +#define S_SCHDENABLE 8 +#define V_SCHDENABLE(x) ((x) << S_SCHDENABLE) +#define F_SCHDENABLE V_SCHDENABLE(1U) + +#define S_REARMDDPOFFSET 4 +#define V_REARMDDPOFFSET(x) ((x) << S_REARMDDPOFFSET) +#define F_REARMDDPOFFSET V_REARMDDPOFFSET(1U) + +#define S_RESETDDPOFFSET 3 +#define V_RESETDDPOFFSET(x) ((x) << S_RESETDDPOFFSET) +#define F_RESETDDPOFFSET V_RESETDDPOFFSET(1U) + +#define S_ONFLYDDPENABLE 2 +#define V_ONFLYDDPENABLE(x) ((x) << S_ONFLYDDPENABLE) +#define F_ONFLYDDPENABLE V_ONFLYDDPENABLE(1U) + +#define S_DACKTIMERSPIN 1 +#define V_DACKTIMERSPIN(x) ((x) << S_DACKTIMERSPIN) +#define F_DACKTIMERSPIN V_DACKTIMERSPIN(1U) + +#define S_PUSHTIMERENABLE 0 +#define V_PUSHTIMERENABLE(x) ((x) << S_PUSHTIMERENABLE) +#define F_PUSHTIMERENABLE V_PUSHTIMERENABLE(1U) + +#define S_ENABLEXOFFPDU 7 +#define V_ENABLEXOFFPDU(x) ((x) << S_ENABLEXOFFPDU) +#define F_ENABLEXOFFPDU V_ENABLEXOFFPDU(1U) + +#define S_ENABLENEWFAR 6 +#define V_ENABLENEWFAR(x) ((x) << S_ENABLENEWFAR) +#define F_ENABLENEWFAR V_ENABLENEWFAR(1U) + +#define S_ENABLEFRAGCHECK 5 +#define V_ENABLEFRAGCHECK(x) ((x) << S_ENABLEFRAGCHECK) +#define F_ENABLEFRAGCHECK V_ENABLEFRAGCHECK(1U) + +#define A_TP_PARA_REG6 0x7d78 + +#define S_TXPDUSIZEADJ 24 +#define M_TXPDUSIZEADJ 0xffU +#define V_TXPDUSIZEADJ(x) ((x) << S_TXPDUSIZEADJ) +#define G_TXPDUSIZEADJ(x) (((x) >> S_TXPDUSIZEADJ) & M_TXPDUSIZEADJ) + +#define S_LIMITEDTRANSMIT 20 +#define M_LIMITEDTRANSMIT 0xfU +#define V_LIMITEDTRANSMIT(x) ((x) << S_LIMITEDTRANSMIT) +#define G_LIMITEDTRANSMIT(x) (((x) >> S_LIMITEDTRANSMIT) & M_LIMITEDTRANSMIT) + +#define S_ENABLECSAV 19 +#define V_ENABLECSAV(x) ((x) << S_ENABLECSAV) +#define F_ENABLECSAV V_ENABLECSAV(1U) + +#define S_ENABLEDEFERPDU 18 +#define V_ENABLEDEFERPDU(x) ((x) << S_ENABLEDEFERPDU) +#define F_ENABLEDEFERPDU V_ENABLEDEFERPDU(1U) + +#define S_ENABLEFLUSH 17 +#define V_ENABLEFLUSH(x) ((x) << S_ENABLEFLUSH) +#define F_ENABLEFLUSH V_ENABLEFLUSH(1U) + +#define S_ENABLEBYTEPERSIST 16 +#define V_ENABLEBYTEPERSIST(x) ((x) << S_ENABLEBYTEPERSIST) +#define F_ENABLEBYTEPERSIST V_ENABLEBYTEPERSIST(1U) + +#define S_DISABLETMOCNG 15 +#define V_DISABLETMOCNG(x) ((x) << S_DISABLETMOCNG) +#define F_DISABLETMOCNG V_DISABLETMOCNG(1U) + +#define S_TXREADAHEAD 14 +#define V_TXREADAHEAD(x) ((x) << S_TXREADAHEAD) +#define F_TXREADAHEAD V_TXREADAHEAD(1U) + +#define S_ALLOWEXEPTION 13 +#define V_ALLOWEXEPTION(x) ((x) << S_ALLOWEXEPTION) +#define F_ALLOWEXEPTION V_ALLOWEXEPTION(1U) + +#define S_ENABLEDEFERACK 12 +#define V_ENABLEDEFERACK(x) ((x) << S_ENABLEDEFERACK) +#define F_ENABLEDEFERACK V_ENABLEDEFERACK(1U) + +#define S_ENABLEESND 11 +#define V_ENABLEESND(x) ((x) << S_ENABLEESND) +#define F_ENABLEESND V_ENABLEESND(1U) + +#define S_ENABLECSND 10 +#define V_ENABLECSND(x) ((x) << S_ENABLECSND) +#define F_ENABLECSND V_ENABLECSND(1U) + +#define S_ENABLEPDUE 9 +#define V_ENABLEPDUE(x) ((x) << S_ENABLEPDUE) +#define F_ENABLEPDUE V_ENABLEPDUE(1U) + +#define S_ENABLEPDUC 8 +#define V_ENABLEPDUC(x) ((x) << S_ENABLEPDUC) +#define F_ENABLEPDUC V_ENABLEPDUC(1U) + +#define S_ENABLEBUFI 7 +#define V_ENABLEBUFI(x) ((x) << S_ENABLEBUFI) +#define F_ENABLEBUFI V_ENABLEBUFI(1U) + +#define S_ENABLEBUFE 6 +#define V_ENABLEBUFE(x) ((x) << S_ENABLEBUFE) +#define F_ENABLEBUFE V_ENABLEBUFE(1U) + +#define S_ENABLEDEFER 5 +#define V_ENABLEDEFER(x) ((x) << S_ENABLEDEFER) +#define F_ENABLEDEFER V_ENABLEDEFER(1U) + +#define S_ENABLECLEARRXMTOOS 4 +#define V_ENABLECLEARRXMTOOS(x) ((x) << S_ENABLECLEARRXMTOOS) +#define F_ENABLECLEARRXMTOOS V_ENABLECLEARRXMTOOS(1U) + +#define S_DISABLEPDUCNG 3 +#define V_DISABLEPDUCNG(x) ((x) << S_DISABLEPDUCNG) +#define F_DISABLEPDUCNG V_DISABLEPDUCNG(1U) + +#define S_DISABLEPDUTIMEOUT 2 +#define V_DISABLEPDUTIMEOUT(x) ((x) << S_DISABLEPDUTIMEOUT) +#define F_DISABLEPDUTIMEOUT V_DISABLEPDUTIMEOUT(1U) + +#define S_DISABLEPDURXMT 1 +#define V_DISABLEPDURXMT(x) ((x) << S_DISABLEPDURXMT) +#define F_DISABLEPDURXMT V_DISABLEPDURXMT(1U) + +#define S_DISABLEPDUXMT 0 +#define V_DISABLEPDUXMT(x) ((x) << S_DISABLEPDUXMT) +#define F_DISABLEPDUXMT V_DISABLEPDUXMT(1U) + +#define S_DISABLEPDUACK 20 +#define V_DISABLEPDUACK(x) ((x) << S_DISABLEPDUACK) +#define F_DISABLEPDUACK V_DISABLEPDUACK(1U) + +#define A_TP_PARA_REG7 0x7d7c + +#define S_PMMAXXFERLEN1 16 +#define M_PMMAXXFERLEN1 0xffffU +#define V_PMMAXXFERLEN1(x) ((x) << S_PMMAXXFERLEN1) +#define G_PMMAXXFERLEN1(x) (((x) >> S_PMMAXXFERLEN1) & M_PMMAXXFERLEN1) + +#define S_PMMAXXFERLEN0 0 +#define M_PMMAXXFERLEN0 0xffffU +#define V_PMMAXXFERLEN0(x) ((x) << S_PMMAXXFERLEN0) +#define G_PMMAXXFERLEN0(x) (((x) >> S_PMMAXXFERLEN0) & M_PMMAXXFERLEN0) + +#define A_TP_ENG_CONFIG 0x7d80 + +#define S_TABLELATENCYDONE 28 +#define M_TABLELATENCYDONE 0xfU +#define V_TABLELATENCYDONE(x) ((x) << S_TABLELATENCYDONE) +#define G_TABLELATENCYDONE(x) (((x) >> S_TABLELATENCYDONE) & M_TABLELATENCYDONE) + +#define S_TABLELATENCYSTART 24 +#define M_TABLELATENCYSTART 0xfU +#define V_TABLELATENCYSTART(x) ((x) << S_TABLELATENCYSTART) +#define G_TABLELATENCYSTART(x) (((x) >> S_TABLELATENCYSTART) & M_TABLELATENCYSTART) + +#define S_ENGINELATENCYDELTA 16 +#define M_ENGINELATENCYDELTA 0xfU +#define V_ENGINELATENCYDELTA(x) ((x) << S_ENGINELATENCYDELTA) +#define G_ENGINELATENCYDELTA(x) (((x) >> S_ENGINELATENCYDELTA) & M_ENGINELATENCYDELTA) + +#define S_ENGINELATENCYMMGR 12 +#define M_ENGINELATENCYMMGR 0xfU +#define V_ENGINELATENCYMMGR(x) ((x) << S_ENGINELATENCYMMGR) +#define G_ENGINELATENCYMMGR(x) (((x) >> S_ENGINELATENCYMMGR) & M_ENGINELATENCYMMGR) + +#define S_ENGINELATENCYWIREIP6 8 +#define M_ENGINELATENCYWIREIP6 0xfU +#define V_ENGINELATENCYWIREIP6(x) ((x) << S_ENGINELATENCYWIREIP6) +#define G_ENGINELATENCYWIREIP6(x) (((x) >> S_ENGINELATENCYWIREIP6) & M_ENGINELATENCYWIREIP6) + +#define S_ENGINELATENCYWIRE 4 +#define M_ENGINELATENCYWIRE 0xfU +#define V_ENGINELATENCYWIRE(x) ((x) << S_ENGINELATENCYWIRE) +#define G_ENGINELATENCYWIRE(x) (((x) >> S_ENGINELATENCYWIRE) & M_ENGINELATENCYWIRE) + +#define S_ENGINELATENCYBASE 0 +#define M_ENGINELATENCYBASE 0xfU +#define V_ENGINELATENCYBASE(x) ((x) << S_ENGINELATENCYBASE) +#define G_ENGINELATENCYBASE(x) (((x) >> S_ENGINELATENCYBASE) & M_ENGINELATENCYBASE) + +#define A_TP_ERR_CONFIG 0x7d8c + +#define S_TNLERRORPING 30 +#define V_TNLERRORPING(x) ((x) << S_TNLERRORPING) +#define F_TNLERRORPING V_TNLERRORPING(1U) + +#define S_TNLERRORCSUM 29 +#define V_TNLERRORCSUM(x) ((x) << S_TNLERRORCSUM) +#define F_TNLERRORCSUM V_TNLERRORCSUM(1U) + +#define S_TNLERRORCSUMIP 28 +#define V_TNLERRORCSUMIP(x) ((x) << S_TNLERRORCSUMIP) +#define F_TNLERRORCSUMIP V_TNLERRORCSUMIP(1U) + +#define S_TNLERRORTCPOPT 25 +#define V_TNLERRORTCPOPT(x) ((x) << S_TNLERRORTCPOPT) +#define F_TNLERRORTCPOPT V_TNLERRORTCPOPT(1U) + +#define S_TNLERRORPKTLEN 24 +#define V_TNLERRORPKTLEN(x) ((x) << S_TNLERRORPKTLEN) +#define F_TNLERRORPKTLEN V_TNLERRORPKTLEN(1U) + +#define S_TNLERRORTCPHDRLEN 23 +#define V_TNLERRORTCPHDRLEN(x) ((x) << S_TNLERRORTCPHDRLEN) +#define F_TNLERRORTCPHDRLEN V_TNLERRORTCPHDRLEN(1U) + +#define S_TNLERRORIPHDRLEN 22 +#define V_TNLERRORIPHDRLEN(x) ((x) << S_TNLERRORIPHDRLEN) +#define F_TNLERRORIPHDRLEN V_TNLERRORIPHDRLEN(1U) + +#define S_TNLERRORETHHDRLEN 21 +#define V_TNLERRORETHHDRLEN(x) ((x) << S_TNLERRORETHHDRLEN) +#define F_TNLERRORETHHDRLEN V_TNLERRORETHHDRLEN(1U) + +#define S_TNLERRORATTACK 20 +#define V_TNLERRORATTACK(x) ((x) << S_TNLERRORATTACK) +#define F_TNLERRORATTACK V_TNLERRORATTACK(1U) + +#define S_TNLERRORFRAG 19 +#define V_TNLERRORFRAG(x) ((x) << S_TNLERRORFRAG) +#define F_TNLERRORFRAG V_TNLERRORFRAG(1U) + +#define S_TNLERRORIPVER 18 +#define V_TNLERRORIPVER(x) ((x) << S_TNLERRORIPVER) +#define F_TNLERRORIPVER V_TNLERRORIPVER(1U) + +#define S_TNLERRORMAC 17 +#define V_TNLERRORMAC(x) ((x) << S_TNLERRORMAC) +#define F_TNLERRORMAC V_TNLERRORMAC(1U) + +#define S_TNLERRORANY 16 +#define V_TNLERRORANY(x) ((x) << S_TNLERRORANY) +#define F_TNLERRORANY V_TNLERRORANY(1U) + +#define S_DROPERRORPING 14 +#define V_DROPERRORPING(x) ((x) << S_DROPERRORPING) +#define F_DROPERRORPING V_DROPERRORPING(1U) + +#define S_DROPERRORCSUM 13 +#define V_DROPERRORCSUM(x) ((x) << S_DROPERRORCSUM) +#define F_DROPERRORCSUM V_DROPERRORCSUM(1U) + +#define S_DROPERRORCSUMIP 12 +#define V_DROPERRORCSUMIP(x) ((x) << S_DROPERRORCSUMIP) +#define F_DROPERRORCSUMIP V_DROPERRORCSUMIP(1U) + +#define S_DROPERRORTCPOPT 9 +#define V_DROPERRORTCPOPT(x) ((x) << S_DROPERRORTCPOPT) +#define F_DROPERRORTCPOPT V_DROPERRORTCPOPT(1U) + +#define S_DROPERRORPKTLEN 8 +#define V_DROPERRORPKTLEN(x) ((x) << S_DROPERRORPKTLEN) +#define F_DROPERRORPKTLEN V_DROPERRORPKTLEN(1U) + +#define S_DROPERRORTCPHDRLEN 7 +#define V_DROPERRORTCPHDRLEN(x) ((x) << S_DROPERRORTCPHDRLEN) +#define F_DROPERRORTCPHDRLEN V_DROPERRORTCPHDRLEN(1U) + +#define S_DROPERRORIPHDRLEN 6 +#define V_DROPERRORIPHDRLEN(x) ((x) << S_DROPERRORIPHDRLEN) +#define F_DROPERRORIPHDRLEN V_DROPERRORIPHDRLEN(1U) + +#define S_DROPERRORETHHDRLEN 5 +#define V_DROPERRORETHHDRLEN(x) ((x) << S_DROPERRORETHHDRLEN) +#define F_DROPERRORETHHDRLEN V_DROPERRORETHHDRLEN(1U) + +#define S_DROPERRORATTACK 4 +#define V_DROPERRORATTACK(x) ((x) << S_DROPERRORATTACK) +#define F_DROPERRORATTACK V_DROPERRORATTACK(1U) + +#define S_DROPERRORFRAG 3 +#define V_DROPERRORFRAG(x) ((x) << S_DROPERRORFRAG) +#define F_DROPERRORFRAG V_DROPERRORFRAG(1U) + +#define S_DROPERRORIPVER 2 +#define V_DROPERRORIPVER(x) ((x) << S_DROPERRORIPVER) +#define F_DROPERRORIPVER V_DROPERRORIPVER(1U) + +#define S_DROPERRORMAC 1 +#define V_DROPERRORMAC(x) ((x) << S_DROPERRORMAC) +#define F_DROPERRORMAC V_DROPERRORMAC(1U) + +#define S_DROPERRORANY 0 +#define V_DROPERRORANY(x) ((x) << S_DROPERRORANY) +#define F_DROPERRORANY V_DROPERRORANY(1U) + +#define S_TNLERRORFPMA 31 +#define V_TNLERRORFPMA(x) ((x) << S_TNLERRORFPMA) +#define F_TNLERRORFPMA V_TNLERRORFPMA(1U) + +#define S_DROPERRORFPMA 15 +#define V_DROPERRORFPMA(x) ((x) << S_DROPERRORFPMA) +#define F_DROPERRORFPMA V_DROPERRORFPMA(1U) + +#define A_TP_TIMER_RESOLUTION 0x7d90 + +#define S_TIMERRESOLUTION 16 +#define M_TIMERRESOLUTION 0xffU +#define V_TIMERRESOLUTION(x) ((x) << S_TIMERRESOLUTION) +#define G_TIMERRESOLUTION(x) (((x) >> S_TIMERRESOLUTION) & M_TIMERRESOLUTION) + +#define S_TIMESTAMPRESOLUTION 8 +#define M_TIMESTAMPRESOLUTION 0xffU +#define V_TIMESTAMPRESOLUTION(x) ((x) << S_TIMESTAMPRESOLUTION) +#define G_TIMESTAMPRESOLUTION(x) (((x) >> S_TIMESTAMPRESOLUTION) & M_TIMESTAMPRESOLUTION) + +#define S_DELAYEDACKRESOLUTION 0 +#define M_DELAYEDACKRESOLUTION 0xffU +#define V_DELAYEDACKRESOLUTION(x) ((x) << S_DELAYEDACKRESOLUTION) +#define G_DELAYEDACKRESOLUTION(x) (((x) >> S_DELAYEDACKRESOLUTION) & M_DELAYEDACKRESOLUTION) + +#define A_TP_MSL 0x7d94 + +#define S_MSL 0 +#define M_MSL 0x3fffffffU +#define V_MSL(x) ((x) << S_MSL) +#define G_MSL(x) (((x) >> S_MSL) & M_MSL) + +#define A_TP_RXT_MIN 0x7d98 + +#define S_RXTMIN 0 +#define M_RXTMIN 0x3fffffffU +#define V_RXTMIN(x) ((x) << S_RXTMIN) +#define G_RXTMIN(x) (((x) >> S_RXTMIN) & M_RXTMIN) + +#define A_TP_RXT_MAX 0x7d9c + +#define S_RXTMAX 0 +#define M_RXTMAX 0x3fffffffU +#define V_RXTMAX(x) ((x) << S_RXTMAX) +#define G_RXTMAX(x) (((x) >> S_RXTMAX) & M_RXTMAX) + +#define A_TP_PERS_MIN 0x7da0 + +#define S_PERSMIN 0 +#define M_PERSMIN 0x3fffffffU +#define V_PERSMIN(x) ((x) << S_PERSMIN) +#define G_PERSMIN(x) (((x) >> S_PERSMIN) & M_PERSMIN) + +#define A_TP_PERS_MAX 0x7da4 + +#define S_PERSMAX 0 +#define M_PERSMAX 0x3fffffffU +#define V_PERSMAX(x) ((x) << S_PERSMAX) +#define G_PERSMAX(x) (((x) >> S_PERSMAX) & M_PERSMAX) + +#define A_TP_KEEP_IDLE 0x7da8 + +#define S_KEEPALIVEIDLE 0 +#define M_KEEPALIVEIDLE 0x3fffffffU +#define V_KEEPALIVEIDLE(x) ((x) << S_KEEPALIVEIDLE) +#define G_KEEPALIVEIDLE(x) (((x) >> S_KEEPALIVEIDLE) & M_KEEPALIVEIDLE) + +#define A_TP_KEEP_INTVL 0x7dac + +#define S_KEEPALIVEINTVL 0 +#define M_KEEPALIVEINTVL 0x3fffffffU +#define V_KEEPALIVEINTVL(x) ((x) << S_KEEPALIVEINTVL) +#define G_KEEPALIVEINTVL(x) (((x) >> S_KEEPALIVEINTVL) & M_KEEPALIVEINTVL) + +#define A_TP_INIT_SRTT 0x7db0 + +#define S_MAXRTT 16 +#define M_MAXRTT 0xffffU +#define V_MAXRTT(x) ((x) << S_MAXRTT) +#define G_MAXRTT(x) (((x) >> S_MAXRTT) & M_MAXRTT) + +#define S_INITSRTT 0 +#define M_INITSRTT 0xffffU +#define V_INITSRTT(x) ((x) << S_INITSRTT) +#define G_INITSRTT(x) (((x) >> S_INITSRTT) & M_INITSRTT) + +#define A_TP_DACK_TIMER 0x7db4 + +#define S_DACKTIME 0 +#define M_DACKTIME 0xfffU +#define V_DACKTIME(x) ((x) << S_DACKTIME) +#define G_DACKTIME(x) (((x) >> S_DACKTIME) & M_DACKTIME) + +#define A_TP_FINWAIT2_TIMER 0x7db8 + +#define S_FINWAIT2TIME 0 +#define M_FINWAIT2TIME 0x3fffffffU +#define V_FINWAIT2TIME(x) ((x) << S_FINWAIT2TIME) +#define G_FINWAIT2TIME(x) (((x) >> S_FINWAIT2TIME) & M_FINWAIT2TIME) + +#define A_TP_FAST_FINWAIT2_TIMER 0x7dbc + +#define S_FASTFINWAIT2TIME 0 +#define M_FASTFINWAIT2TIME 0x3fffffffU +#define V_FASTFINWAIT2TIME(x) ((x) << S_FASTFINWAIT2TIME) +#define G_FASTFINWAIT2TIME(x) (((x) >> S_FASTFINWAIT2TIME) & M_FASTFINWAIT2TIME) + +#define A_TP_SHIFT_CNT 0x7dc0 + +#define S_SYNSHIFTMAX 24 +#define M_SYNSHIFTMAX 0xffU +#define V_SYNSHIFTMAX(x) ((x) << S_SYNSHIFTMAX) +#define G_SYNSHIFTMAX(x) (((x) >> S_SYNSHIFTMAX) & M_SYNSHIFTMAX) + +#define S_RXTSHIFTMAXR1 20 +#define M_RXTSHIFTMAXR1 0xfU +#define V_RXTSHIFTMAXR1(x) ((x) << S_RXTSHIFTMAXR1) +#define G_RXTSHIFTMAXR1(x) (((x) >> S_RXTSHIFTMAXR1) & M_RXTSHIFTMAXR1) + +#define S_RXTSHIFTMAXR2 16 +#define M_RXTSHIFTMAXR2 0xfU +#define V_RXTSHIFTMAXR2(x) ((x) << S_RXTSHIFTMAXR2) +#define G_RXTSHIFTMAXR2(x) (((x) >> S_RXTSHIFTMAXR2) & M_RXTSHIFTMAXR2) + +#define S_PERSHIFTBACKOFFMAX 12 +#define M_PERSHIFTBACKOFFMAX 0xfU +#define V_PERSHIFTBACKOFFMAX(x) ((x) << S_PERSHIFTBACKOFFMAX) +#define G_PERSHIFTBACKOFFMAX(x) (((x) >> S_PERSHIFTBACKOFFMAX) & M_PERSHIFTBACKOFFMAX) + +#define S_PERSHIFTMAX 8 +#define M_PERSHIFTMAX 0xfU +#define V_PERSHIFTMAX(x) ((x) << S_PERSHIFTMAX) +#define G_PERSHIFTMAX(x) (((x) >> S_PERSHIFTMAX) & M_PERSHIFTMAX) + +#define S_KEEPALIVEMAXR1 4 +#define M_KEEPALIVEMAXR1 0xfU +#define V_KEEPALIVEMAXR1(x) ((x) << S_KEEPALIVEMAXR1) +#define G_KEEPALIVEMAXR1(x) (((x) >> S_KEEPALIVEMAXR1) & M_KEEPALIVEMAXR1) + +#define S_KEEPALIVEMAXR2 0 +#define M_KEEPALIVEMAXR2 0xfU +#define V_KEEPALIVEMAXR2(x) ((x) << S_KEEPALIVEMAXR2) +#define G_KEEPALIVEMAXR2(x) (((x) >> S_KEEPALIVEMAXR2) & M_KEEPALIVEMAXR2) + +#define A_TP_TM_CONFIG 0x7dc4 + +#define S_CMTIMERMAXNUM 0 +#define M_CMTIMERMAXNUM 0x7U +#define V_CMTIMERMAXNUM(x) ((x) << S_CMTIMERMAXNUM) +#define G_CMTIMERMAXNUM(x) (((x) >> S_CMTIMERMAXNUM) & M_CMTIMERMAXNUM) + +#define A_TP_TIME_LO 0x7dc8 +#define A_TP_TIME_HI 0x7dcc +#define A_TP_PORT_MTU_0 0x7dd0 + +#define S_PORT1MTUVALUE 16 +#define M_PORT1MTUVALUE 0xffffU +#define V_PORT1MTUVALUE(x) ((x) << S_PORT1MTUVALUE) +#define G_PORT1MTUVALUE(x) (((x) >> S_PORT1MTUVALUE) & M_PORT1MTUVALUE) + +#define S_PORT0MTUVALUE 0 +#define M_PORT0MTUVALUE 0xffffU +#define V_PORT0MTUVALUE(x) ((x) << S_PORT0MTUVALUE) +#define G_PORT0MTUVALUE(x) (((x) >> S_PORT0MTUVALUE) & M_PORT0MTUVALUE) + +#define A_TP_PORT_MTU_1 0x7dd4 + +#define S_PORT3MTUVALUE 16 +#define M_PORT3MTUVALUE 0xffffU +#define V_PORT3MTUVALUE(x) ((x) << S_PORT3MTUVALUE) +#define G_PORT3MTUVALUE(x) (((x) >> S_PORT3MTUVALUE) & M_PORT3MTUVALUE) + +#define S_PORT2MTUVALUE 0 +#define M_PORT2MTUVALUE 0xffffU +#define V_PORT2MTUVALUE(x) ((x) << S_PORT2MTUVALUE) +#define G_PORT2MTUVALUE(x) (((x) >> S_PORT2MTUVALUE) & M_PORT2MTUVALUE) + +#define A_TP_PACE_TABLE 0x7dd8 +#define A_TP_CCTRL_TABLE 0x7ddc + +#define S_ROWINDEX 16 +#define M_ROWINDEX 0xffffU +#define V_ROWINDEX(x) ((x) << S_ROWINDEX) +#define G_ROWINDEX(x) (((x) >> S_ROWINDEX) & M_ROWINDEX) + +#define S_ROWVALUE 0 +#define M_ROWVALUE 0xffffU +#define V_ROWVALUE(x) ((x) << S_ROWVALUE) +#define G_ROWVALUE(x) (((x) >> S_ROWVALUE) & M_ROWVALUE) + +#define A_TP_MTU_TABLE 0x7de4 + +#define S_MTUINDEX 24 +#define M_MTUINDEX 0xffU +#define V_MTUINDEX(x) ((x) << S_MTUINDEX) +#define G_MTUINDEX(x) (((x) >> S_MTUINDEX) & M_MTUINDEX) + +#define S_MTUWIDTH 16 +#define M_MTUWIDTH 0xfU +#define V_MTUWIDTH(x) ((x) << S_MTUWIDTH) +#define G_MTUWIDTH(x) (((x) >> S_MTUWIDTH) & M_MTUWIDTH) + +#define S_MTUVALUE 0 +#define M_MTUVALUE 0x3fffU +#define V_MTUVALUE(x) ((x) << S_MTUVALUE) +#define G_MTUVALUE(x) (((x) >> S_MTUVALUE) & M_MTUVALUE) + +#define A_TP_ULP_TABLE 0x7de8 + +#define S_ULPTYPE7FIELD 28 +#define M_ULPTYPE7FIELD 0xfU +#define V_ULPTYPE7FIELD(x) ((x) << S_ULPTYPE7FIELD) +#define G_ULPTYPE7FIELD(x) (((x) >> S_ULPTYPE7FIELD) & M_ULPTYPE7FIELD) + +#define S_ULPTYPE6FIELD 24 +#define M_ULPTYPE6FIELD 0xfU +#define V_ULPTYPE6FIELD(x) ((x) << S_ULPTYPE6FIELD) +#define G_ULPTYPE6FIELD(x) (((x) >> S_ULPTYPE6FIELD) & M_ULPTYPE6FIELD) + +#define S_ULPTYPE5FIELD 20 +#define M_ULPTYPE5FIELD 0xfU +#define V_ULPTYPE5FIELD(x) ((x) << S_ULPTYPE5FIELD) +#define G_ULPTYPE5FIELD(x) (((x) >> S_ULPTYPE5FIELD) & M_ULPTYPE5FIELD) + +#define S_ULPTYPE4FIELD 16 +#define M_ULPTYPE4FIELD 0xfU +#define V_ULPTYPE4FIELD(x) ((x) << S_ULPTYPE4FIELD) +#define G_ULPTYPE4FIELD(x) (((x) >> S_ULPTYPE4FIELD) & M_ULPTYPE4FIELD) + +#define S_ULPTYPE3FIELD 12 +#define M_ULPTYPE3FIELD 0xfU +#define V_ULPTYPE3FIELD(x) ((x) << S_ULPTYPE3FIELD) +#define G_ULPTYPE3FIELD(x) (((x) >> S_ULPTYPE3FIELD) & M_ULPTYPE3FIELD) + +#define S_ULPTYPE2FIELD 8 +#define M_ULPTYPE2FIELD 0xfU +#define V_ULPTYPE2FIELD(x) ((x) << S_ULPTYPE2FIELD) +#define G_ULPTYPE2FIELD(x) (((x) >> S_ULPTYPE2FIELD) & M_ULPTYPE2FIELD) + +#define S_ULPTYPE1FIELD 4 +#define M_ULPTYPE1FIELD 0xfU +#define V_ULPTYPE1FIELD(x) ((x) << S_ULPTYPE1FIELD) +#define G_ULPTYPE1FIELD(x) (((x) >> S_ULPTYPE1FIELD) & M_ULPTYPE1FIELD) + +#define S_ULPTYPE0FIELD 0 +#define M_ULPTYPE0FIELD 0xfU +#define V_ULPTYPE0FIELD(x) ((x) << S_ULPTYPE0FIELD) +#define G_ULPTYPE0FIELD(x) (((x) >> S_ULPTYPE0FIELD) & M_ULPTYPE0FIELD) + +#define A_TP_RSS_LKP_TABLE 0x7dec + +#define S_LKPTBLROWVLD 31 +#define V_LKPTBLROWVLD(x) ((x) << S_LKPTBLROWVLD) +#define F_LKPTBLROWVLD V_LKPTBLROWVLD(1U) + +#define S_LKPTBLROWIDX 20 +#define M_LKPTBLROWIDX 0x3ffU +#define V_LKPTBLROWIDX(x) ((x) << S_LKPTBLROWIDX) +#define G_LKPTBLROWIDX(x) (((x) >> S_LKPTBLROWIDX) & M_LKPTBLROWIDX) + +#define S_LKPTBLQUEUE1 10 +#define M_LKPTBLQUEUE1 0x3ffU +#define V_LKPTBLQUEUE1(x) ((x) << S_LKPTBLQUEUE1) +#define G_LKPTBLQUEUE1(x) (((x) >> S_LKPTBLQUEUE1) & M_LKPTBLQUEUE1) + +#define S_LKPTBLQUEUE0 0 +#define M_LKPTBLQUEUE0 0x3ffU +#define V_LKPTBLQUEUE0(x) ((x) << S_LKPTBLQUEUE0) +#define G_LKPTBLQUEUE0(x) (((x) >> S_LKPTBLQUEUE0) & M_LKPTBLQUEUE0) + +#define A_TP_RSS_CONFIG 0x7df0 + +#define S_TNL4TUPENIPV6 31 +#define V_TNL4TUPENIPV6(x) ((x) << S_TNL4TUPENIPV6) +#define F_TNL4TUPENIPV6 V_TNL4TUPENIPV6(1U) + +#define S_TNL2TUPENIPV6 30 +#define V_TNL2TUPENIPV6(x) ((x) << S_TNL2TUPENIPV6) +#define F_TNL2TUPENIPV6 V_TNL2TUPENIPV6(1U) + +#define S_TNL4TUPENIPV4 29 +#define V_TNL4TUPENIPV4(x) ((x) << S_TNL4TUPENIPV4) +#define F_TNL4TUPENIPV4 V_TNL4TUPENIPV4(1U) + +#define S_TNL2TUPENIPV4 28 +#define V_TNL2TUPENIPV4(x) ((x) << S_TNL2TUPENIPV4) +#define F_TNL2TUPENIPV4 V_TNL2TUPENIPV4(1U) + +#define S_TNLTCPSEL 27 +#define V_TNLTCPSEL(x) ((x) << S_TNLTCPSEL) +#define F_TNLTCPSEL V_TNLTCPSEL(1U) + +#define S_TNLIP6SEL 26 +#define V_TNLIP6SEL(x) ((x) << S_TNLIP6SEL) +#define F_TNLIP6SEL V_TNLIP6SEL(1U) + +#define S_TNLVRTSEL 25 +#define V_TNLVRTSEL(x) ((x) << S_TNLVRTSEL) +#define F_TNLVRTSEL V_TNLVRTSEL(1U) + +#define S_TNLMAPEN 24 +#define V_TNLMAPEN(x) ((x) << S_TNLMAPEN) +#define F_TNLMAPEN V_TNLMAPEN(1U) + +#define S_OFDHASHSAVE 19 +#define V_OFDHASHSAVE(x) ((x) << S_OFDHASHSAVE) +#define F_OFDHASHSAVE V_OFDHASHSAVE(1U) + +#define S_OFDVRTSEL 18 +#define V_OFDVRTSEL(x) ((x) << S_OFDVRTSEL) +#define F_OFDVRTSEL V_OFDVRTSEL(1U) + +#define S_OFDMAPEN 17 +#define V_OFDMAPEN(x) ((x) << S_OFDMAPEN) +#define F_OFDMAPEN V_OFDMAPEN(1U) + +#define S_OFDLKPEN 16 +#define V_OFDLKPEN(x) ((x) << S_OFDLKPEN) +#define F_OFDLKPEN V_OFDLKPEN(1U) + +#define S_SYN4TUPENIPV6 15 +#define V_SYN4TUPENIPV6(x) ((x) << S_SYN4TUPENIPV6) +#define F_SYN4TUPENIPV6 V_SYN4TUPENIPV6(1U) + +#define S_SYN2TUPENIPV6 14 +#define V_SYN2TUPENIPV6(x) ((x) << S_SYN2TUPENIPV6) +#define F_SYN2TUPENIPV6 V_SYN2TUPENIPV6(1U) + +#define S_SYN4TUPENIPV4 13 +#define V_SYN4TUPENIPV4(x) ((x) << S_SYN4TUPENIPV4) +#define F_SYN4TUPENIPV4 V_SYN4TUPENIPV4(1U) + +#define S_SYN2TUPENIPV4 12 +#define V_SYN2TUPENIPV4(x) ((x) << S_SYN2TUPENIPV4) +#define F_SYN2TUPENIPV4 V_SYN2TUPENIPV4(1U) + +#define S_SYNIP6SEL 11 +#define V_SYNIP6SEL(x) ((x) << S_SYNIP6SEL) +#define F_SYNIP6SEL V_SYNIP6SEL(1U) + +#define S_SYNVRTSEL 10 +#define V_SYNVRTSEL(x) ((x) << S_SYNVRTSEL) +#define F_SYNVRTSEL V_SYNVRTSEL(1U) + +#define S_SYNMAPEN 9 +#define V_SYNMAPEN(x) ((x) << S_SYNMAPEN) +#define F_SYNMAPEN V_SYNMAPEN(1U) + +#define S_SYNLKPEN 8 +#define V_SYNLKPEN(x) ((x) << S_SYNLKPEN) +#define F_SYNLKPEN V_SYNLKPEN(1U) + +#define S_CHANNELENABLE 7 +#define V_CHANNELENABLE(x) ((x) << S_CHANNELENABLE) +#define F_CHANNELENABLE V_CHANNELENABLE(1U) + +#define S_PORTENABLE 6 +#define V_PORTENABLE(x) ((x) << S_PORTENABLE) +#define F_PORTENABLE V_PORTENABLE(1U) + +#define S_TNLALLLOOKUP 5 +#define V_TNLALLLOOKUP(x) ((x) << S_TNLALLLOOKUP) +#define F_TNLALLLOOKUP V_TNLALLLOOKUP(1U) + +#define S_VIRTENABLE 4 +#define V_VIRTENABLE(x) ((x) << S_VIRTENABLE) +#define F_VIRTENABLE V_VIRTENABLE(1U) + +#define S_CONGESTIONENABLE 3 +#define V_CONGESTIONENABLE(x) ((x) << S_CONGESTIONENABLE) +#define F_CONGESTIONENABLE V_CONGESTIONENABLE(1U) + +#define S_HASHTOEPLITZ 2 +#define V_HASHTOEPLITZ(x) ((x) << S_HASHTOEPLITZ) +#define F_HASHTOEPLITZ V_HASHTOEPLITZ(1U) + +#define S_UDPENABLE 1 +#define V_UDPENABLE(x) ((x) << S_UDPENABLE) +#define F_UDPENABLE V_UDPENABLE(1U) + +#define S_DISABLE 0 +#define V_DISABLE(x) ((x) << S_DISABLE) +#define F_DISABLE V_DISABLE(1U) + +#define S_TNLFCOEMODE 23 +#define V_TNLFCOEMODE(x) ((x) << S_TNLFCOEMODE) +#define F_TNLFCOEMODE V_TNLFCOEMODE(1U) + +#define S_TNLFCOEEN 21 +#define V_TNLFCOEEN(x) ((x) << S_TNLFCOEEN) +#define F_TNLFCOEEN V_TNLFCOEEN(1U) + +#define S_HASHXOR 20 +#define V_HASHXOR(x) ((x) << S_HASHXOR) +#define F_HASHXOR V_HASHXOR(1U) + +#define A_TP_RSS_CONFIG_TNL 0x7df4 + +#define S_MASKSIZE 28 +#define M_MASKSIZE 0xfU +#define V_MASKSIZE(x) ((x) << S_MASKSIZE) +#define G_MASKSIZE(x) (((x) >> S_MASKSIZE) & M_MASKSIZE) + +#define S_MASKFILTER 16 +#define M_MASKFILTER 0x7ffU +#define V_MASKFILTER(x) ((x) << S_MASKFILTER) +#define G_MASKFILTER(x) (((x) >> S_MASKFILTER) & M_MASKFILTER) + +#define S_USEWIRECH 0 +#define V_USEWIRECH(x) ((x) << S_USEWIRECH) +#define F_USEWIRECH V_USEWIRECH(1U) + +#define A_TP_RSS_CONFIG_OFD 0x7df8 + +#define S_RRCPLMAPEN 20 +#define V_RRCPLMAPEN(x) ((x) << S_RRCPLMAPEN) +#define F_RRCPLMAPEN V_RRCPLMAPEN(1U) + +#define S_RRCPLQUEWIDTH 16 +#define M_RRCPLQUEWIDTH 0xfU +#define V_RRCPLQUEWIDTH(x) ((x) << S_RRCPLQUEWIDTH) +#define G_RRCPLQUEWIDTH(x) (((x) >> S_RRCPLQUEWIDTH) & M_RRCPLQUEWIDTH) + +#define S_FRMWRQUEMASK 12 +#define M_FRMWRQUEMASK 0xfU +#define V_FRMWRQUEMASK(x) ((x) << S_FRMWRQUEMASK) +#define G_FRMWRQUEMASK(x) (((x) >> S_FRMWRQUEMASK) & M_FRMWRQUEMASK) + +#define A_TP_RSS_CONFIG_SYN 0x7dfc +#define A_TP_RSS_CONFIG_VRT 0x7e00 + +#define S_VFRDRG 25 +#define V_VFRDRG(x) ((x) << S_VFRDRG) +#define F_VFRDRG V_VFRDRG(1U) + +#define S_VFRDEN 24 +#define V_VFRDEN(x) ((x) << S_VFRDEN) +#define F_VFRDEN V_VFRDEN(1U) + +#define S_VFPERREN 23 +#define V_VFPERREN(x) ((x) << S_VFPERREN) +#define F_VFPERREN V_VFPERREN(1U) + +#define S_KEYPERREN 22 +#define V_KEYPERREN(x) ((x) << S_KEYPERREN) +#define F_KEYPERREN V_KEYPERREN(1U) + +#define S_DISABLEVLAN 21 +#define V_DISABLEVLAN(x) ((x) << S_DISABLEVLAN) +#define F_DISABLEVLAN V_DISABLEVLAN(1U) + +#define S_ENABLEUP0 20 +#define V_ENABLEUP0(x) ((x) << S_ENABLEUP0) +#define F_ENABLEUP0 V_ENABLEUP0(1U) + +#define S_HASHDELAY 16 +#define M_HASHDELAY 0xfU +#define V_HASHDELAY(x) ((x) << S_HASHDELAY) +#define G_HASHDELAY(x) (((x) >> S_HASHDELAY) & M_HASHDELAY) + +#define S_VFWRADDR 8 +#define M_VFWRADDR 0x7fU +#define V_VFWRADDR(x) ((x) << S_VFWRADDR) +#define G_VFWRADDR(x) (((x) >> S_VFWRADDR) & M_VFWRADDR) + +#define S_KEYMODE 6 +#define M_KEYMODE 0x3U +#define V_KEYMODE(x) ((x) << S_KEYMODE) +#define G_KEYMODE(x) (((x) >> S_KEYMODE) & M_KEYMODE) + +#define S_VFWREN 5 +#define V_VFWREN(x) ((x) << S_VFWREN) +#define F_VFWREN V_VFWREN(1U) + +#define S_KEYWREN 4 +#define V_KEYWREN(x) ((x) << S_KEYWREN) +#define F_KEYWREN V_KEYWREN(1U) + +#define S_KEYWRADDR 0 +#define M_KEYWRADDR 0xfU +#define V_KEYWRADDR(x) ((x) << S_KEYWRADDR) +#define G_KEYWRADDR(x) (((x) >> S_KEYWRADDR) & M_KEYWRADDR) + +#define S_VFVLANEN 21 +#define V_VFVLANEN(x) ((x) << S_VFVLANEN) +#define F_VFVLANEN V_VFVLANEN(1U) + +#define S_VFFWEN 20 +#define V_VFFWEN(x) ((x) << S_VFFWEN) +#define F_VFFWEN V_VFFWEN(1U) + +#define A_TP_RSS_CONFIG_CNG 0x7e04 + +#define S_CHNCOUNT3 31 +#define V_CHNCOUNT3(x) ((x) << S_CHNCOUNT3) +#define F_CHNCOUNT3 V_CHNCOUNT3(1U) + +#define S_CHNCOUNT2 30 +#define V_CHNCOUNT2(x) ((x) << S_CHNCOUNT2) +#define F_CHNCOUNT2 V_CHNCOUNT2(1U) + +#define S_CHNCOUNT1 29 +#define V_CHNCOUNT1(x) ((x) << S_CHNCOUNT1) +#define F_CHNCOUNT1 V_CHNCOUNT1(1U) + +#define S_CHNCOUNT0 28 +#define V_CHNCOUNT0(x) ((x) << S_CHNCOUNT0) +#define F_CHNCOUNT0 V_CHNCOUNT0(1U) + +#define S_CHNUNDFLOW3 27 +#define V_CHNUNDFLOW3(x) ((x) << S_CHNUNDFLOW3) +#define F_CHNUNDFLOW3 V_CHNUNDFLOW3(1U) + +#define S_CHNUNDFLOW2 26 +#define V_CHNUNDFLOW2(x) ((x) << S_CHNUNDFLOW2) +#define F_CHNUNDFLOW2 V_CHNUNDFLOW2(1U) + +#define S_CHNUNDFLOW1 25 +#define V_CHNUNDFLOW1(x) ((x) << S_CHNUNDFLOW1) +#define F_CHNUNDFLOW1 V_CHNUNDFLOW1(1U) + +#define S_CHNUNDFLOW0 24 +#define V_CHNUNDFLOW0(x) ((x) << S_CHNUNDFLOW0) +#define F_CHNUNDFLOW0 V_CHNUNDFLOW0(1U) + +#define S_CHNOVRFLOW3 23 +#define V_CHNOVRFLOW3(x) ((x) << S_CHNOVRFLOW3) +#define F_CHNOVRFLOW3 V_CHNOVRFLOW3(1U) + +#define S_CHNOVRFLOW2 22 +#define V_CHNOVRFLOW2(x) ((x) << S_CHNOVRFLOW2) +#define F_CHNOVRFLOW2 V_CHNOVRFLOW2(1U) + +#define S_CHNOVRFLOW1 21 +#define V_CHNOVRFLOW1(x) ((x) << S_CHNOVRFLOW1) +#define F_CHNOVRFLOW1 V_CHNOVRFLOW1(1U) + +#define S_CHNOVRFLOW0 20 +#define V_CHNOVRFLOW0(x) ((x) << S_CHNOVRFLOW0) +#define F_CHNOVRFLOW0 V_CHNOVRFLOW0(1U) + +#define S_RSTCHN3 19 +#define V_RSTCHN3(x) ((x) << S_RSTCHN3) +#define F_RSTCHN3 V_RSTCHN3(1U) + +#define S_RSTCHN2 18 +#define V_RSTCHN2(x) ((x) << S_RSTCHN2) +#define F_RSTCHN2 V_RSTCHN2(1U) + +#define S_RSTCHN1 17 +#define V_RSTCHN1(x) ((x) << S_RSTCHN1) +#define F_RSTCHN1 V_RSTCHN1(1U) + +#define S_RSTCHN0 16 +#define V_RSTCHN0(x) ((x) << S_RSTCHN0) +#define F_RSTCHN0 V_RSTCHN0(1U) + +#define S_UPDVLD 15 +#define V_UPDVLD(x) ((x) << S_UPDVLD) +#define F_UPDVLD V_UPDVLD(1U) + +#define S_XOFF 14 +#define V_XOFF(x) ((x) << S_XOFF) +#define F_XOFF V_XOFF(1U) + +#define S_UPDCHN3 13 +#define V_UPDCHN3(x) ((x) << S_UPDCHN3) +#define F_UPDCHN3 V_UPDCHN3(1U) + +#define S_UPDCHN2 12 +#define V_UPDCHN2(x) ((x) << S_UPDCHN2) +#define F_UPDCHN2 V_UPDCHN2(1U) + +#define S_UPDCHN1 11 +#define V_UPDCHN1(x) ((x) << S_UPDCHN1) +#define F_UPDCHN1 V_UPDCHN1(1U) + +#define S_UPDCHN0 10 +#define V_UPDCHN0(x) ((x) << S_UPDCHN0) +#define F_UPDCHN0 V_UPDCHN0(1U) + +#define S_QUEUE 0 +#define M_QUEUE 0x3ffU +#define V_QUEUE(x) ((x) << S_QUEUE) +#define G_QUEUE(x) (((x) >> S_QUEUE) & M_QUEUE) + +#define A_TP_LA_TABLE_0 0x7e10 + +#define S_VIRTPORT1TABLE 16 +#define M_VIRTPORT1TABLE 0xffffU +#define V_VIRTPORT1TABLE(x) ((x) << S_VIRTPORT1TABLE) +#define G_VIRTPORT1TABLE(x) (((x) >> S_VIRTPORT1TABLE) & M_VIRTPORT1TABLE) + +#define S_VIRTPORT0TABLE 0 +#define M_VIRTPORT0TABLE 0xffffU +#define V_VIRTPORT0TABLE(x) ((x) << S_VIRTPORT0TABLE) +#define G_VIRTPORT0TABLE(x) (((x) >> S_VIRTPORT0TABLE) & M_VIRTPORT0TABLE) + +#define A_TP_LA_TABLE_1 0x7e14 + +#define S_VIRTPORT3TABLE 16 +#define M_VIRTPORT3TABLE 0xffffU +#define V_VIRTPORT3TABLE(x) ((x) << S_VIRTPORT3TABLE) +#define G_VIRTPORT3TABLE(x) (((x) >> S_VIRTPORT3TABLE) & M_VIRTPORT3TABLE) + +#define S_VIRTPORT2TABLE 0 +#define M_VIRTPORT2TABLE 0xffffU +#define V_VIRTPORT2TABLE(x) ((x) << S_VIRTPORT2TABLE) +#define G_VIRTPORT2TABLE(x) (((x) >> S_VIRTPORT2TABLE) & M_VIRTPORT2TABLE) + +#define A_TP_TM_PIO_ADDR 0x7e18 +#define A_TP_TM_PIO_DATA 0x7e1c +#define A_TP_MOD_CONFIG 0x7e24 + +#define S_RXCHANNELWEIGHT1 24 +#define M_RXCHANNELWEIGHT1 0xffU +#define V_RXCHANNELWEIGHT1(x) ((x) << S_RXCHANNELWEIGHT1) +#define G_RXCHANNELWEIGHT1(x) (((x) >> S_RXCHANNELWEIGHT1) & M_RXCHANNELWEIGHT1) + +#define S_RXCHANNELWEIGHT0 16 +#define M_RXCHANNELWEIGHT0 0xffU +#define V_RXCHANNELWEIGHT0(x) ((x) << S_RXCHANNELWEIGHT0) +#define G_RXCHANNELWEIGHT0(x) (((x) >> S_RXCHANNELWEIGHT0) & M_RXCHANNELWEIGHT0) + +#define S_TIMERMODE 8 +#define M_TIMERMODE 0xffU +#define V_TIMERMODE(x) ((x) << S_TIMERMODE) +#define G_TIMERMODE(x) (((x) >> S_TIMERMODE) & M_TIMERMODE) + +#define S_TXCHANNELXOFFEN 0 +#define M_TXCHANNELXOFFEN 0xfU +#define V_TXCHANNELXOFFEN(x) ((x) << S_TXCHANNELXOFFEN) +#define G_TXCHANNELXOFFEN(x) (((x) >> S_TXCHANNELXOFFEN) & M_TXCHANNELXOFFEN) + +#define A_TP_TX_MOD_QUEUE_REQ_MAP 0x7e28 + +#define S_RX_MOD_WEIGHT 24 +#define M_RX_MOD_WEIGHT 0xffU +#define V_RX_MOD_WEIGHT(x) ((x) << S_RX_MOD_WEIGHT) +#define G_RX_MOD_WEIGHT(x) (((x) >> S_RX_MOD_WEIGHT) & M_RX_MOD_WEIGHT) + +#define S_TX_MOD_WEIGHT 16 +#define M_TX_MOD_WEIGHT 0xffU +#define V_TX_MOD_WEIGHT(x) ((x) << S_TX_MOD_WEIGHT) +#define G_TX_MOD_WEIGHT(x) (((x) >> S_TX_MOD_WEIGHT) & M_TX_MOD_WEIGHT) + +#define S_TX_MOD_QUEUE_REQ_MAP 0 +#define M_TX_MOD_QUEUE_REQ_MAP 0xffffU +#define V_TX_MOD_QUEUE_REQ_MAP(x) ((x) << S_TX_MOD_QUEUE_REQ_MAP) +#define G_TX_MOD_QUEUE_REQ_MAP(x) (((x) >> S_TX_MOD_QUEUE_REQ_MAP) & M_TX_MOD_QUEUE_REQ_MAP) + +#define A_TP_TX_MOD_QUEUE_WEIGHT1 0x7e2c + +#define S_TX_MODQ_WEIGHT7 24 +#define M_TX_MODQ_WEIGHT7 0xffU +#define V_TX_MODQ_WEIGHT7(x) ((x) << S_TX_MODQ_WEIGHT7) +#define G_TX_MODQ_WEIGHT7(x) (((x) >> S_TX_MODQ_WEIGHT7) & M_TX_MODQ_WEIGHT7) + +#define S_TX_MODQ_WEIGHT6 16 +#define M_TX_MODQ_WEIGHT6 0xffU +#define V_TX_MODQ_WEIGHT6(x) ((x) << S_TX_MODQ_WEIGHT6) +#define G_TX_MODQ_WEIGHT6(x) (((x) >> S_TX_MODQ_WEIGHT6) & M_TX_MODQ_WEIGHT6) + +#define S_TX_MODQ_WEIGHT5 8 +#define M_TX_MODQ_WEIGHT5 0xffU +#define V_TX_MODQ_WEIGHT5(x) ((x) << S_TX_MODQ_WEIGHT5) +#define G_TX_MODQ_WEIGHT5(x) (((x) >> S_TX_MODQ_WEIGHT5) & M_TX_MODQ_WEIGHT5) + +#define S_TX_MODQ_WEIGHT4 0 +#define M_TX_MODQ_WEIGHT4 0xffU +#define V_TX_MODQ_WEIGHT4(x) ((x) << S_TX_MODQ_WEIGHT4) +#define G_TX_MODQ_WEIGHT4(x) (((x) >> S_TX_MODQ_WEIGHT4) & M_TX_MODQ_WEIGHT4) + +#define A_TP_TX_MOD_QUEUE_WEIGHT0 0x7e30 + +#define S_TX_MODQ_WEIGHT3 24 +#define M_TX_MODQ_WEIGHT3 0xffU +#define V_TX_MODQ_WEIGHT3(x) ((x) << S_TX_MODQ_WEIGHT3) +#define G_TX_MODQ_WEIGHT3(x) (((x) >> S_TX_MODQ_WEIGHT3) & M_TX_MODQ_WEIGHT3) + +#define S_TX_MODQ_WEIGHT2 16 +#define M_TX_MODQ_WEIGHT2 0xffU +#define V_TX_MODQ_WEIGHT2(x) ((x) << S_TX_MODQ_WEIGHT2) +#define G_TX_MODQ_WEIGHT2(x) (((x) >> S_TX_MODQ_WEIGHT2) & M_TX_MODQ_WEIGHT2) + +#define S_TX_MODQ_WEIGHT1 8 +#define M_TX_MODQ_WEIGHT1 0xffU +#define V_TX_MODQ_WEIGHT1(x) ((x) << S_TX_MODQ_WEIGHT1) +#define G_TX_MODQ_WEIGHT1(x) (((x) >> S_TX_MODQ_WEIGHT1) & M_TX_MODQ_WEIGHT1) + +#define S_TX_MODQ_WEIGHT0 0 +#define M_TX_MODQ_WEIGHT0 0xffU +#define V_TX_MODQ_WEIGHT0(x) ((x) << S_TX_MODQ_WEIGHT0) +#define G_TX_MODQ_WEIGHT0(x) (((x) >> S_TX_MODQ_WEIGHT0) & M_TX_MODQ_WEIGHT0) + +#define A_TP_TX_MOD_CHANNEL_WEIGHT 0x7e34 +#define A_TP_MOD_RATE_LIMIT 0x7e38 + +#define S_RX_MOD_RATE_LIMIT_INC 24 +#define M_RX_MOD_RATE_LIMIT_INC 0xffU +#define V_RX_MOD_RATE_LIMIT_INC(x) ((x) << S_RX_MOD_RATE_LIMIT_INC) +#define G_RX_MOD_RATE_LIMIT_INC(x) (((x) >> S_RX_MOD_RATE_LIMIT_INC) & M_RX_MOD_RATE_LIMIT_INC) + +#define S_RX_MOD_RATE_LIMIT_TICK 16 +#define M_RX_MOD_RATE_LIMIT_TICK 0xffU +#define V_RX_MOD_RATE_LIMIT_TICK(x) ((x) << S_RX_MOD_RATE_LIMIT_TICK) +#define G_RX_MOD_RATE_LIMIT_TICK(x) (((x) >> S_RX_MOD_RATE_LIMIT_TICK) & M_RX_MOD_RATE_LIMIT_TICK) + +#define S_TX_MOD_RATE_LIMIT_INC 8 +#define M_TX_MOD_RATE_LIMIT_INC 0xffU +#define V_TX_MOD_RATE_LIMIT_INC(x) ((x) << S_TX_MOD_RATE_LIMIT_INC) +#define G_TX_MOD_RATE_LIMIT_INC(x) (((x) >> S_TX_MOD_RATE_LIMIT_INC) & M_TX_MOD_RATE_LIMIT_INC) + +#define S_TX_MOD_RATE_LIMIT_TICK 0 +#define M_TX_MOD_RATE_LIMIT_TICK 0xffU +#define V_TX_MOD_RATE_LIMIT_TICK(x) ((x) << S_TX_MOD_RATE_LIMIT_TICK) +#define G_TX_MOD_RATE_LIMIT_TICK(x) (((x) >> S_TX_MOD_RATE_LIMIT_TICK) & M_TX_MOD_RATE_LIMIT_TICK) + +#define A_TP_PIO_ADDR 0x7e40 +#define A_TP_PIO_DATA 0x7e44 +#define A_TP_RESET 0x7e4c + +#define S_FLSTINITENABLE 1 +#define V_FLSTINITENABLE(x) ((x) << S_FLSTINITENABLE) +#define F_FLSTINITENABLE V_FLSTINITENABLE(1U) + +#define S_TPRESET 0 +#define V_TPRESET(x) ((x) << S_TPRESET) +#define F_TPRESET V_TPRESET(1U) + +#define A_TP_MIB_INDEX 0x7e50 +#define A_TP_MIB_DATA 0x7e54 +#define A_TP_SYNC_TIME_HI 0x7e58 +#define A_TP_SYNC_TIME_LO 0x7e5c +#define A_TP_CMM_MM_RX_FLST_BASE 0x7e60 +#define A_TP_CMM_MM_TX_FLST_BASE 0x7e64 +#define A_TP_CMM_MM_PS_FLST_BASE 0x7e68 +#define A_TP_CMM_MM_MAX_PSTRUCT 0x7e6c + +#define S_CMMAXPSTRUCT 0 +#define M_CMMAXPSTRUCT 0x1fffffU +#define V_CMMAXPSTRUCT(x) ((x) << S_CMMAXPSTRUCT) +#define G_CMMAXPSTRUCT(x) (((x) >> S_CMMAXPSTRUCT) & M_CMMAXPSTRUCT) + +#define A_TP_INT_ENABLE 0x7e70 + +#define S_FLMTXFLSTEMPTY 30 +#define V_FLMTXFLSTEMPTY(x) ((x) << S_FLMTXFLSTEMPTY) +#define F_FLMTXFLSTEMPTY V_FLMTXFLSTEMPTY(1U) + +#define S_RSSLKPPERR 29 +#define V_RSSLKPPERR(x) ((x) << S_RSSLKPPERR) +#define F_RSSLKPPERR V_RSSLKPPERR(1U) + +#define S_FLMPERRSET 28 +#define V_FLMPERRSET(x) ((x) << S_FLMPERRSET) +#define F_FLMPERRSET V_FLMPERRSET(1U) + +#define S_PROTOCOLSRAMPERR 27 +#define V_PROTOCOLSRAMPERR(x) ((x) << S_PROTOCOLSRAMPERR) +#define F_PROTOCOLSRAMPERR V_PROTOCOLSRAMPERR(1U) + +#define S_ARPLUTPERR 26 +#define V_ARPLUTPERR(x) ((x) << S_ARPLUTPERR) +#define F_ARPLUTPERR V_ARPLUTPERR(1U) + +#define S_CMRCFOPPERR 25 +#define V_CMRCFOPPERR(x) ((x) << S_CMRCFOPPERR) +#define F_CMRCFOPPERR V_CMRCFOPPERR(1U) + +#define S_CMCACHEPERR 24 +#define V_CMCACHEPERR(x) ((x) << S_CMCACHEPERR) +#define F_CMCACHEPERR V_CMCACHEPERR(1U) + +#define S_CMRCFDATAPERR 23 +#define V_CMRCFDATAPERR(x) ((x) << S_CMRCFDATAPERR) +#define F_CMRCFDATAPERR V_CMRCFDATAPERR(1U) + +#define S_DBL2TLUTPERR 22 +#define V_DBL2TLUTPERR(x) ((x) << S_DBL2TLUTPERR) +#define F_DBL2TLUTPERR V_DBL2TLUTPERR(1U) + +#define S_DBTXTIDPERR 21 +#define V_DBTXTIDPERR(x) ((x) << S_DBTXTIDPERR) +#define F_DBTXTIDPERR V_DBTXTIDPERR(1U) + +#define S_DBEXTPERR 20 +#define V_DBEXTPERR(x) ((x) << S_DBEXTPERR) +#define F_DBEXTPERR V_DBEXTPERR(1U) + +#define S_DBOPPERR 19 +#define V_DBOPPERR(x) ((x) << S_DBOPPERR) +#define F_DBOPPERR V_DBOPPERR(1U) + +#define S_TMCACHEPERR 18 +#define V_TMCACHEPERR(x) ((x) << S_TMCACHEPERR) +#define F_TMCACHEPERR V_TMCACHEPERR(1U) + +#define S_ETPOUTCPLFIFOPERR 17 +#define V_ETPOUTCPLFIFOPERR(x) ((x) << S_ETPOUTCPLFIFOPERR) +#define F_ETPOUTCPLFIFOPERR V_ETPOUTCPLFIFOPERR(1U) + +#define S_ETPOUTTCPFIFOPERR 16 +#define V_ETPOUTTCPFIFOPERR(x) ((x) << S_ETPOUTTCPFIFOPERR) +#define F_ETPOUTTCPFIFOPERR V_ETPOUTTCPFIFOPERR(1U) + +#define S_ETPOUTIPFIFOPERR 15 +#define V_ETPOUTIPFIFOPERR(x) ((x) << S_ETPOUTIPFIFOPERR) +#define F_ETPOUTIPFIFOPERR V_ETPOUTIPFIFOPERR(1U) + +#define S_ETPOUTETHFIFOPERR 14 +#define V_ETPOUTETHFIFOPERR(x) ((x) << S_ETPOUTETHFIFOPERR) +#define F_ETPOUTETHFIFOPERR V_ETPOUTETHFIFOPERR(1U) + +#define S_ETPINCPLFIFOPERR 13 +#define V_ETPINCPLFIFOPERR(x) ((x) << S_ETPINCPLFIFOPERR) +#define F_ETPINCPLFIFOPERR V_ETPINCPLFIFOPERR(1U) + +#define S_ETPINTCPOPTFIFOPERR 12 +#define V_ETPINTCPOPTFIFOPERR(x) ((x) << S_ETPINTCPOPTFIFOPERR) +#define F_ETPINTCPOPTFIFOPERR V_ETPINTCPOPTFIFOPERR(1U) + +#define S_ETPINTCPFIFOPERR 11 +#define V_ETPINTCPFIFOPERR(x) ((x) << S_ETPINTCPFIFOPERR) +#define F_ETPINTCPFIFOPERR V_ETPINTCPFIFOPERR(1U) + +#define S_ETPINIPFIFOPERR 10 +#define V_ETPINIPFIFOPERR(x) ((x) << S_ETPINIPFIFOPERR) +#define F_ETPINIPFIFOPERR V_ETPINIPFIFOPERR(1U) + +#define S_ETPINETHFIFOPERR 9 +#define V_ETPINETHFIFOPERR(x) ((x) << S_ETPINETHFIFOPERR) +#define F_ETPINETHFIFOPERR V_ETPINETHFIFOPERR(1U) + +#define S_CTPOUTCPLFIFOPERR 8 +#define V_CTPOUTCPLFIFOPERR(x) ((x) << S_CTPOUTCPLFIFOPERR) +#define F_CTPOUTCPLFIFOPERR V_CTPOUTCPLFIFOPERR(1U) + +#define S_CTPOUTTCPFIFOPERR 7 +#define V_CTPOUTTCPFIFOPERR(x) ((x) << S_CTPOUTTCPFIFOPERR) +#define F_CTPOUTTCPFIFOPERR V_CTPOUTTCPFIFOPERR(1U) + +#define S_CTPOUTIPFIFOPERR 6 +#define V_CTPOUTIPFIFOPERR(x) ((x) << S_CTPOUTIPFIFOPERR) +#define F_CTPOUTIPFIFOPERR V_CTPOUTIPFIFOPERR(1U) + +#define S_CTPOUTETHFIFOPERR 5 +#define V_CTPOUTETHFIFOPERR(x) ((x) << S_CTPOUTETHFIFOPERR) +#define F_CTPOUTETHFIFOPERR V_CTPOUTETHFIFOPERR(1U) + +#define S_CTPINCPLFIFOPERR 4 +#define V_CTPINCPLFIFOPERR(x) ((x) << S_CTPINCPLFIFOPERR) +#define F_CTPINCPLFIFOPERR V_CTPINCPLFIFOPERR(1U) + +#define S_CTPINTCPOPFIFOPERR 3 +#define V_CTPINTCPOPFIFOPERR(x) ((x) << S_CTPINTCPOPFIFOPERR) +#define F_CTPINTCPOPFIFOPERR V_CTPINTCPOPFIFOPERR(1U) + +#define S_PDUFBKFIFOPERR 2 +#define V_PDUFBKFIFOPERR(x) ((x) << S_PDUFBKFIFOPERR) +#define F_PDUFBKFIFOPERR V_PDUFBKFIFOPERR(1U) + +#define S_CMOPEXTFIFOPERR 1 +#define V_CMOPEXTFIFOPERR(x) ((x) << S_CMOPEXTFIFOPERR) +#define F_CMOPEXTFIFOPERR V_CMOPEXTFIFOPERR(1U) + +#define S_DELINVFIFOPERR 0 +#define V_DELINVFIFOPERR(x) ((x) << S_DELINVFIFOPERR) +#define F_DELINVFIFOPERR V_DELINVFIFOPERR(1U) + +#define S_CTPOUTPLDFIFOPERR 7 +#define V_CTPOUTPLDFIFOPERR(x) ((x) << S_CTPOUTPLDFIFOPERR) +#define F_CTPOUTPLDFIFOPERR V_CTPOUTPLDFIFOPERR(1U) + +#define A_TP_INT_CAUSE 0x7e74 +#define A_TP_PER_ENABLE 0x7e78 +#define A_TP_FLM_FREE_PS_CNT 0x7e80 + +#define S_FREEPSTRUCTCOUNT 0 +#define M_FREEPSTRUCTCOUNT 0x1fffffU +#define V_FREEPSTRUCTCOUNT(x) ((x) << S_FREEPSTRUCTCOUNT) +#define G_FREEPSTRUCTCOUNT(x) (((x) >> S_FREEPSTRUCTCOUNT) & M_FREEPSTRUCTCOUNT) + +#define A_TP_FLM_FREE_RX_CNT 0x7e84 + +#define S_FREERXPAGECHN 28 +#define V_FREERXPAGECHN(x) ((x) << S_FREERXPAGECHN) +#define F_FREERXPAGECHN V_FREERXPAGECHN(1U) + +#define S_FREERXPAGECOUNT 0 +#define M_FREERXPAGECOUNT 0x1fffffU +#define V_FREERXPAGECOUNT(x) ((x) << S_FREERXPAGECOUNT) +#define G_FREERXPAGECOUNT(x) (((x) >> S_FREERXPAGECOUNT) & M_FREERXPAGECOUNT) + +#define A_TP_FLM_FREE_TX_CNT 0x7e88 + +#define S_FREETXPAGECHN 28 +#define M_FREETXPAGECHN 0x3U +#define V_FREETXPAGECHN(x) ((x) << S_FREETXPAGECHN) +#define G_FREETXPAGECHN(x) (((x) >> S_FREETXPAGECHN) & M_FREETXPAGECHN) + +#define S_FREETXPAGECOUNT 0 +#define M_FREETXPAGECOUNT 0x1fffffU +#define V_FREETXPAGECOUNT(x) ((x) << S_FREETXPAGECOUNT) +#define G_FREETXPAGECOUNT(x) (((x) >> S_FREETXPAGECOUNT) & M_FREETXPAGECOUNT) + +#define A_TP_TM_HEAP_PUSH_CNT 0x7e8c +#define A_TP_TM_HEAP_POP_CNT 0x7e90 +#define A_TP_TM_DACK_PUSH_CNT 0x7e94 +#define A_TP_TM_DACK_POP_CNT 0x7e98 +#define A_TP_TM_MOD_PUSH_CNT 0x7e9c +#define A_TP_MOD_POP_CNT 0x7ea0 +#define A_TP_TIMER_SEPARATOR 0x7ea4 + +#define S_TIMERSEPARATOR 16 +#define M_TIMERSEPARATOR 0xffffU +#define V_TIMERSEPARATOR(x) ((x) << S_TIMERSEPARATOR) +#define G_TIMERSEPARATOR(x) (((x) >> S_TIMERSEPARATOR) & M_TIMERSEPARATOR) + +#define S_DISABLETIMEFREEZE 0 +#define V_DISABLETIMEFREEZE(x) ((x) << S_DISABLETIMEFREEZE) +#define F_DISABLETIMEFREEZE V_DISABLETIMEFREEZE(1U) + +#define A_TP_STAMP_TIME 0x7ea8 +#define A_TP_DEBUG_FLAGS 0x7eac + +#define S_RXTIMERDACKFIRST 26 +#define V_RXTIMERDACKFIRST(x) ((x) << S_RXTIMERDACKFIRST) +#define F_RXTIMERDACKFIRST V_RXTIMERDACKFIRST(1U) + +#define S_RXTIMERDACK 25 +#define V_RXTIMERDACK(x) ((x) << S_RXTIMERDACK) +#define F_RXTIMERDACK V_RXTIMERDACK(1U) + +#define S_RXTIMERHEARTBEAT 24 +#define V_RXTIMERHEARTBEAT(x) ((x) << S_RXTIMERHEARTBEAT) +#define F_RXTIMERHEARTBEAT V_RXTIMERHEARTBEAT(1U) + +#define S_RXPAWSDROP 23 +#define V_RXPAWSDROP(x) ((x) << S_RXPAWSDROP) +#define F_RXPAWSDROP V_RXPAWSDROP(1U) + +#define S_RXURGDATADROP 22 +#define V_RXURGDATADROP(x) ((x) << S_RXURGDATADROP) +#define F_RXURGDATADROP V_RXURGDATADROP(1U) + +#define S_RXFUTUREDATA 21 +#define V_RXFUTUREDATA(x) ((x) << S_RXFUTUREDATA) +#define F_RXFUTUREDATA V_RXFUTUREDATA(1U) + +#define S_RXRCVRXMDATA 20 +#define V_RXRCVRXMDATA(x) ((x) << S_RXRCVRXMDATA) +#define F_RXRCVRXMDATA V_RXRCVRXMDATA(1U) + +#define S_RXRCVOOODATAFIN 19 +#define V_RXRCVOOODATAFIN(x) ((x) << S_RXRCVOOODATAFIN) +#define F_RXRCVOOODATAFIN V_RXRCVOOODATAFIN(1U) + +#define S_RXRCVOOODATA 18 +#define V_RXRCVOOODATA(x) ((x) << S_RXRCVOOODATA) +#define F_RXRCVOOODATA V_RXRCVOOODATA(1U) + +#define S_RXRCVWNDZERO 17 +#define V_RXRCVWNDZERO(x) ((x) << S_RXRCVWNDZERO) +#define F_RXRCVWNDZERO V_RXRCVWNDZERO(1U) + +#define S_RXRCVWNDLTMSS 16 +#define V_RXRCVWNDLTMSS(x) ((x) << S_RXRCVWNDLTMSS) +#define F_RXRCVWNDLTMSS V_RXRCVWNDLTMSS(1U) + +#define S_TXDUPACKINC 11 +#define V_TXDUPACKINC(x) ((x) << S_TXDUPACKINC) +#define F_TXDUPACKINC V_TXDUPACKINC(1U) + +#define S_TXRXMURG 10 +#define V_TXRXMURG(x) ((x) << S_TXRXMURG) +#define F_TXRXMURG V_TXRXMURG(1U) + +#define S_TXRXMFIN 9 +#define V_TXRXMFIN(x) ((x) << S_TXRXMFIN) +#define F_TXRXMFIN V_TXRXMFIN(1U) + +#define S_TXRXMSYN 8 +#define V_TXRXMSYN(x) ((x) << S_TXRXMSYN) +#define F_TXRXMSYN V_TXRXMSYN(1U) + +#define S_TXRXMNEWRENO 7 +#define V_TXRXMNEWRENO(x) ((x) << S_TXRXMNEWRENO) +#define F_TXRXMNEWRENO V_TXRXMNEWRENO(1U) + +#define S_TXRXMFAST 6 +#define V_TXRXMFAST(x) ((x) << S_TXRXMFAST) +#define F_TXRXMFAST V_TXRXMFAST(1U) + +#define S_TXRXMTIMER 5 +#define V_TXRXMTIMER(x) ((x) << S_TXRXMTIMER) +#define F_TXRXMTIMER V_TXRXMTIMER(1U) + +#define S_TXRXMTIMERKEEPALIVE 4 +#define V_TXRXMTIMERKEEPALIVE(x) ((x) << S_TXRXMTIMERKEEPALIVE) +#define F_TXRXMTIMERKEEPALIVE V_TXRXMTIMERKEEPALIVE(1U) + +#define S_TXRXMTIMERPERSIST 3 +#define V_TXRXMTIMERPERSIST(x) ((x) << S_TXRXMTIMERPERSIST) +#define F_TXRXMTIMERPERSIST V_TXRXMTIMERPERSIST(1U) + +#define S_TXRCVADVSHRUNK 2 +#define V_TXRCVADVSHRUNK(x) ((x) << S_TXRCVADVSHRUNK) +#define F_TXRCVADVSHRUNK V_TXRCVADVSHRUNK(1U) + +#define S_TXRCVADVZERO 1 +#define V_TXRCVADVZERO(x) ((x) << S_TXRCVADVZERO) +#define F_TXRCVADVZERO V_TXRCVADVZERO(1U) + +#define S_TXRCVADVLTMSS 0 +#define V_TXRCVADVLTMSS(x) ((x) << S_TXRCVADVLTMSS) +#define F_TXRCVADVLTMSS V_TXRCVADVLTMSS(1U) + +#define S_RXTIMERCOMPBUFFER 27 +#define V_RXTIMERCOMPBUFFER(x) ((x) << S_RXTIMERCOMPBUFFER) +#define F_RXTIMERCOMPBUFFER V_RXTIMERCOMPBUFFER(1U) + +#define S_TXDFRFAST 13 +#define V_TXDFRFAST(x) ((x) << S_TXDFRFAST) +#define F_TXDFRFAST V_TXDFRFAST(1U) + +#define S_TXRXMMISC 12 +#define V_TXRXMMISC(x) ((x) << S_TXRXMMISC) +#define F_TXRXMMISC V_TXRXMMISC(1U) + +#define A_TP_RX_SCHED 0x7eb0 + +#define S_RXCOMMITRESET1 31 +#define V_RXCOMMITRESET1(x) ((x) << S_RXCOMMITRESET1) +#define F_RXCOMMITRESET1 V_RXCOMMITRESET1(1U) + +#define S_RXCOMMITRESET0 30 +#define V_RXCOMMITRESET0(x) ((x) << S_RXCOMMITRESET0) +#define F_RXCOMMITRESET0 V_RXCOMMITRESET0(1U) + +#define S_RXFORCECONG1 29 +#define V_RXFORCECONG1(x) ((x) << S_RXFORCECONG1) +#define F_RXFORCECONG1 V_RXFORCECONG1(1U) + +#define S_RXFORCECONG0 28 +#define V_RXFORCECONG0(x) ((x) << S_RXFORCECONG0) +#define F_RXFORCECONG0 V_RXFORCECONG0(1U) + +#define S_ENABLELPBKFULL1 26 +#define M_ENABLELPBKFULL1 0x3U +#define V_ENABLELPBKFULL1(x) ((x) << S_ENABLELPBKFULL1) +#define G_ENABLELPBKFULL1(x) (((x) >> S_ENABLELPBKFULL1) & M_ENABLELPBKFULL1) + +#define S_ENABLELPBKFULL0 24 +#define M_ENABLELPBKFULL0 0x3U +#define V_ENABLELPBKFULL0(x) ((x) << S_ENABLELPBKFULL0) +#define G_ENABLELPBKFULL0(x) (((x) >> S_ENABLELPBKFULL0) & M_ENABLELPBKFULL0) + +#define S_ENABLEFIFOFULL1 22 +#define M_ENABLEFIFOFULL1 0x3U +#define V_ENABLEFIFOFULL1(x) ((x) << S_ENABLEFIFOFULL1) +#define G_ENABLEFIFOFULL1(x) (((x) >> S_ENABLEFIFOFULL1) & M_ENABLEFIFOFULL1) + +#define S_ENABLEPCMDFULL1 20 +#define M_ENABLEPCMDFULL1 0x3U +#define V_ENABLEPCMDFULL1(x) ((x) << S_ENABLEPCMDFULL1) +#define G_ENABLEPCMDFULL1(x) (((x) >> S_ENABLEPCMDFULL1) & M_ENABLEPCMDFULL1) + +#define S_ENABLEHDRFULL1 18 +#define M_ENABLEHDRFULL1 0x3U +#define V_ENABLEHDRFULL1(x) ((x) << S_ENABLEHDRFULL1) +#define G_ENABLEHDRFULL1(x) (((x) >> S_ENABLEHDRFULL1) & M_ENABLEHDRFULL1) + +#define S_ENABLEFIFOFULL0 16 +#define M_ENABLEFIFOFULL0 0x3U +#define V_ENABLEFIFOFULL0(x) ((x) << S_ENABLEFIFOFULL0) +#define G_ENABLEFIFOFULL0(x) (((x) >> S_ENABLEFIFOFULL0) & M_ENABLEFIFOFULL0) + +#define S_ENABLEPCMDFULL0 14 +#define M_ENABLEPCMDFULL0 0x3U +#define V_ENABLEPCMDFULL0(x) ((x) << S_ENABLEPCMDFULL0) +#define G_ENABLEPCMDFULL0(x) (((x) >> S_ENABLEPCMDFULL0) & M_ENABLEPCMDFULL0) + +#define S_ENABLEHDRFULL0 12 +#define M_ENABLEHDRFULL0 0x3U +#define V_ENABLEHDRFULL0(x) ((x) << S_ENABLEHDRFULL0) +#define G_ENABLEHDRFULL0(x) (((x) >> S_ENABLEHDRFULL0) & M_ENABLEHDRFULL0) + +#define S_COMMITLIMIT1 6 +#define M_COMMITLIMIT1 0x3fU +#define V_COMMITLIMIT1(x) ((x) << S_COMMITLIMIT1) +#define G_COMMITLIMIT1(x) (((x) >> S_COMMITLIMIT1) & M_COMMITLIMIT1) + +#define S_COMMITLIMIT0 0 +#define M_COMMITLIMIT0 0x3fU +#define V_COMMITLIMIT0(x) ((x) << S_COMMITLIMIT0) +#define G_COMMITLIMIT0(x) (((x) >> S_COMMITLIMIT0) & M_COMMITLIMIT0) + +#define A_TP_TX_SCHED 0x7eb4 + +#define S_COMMITRESET3 31 +#define V_COMMITRESET3(x) ((x) << S_COMMITRESET3) +#define F_COMMITRESET3 V_COMMITRESET3(1U) + +#define S_COMMITRESET2 30 +#define V_COMMITRESET2(x) ((x) << S_COMMITRESET2) +#define F_COMMITRESET2 V_COMMITRESET2(1U) + +#define S_COMMITRESET1 29 +#define V_COMMITRESET1(x) ((x) << S_COMMITRESET1) +#define F_COMMITRESET1 V_COMMITRESET1(1U) + +#define S_COMMITRESET0 28 +#define V_COMMITRESET0(x) ((x) << S_COMMITRESET0) +#define F_COMMITRESET0 V_COMMITRESET0(1U) + +#define S_FORCECONG3 27 +#define V_FORCECONG3(x) ((x) << S_FORCECONG3) +#define F_FORCECONG3 V_FORCECONG3(1U) + +#define S_FORCECONG2 26 +#define V_FORCECONG2(x) ((x) << S_FORCECONG2) +#define F_FORCECONG2 V_FORCECONG2(1U) + +#define S_FORCECONG1 25 +#define V_FORCECONG1(x) ((x) << S_FORCECONG1) +#define F_FORCECONG1 V_FORCECONG1(1U) + +#define S_FORCECONG0 24 +#define V_FORCECONG0(x) ((x) << S_FORCECONG0) +#define F_FORCECONG0 V_FORCECONG0(1U) + +#define S_COMMITLIMIT3 18 +#define M_COMMITLIMIT3 0x3fU +#define V_COMMITLIMIT3(x) ((x) << S_COMMITLIMIT3) +#define G_COMMITLIMIT3(x) (((x) >> S_COMMITLIMIT3) & M_COMMITLIMIT3) + +#define S_COMMITLIMIT2 12 +#define M_COMMITLIMIT2 0x3fU +#define V_COMMITLIMIT2(x) ((x) << S_COMMITLIMIT2) +#define G_COMMITLIMIT2(x) (((x) >> S_COMMITLIMIT2) & M_COMMITLIMIT2) + +#define A_TP_FX_SCHED 0x7eb8 + +#define S_TXCHNXOFF3 19 +#define V_TXCHNXOFF3(x) ((x) << S_TXCHNXOFF3) +#define F_TXCHNXOFF3 V_TXCHNXOFF3(1U) + +#define S_TXCHNXOFF2 18 +#define V_TXCHNXOFF2(x) ((x) << S_TXCHNXOFF2) +#define F_TXCHNXOFF2 V_TXCHNXOFF2(1U) + +#define S_TXCHNXOFF1 17 +#define V_TXCHNXOFF1(x) ((x) << S_TXCHNXOFF1) +#define F_TXCHNXOFF1 V_TXCHNXOFF1(1U) + +#define S_TXCHNXOFF0 16 +#define V_TXCHNXOFF0(x) ((x) << S_TXCHNXOFF0) +#define F_TXCHNXOFF0 V_TXCHNXOFF0(1U) + +#define S_TXMODXOFF7 15 +#define V_TXMODXOFF7(x) ((x) << S_TXMODXOFF7) +#define F_TXMODXOFF7 V_TXMODXOFF7(1U) + +#define S_TXMODXOFF6 14 +#define V_TXMODXOFF6(x) ((x) << S_TXMODXOFF6) +#define F_TXMODXOFF6 V_TXMODXOFF6(1U) + +#define S_TXMODXOFF5 13 +#define V_TXMODXOFF5(x) ((x) << S_TXMODXOFF5) +#define F_TXMODXOFF5 V_TXMODXOFF5(1U) + +#define S_TXMODXOFF4 12 +#define V_TXMODXOFF4(x) ((x) << S_TXMODXOFF4) +#define F_TXMODXOFF4 V_TXMODXOFF4(1U) + +#define S_TXMODXOFF3 11 +#define V_TXMODXOFF3(x) ((x) << S_TXMODXOFF3) +#define F_TXMODXOFF3 V_TXMODXOFF3(1U) + +#define S_TXMODXOFF2 10 +#define V_TXMODXOFF2(x) ((x) << S_TXMODXOFF2) +#define F_TXMODXOFF2 V_TXMODXOFF2(1U) + +#define S_TXMODXOFF1 9 +#define V_TXMODXOFF1(x) ((x) << S_TXMODXOFF1) +#define F_TXMODXOFF1 V_TXMODXOFF1(1U) + +#define S_TXMODXOFF0 8 +#define V_TXMODXOFF0(x) ((x) << S_TXMODXOFF0) +#define F_TXMODXOFF0 V_TXMODXOFF0(1U) + +#define S_RXCHNXOFF3 7 +#define V_RXCHNXOFF3(x) ((x) << S_RXCHNXOFF3) +#define F_RXCHNXOFF3 V_RXCHNXOFF3(1U) + +#define S_RXCHNXOFF2 6 +#define V_RXCHNXOFF2(x) ((x) << S_RXCHNXOFF2) +#define F_RXCHNXOFF2 V_RXCHNXOFF2(1U) + +#define S_RXCHNXOFF1 5 +#define V_RXCHNXOFF1(x) ((x) << S_RXCHNXOFF1) +#define F_RXCHNXOFF1 V_RXCHNXOFF1(1U) + +#define S_RXCHNXOFF0 4 +#define V_RXCHNXOFF0(x) ((x) << S_RXCHNXOFF0) +#define F_RXCHNXOFF0 V_RXCHNXOFF0(1U) + +#define S_RXMODXOFF1 1 +#define V_RXMODXOFF1(x) ((x) << S_RXMODXOFF1) +#define F_RXMODXOFF1 V_RXMODXOFF1(1U) + +#define S_RXMODXOFF0 0 +#define V_RXMODXOFF0(x) ((x) << S_RXMODXOFF0) +#define F_RXMODXOFF0 V_RXMODXOFF0(1U) + +#define A_TP_TX_ORATE 0x7ebc + +#define S_OFDRATE3 24 +#define M_OFDRATE3 0xffU +#define V_OFDRATE3(x) ((x) << S_OFDRATE3) +#define G_OFDRATE3(x) (((x) >> S_OFDRATE3) & M_OFDRATE3) + +#define S_OFDRATE2 16 +#define M_OFDRATE2 0xffU +#define V_OFDRATE2(x) ((x) << S_OFDRATE2) +#define G_OFDRATE2(x) (((x) >> S_OFDRATE2) & M_OFDRATE2) + +#define S_OFDRATE1 8 +#define M_OFDRATE1 0xffU +#define V_OFDRATE1(x) ((x) << S_OFDRATE1) +#define G_OFDRATE1(x) (((x) >> S_OFDRATE1) & M_OFDRATE1) + +#define S_OFDRATE0 0 +#define M_OFDRATE0 0xffU +#define V_OFDRATE0(x) ((x) << S_OFDRATE0) +#define G_OFDRATE0(x) (((x) >> S_OFDRATE0) & M_OFDRATE0) + +#define A_TP_IX_SCHED0 0x7ec0 +#define A_TP_IX_SCHED1 0x7ec4 +#define A_TP_IX_SCHED2 0x7ec8 +#define A_TP_IX_SCHED3 0x7ecc +#define A_TP_TX_TRATE 0x7ed0 + +#define S_TNLRATE3 24 +#define M_TNLRATE3 0xffU +#define V_TNLRATE3(x) ((x) << S_TNLRATE3) +#define G_TNLRATE3(x) (((x) >> S_TNLRATE3) & M_TNLRATE3) + +#define S_TNLRATE2 16 +#define M_TNLRATE2 0xffU +#define V_TNLRATE2(x) ((x) << S_TNLRATE2) +#define G_TNLRATE2(x) (((x) >> S_TNLRATE2) & M_TNLRATE2) + +#define S_TNLRATE1 8 +#define M_TNLRATE1 0xffU +#define V_TNLRATE1(x) ((x) << S_TNLRATE1) +#define G_TNLRATE1(x) (((x) >> S_TNLRATE1) & M_TNLRATE1) + +#define S_TNLRATE0 0 +#define M_TNLRATE0 0xffU +#define V_TNLRATE0(x) ((x) << S_TNLRATE0) +#define G_TNLRATE0(x) (((x) >> S_TNLRATE0) & M_TNLRATE0) + +#define A_TP_DBG_LA_CONFIG 0x7ed4 + +#define S_DBGLAOPCENABLE 24 +#define M_DBGLAOPCENABLE 0xffU +#define V_DBGLAOPCENABLE(x) ((x) << S_DBGLAOPCENABLE) +#define G_DBGLAOPCENABLE(x) (((x) >> S_DBGLAOPCENABLE) & M_DBGLAOPCENABLE) + +#define S_DBGLAWHLF 23 +#define V_DBGLAWHLF(x) ((x) << S_DBGLAWHLF) +#define F_DBGLAWHLF V_DBGLAWHLF(1U) + +#define S_DBGLAWPTR 16 +#define M_DBGLAWPTR 0x7fU +#define V_DBGLAWPTR(x) ((x) << S_DBGLAWPTR) +#define G_DBGLAWPTR(x) (((x) >> S_DBGLAWPTR) & M_DBGLAWPTR) + +#define S_DBGLAMODE 14 +#define M_DBGLAMODE 0x3U +#define V_DBGLAMODE(x) ((x) << S_DBGLAMODE) +#define G_DBGLAMODE(x) (((x) >> S_DBGLAMODE) & M_DBGLAMODE) + +#define S_DBGLAFATALFREEZE 13 +#define V_DBGLAFATALFREEZE(x) ((x) << S_DBGLAFATALFREEZE) +#define F_DBGLAFATALFREEZE V_DBGLAFATALFREEZE(1U) + +#define S_DBGLAENABLE 12 +#define V_DBGLAENABLE(x) ((x) << S_DBGLAENABLE) +#define F_DBGLAENABLE V_DBGLAENABLE(1U) + +#define S_DBGLARPTR 0 +#define M_DBGLARPTR 0x7fU +#define V_DBGLARPTR(x) ((x) << S_DBGLARPTR) +#define G_DBGLARPTR(x) (((x) >> S_DBGLARPTR) & M_DBGLARPTR) + +#define A_TP_DBG_LA_DATAL 0x7ed8 +#define A_TP_DBG_LA_DATAH 0x7edc +#define A_TP_PROTOCOL_CNTRL 0x7ee8 + +#define S_WRITEENABLE 31 +#define V_WRITEENABLE(x) ((x) << S_WRITEENABLE) +#define F_WRITEENABLE V_WRITEENABLE(1U) + +#define S_TCAMENABLE 10 +#define V_TCAMENABLE(x) ((x) << S_TCAMENABLE) +#define F_TCAMENABLE V_TCAMENABLE(1U) + +#define S_BLOCKSELECT 8 +#define M_BLOCKSELECT 0x3U +#define V_BLOCKSELECT(x) ((x) << S_BLOCKSELECT) +#define G_BLOCKSELECT(x) (((x) >> S_BLOCKSELECT) & M_BLOCKSELECT) + +#define S_LINEADDRESS 1 +#define M_LINEADDRESS 0x7fU +#define V_LINEADDRESS(x) ((x) << S_LINEADDRESS) +#define G_LINEADDRESS(x) (((x) >> S_LINEADDRESS) & M_LINEADDRESS) + +#define S_REQUESTDONE 0 +#define V_REQUESTDONE(x) ((x) << S_REQUESTDONE) +#define F_REQUESTDONE V_REQUESTDONE(1U) + +#define A_TP_PROTOCOL_DATA0 0x7eec +#define A_TP_PROTOCOL_DATA1 0x7ef0 +#define A_TP_PROTOCOL_DATA2 0x7ef4 +#define A_TP_PROTOCOL_DATA3 0x7ef8 +#define A_TP_PROTOCOL_DATA4 0x7efc + +#define S_PROTOCOLDATAFIELD 0 +#define M_PROTOCOLDATAFIELD 0xfU +#define V_PROTOCOLDATAFIELD(x) ((x) << S_PROTOCOLDATAFIELD) +#define G_PROTOCOLDATAFIELD(x) (((x) >> S_PROTOCOLDATAFIELD) & M_PROTOCOLDATAFIELD) + +#define A_TP_TX_MOD_Q7_Q6_TIMER_SEPARATOR 0x0 + +#define S_TXTIMERSEPQ7 16 +#define M_TXTIMERSEPQ7 0xffffU +#define V_TXTIMERSEPQ7(x) ((x) << S_TXTIMERSEPQ7) +#define G_TXTIMERSEPQ7(x) (((x) >> S_TXTIMERSEPQ7) & M_TXTIMERSEPQ7) + +#define S_TXTIMERSEPQ6 0 +#define M_TXTIMERSEPQ6 0xffffU +#define V_TXTIMERSEPQ6(x) ((x) << S_TXTIMERSEPQ6) +#define G_TXTIMERSEPQ6(x) (((x) >> S_TXTIMERSEPQ6) & M_TXTIMERSEPQ6) + +#define A_TP_TX_MOD_Q5_Q4_TIMER_SEPARATOR 0x1 + +#define S_TXTIMERSEPQ5 16 +#define M_TXTIMERSEPQ5 0xffffU +#define V_TXTIMERSEPQ5(x) ((x) << S_TXTIMERSEPQ5) +#define G_TXTIMERSEPQ5(x) (((x) >> S_TXTIMERSEPQ5) & M_TXTIMERSEPQ5) + +#define S_TXTIMERSEPQ4 0 +#define M_TXTIMERSEPQ4 0xffffU +#define V_TXTIMERSEPQ4(x) ((x) << S_TXTIMERSEPQ4) +#define G_TXTIMERSEPQ4(x) (((x) >> S_TXTIMERSEPQ4) & M_TXTIMERSEPQ4) + +#define A_TP_TX_MOD_Q3_Q2_TIMER_SEPARATOR 0x2 + +#define S_TXTIMERSEPQ3 16 +#define M_TXTIMERSEPQ3 0xffffU +#define V_TXTIMERSEPQ3(x) ((x) << S_TXTIMERSEPQ3) +#define G_TXTIMERSEPQ3(x) (((x) >> S_TXTIMERSEPQ3) & M_TXTIMERSEPQ3) + +#define S_TXTIMERSEPQ2 0 +#define M_TXTIMERSEPQ2 0xffffU +#define V_TXTIMERSEPQ2(x) ((x) << S_TXTIMERSEPQ2) +#define G_TXTIMERSEPQ2(x) (((x) >> S_TXTIMERSEPQ2) & M_TXTIMERSEPQ2) + +#define A_TP_TX_MOD_Q1_Q0_TIMER_SEPARATOR 0x3 + +#define S_TXTIMERSEPQ1 16 +#define M_TXTIMERSEPQ1 0xffffU +#define V_TXTIMERSEPQ1(x) ((x) << S_TXTIMERSEPQ1) +#define G_TXTIMERSEPQ1(x) (((x) >> S_TXTIMERSEPQ1) & M_TXTIMERSEPQ1) + +#define S_TXTIMERSEPQ0 0 +#define M_TXTIMERSEPQ0 0xffffU +#define V_TXTIMERSEPQ0(x) ((x) << S_TXTIMERSEPQ0) +#define G_TXTIMERSEPQ0(x) (((x) >> S_TXTIMERSEPQ0) & M_TXTIMERSEPQ0) + +#define A_TP_RX_MOD_Q1_Q0_TIMER_SEPARATOR 0x4 + +#define S_RXTIMERSEPQ1 16 +#define M_RXTIMERSEPQ1 0xffffU +#define V_RXTIMERSEPQ1(x) ((x) << S_RXTIMERSEPQ1) +#define G_RXTIMERSEPQ1(x) (((x) >> S_RXTIMERSEPQ1) & M_RXTIMERSEPQ1) + +#define S_RXTIMERSEPQ0 0 +#define M_RXTIMERSEPQ0 0xffffU +#define V_RXTIMERSEPQ0(x) ((x) << S_RXTIMERSEPQ0) +#define G_RXTIMERSEPQ0(x) (((x) >> S_RXTIMERSEPQ0) & M_RXTIMERSEPQ0) + +#define A_TP_TX_MOD_Q7_Q6_RATE_LIMIT 0x5 + +#define S_TXRATEINCQ7 24 +#define M_TXRATEINCQ7 0xffU +#define V_TXRATEINCQ7(x) ((x) << S_TXRATEINCQ7) +#define G_TXRATEINCQ7(x) (((x) >> S_TXRATEINCQ7) & M_TXRATEINCQ7) + +#define S_TXRATETCKQ7 16 +#define M_TXRATETCKQ7 0xffU +#define V_TXRATETCKQ7(x) ((x) << S_TXRATETCKQ7) +#define G_TXRATETCKQ7(x) (((x) >> S_TXRATETCKQ7) & M_TXRATETCKQ7) + +#define S_TXRATEINCQ6 8 +#define M_TXRATEINCQ6 0xffU +#define V_TXRATEINCQ6(x) ((x) << S_TXRATEINCQ6) +#define G_TXRATEINCQ6(x) (((x) >> S_TXRATEINCQ6) & M_TXRATEINCQ6) + +#define S_TXRATETCKQ6 0 +#define M_TXRATETCKQ6 0xffU +#define V_TXRATETCKQ6(x) ((x) << S_TXRATETCKQ6) +#define G_TXRATETCKQ6(x) (((x) >> S_TXRATETCKQ6) & M_TXRATETCKQ6) + +#define A_TP_TX_MOD_Q5_Q4_RATE_LIMIT 0x6 + +#define S_TXRATEINCQ5 24 +#define M_TXRATEINCQ5 0xffU +#define V_TXRATEINCQ5(x) ((x) << S_TXRATEINCQ5) +#define G_TXRATEINCQ5(x) (((x) >> S_TXRATEINCQ5) & M_TXRATEINCQ5) + +#define S_TXRATETCKQ5 16 +#define M_TXRATETCKQ5 0xffU +#define V_TXRATETCKQ5(x) ((x) << S_TXRATETCKQ5) +#define G_TXRATETCKQ5(x) (((x) >> S_TXRATETCKQ5) & M_TXRATETCKQ5) + +#define S_TXRATEINCQ4 8 +#define M_TXRATEINCQ4 0xffU +#define V_TXRATEINCQ4(x) ((x) << S_TXRATEINCQ4) +#define G_TXRATEINCQ4(x) (((x) >> S_TXRATEINCQ4) & M_TXRATEINCQ4) + +#define S_TXRATETCKQ4 0 +#define M_TXRATETCKQ4 0xffU +#define V_TXRATETCKQ4(x) ((x) << S_TXRATETCKQ4) +#define G_TXRATETCKQ4(x) (((x) >> S_TXRATETCKQ4) & M_TXRATETCKQ4) + +#define A_TP_TX_MOD_Q3_Q2_RATE_LIMIT 0x7 + +#define S_TXRATEINCQ3 24 +#define M_TXRATEINCQ3 0xffU +#define V_TXRATEINCQ3(x) ((x) << S_TXRATEINCQ3) +#define G_TXRATEINCQ3(x) (((x) >> S_TXRATEINCQ3) & M_TXRATEINCQ3) + +#define S_TXRATETCKQ3 16 +#define M_TXRATETCKQ3 0xffU +#define V_TXRATETCKQ3(x) ((x) << S_TXRATETCKQ3) +#define G_TXRATETCKQ3(x) (((x) >> S_TXRATETCKQ3) & M_TXRATETCKQ3) + +#define S_TXRATEINCQ2 8 +#define M_TXRATEINCQ2 0xffU +#define V_TXRATEINCQ2(x) ((x) << S_TXRATEINCQ2) +#define G_TXRATEINCQ2(x) (((x) >> S_TXRATEINCQ2) & M_TXRATEINCQ2) + +#define S_TXRATETCKQ2 0 +#define M_TXRATETCKQ2 0xffU +#define V_TXRATETCKQ2(x) ((x) << S_TXRATETCKQ2) +#define G_TXRATETCKQ2(x) (((x) >> S_TXRATETCKQ2) & M_TXRATETCKQ2) + +#define A_TP_TX_MOD_Q1_Q0_RATE_LIMIT 0x8 + +#define S_TXRATEINCQ1 24 +#define M_TXRATEINCQ1 0xffU +#define V_TXRATEINCQ1(x) ((x) << S_TXRATEINCQ1) +#define G_TXRATEINCQ1(x) (((x) >> S_TXRATEINCQ1) & M_TXRATEINCQ1) + +#define S_TXRATETCKQ1 16 +#define M_TXRATETCKQ1 0xffU +#define V_TXRATETCKQ1(x) ((x) << S_TXRATETCKQ1) +#define G_TXRATETCKQ1(x) (((x) >> S_TXRATETCKQ1) & M_TXRATETCKQ1) + +#define S_TXRATEINCQ0 8 +#define M_TXRATEINCQ0 0xffU +#define V_TXRATEINCQ0(x) ((x) << S_TXRATEINCQ0) +#define G_TXRATEINCQ0(x) (((x) >> S_TXRATEINCQ0) & M_TXRATEINCQ0) + +#define S_TXRATETCKQ0 0 +#define M_TXRATETCKQ0 0xffU +#define V_TXRATETCKQ0(x) ((x) << S_TXRATETCKQ0) +#define G_TXRATETCKQ0(x) (((x) >> S_TXRATETCKQ0) & M_TXRATETCKQ0) + +#define A_TP_RX_MOD_Q1_Q0_RATE_LIMIT 0x9 + +#define S_RXRATEINCQ1 24 +#define M_RXRATEINCQ1 0xffU +#define V_RXRATEINCQ1(x) ((x) << S_RXRATEINCQ1) +#define G_RXRATEINCQ1(x) (((x) >> S_RXRATEINCQ1) & M_RXRATEINCQ1) + +#define S_RXRATETCKQ1 16 +#define M_RXRATETCKQ1 0xffU +#define V_RXRATETCKQ1(x) ((x) << S_RXRATETCKQ1) +#define G_RXRATETCKQ1(x) (((x) >> S_RXRATETCKQ1) & M_RXRATETCKQ1) + +#define S_RXRATEINCQ0 8 +#define M_RXRATEINCQ0 0xffU +#define V_RXRATEINCQ0(x) ((x) << S_RXRATEINCQ0) +#define G_RXRATEINCQ0(x) (((x) >> S_RXRATEINCQ0) & M_RXRATEINCQ0) + +#define S_RXRATETCKQ0 0 +#define M_RXRATETCKQ0 0xffU +#define V_RXRATETCKQ0(x) ((x) << S_RXRATETCKQ0) +#define G_RXRATETCKQ0(x) (((x) >> S_RXRATETCKQ0) & M_RXRATETCKQ0) + +#define A_TP_TX_MOD_C3_C2_RATE_LIMIT 0xa +#define A_TP_TX_MOD_C1_C0_RATE_LIMIT 0xb +#define A_TP_RX_SCHED_MAP 0x20 + +#define S_RXMAPCHANNEL3 24 +#define M_RXMAPCHANNEL3 0xffU +#define V_RXMAPCHANNEL3(x) ((x) << S_RXMAPCHANNEL3) +#define G_RXMAPCHANNEL3(x) (((x) >> S_RXMAPCHANNEL3) & M_RXMAPCHANNEL3) + +#define S_RXMAPCHANNEL2 16 +#define M_RXMAPCHANNEL2 0xffU +#define V_RXMAPCHANNEL2(x) ((x) << S_RXMAPCHANNEL2) +#define G_RXMAPCHANNEL2(x) (((x) >> S_RXMAPCHANNEL2) & M_RXMAPCHANNEL2) + +#define S_RXMAPCHANNEL1 8 +#define M_RXMAPCHANNEL1 0xffU +#define V_RXMAPCHANNEL1(x) ((x) << S_RXMAPCHANNEL1) +#define G_RXMAPCHANNEL1(x) (((x) >> S_RXMAPCHANNEL1) & M_RXMAPCHANNEL1) + +#define S_RXMAPCHANNEL0 0 +#define M_RXMAPCHANNEL0 0xffU +#define V_RXMAPCHANNEL0(x) ((x) << S_RXMAPCHANNEL0) +#define G_RXMAPCHANNEL0(x) (((x) >> S_RXMAPCHANNEL0) & M_RXMAPCHANNEL0) + +#define A_TP_RX_SCHED_SGE 0x21 + +#define S_RXSGEMOD1 12 +#define M_RXSGEMOD1 0xfU +#define V_RXSGEMOD1(x) ((x) << S_RXSGEMOD1) +#define G_RXSGEMOD1(x) (((x) >> S_RXSGEMOD1) & M_RXSGEMOD1) + +#define S_RXSGEMOD0 8 +#define M_RXSGEMOD0 0xfU +#define V_RXSGEMOD0(x) ((x) << S_RXSGEMOD0) +#define G_RXSGEMOD0(x) (((x) >> S_RXSGEMOD0) & M_RXSGEMOD0) + +#define S_RXSGECHANNEL3 3 +#define V_RXSGECHANNEL3(x) ((x) << S_RXSGECHANNEL3) +#define F_RXSGECHANNEL3 V_RXSGECHANNEL3(1U) + +#define S_RXSGECHANNEL2 2 +#define V_RXSGECHANNEL2(x) ((x) << S_RXSGECHANNEL2) +#define F_RXSGECHANNEL2 V_RXSGECHANNEL2(1U) + +#define S_RXSGECHANNEL1 1 +#define V_RXSGECHANNEL1(x) ((x) << S_RXSGECHANNEL1) +#define F_RXSGECHANNEL1 V_RXSGECHANNEL1(1U) + +#define S_RXSGECHANNEL0 0 +#define V_RXSGECHANNEL0(x) ((x) << S_RXSGECHANNEL0) +#define F_RXSGECHANNEL0 V_RXSGECHANNEL0(1U) + +#define A_TP_TX_SCHED_MAP 0x22 + +#define S_TXMAPCHANNEL3 12 +#define M_TXMAPCHANNEL3 0xfU +#define V_TXMAPCHANNEL3(x) ((x) << S_TXMAPCHANNEL3) +#define G_TXMAPCHANNEL3(x) (((x) >> S_TXMAPCHANNEL3) & M_TXMAPCHANNEL3) + +#define S_TXMAPCHANNEL2 8 +#define M_TXMAPCHANNEL2 0xfU +#define V_TXMAPCHANNEL2(x) ((x) << S_TXMAPCHANNEL2) +#define G_TXMAPCHANNEL2(x) (((x) >> S_TXMAPCHANNEL2) & M_TXMAPCHANNEL2) + +#define S_TXMAPCHANNEL1 4 +#define M_TXMAPCHANNEL1 0xfU +#define V_TXMAPCHANNEL1(x) ((x) << S_TXMAPCHANNEL1) +#define G_TXMAPCHANNEL1(x) (((x) >> S_TXMAPCHANNEL1) & M_TXMAPCHANNEL1) + +#define S_TXMAPCHANNEL0 0 +#define M_TXMAPCHANNEL0 0xfU +#define V_TXMAPCHANNEL0(x) ((x) << S_TXMAPCHANNEL0) +#define G_TXMAPCHANNEL0(x) (((x) >> S_TXMAPCHANNEL0) & M_TXMAPCHANNEL0) + +#define A_TP_TX_SCHED_HDR 0x23 + +#define S_TXMAPHDRCHANNEL7 28 +#define M_TXMAPHDRCHANNEL7 0xfU +#define V_TXMAPHDRCHANNEL7(x) ((x) << S_TXMAPHDRCHANNEL7) +#define G_TXMAPHDRCHANNEL7(x) (((x) >> S_TXMAPHDRCHANNEL7) & M_TXMAPHDRCHANNEL7) + +#define S_TXMAPHDRCHANNEL6 24 +#define M_TXMAPHDRCHANNEL6 0xfU +#define V_TXMAPHDRCHANNEL6(x) ((x) << S_TXMAPHDRCHANNEL6) +#define G_TXMAPHDRCHANNEL6(x) (((x) >> S_TXMAPHDRCHANNEL6) & M_TXMAPHDRCHANNEL6) + +#define S_TXMAPHDRCHANNEL5 20 +#define M_TXMAPHDRCHANNEL5 0xfU +#define V_TXMAPHDRCHANNEL5(x) ((x) << S_TXMAPHDRCHANNEL5) +#define G_TXMAPHDRCHANNEL5(x) (((x) >> S_TXMAPHDRCHANNEL5) & M_TXMAPHDRCHANNEL5) + +#define S_TXMAPHDRCHANNEL4 16 +#define M_TXMAPHDRCHANNEL4 0xfU +#define V_TXMAPHDRCHANNEL4(x) ((x) << S_TXMAPHDRCHANNEL4) +#define G_TXMAPHDRCHANNEL4(x) (((x) >> S_TXMAPHDRCHANNEL4) & M_TXMAPHDRCHANNEL4) + +#define S_TXMAPHDRCHANNEL3 12 +#define M_TXMAPHDRCHANNEL3 0xfU +#define V_TXMAPHDRCHANNEL3(x) ((x) << S_TXMAPHDRCHANNEL3) +#define G_TXMAPHDRCHANNEL3(x) (((x) >> S_TXMAPHDRCHANNEL3) & M_TXMAPHDRCHANNEL3) + +#define S_TXMAPHDRCHANNEL2 8 +#define M_TXMAPHDRCHANNEL2 0xfU +#define V_TXMAPHDRCHANNEL2(x) ((x) << S_TXMAPHDRCHANNEL2) +#define G_TXMAPHDRCHANNEL2(x) (((x) >> S_TXMAPHDRCHANNEL2) & M_TXMAPHDRCHANNEL2) + +#define S_TXMAPHDRCHANNEL1 4 +#define M_TXMAPHDRCHANNEL1 0xfU +#define V_TXMAPHDRCHANNEL1(x) ((x) << S_TXMAPHDRCHANNEL1) +#define G_TXMAPHDRCHANNEL1(x) (((x) >> S_TXMAPHDRCHANNEL1) & M_TXMAPHDRCHANNEL1) + +#define S_TXMAPHDRCHANNEL0 0 +#define M_TXMAPHDRCHANNEL0 0xfU +#define V_TXMAPHDRCHANNEL0(x) ((x) << S_TXMAPHDRCHANNEL0) +#define G_TXMAPHDRCHANNEL0(x) (((x) >> S_TXMAPHDRCHANNEL0) & M_TXMAPHDRCHANNEL0) + +#define A_TP_TX_SCHED_FIFO 0x24 + +#define S_TXMAPFIFOCHANNEL7 28 +#define M_TXMAPFIFOCHANNEL7 0xfU +#define V_TXMAPFIFOCHANNEL7(x) ((x) << S_TXMAPFIFOCHANNEL7) +#define G_TXMAPFIFOCHANNEL7(x) (((x) >> S_TXMAPFIFOCHANNEL7) & M_TXMAPFIFOCHANNEL7) + +#define S_TXMAPFIFOCHANNEL6 24 +#define M_TXMAPFIFOCHANNEL6 0xfU +#define V_TXMAPFIFOCHANNEL6(x) ((x) << S_TXMAPFIFOCHANNEL6) +#define G_TXMAPFIFOCHANNEL6(x) (((x) >> S_TXMAPFIFOCHANNEL6) & M_TXMAPFIFOCHANNEL6) + +#define S_TXMAPFIFOCHANNEL5 20 +#define M_TXMAPFIFOCHANNEL5 0xfU +#define V_TXMAPFIFOCHANNEL5(x) ((x) << S_TXMAPFIFOCHANNEL5) +#define G_TXMAPFIFOCHANNEL5(x) (((x) >> S_TXMAPFIFOCHANNEL5) & M_TXMAPFIFOCHANNEL5) + +#define S_TXMAPFIFOCHANNEL4 16 +#define M_TXMAPFIFOCHANNEL4 0xfU +#define V_TXMAPFIFOCHANNEL4(x) ((x) << S_TXMAPFIFOCHANNEL4) +#define G_TXMAPFIFOCHANNEL4(x) (((x) >> S_TXMAPFIFOCHANNEL4) & M_TXMAPFIFOCHANNEL4) + +#define S_TXMAPFIFOCHANNEL3 12 +#define M_TXMAPFIFOCHANNEL3 0xfU +#define V_TXMAPFIFOCHANNEL3(x) ((x) << S_TXMAPFIFOCHANNEL3) +#define G_TXMAPFIFOCHANNEL3(x) (((x) >> S_TXMAPFIFOCHANNEL3) & M_TXMAPFIFOCHANNEL3) + +#define S_TXMAPFIFOCHANNEL2 8 +#define M_TXMAPFIFOCHANNEL2 0xfU +#define V_TXMAPFIFOCHANNEL2(x) ((x) << S_TXMAPFIFOCHANNEL2) +#define G_TXMAPFIFOCHANNEL2(x) (((x) >> S_TXMAPFIFOCHANNEL2) & M_TXMAPFIFOCHANNEL2) + +#define S_TXMAPFIFOCHANNEL1 4 +#define M_TXMAPFIFOCHANNEL1 0xfU +#define V_TXMAPFIFOCHANNEL1(x) ((x) << S_TXMAPFIFOCHANNEL1) +#define G_TXMAPFIFOCHANNEL1(x) (((x) >> S_TXMAPFIFOCHANNEL1) & M_TXMAPFIFOCHANNEL1) + +#define S_TXMAPFIFOCHANNEL0 0 +#define M_TXMAPFIFOCHANNEL0 0xfU +#define V_TXMAPFIFOCHANNEL0(x) ((x) << S_TXMAPFIFOCHANNEL0) +#define G_TXMAPFIFOCHANNEL0(x) (((x) >> S_TXMAPFIFOCHANNEL0) & M_TXMAPFIFOCHANNEL0) + +#define A_TP_TX_SCHED_PCMD 0x25 + +#define S_TXMAPPCMDCHANNEL7 28 +#define M_TXMAPPCMDCHANNEL7 0xfU +#define V_TXMAPPCMDCHANNEL7(x) ((x) << S_TXMAPPCMDCHANNEL7) +#define G_TXMAPPCMDCHANNEL7(x) (((x) >> S_TXMAPPCMDCHANNEL7) & M_TXMAPPCMDCHANNEL7) + +#define S_TXMAPPCMDCHANNEL6 24 +#define M_TXMAPPCMDCHANNEL6 0xfU +#define V_TXMAPPCMDCHANNEL6(x) ((x) << S_TXMAPPCMDCHANNEL6) +#define G_TXMAPPCMDCHANNEL6(x) (((x) >> S_TXMAPPCMDCHANNEL6) & M_TXMAPPCMDCHANNEL6) + +#define S_TXMAPPCMDCHANNEL5 20 +#define M_TXMAPPCMDCHANNEL5 0xfU +#define V_TXMAPPCMDCHANNEL5(x) ((x) << S_TXMAPPCMDCHANNEL5) +#define G_TXMAPPCMDCHANNEL5(x) (((x) >> S_TXMAPPCMDCHANNEL5) & M_TXMAPPCMDCHANNEL5) + +#define S_TXMAPPCMDCHANNEL4 16 +#define M_TXMAPPCMDCHANNEL4 0xfU +#define V_TXMAPPCMDCHANNEL4(x) ((x) << S_TXMAPPCMDCHANNEL4) +#define G_TXMAPPCMDCHANNEL4(x) (((x) >> S_TXMAPPCMDCHANNEL4) & M_TXMAPPCMDCHANNEL4) + +#define S_TXMAPPCMDCHANNEL3 12 +#define M_TXMAPPCMDCHANNEL3 0xfU +#define V_TXMAPPCMDCHANNEL3(x) ((x) << S_TXMAPPCMDCHANNEL3) +#define G_TXMAPPCMDCHANNEL3(x) (((x) >> S_TXMAPPCMDCHANNEL3) & M_TXMAPPCMDCHANNEL3) + +#define S_TXMAPPCMDCHANNEL2 8 +#define M_TXMAPPCMDCHANNEL2 0xfU +#define V_TXMAPPCMDCHANNEL2(x) ((x) << S_TXMAPPCMDCHANNEL2) +#define G_TXMAPPCMDCHANNEL2(x) (((x) >> S_TXMAPPCMDCHANNEL2) & M_TXMAPPCMDCHANNEL2) + +#define S_TXMAPPCMDCHANNEL1 4 +#define M_TXMAPPCMDCHANNEL1 0xfU +#define V_TXMAPPCMDCHANNEL1(x) ((x) << S_TXMAPPCMDCHANNEL1) +#define G_TXMAPPCMDCHANNEL1(x) (((x) >> S_TXMAPPCMDCHANNEL1) & M_TXMAPPCMDCHANNEL1) + +#define S_TXMAPPCMDCHANNEL0 0 +#define M_TXMAPPCMDCHANNEL0 0xfU +#define V_TXMAPPCMDCHANNEL0(x) ((x) << S_TXMAPPCMDCHANNEL0) +#define G_TXMAPPCMDCHANNEL0(x) (((x) >> S_TXMAPPCMDCHANNEL0) & M_TXMAPPCMDCHANNEL0) + +#define A_TP_TX_SCHED_LPBK 0x26 + +#define S_TXMAPLPBKCHANNEL7 28 +#define M_TXMAPLPBKCHANNEL7 0xfU +#define V_TXMAPLPBKCHANNEL7(x) ((x) << S_TXMAPLPBKCHANNEL7) +#define G_TXMAPLPBKCHANNEL7(x) (((x) >> S_TXMAPLPBKCHANNEL7) & M_TXMAPLPBKCHANNEL7) + +#define S_TXMAPLPBKCHANNEL6 24 +#define M_TXMAPLPBKCHANNEL6 0xfU +#define V_TXMAPLPBKCHANNEL6(x) ((x) << S_TXMAPLPBKCHANNEL6) +#define G_TXMAPLPBKCHANNEL6(x) (((x) >> S_TXMAPLPBKCHANNEL6) & M_TXMAPLPBKCHANNEL6) + +#define S_TXMAPLPBKCHANNEL5 20 +#define M_TXMAPLPBKCHANNEL5 0xfU +#define V_TXMAPLPBKCHANNEL5(x) ((x) << S_TXMAPLPBKCHANNEL5) +#define G_TXMAPLPBKCHANNEL5(x) (((x) >> S_TXMAPLPBKCHANNEL5) & M_TXMAPLPBKCHANNEL5) + +#define S_TXMAPLPBKCHANNEL4 16 +#define M_TXMAPLPBKCHANNEL4 0xfU +#define V_TXMAPLPBKCHANNEL4(x) ((x) << S_TXMAPLPBKCHANNEL4) +#define G_TXMAPLPBKCHANNEL4(x) (((x) >> S_TXMAPLPBKCHANNEL4) & M_TXMAPLPBKCHANNEL4) + +#define S_TXMAPLPBKCHANNEL3 12 +#define M_TXMAPLPBKCHANNEL3 0xfU +#define V_TXMAPLPBKCHANNEL3(x) ((x) << S_TXMAPLPBKCHANNEL3) +#define G_TXMAPLPBKCHANNEL3(x) (((x) >> S_TXMAPLPBKCHANNEL3) & M_TXMAPLPBKCHANNEL3) + +#define S_TXMAPLPBKCHANNEL2 8 +#define M_TXMAPLPBKCHANNEL2 0xfU +#define V_TXMAPLPBKCHANNEL2(x) ((x) << S_TXMAPLPBKCHANNEL2) +#define G_TXMAPLPBKCHANNEL2(x) (((x) >> S_TXMAPLPBKCHANNEL2) & M_TXMAPLPBKCHANNEL2) + +#define S_TXMAPLPBKCHANNEL1 4 +#define M_TXMAPLPBKCHANNEL1 0xfU +#define V_TXMAPLPBKCHANNEL1(x) ((x) << S_TXMAPLPBKCHANNEL1) +#define G_TXMAPLPBKCHANNEL1(x) (((x) >> S_TXMAPLPBKCHANNEL1) & M_TXMAPLPBKCHANNEL1) + +#define S_TXMAPLPBKCHANNEL0 0 +#define M_TXMAPLPBKCHANNEL0 0xfU +#define V_TXMAPLPBKCHANNEL0(x) ((x) << S_TXMAPLPBKCHANNEL0) +#define G_TXMAPLPBKCHANNEL0(x) (((x) >> S_TXMAPLPBKCHANNEL0) & M_TXMAPLPBKCHANNEL0) + +#define A_TP_CHANNEL_MAP 0x27 + +#define S_RXMAPCHANNELELN 16 +#define M_RXMAPCHANNELELN 0xfU +#define V_RXMAPCHANNELELN(x) ((x) << S_RXMAPCHANNELELN) +#define G_RXMAPCHANNELELN(x) (((x) >> S_RXMAPCHANNELELN) & M_RXMAPCHANNELELN) + +#define S_RXMAPE2LCHANNEL3 14 +#define M_RXMAPE2LCHANNEL3 0x3U +#define V_RXMAPE2LCHANNEL3(x) ((x) << S_RXMAPE2LCHANNEL3) +#define G_RXMAPE2LCHANNEL3(x) (((x) >> S_RXMAPE2LCHANNEL3) & M_RXMAPE2LCHANNEL3) + +#define S_RXMAPE2LCHANNEL2 12 +#define M_RXMAPE2LCHANNEL2 0x3U +#define V_RXMAPE2LCHANNEL2(x) ((x) << S_RXMAPE2LCHANNEL2) +#define G_RXMAPE2LCHANNEL2(x) (((x) >> S_RXMAPE2LCHANNEL2) & M_RXMAPE2LCHANNEL2) + +#define S_RXMAPE2LCHANNEL1 10 +#define M_RXMAPE2LCHANNEL1 0x3U +#define V_RXMAPE2LCHANNEL1(x) ((x) << S_RXMAPE2LCHANNEL1) +#define G_RXMAPE2LCHANNEL1(x) (((x) >> S_RXMAPE2LCHANNEL1) & M_RXMAPE2LCHANNEL1) + +#define S_RXMAPE2LCHANNEL0 8 +#define M_RXMAPE2LCHANNEL0 0x3U +#define V_RXMAPE2LCHANNEL0(x) ((x) << S_RXMAPE2LCHANNEL0) +#define G_RXMAPE2LCHANNEL0(x) (((x) >> S_RXMAPE2LCHANNEL0) & M_RXMAPE2LCHANNEL0) + +#define S_RXMAPC2CCHANNEL3 7 +#define V_RXMAPC2CCHANNEL3(x) ((x) << S_RXMAPC2CCHANNEL3) +#define F_RXMAPC2CCHANNEL3 V_RXMAPC2CCHANNEL3(1U) + +#define S_RXMAPC2CCHANNEL2 6 +#define V_RXMAPC2CCHANNEL2(x) ((x) << S_RXMAPC2CCHANNEL2) +#define F_RXMAPC2CCHANNEL2 V_RXMAPC2CCHANNEL2(1U) + +#define S_RXMAPC2CCHANNEL1 5 +#define V_RXMAPC2CCHANNEL1(x) ((x) << S_RXMAPC2CCHANNEL1) +#define F_RXMAPC2CCHANNEL1 V_RXMAPC2CCHANNEL1(1U) + +#define S_RXMAPC2CCHANNEL0 4 +#define V_RXMAPC2CCHANNEL0(x) ((x) << S_RXMAPC2CCHANNEL0) +#define F_RXMAPC2CCHANNEL0 V_RXMAPC2CCHANNEL0(1U) + +#define S_RXMAPE2CCHANNEL3 3 +#define V_RXMAPE2CCHANNEL3(x) ((x) << S_RXMAPE2CCHANNEL3) +#define F_RXMAPE2CCHANNEL3 V_RXMAPE2CCHANNEL3(1U) + +#define S_RXMAPE2CCHANNEL2 2 +#define V_RXMAPE2CCHANNEL2(x) ((x) << S_RXMAPE2CCHANNEL2) +#define F_RXMAPE2CCHANNEL2 V_RXMAPE2CCHANNEL2(1U) + +#define S_RXMAPE2CCHANNEL1 1 +#define V_RXMAPE2CCHANNEL1(x) ((x) << S_RXMAPE2CCHANNEL1) +#define F_RXMAPE2CCHANNEL1 V_RXMAPE2CCHANNEL1(1U) + +#define S_RXMAPE2CCHANNEL0 0 +#define V_RXMAPE2CCHANNEL0(x) ((x) << S_RXMAPE2CCHANNEL0) +#define F_RXMAPE2CCHANNEL0 V_RXMAPE2CCHANNEL0(1U) + +#define A_TP_RX_LPBK 0x28 +#define A_TP_TX_LPBK 0x29 +#define A_TP_TX_SCHED_PPP 0x2a + +#define S_TXPPPENPORT3 24 +#define M_TXPPPENPORT3 0xffU +#define V_TXPPPENPORT3(x) ((x) << S_TXPPPENPORT3) +#define G_TXPPPENPORT3(x) (((x) >> S_TXPPPENPORT3) & M_TXPPPENPORT3) + +#define S_TXPPPENPORT2 16 +#define M_TXPPPENPORT2 0xffU +#define V_TXPPPENPORT2(x) ((x) << S_TXPPPENPORT2) +#define G_TXPPPENPORT2(x) (((x) >> S_TXPPPENPORT2) & M_TXPPPENPORT2) + +#define S_TXPPPENPORT1 8 +#define M_TXPPPENPORT1 0xffU +#define V_TXPPPENPORT1(x) ((x) << S_TXPPPENPORT1) +#define G_TXPPPENPORT1(x) (((x) >> S_TXPPPENPORT1) & M_TXPPPENPORT1) + +#define S_TXPPPENPORT0 0 +#define M_TXPPPENPORT0 0xffU +#define V_TXPPPENPORT0(x) ((x) << S_TXPPPENPORT0) +#define G_TXPPPENPORT0(x) (((x) >> S_TXPPPENPORT0) & M_TXPPPENPORT0) + +#define A_TP_RX_SCHED_FIFO 0x2b + +#define S_COMMITLIMIT1H 24 +#define M_COMMITLIMIT1H 0xffU +#define V_COMMITLIMIT1H(x) ((x) << S_COMMITLIMIT1H) +#define G_COMMITLIMIT1H(x) (((x) >> S_COMMITLIMIT1H) & M_COMMITLIMIT1H) + +#define S_COMMITLIMIT1L 16 +#define M_COMMITLIMIT1L 0xffU +#define V_COMMITLIMIT1L(x) ((x) << S_COMMITLIMIT1L) +#define G_COMMITLIMIT1L(x) (((x) >> S_COMMITLIMIT1L) & M_COMMITLIMIT1L) + +#define S_COMMITLIMIT0H 8 +#define M_COMMITLIMIT0H 0xffU +#define V_COMMITLIMIT0H(x) ((x) << S_COMMITLIMIT0H) +#define G_COMMITLIMIT0H(x) (((x) >> S_COMMITLIMIT0H) & M_COMMITLIMIT0H) + +#define S_COMMITLIMIT0L 0 +#define M_COMMITLIMIT0L 0xffU +#define V_COMMITLIMIT0L(x) ((x) << S_COMMITLIMIT0L) +#define G_COMMITLIMIT0L(x) (((x) >> S_COMMITLIMIT0L) & M_COMMITLIMIT0L) + +#define A_TP_IPMI_CFG1 0x2e + +#define S_VLANENABLE 31 +#define V_VLANENABLE(x) ((x) << S_VLANENABLE) +#define F_VLANENABLE V_VLANENABLE(1U) + +#define S_PRIMARYPORTENABLE 30 +#define V_PRIMARYPORTENABLE(x) ((x) << S_PRIMARYPORTENABLE) +#define F_PRIMARYPORTENABLE V_PRIMARYPORTENABLE(1U) + +#define S_SECUREPORTENABLE 29 +#define V_SECUREPORTENABLE(x) ((x) << S_SECUREPORTENABLE) +#define F_SECUREPORTENABLE V_SECUREPORTENABLE(1U) + +#define S_ARPENABLE 28 +#define V_ARPENABLE(x) ((x) << S_ARPENABLE) +#define F_ARPENABLE V_ARPENABLE(1U) + +#define S_IPMI_VLAN 0 +#define M_IPMI_VLAN 0xffffU +#define V_IPMI_VLAN(x) ((x) << S_IPMI_VLAN) +#define G_IPMI_VLAN(x) (((x) >> S_IPMI_VLAN) & M_IPMI_VLAN) + +#define A_TP_IPMI_CFG2 0x2f + +#define S_SECUREPORT 16 +#define M_SECUREPORT 0xffffU +#define V_SECUREPORT(x) ((x) << S_SECUREPORT) +#define G_SECUREPORT(x) (((x) >> S_SECUREPORT) & M_SECUREPORT) + +#define S_PRIMARYPORT 0 +#define M_PRIMARYPORT 0xffffU +#define V_PRIMARYPORT(x) ((x) << S_PRIMARYPORT) +#define G_PRIMARYPORT(x) (((x) >> S_PRIMARYPORT) & M_PRIMARYPORT) + +#define A_TP_RSS_PF0_CONFIG 0x30 + +#define S_MAPENABLE 31 +#define V_MAPENABLE(x) ((x) << S_MAPENABLE) +#define F_MAPENABLE V_MAPENABLE(1U) + +#define S_CHNENABLE 30 +#define V_CHNENABLE(x) ((x) << S_CHNENABLE) +#define F_CHNENABLE V_CHNENABLE(1U) + +#define S_PRTENABLE 29 +#define V_PRTENABLE(x) ((x) << S_PRTENABLE) +#define F_PRTENABLE V_PRTENABLE(1U) + +#define S_UDPFOURTUPEN 28 +#define V_UDPFOURTUPEN(x) ((x) << S_UDPFOURTUPEN) +#define F_UDPFOURTUPEN V_UDPFOURTUPEN(1U) + +#define S_IP6FOURTUPEN 27 +#define V_IP6FOURTUPEN(x) ((x) << S_IP6FOURTUPEN) +#define F_IP6FOURTUPEN V_IP6FOURTUPEN(1U) + +#define S_IP6TWOTUPEN 26 +#define V_IP6TWOTUPEN(x) ((x) << S_IP6TWOTUPEN) +#define F_IP6TWOTUPEN V_IP6TWOTUPEN(1U) + +#define S_IP4FOURTUPEN 25 +#define V_IP4FOURTUPEN(x) ((x) << S_IP4FOURTUPEN) +#define F_IP4FOURTUPEN V_IP4FOURTUPEN(1U) + +#define S_IP4TWOTUPEN 24 +#define V_IP4TWOTUPEN(x) ((x) << S_IP4TWOTUPEN) +#define F_IP4TWOTUPEN V_IP4TWOTUPEN(1U) + +#define S_IVFWIDTH 20 +#define M_IVFWIDTH 0xfU +#define V_IVFWIDTH(x) ((x) << S_IVFWIDTH) +#define G_IVFWIDTH(x) (((x) >> S_IVFWIDTH) & M_IVFWIDTH) + +#define S_CH1DEFAULTQUEUE 10 +#define M_CH1DEFAULTQUEUE 0x3ffU +#define V_CH1DEFAULTQUEUE(x) ((x) << S_CH1DEFAULTQUEUE) +#define G_CH1DEFAULTQUEUE(x) (((x) >> S_CH1DEFAULTQUEUE) & M_CH1DEFAULTQUEUE) + +#define S_CH0DEFAULTQUEUE 0 +#define M_CH0DEFAULTQUEUE 0x3ffU +#define V_CH0DEFAULTQUEUE(x) ((x) << S_CH0DEFAULTQUEUE) +#define G_CH0DEFAULTQUEUE(x) (((x) >> S_CH0DEFAULTQUEUE) & M_CH0DEFAULTQUEUE) + +#define A_TP_RSS_PF1_CONFIG 0x31 +#define A_TP_RSS_PF2_CONFIG 0x32 +#define A_TP_RSS_PF3_CONFIG 0x33 +#define A_TP_RSS_PF4_CONFIG 0x34 +#define A_TP_RSS_PF5_CONFIG 0x35 +#define A_TP_RSS_PF6_CONFIG 0x36 +#define A_TP_RSS_PF7_CONFIG 0x37 +#define A_TP_RSS_PF_MAP 0x38 + +#define S_LKPIDXSIZE 24 +#define M_LKPIDXSIZE 0x3U +#define V_LKPIDXSIZE(x) ((x) << S_LKPIDXSIZE) +#define G_LKPIDXSIZE(x) (((x) >> S_LKPIDXSIZE) & M_LKPIDXSIZE) + +#define S_PF7LKPIDX 21 +#define M_PF7LKPIDX 0x7U +#define V_PF7LKPIDX(x) ((x) << S_PF7LKPIDX) +#define G_PF7LKPIDX(x) (((x) >> S_PF7LKPIDX) & M_PF7LKPIDX) + +#define S_PF6LKPIDX 18 +#define M_PF6LKPIDX 0x7U +#define V_PF6LKPIDX(x) ((x) << S_PF6LKPIDX) +#define G_PF6LKPIDX(x) (((x) >> S_PF6LKPIDX) & M_PF6LKPIDX) + +#define S_PF5LKPIDX 15 +#define M_PF5LKPIDX 0x7U +#define V_PF5LKPIDX(x) ((x) << S_PF5LKPIDX) +#define G_PF5LKPIDX(x) (((x) >> S_PF5LKPIDX) & M_PF5LKPIDX) + +#define S_PF4LKPIDX 12 +#define M_PF4LKPIDX 0x7U +#define V_PF4LKPIDX(x) ((x) << S_PF4LKPIDX) +#define G_PF4LKPIDX(x) (((x) >> S_PF4LKPIDX) & M_PF4LKPIDX) + +#define S_PF3LKPIDX 9 +#define M_PF3LKPIDX 0x7U +#define V_PF3LKPIDX(x) ((x) << S_PF3LKPIDX) +#define G_PF3LKPIDX(x) (((x) >> S_PF3LKPIDX) & M_PF3LKPIDX) + +#define S_PF2LKPIDX 6 +#define M_PF2LKPIDX 0x7U +#define V_PF2LKPIDX(x) ((x) << S_PF2LKPIDX) +#define G_PF2LKPIDX(x) (((x) >> S_PF2LKPIDX) & M_PF2LKPIDX) + +#define S_PF1LKPIDX 3 +#define M_PF1LKPIDX 0x7U +#define V_PF1LKPIDX(x) ((x) << S_PF1LKPIDX) +#define G_PF1LKPIDX(x) (((x) >> S_PF1LKPIDX) & M_PF1LKPIDX) + +#define S_PF0LKPIDX 0 +#define M_PF0LKPIDX 0x7U +#define V_PF0LKPIDX(x) ((x) << S_PF0LKPIDX) +#define G_PF0LKPIDX(x) (((x) >> S_PF0LKPIDX) & M_PF0LKPIDX) + +#define A_TP_RSS_PF_MSK 0x39 + +#define S_PF7MSKSIZE 28 +#define M_PF7MSKSIZE 0xfU +#define V_PF7MSKSIZE(x) ((x) << S_PF7MSKSIZE) +#define G_PF7MSKSIZE(x) (((x) >> S_PF7MSKSIZE) & M_PF7MSKSIZE) + +#define S_PF6MSKSIZE 24 +#define M_PF6MSKSIZE 0xfU +#define V_PF6MSKSIZE(x) ((x) << S_PF6MSKSIZE) +#define G_PF6MSKSIZE(x) (((x) >> S_PF6MSKSIZE) & M_PF6MSKSIZE) + +#define S_PF5MSKSIZE 20 +#define M_PF5MSKSIZE 0xfU +#define V_PF5MSKSIZE(x) ((x) << S_PF5MSKSIZE) +#define G_PF5MSKSIZE(x) (((x) >> S_PF5MSKSIZE) & M_PF5MSKSIZE) + +#define S_PF4MSKSIZE 16 +#define M_PF4MSKSIZE 0xfU +#define V_PF4MSKSIZE(x) ((x) << S_PF4MSKSIZE) +#define G_PF4MSKSIZE(x) (((x) >> S_PF4MSKSIZE) & M_PF4MSKSIZE) + +#define S_PF3MSKSIZE 12 +#define M_PF3MSKSIZE 0xfU +#define V_PF3MSKSIZE(x) ((x) << S_PF3MSKSIZE) +#define G_PF3MSKSIZE(x) (((x) >> S_PF3MSKSIZE) & M_PF3MSKSIZE) + +#define S_PF2MSKSIZE 8 +#define M_PF2MSKSIZE 0xfU +#define V_PF2MSKSIZE(x) ((x) << S_PF2MSKSIZE) +#define G_PF2MSKSIZE(x) (((x) >> S_PF2MSKSIZE) & M_PF2MSKSIZE) + +#define S_PF1MSKSIZE 4 +#define M_PF1MSKSIZE 0xfU +#define V_PF1MSKSIZE(x) ((x) << S_PF1MSKSIZE) +#define G_PF1MSKSIZE(x) (((x) >> S_PF1MSKSIZE) & M_PF1MSKSIZE) + +#define S_PF0MSKSIZE 0 +#define M_PF0MSKSIZE 0xfU +#define V_PF0MSKSIZE(x) ((x) << S_PF0MSKSIZE) +#define G_PF0MSKSIZE(x) (((x) >> S_PF0MSKSIZE) & M_PF0MSKSIZE) + +#define A_TP_RSS_VFL_CONFIG 0x3a +#define A_TP_RSS_VFH_CONFIG 0x3b + +#define S_ENABLEUDPHASH 31 +#define V_ENABLEUDPHASH(x) ((x) << S_ENABLEUDPHASH) +#define F_ENABLEUDPHASH V_ENABLEUDPHASH(1U) + +#define S_VFUPEN 30 +#define V_VFUPEN(x) ((x) << S_VFUPEN) +#define F_VFUPEN V_VFUPEN(1U) + +#define S_VFVLNEX 28 +#define V_VFVLNEX(x) ((x) << S_VFVLNEX) +#define F_VFVLNEX V_VFVLNEX(1U) + +#define S_VFPRTEN 27 +#define V_VFPRTEN(x) ((x) << S_VFPRTEN) +#define F_VFPRTEN V_VFPRTEN(1U) + +#define S_VFCHNEN 26 +#define V_VFCHNEN(x) ((x) << S_VFCHNEN) +#define F_VFCHNEN V_VFCHNEN(1U) + +#define S_DEFAULTQUEUE 16 +#define M_DEFAULTQUEUE 0x3ffU +#define V_DEFAULTQUEUE(x) ((x) << S_DEFAULTQUEUE) +#define G_DEFAULTQUEUE(x) (((x) >> S_DEFAULTQUEUE) & M_DEFAULTQUEUE) + +#define S_VFLKPIDX 8 +#define M_VFLKPIDX 0xffU +#define V_VFLKPIDX(x) ((x) << S_VFLKPIDX) +#define G_VFLKPIDX(x) (((x) >> S_VFLKPIDX) & M_VFLKPIDX) + +#define S_VFIP6FOURTUPEN 7 +#define V_VFIP6FOURTUPEN(x) ((x) << S_VFIP6FOURTUPEN) +#define F_VFIP6FOURTUPEN V_VFIP6FOURTUPEN(1U) + +#define S_VFIP6TWOTUPEN 6 +#define V_VFIP6TWOTUPEN(x) ((x) << S_VFIP6TWOTUPEN) +#define F_VFIP6TWOTUPEN V_VFIP6TWOTUPEN(1U) + +#define S_VFIP4FOURTUPEN 5 +#define V_VFIP4FOURTUPEN(x) ((x) << S_VFIP4FOURTUPEN) +#define F_VFIP4FOURTUPEN V_VFIP4FOURTUPEN(1U) + +#define S_VFIP4TWOTUPEN 4 +#define V_VFIP4TWOTUPEN(x) ((x) << S_VFIP4TWOTUPEN) +#define F_VFIP4TWOTUPEN V_VFIP4TWOTUPEN(1U) + +#define S_KEYINDEX 0 +#define M_KEYINDEX 0xfU +#define V_KEYINDEX(x) ((x) << S_KEYINDEX) +#define G_KEYINDEX(x) (((x) >> S_KEYINDEX) & M_KEYINDEX) + +#define A_TP_RSS_SECRET_KEY0 0x40 +#define A_TP_RSS_SECRET_KEY1 0x41 +#define A_TP_RSS_SECRET_KEY2 0x42 +#define A_TP_RSS_SECRET_KEY3 0x43 +#define A_TP_RSS_SECRET_KEY4 0x44 +#define A_TP_RSS_SECRET_KEY5 0x45 +#define A_TP_RSS_SECRET_KEY6 0x46 +#define A_TP_RSS_SECRET_KEY7 0x47 +#define A_TP_RSS_SECRET_KEY8 0x48 +#define A_TP_RSS_SECRET_KEY9 0x49 +#define A_TP_ETHER_TYPE_VL 0x50 + +#define S_CQFCTYPE 16 +#define M_CQFCTYPE 0xffffU +#define V_CQFCTYPE(x) ((x) << S_CQFCTYPE) +#define G_CQFCTYPE(x) (((x) >> S_CQFCTYPE) & M_CQFCTYPE) + +#define S_VLANTYPE 0 +#define M_VLANTYPE 0xffffU +#define V_VLANTYPE(x) ((x) << S_VLANTYPE) +#define G_VLANTYPE(x) (((x) >> S_VLANTYPE) & M_VLANTYPE) + +#define A_TP_ETHER_TYPE_IP 0x51 + +#define S_IPV6TYPE 16 +#define M_IPV6TYPE 0xffffU +#define V_IPV6TYPE(x) ((x) << S_IPV6TYPE) +#define G_IPV6TYPE(x) (((x) >> S_IPV6TYPE) & M_IPV6TYPE) + +#define S_IPV4TYPE 0 +#define M_IPV4TYPE 0xffffU +#define V_IPV4TYPE(x) ((x) << S_IPV4TYPE) +#define G_IPV4TYPE(x) (((x) >> S_IPV4TYPE) & M_IPV4TYPE) + +#define A_TP_ETHER_TYPE_FW 0x52 + +#define S_ETHTYPE1 16 +#define M_ETHTYPE1 0xffffU +#define V_ETHTYPE1(x) ((x) << S_ETHTYPE1) +#define G_ETHTYPE1(x) (((x) >> S_ETHTYPE1) & M_ETHTYPE1) + +#define S_ETHTYPE0 0 +#define M_ETHTYPE0 0xffffU +#define V_ETHTYPE0(x) ((x) << S_ETHTYPE0) +#define G_ETHTYPE0(x) (((x) >> S_ETHTYPE0) & M_ETHTYPE0) + +#define A_TP_CORE_POWER 0x54 + +#define S_SLEEPRDYVNT 12 +#define V_SLEEPRDYVNT(x) ((x) << S_SLEEPRDYVNT) +#define F_SLEEPRDYVNT V_SLEEPRDYVNT(1U) + +#define S_SLEEPRDYTBL 11 +#define V_SLEEPRDYTBL(x) ((x) << S_SLEEPRDYTBL) +#define F_SLEEPRDYTBL V_SLEEPRDYTBL(1U) + +#define S_SLEEPRDYMIB 10 +#define V_SLEEPRDYMIB(x) ((x) << S_SLEEPRDYMIB) +#define F_SLEEPRDYMIB V_SLEEPRDYMIB(1U) + +#define S_SLEEPRDYARP 9 +#define V_SLEEPRDYARP(x) ((x) << S_SLEEPRDYARP) +#define F_SLEEPRDYARP V_SLEEPRDYARP(1U) + +#define S_SLEEPRDYRSS 8 +#define V_SLEEPRDYRSS(x) ((x) << S_SLEEPRDYRSS) +#define F_SLEEPRDYRSS V_SLEEPRDYRSS(1U) + +#define S_SLEEPREQVNT 4 +#define V_SLEEPREQVNT(x) ((x) << S_SLEEPREQVNT) +#define F_SLEEPREQVNT V_SLEEPREQVNT(1U) + +#define S_SLEEPREQTBL 3 +#define V_SLEEPREQTBL(x) ((x) << S_SLEEPREQTBL) +#define F_SLEEPREQTBL V_SLEEPREQTBL(1U) + +#define S_SLEEPREQMIB 2 +#define V_SLEEPREQMIB(x) ((x) << S_SLEEPREQMIB) +#define F_SLEEPREQMIB V_SLEEPREQMIB(1U) + +#define S_SLEEPREQARP 1 +#define V_SLEEPREQARP(x) ((x) << S_SLEEPREQARP) +#define F_SLEEPREQARP V_SLEEPREQARP(1U) + +#define S_SLEEPREQRSS 0 +#define V_SLEEPREQRSS(x) ((x) << S_SLEEPREQRSS) +#define F_SLEEPREQRSS V_SLEEPREQRSS(1U) + +#define A_TP_CORE_RDMA 0x55 + +#define S_IMMEDIATEOP 20 +#define M_IMMEDIATEOP 0xfU +#define V_IMMEDIATEOP(x) ((x) << S_IMMEDIATEOP) +#define G_IMMEDIATEOP(x) (((x) >> S_IMMEDIATEOP) & M_IMMEDIATEOP) + +#define S_IMMEDIATESE 16 +#define M_IMMEDIATESE 0xfU +#define V_IMMEDIATESE(x) ((x) << S_IMMEDIATESE) +#define G_IMMEDIATESE(x) (((x) >> S_IMMEDIATESE) & M_IMMEDIATESE) + +#define S_ATOMICREQOP 12 +#define M_ATOMICREQOP 0xfU +#define V_ATOMICREQOP(x) ((x) << S_ATOMICREQOP) +#define G_ATOMICREQOP(x) (((x) >> S_ATOMICREQOP) & M_ATOMICREQOP) + +#define S_ATOMICRSPOP 8 +#define M_ATOMICRSPOP 0xfU +#define V_ATOMICRSPOP(x) ((x) << S_ATOMICRSPOP) +#define G_ATOMICRSPOP(x) (((x) >> S_ATOMICRSPOP) & M_ATOMICRSPOP) + +#define S_IMMEDIASEEN 1 +#define V_IMMEDIASEEN(x) ((x) << S_IMMEDIASEEN) +#define F_IMMEDIASEEN V_IMMEDIASEEN(1U) + +#define S_IMMEDIATEEN 0 +#define V_IMMEDIATEEN(x) ((x) << S_IMMEDIATEEN) +#define F_IMMEDIATEEN V_IMMEDIATEEN(1U) + +#define A_TP_DBG_CLEAR 0x60 +#define A_TP_DBG_CORE_HDR0 0x61 + +#define S_E_TCP_OP_SRDY 16 +#define V_E_TCP_OP_SRDY(x) ((x) << S_E_TCP_OP_SRDY) +#define F_E_TCP_OP_SRDY V_E_TCP_OP_SRDY(1U) + +#define S_E_PLD_TXZEROP_SRDY 15 +#define V_E_PLD_TXZEROP_SRDY(x) ((x) << S_E_PLD_TXZEROP_SRDY) +#define F_E_PLD_TXZEROP_SRDY V_E_PLD_TXZEROP_SRDY(1U) + +#define S_E_PLD_RX_SRDY 14 +#define V_E_PLD_RX_SRDY(x) ((x) << S_E_PLD_RX_SRDY) +#define F_E_PLD_RX_SRDY V_E_PLD_RX_SRDY(1U) + +#define S_E_RX_ERROR_SRDY 13 +#define V_E_RX_ERROR_SRDY(x) ((x) << S_E_RX_ERROR_SRDY) +#define F_E_RX_ERROR_SRDY V_E_RX_ERROR_SRDY(1U) + +#define S_E_RX_ISS_SRDY 12 +#define V_E_RX_ISS_SRDY(x) ((x) << S_E_RX_ISS_SRDY) +#define F_E_RX_ISS_SRDY V_E_RX_ISS_SRDY(1U) + +#define S_C_TCP_OP_SRDY 11 +#define V_C_TCP_OP_SRDY(x) ((x) << S_C_TCP_OP_SRDY) +#define F_C_TCP_OP_SRDY V_C_TCP_OP_SRDY(1U) + +#define S_C_PLD_TXZEROP_SRDY 10 +#define V_C_PLD_TXZEROP_SRDY(x) ((x) << S_C_PLD_TXZEROP_SRDY) +#define F_C_PLD_TXZEROP_SRDY V_C_PLD_TXZEROP_SRDY(1U) + +#define S_C_PLD_RX_SRDY 9 +#define V_C_PLD_RX_SRDY(x) ((x) << S_C_PLD_RX_SRDY) +#define F_C_PLD_RX_SRDY V_C_PLD_RX_SRDY(1U) + +#define S_C_RX_ERROR_SRDY 8 +#define V_C_RX_ERROR_SRDY(x) ((x) << S_C_RX_ERROR_SRDY) +#define F_C_RX_ERROR_SRDY V_C_RX_ERROR_SRDY(1U) + +#define S_C_RX_ISS_SRDY 7 +#define V_C_RX_ISS_SRDY(x) ((x) << S_C_RX_ISS_SRDY) +#define F_C_RX_ISS_SRDY V_C_RX_ISS_SRDY(1U) + +#define S_E_CPL5_TXVALID 6 +#define V_E_CPL5_TXVALID(x) ((x) << S_E_CPL5_TXVALID) +#define F_E_CPL5_TXVALID V_E_CPL5_TXVALID(1U) + +#define S_E_ETH_TXVALID 5 +#define V_E_ETH_TXVALID(x) ((x) << S_E_ETH_TXVALID) +#define F_E_ETH_TXVALID V_E_ETH_TXVALID(1U) + +#define S_E_IP_TXVALID 4 +#define V_E_IP_TXVALID(x) ((x) << S_E_IP_TXVALID) +#define F_E_IP_TXVALID V_E_IP_TXVALID(1U) + +#define S_E_TCP_TXVALID 3 +#define V_E_TCP_TXVALID(x) ((x) << S_E_TCP_TXVALID) +#define F_E_TCP_TXVALID V_E_TCP_TXVALID(1U) + +#define S_C_CPL5_RXVALID 2 +#define V_C_CPL5_RXVALID(x) ((x) << S_C_CPL5_RXVALID) +#define F_C_CPL5_RXVALID V_C_CPL5_RXVALID(1U) + +#define S_C_CPL5_TXVALID 1 +#define V_C_CPL5_TXVALID(x) ((x) << S_C_CPL5_TXVALID) +#define F_C_CPL5_TXVALID V_C_CPL5_TXVALID(1U) + +#define S_E_TCP_OPT_RXVALID 0 +#define V_E_TCP_OPT_RXVALID(x) ((x) << S_E_TCP_OPT_RXVALID) +#define F_E_TCP_OPT_RXVALID V_E_TCP_OPT_RXVALID(1U) + +#define A_TP_DBG_CORE_HDR1 0x62 + +#define S_E_CPL5_TXFULL 6 +#define V_E_CPL5_TXFULL(x) ((x) << S_E_CPL5_TXFULL) +#define F_E_CPL5_TXFULL V_E_CPL5_TXFULL(1U) + +#define S_E_ETH_TXFULL 5 +#define V_E_ETH_TXFULL(x) ((x) << S_E_ETH_TXFULL) +#define F_E_ETH_TXFULL V_E_ETH_TXFULL(1U) + +#define S_E_IP_TXFULL 4 +#define V_E_IP_TXFULL(x) ((x) << S_E_IP_TXFULL) +#define F_E_IP_TXFULL V_E_IP_TXFULL(1U) + +#define S_E_TCP_TXFULL 3 +#define V_E_TCP_TXFULL(x) ((x) << S_E_TCP_TXFULL) +#define F_E_TCP_TXFULL V_E_TCP_TXFULL(1U) + +#define S_C_CPL5_RXFULL 2 +#define V_C_CPL5_RXFULL(x) ((x) << S_C_CPL5_RXFULL) +#define F_C_CPL5_RXFULL V_C_CPL5_RXFULL(1U) + +#define S_C_CPL5_TXFULL 1 +#define V_C_CPL5_TXFULL(x) ((x) << S_C_CPL5_TXFULL) +#define F_C_CPL5_TXFULL V_C_CPL5_TXFULL(1U) + +#define S_E_TCP_OPT_RXFULL 0 +#define V_E_TCP_OPT_RXFULL(x) ((x) << S_E_TCP_OPT_RXFULL) +#define F_E_TCP_OPT_RXFULL V_E_TCP_OPT_RXFULL(1U) + +#define A_TP_DBG_CORE_FATAL 0x63 + +#define S_EMSGFATAL 31 +#define V_EMSGFATAL(x) ((x) << S_EMSGFATAL) +#define F_EMSGFATAL V_EMSGFATAL(1U) + +#define S_CMSGFATAL 30 +#define V_CMSGFATAL(x) ((x) << S_CMSGFATAL) +#define F_CMSGFATAL V_CMSGFATAL(1U) + +#define S_PAWSFATAL 29 +#define V_PAWSFATAL(x) ((x) << S_PAWSFATAL) +#define F_PAWSFATAL V_PAWSFATAL(1U) + +#define S_SRAMFATAL 28 +#define V_SRAMFATAL(x) ((x) << S_SRAMFATAL) +#define F_SRAMFATAL V_SRAMFATAL(1U) + +#define S_CPCMDCONG 24 +#define M_CPCMDCONG 0xfU +#define V_CPCMDCONG(x) ((x) << S_CPCMDCONG) +#define G_CPCMDCONG(x) (((x) >> S_CPCMDCONG) & M_CPCMDCONG) + +#define S_EPCMDCONG 22 +#define M_EPCMDCONG 0x3U +#define V_EPCMDCONG(x) ((x) << S_EPCMDCONG) +#define G_EPCMDCONG(x) (((x) >> S_EPCMDCONG) & M_EPCMDCONG) + +#define S_CPCMDLENFATAL 21 +#define V_CPCMDLENFATAL(x) ((x) << S_CPCMDLENFATAL) +#define F_CPCMDLENFATAL V_CPCMDLENFATAL(1U) + +#define S_EPCMDLENFATAL 20 +#define V_EPCMDLENFATAL(x) ((x) << S_EPCMDLENFATAL) +#define F_EPCMDLENFATAL V_EPCMDLENFATAL(1U) + +#define S_CPCMDVALID 16 +#define M_CPCMDVALID 0xfU +#define V_CPCMDVALID(x) ((x) << S_CPCMDVALID) +#define G_CPCMDVALID(x) (((x) >> S_CPCMDVALID) & M_CPCMDVALID) + +#define S_CPCMDAFULL 12 +#define M_CPCMDAFULL 0xfU +#define V_CPCMDAFULL(x) ((x) << S_CPCMDAFULL) +#define G_CPCMDAFULL(x) (((x) >> S_CPCMDAFULL) & M_CPCMDAFULL) + +#define S_EPCMDVALID 10 +#define M_EPCMDVALID 0x3U +#define V_EPCMDVALID(x) ((x) << S_EPCMDVALID) +#define G_EPCMDVALID(x) (((x) >> S_EPCMDVALID) & M_EPCMDVALID) + +#define S_EPCMDAFULL 8 +#define M_EPCMDAFULL 0x3U +#define V_EPCMDAFULL(x) ((x) << S_EPCMDAFULL) +#define G_EPCMDAFULL(x) (((x) >> S_EPCMDAFULL) & M_EPCMDAFULL) + +#define S_CPCMDEOIFATAL 7 +#define V_CPCMDEOIFATAL(x) ((x) << S_CPCMDEOIFATAL) +#define F_CPCMDEOIFATAL V_CPCMDEOIFATAL(1U) + +#define S_CMDBRQFATAL 4 +#define V_CMDBRQFATAL(x) ((x) << S_CMDBRQFATAL) +#define F_CMDBRQFATAL V_CMDBRQFATAL(1U) + +#define S_CNONZEROPPOPCNT 2 +#define M_CNONZEROPPOPCNT 0x3U +#define V_CNONZEROPPOPCNT(x) ((x) << S_CNONZEROPPOPCNT) +#define G_CNONZEROPPOPCNT(x) (((x) >> S_CNONZEROPPOPCNT) & M_CNONZEROPPOPCNT) + +#define S_CPCMDEOICNT 0 +#define M_CPCMDEOICNT 0x3U +#define V_CPCMDEOICNT(x) ((x) << S_CPCMDEOICNT) +#define G_CPCMDEOICNT(x) (((x) >> S_CPCMDEOICNT) & M_CPCMDEOICNT) + +#define S_CPCMDTTLFATAL 6 +#define V_CPCMDTTLFATAL(x) ((x) << S_CPCMDTTLFATAL) +#define F_CPCMDTTLFATAL V_CPCMDTTLFATAL(1U) + +#define S_CDATACHNFATAL 5 +#define V_CDATACHNFATAL(x) ((x) << S_CDATACHNFATAL) +#define F_CDATACHNFATAL V_CDATACHNFATAL(1U) + +#define A_TP_DBG_CORE_OUT 0x64 + +#define S_CCPLENC 26 +#define V_CCPLENC(x) ((x) << S_CCPLENC) +#define F_CCPLENC V_CCPLENC(1U) + +#define S_CWRCPLPKT 25 +#define V_CWRCPLPKT(x) ((x) << S_CWRCPLPKT) +#define F_CWRCPLPKT V_CWRCPLPKT(1U) + +#define S_CWRETHPKT 24 +#define V_CWRETHPKT(x) ((x) << S_CWRETHPKT) +#define F_CWRETHPKT V_CWRETHPKT(1U) + +#define S_CWRIPPKT 23 +#define V_CWRIPPKT(x) ((x) << S_CWRIPPKT) +#define F_CWRIPPKT V_CWRIPPKT(1U) + +#define S_CWRTCPPKT 22 +#define V_CWRTCPPKT(x) ((x) << S_CWRTCPPKT) +#define F_CWRTCPPKT V_CWRTCPPKT(1U) + +#define S_CWRZEROP 21 +#define V_CWRZEROP(x) ((x) << S_CWRZEROP) +#define F_CWRZEROP V_CWRZEROP(1U) + +#define S_CCPLTXFULL 20 +#define V_CCPLTXFULL(x) ((x) << S_CCPLTXFULL) +#define F_CCPLTXFULL V_CCPLTXFULL(1U) + +#define S_CETHTXFULL 19 +#define V_CETHTXFULL(x) ((x) << S_CETHTXFULL) +#define F_CETHTXFULL V_CETHTXFULL(1U) + +#define S_CIPTXFULL 18 +#define V_CIPTXFULL(x) ((x) << S_CIPTXFULL) +#define F_CIPTXFULL V_CIPTXFULL(1U) + +#define S_CTCPTXFULL 17 +#define V_CTCPTXFULL(x) ((x) << S_CTCPTXFULL) +#define F_CTCPTXFULL V_CTCPTXFULL(1U) + +#define S_CPLDTXZEROPDRDY 16 +#define V_CPLDTXZEROPDRDY(x) ((x) << S_CPLDTXZEROPDRDY) +#define F_CPLDTXZEROPDRDY V_CPLDTXZEROPDRDY(1U) + +#define S_ECPLENC 10 +#define V_ECPLENC(x) ((x) << S_ECPLENC) +#define F_ECPLENC V_ECPLENC(1U) + +#define S_EWRCPLPKT 9 +#define V_EWRCPLPKT(x) ((x) << S_EWRCPLPKT) +#define F_EWRCPLPKT V_EWRCPLPKT(1U) + +#define S_EWRETHPKT 8 +#define V_EWRETHPKT(x) ((x) << S_EWRETHPKT) +#define F_EWRETHPKT V_EWRETHPKT(1U) + +#define S_EWRIPPKT 7 +#define V_EWRIPPKT(x) ((x) << S_EWRIPPKT) +#define F_EWRIPPKT V_EWRIPPKT(1U) + +#define S_EWRTCPPKT 6 +#define V_EWRTCPPKT(x) ((x) << S_EWRTCPPKT) +#define F_EWRTCPPKT V_EWRTCPPKT(1U) + +#define S_EWRZEROP 5 +#define V_EWRZEROP(x) ((x) << S_EWRZEROP) +#define F_EWRZEROP V_EWRZEROP(1U) + +#define S_ECPLTXFULL 4 +#define V_ECPLTXFULL(x) ((x) << S_ECPLTXFULL) +#define F_ECPLTXFULL V_ECPLTXFULL(1U) + +#define S_EETHTXFULL 3 +#define V_EETHTXFULL(x) ((x) << S_EETHTXFULL) +#define F_EETHTXFULL V_EETHTXFULL(1U) + +#define S_EIPTXFULL 2 +#define V_EIPTXFULL(x) ((x) << S_EIPTXFULL) +#define F_EIPTXFULL V_EIPTXFULL(1U) + +#define S_ETCPTXFULL 1 +#define V_ETCPTXFULL(x) ((x) << S_ETCPTXFULL) +#define F_ETCPTXFULL V_ETCPTXFULL(1U) + +#define S_EPLDTXZEROPDRDY 0 +#define V_EPLDTXZEROPDRDY(x) ((x) << S_EPLDTXZEROPDRDY) +#define F_EPLDTXZEROPDRDY V_EPLDTXZEROPDRDY(1U) + +#define S_CRXBUSYOUT 31 +#define V_CRXBUSYOUT(x) ((x) << S_CRXBUSYOUT) +#define F_CRXBUSYOUT V_CRXBUSYOUT(1U) + +#define S_CTXBUSYOUT 30 +#define V_CTXBUSYOUT(x) ((x) << S_CTXBUSYOUT) +#define F_CTXBUSYOUT V_CTXBUSYOUT(1U) + +#define S_CRDCPLPKT 29 +#define V_CRDCPLPKT(x) ((x) << S_CRDCPLPKT) +#define F_CRDCPLPKT V_CRDCPLPKT(1U) + +#define S_CRDTCPPKT 28 +#define V_CRDTCPPKT(x) ((x) << S_CRDTCPPKT) +#define F_CRDTCPPKT V_CRDTCPPKT(1U) + +#define S_CNEWMSG 27 +#define V_CNEWMSG(x) ((x) << S_CNEWMSG) +#define F_CNEWMSG V_CNEWMSG(1U) + +#define S_ERXBUSYOUT 15 +#define V_ERXBUSYOUT(x) ((x) << S_ERXBUSYOUT) +#define F_ERXBUSYOUT V_ERXBUSYOUT(1U) + +#define S_ETXBUSYOUT 14 +#define V_ETXBUSYOUT(x) ((x) << S_ETXBUSYOUT) +#define F_ETXBUSYOUT V_ETXBUSYOUT(1U) + +#define S_ERDCPLPKT 13 +#define V_ERDCPLPKT(x) ((x) << S_ERDCPLPKT) +#define F_ERDCPLPKT V_ERDCPLPKT(1U) + +#define S_ERDTCPPKT 12 +#define V_ERDTCPPKT(x) ((x) << S_ERDTCPPKT) +#define F_ERDTCPPKT V_ERDTCPPKT(1U) + +#define S_ENEWMSG 11 +#define V_ENEWMSG(x) ((x) << S_ENEWMSG) +#define F_ENEWMSG V_ENEWMSG(1U) + +#define A_TP_DBG_CORE_TID 0x65 + +#define S_LINENUMBER 24 +#define M_LINENUMBER 0x7fU +#define V_LINENUMBER(x) ((x) << S_LINENUMBER) +#define G_LINENUMBER(x) (((x) >> S_LINENUMBER) & M_LINENUMBER) + +#define S_SPURIOUSMSG 23 +#define V_SPURIOUSMSG(x) ((x) << S_SPURIOUSMSG) +#define F_SPURIOUSMSG V_SPURIOUSMSG(1U) + +#define S_SYNLEARNED 20 +#define V_SYNLEARNED(x) ((x) << S_SYNLEARNED) +#define F_SYNLEARNED V_SYNLEARNED(1U) + +#define S_TIDVALUE 0 +#define M_TIDVALUE 0xfffffU +#define V_TIDVALUE(x) ((x) << S_TIDVALUE) +#define G_TIDVALUE(x) (((x) >> S_TIDVALUE) & M_TIDVALUE) + +#define S_SRC 21 +#define M_SRC 0x3U +#define V_SRC(x) ((x) << S_SRC) +#define G_SRC(x) (((x) >> S_SRC) & M_SRC) + +#define A_TP_DBG_ENG_RES0 0x66 + +#define S_RESOURCESREADY 31 +#define V_RESOURCESREADY(x) ((x) << S_RESOURCESREADY) +#define F_RESOURCESREADY V_RESOURCESREADY(1U) + +#define S_RCFOPCODEOUTSRDY 30 +#define V_RCFOPCODEOUTSRDY(x) ((x) << S_RCFOPCODEOUTSRDY) +#define F_RCFOPCODEOUTSRDY V_RCFOPCODEOUTSRDY(1U) + +#define S_RCFDATAOUTSRDY 29 +#define V_RCFDATAOUTSRDY(x) ((x) << S_RCFDATAOUTSRDY) +#define F_RCFDATAOUTSRDY V_RCFDATAOUTSRDY(1U) + +#define S_FLUSHINPUTMSG 28 +#define V_FLUSHINPUTMSG(x) ((x) << S_FLUSHINPUTMSG) +#define F_FLUSHINPUTMSG V_FLUSHINPUTMSG(1U) + +#define S_RCFOPSRCOUT 26 +#define M_RCFOPSRCOUT 0x3U +#define V_RCFOPSRCOUT(x) ((x) << S_RCFOPSRCOUT) +#define G_RCFOPSRCOUT(x) (((x) >> S_RCFOPSRCOUT) & M_RCFOPSRCOUT) + +#define S_C_MSG 25 +#define V_C_MSG(x) ((x) << S_C_MSG) +#define F_C_MSG V_C_MSG(1U) + +#define S_E_MSG 24 +#define V_E_MSG(x) ((x) << S_E_MSG) +#define F_E_MSG V_E_MSG(1U) + +#define S_RCFOPCODEOUT 20 +#define M_RCFOPCODEOUT 0xfU +#define V_RCFOPCODEOUT(x) ((x) << S_RCFOPCODEOUT) +#define G_RCFOPCODEOUT(x) (((x) >> S_RCFOPCODEOUT) & M_RCFOPCODEOUT) + +#define S_EFFRCFOPCODEOUT 16 +#define M_EFFRCFOPCODEOUT 0xfU +#define V_EFFRCFOPCODEOUT(x) ((x) << S_EFFRCFOPCODEOUT) +#define G_EFFRCFOPCODEOUT(x) (((x) >> S_EFFRCFOPCODEOUT) & M_EFFRCFOPCODEOUT) + +#define S_SEENRESOURCESREADY 15 +#define V_SEENRESOURCESREADY(x) ((x) << S_SEENRESOURCESREADY) +#define F_SEENRESOURCESREADY V_SEENRESOURCESREADY(1U) + +#define S_RESOURCESREADYCOPY 14 +#define V_RESOURCESREADYCOPY(x) ((x) << S_RESOURCESREADYCOPY) +#define F_RESOURCESREADYCOPY V_RESOURCESREADYCOPY(1U) + +#define S_OPCODEWAITSFORDATA 13 +#define V_OPCODEWAITSFORDATA(x) ((x) << S_OPCODEWAITSFORDATA) +#define F_OPCODEWAITSFORDATA V_OPCODEWAITSFORDATA(1U) + +#define S_CPLDRXSRDY 12 +#define V_CPLDRXSRDY(x) ((x) << S_CPLDRXSRDY) +#define F_CPLDRXSRDY V_CPLDRXSRDY(1U) + +#define S_CPLDRXZEROPSRDY 11 +#define V_CPLDRXZEROPSRDY(x) ((x) << S_CPLDRXZEROPSRDY) +#define F_CPLDRXZEROPSRDY V_CPLDRXZEROPSRDY(1U) + +#define S_EPLDRXZEROPSRDY 10 +#define V_EPLDRXZEROPSRDY(x) ((x) << S_EPLDRXZEROPSRDY) +#define F_EPLDRXZEROPSRDY V_EPLDRXZEROPSRDY(1U) + +#define S_ERXERRORSRDY 9 +#define V_ERXERRORSRDY(x) ((x) << S_ERXERRORSRDY) +#define F_ERXERRORSRDY V_ERXERRORSRDY(1U) + +#define S_EPLDRXSRDY 8 +#define V_EPLDRXSRDY(x) ((x) << S_EPLDRXSRDY) +#define F_EPLDRXSRDY V_EPLDRXSRDY(1U) + +#define S_CRXBUSY 7 +#define V_CRXBUSY(x) ((x) << S_CRXBUSY) +#define F_CRXBUSY V_CRXBUSY(1U) + +#define S_ERXBUSY 6 +#define V_ERXBUSY(x) ((x) << S_ERXBUSY) +#define F_ERXBUSY V_ERXBUSY(1U) + +#define S_TIMERINSERTBUSY 5 +#define V_TIMERINSERTBUSY(x) ((x) << S_TIMERINSERTBUSY) +#define F_TIMERINSERTBUSY V_TIMERINSERTBUSY(1U) + +#define S_WCFBUSY 4 +#define V_WCFBUSY(x) ((x) << S_WCFBUSY) +#define F_WCFBUSY V_WCFBUSY(1U) + +#define S_CTXBUSY 3 +#define V_CTXBUSY(x) ((x) << S_CTXBUSY) +#define F_CTXBUSY V_CTXBUSY(1U) + +#define S_CPCMDBUSY 2 +#define V_CPCMDBUSY(x) ((x) << S_CPCMDBUSY) +#define F_CPCMDBUSY V_CPCMDBUSY(1U) + +#define S_EPCMDBUSY 1 +#define V_EPCMDBUSY(x) ((x) << S_EPCMDBUSY) +#define F_EPCMDBUSY V_EPCMDBUSY(1U) + +#define S_ETXBUSY 0 +#define V_ETXBUSY(x) ((x) << S_ETXBUSY) +#define F_ETXBUSY V_ETXBUSY(1U) + +#define S_EFFOPCODEOUT 16 +#define M_EFFOPCODEOUT 0xfU +#define V_EFFOPCODEOUT(x) ((x) << S_EFFOPCODEOUT) +#define G_EFFOPCODEOUT(x) (((x) >> S_EFFOPCODEOUT) & M_EFFOPCODEOUT) + +#define S_DELDRDY 14 +#define V_DELDRDY(x) ((x) << S_DELDRDY) +#define F_DELDRDY V_DELDRDY(1U) + +#define A_TP_DBG_ENG_RES1 0x67 + +#define S_RXCPLSRDY 31 +#define V_RXCPLSRDY(x) ((x) << S_RXCPLSRDY) +#define F_RXCPLSRDY V_RXCPLSRDY(1U) + +#define S_RXOPTSRDY 30 +#define V_RXOPTSRDY(x) ((x) << S_RXOPTSRDY) +#define F_RXOPTSRDY V_RXOPTSRDY(1U) + +#define S_RXPLDLENSRDY 29 +#define V_RXPLDLENSRDY(x) ((x) << S_RXPLDLENSRDY) +#define F_RXPLDLENSRDY V_RXPLDLENSRDY(1U) + +#define S_RXNOTBUSY 28 +#define V_RXNOTBUSY(x) ((x) << S_RXNOTBUSY) +#define F_RXNOTBUSY V_RXNOTBUSY(1U) + +#define S_CPLCMDIN 20 +#define M_CPLCMDIN 0xffU +#define V_CPLCMDIN(x) ((x) << S_CPLCMDIN) +#define G_CPLCMDIN(x) (((x) >> S_CPLCMDIN) & M_CPLCMDIN) + +#define S_RCFPTIDSRDY 19 +#define V_RCFPTIDSRDY(x) ((x) << S_RCFPTIDSRDY) +#define F_RCFPTIDSRDY V_RCFPTIDSRDY(1U) + +#define S_EPDUHDRSRDY 18 +#define V_EPDUHDRSRDY(x) ((x) << S_EPDUHDRSRDY) +#define F_EPDUHDRSRDY V_EPDUHDRSRDY(1U) + +#define S_TUNNELPKTREG 17 +#define V_TUNNELPKTREG(x) ((x) << S_TUNNELPKTREG) +#define F_TUNNELPKTREG V_TUNNELPKTREG(1U) + +#define S_TXPKTCSUMSRDY 16 +#define V_TXPKTCSUMSRDY(x) ((x) << S_TXPKTCSUMSRDY) +#define F_TXPKTCSUMSRDY V_TXPKTCSUMSRDY(1U) + +#define S_TABLEACCESSLATENCY 12 +#define M_TABLEACCESSLATENCY 0xfU +#define V_TABLEACCESSLATENCY(x) ((x) << S_TABLEACCESSLATENCY) +#define G_TABLEACCESSLATENCY(x) (((x) >> S_TABLEACCESSLATENCY) & M_TABLEACCESSLATENCY) + +#define S_MMGRDONE 11 +#define V_MMGRDONE(x) ((x) << S_MMGRDONE) +#define F_MMGRDONE V_MMGRDONE(1U) + +#define S_SEENMMGRDONE 10 +#define V_SEENMMGRDONE(x) ((x) << S_SEENMMGRDONE) +#define F_SEENMMGRDONE V_SEENMMGRDONE(1U) + +#define S_RXERRORSRDY 9 +#define V_RXERRORSRDY(x) ((x) << S_RXERRORSRDY) +#define F_RXERRORSRDY V_RXERRORSRDY(1U) + +#define S_RCFOPTIONSTCPSRDY 8 +#define V_RCFOPTIONSTCPSRDY(x) ((x) << S_RCFOPTIONSTCPSRDY) +#define F_RCFOPTIONSTCPSRDY V_RCFOPTIONSTCPSRDY(1U) + +#define S_ENGINESTATE 6 +#define M_ENGINESTATE 0x3U +#define V_ENGINESTATE(x) ((x) << S_ENGINESTATE) +#define G_ENGINESTATE(x) (((x) >> S_ENGINESTATE) & M_ENGINESTATE) + +#define S_TABLEACCESINCREMENT 5 +#define V_TABLEACCESINCREMENT(x) ((x) << S_TABLEACCESINCREMENT) +#define F_TABLEACCESINCREMENT V_TABLEACCESINCREMENT(1U) + +#define S_TABLEACCESCOMPLETE 4 +#define V_TABLEACCESCOMPLETE(x) ((x) << S_TABLEACCESCOMPLETE) +#define F_TABLEACCESCOMPLETE V_TABLEACCESCOMPLETE(1U) + +#define S_RCFOPCODEOUTUSABLE 3 +#define V_RCFOPCODEOUTUSABLE(x) ((x) << S_RCFOPCODEOUTUSABLE) +#define F_RCFOPCODEOUTUSABLE V_RCFOPCODEOUTUSABLE(1U) + +#define S_RCFDATAOUTUSABLE 2 +#define V_RCFDATAOUTUSABLE(x) ((x) << S_RCFDATAOUTUSABLE) +#define F_RCFDATAOUTUSABLE V_RCFDATAOUTUSABLE(1U) + +#define S_RCFDATAWAITAFTERRD 1 +#define V_RCFDATAWAITAFTERRD(x) ((x) << S_RCFDATAWAITAFTERRD) +#define F_RCFDATAWAITAFTERRD V_RCFDATAWAITAFTERRD(1U) + +#define S_RCFDATACMRDY 0 +#define V_RCFDATACMRDY(x) ((x) << S_RCFDATACMRDY) +#define F_RCFDATACMRDY V_RCFDATACMRDY(1U) + +#define A_TP_DBG_ENG_RES2 0x68 + +#define S_CPLCMDRAW 24 +#define M_CPLCMDRAW 0xffU +#define V_CPLCMDRAW(x) ((x) << S_CPLCMDRAW) +#define G_CPLCMDRAW(x) (((x) >> S_CPLCMDRAW) & M_CPLCMDRAW) + +#define S_RXMACPORT 20 +#define M_RXMACPORT 0xfU +#define V_RXMACPORT(x) ((x) << S_RXMACPORT) +#define G_RXMACPORT(x) (((x) >> S_RXMACPORT) & M_RXMACPORT) + +#define S_TXECHANNEL 18 +#define M_TXECHANNEL 0x3U +#define V_TXECHANNEL(x) ((x) << S_TXECHANNEL) +#define G_TXECHANNEL(x) (((x) >> S_TXECHANNEL) & M_TXECHANNEL) + +#define S_RXECHANNEL 16 +#define M_RXECHANNEL 0x3U +#define V_RXECHANNEL(x) ((x) << S_RXECHANNEL) +#define G_RXECHANNEL(x) (((x) >> S_RXECHANNEL) & M_RXECHANNEL) + +#define S_CDATAOUT 15 +#define V_CDATAOUT(x) ((x) << S_CDATAOUT) +#define F_CDATAOUT V_CDATAOUT(1U) + +#define S_CREADPDU 14 +#define V_CREADPDU(x) ((x) << S_CREADPDU) +#define F_CREADPDU V_CREADPDU(1U) + +#define S_EDATAOUT 13 +#define V_EDATAOUT(x) ((x) << S_EDATAOUT) +#define F_EDATAOUT V_EDATAOUT(1U) + +#define S_EREADPDU 12 +#define V_EREADPDU(x) ((x) << S_EREADPDU) +#define F_EREADPDU V_EREADPDU(1U) + +#define S_ETCPOPSRDY 11 +#define V_ETCPOPSRDY(x) ((x) << S_ETCPOPSRDY) +#define F_ETCPOPSRDY V_ETCPOPSRDY(1U) + +#define S_CTCPOPSRDY 10 +#define V_CTCPOPSRDY(x) ((x) << S_CTCPOPSRDY) +#define F_CTCPOPSRDY V_CTCPOPSRDY(1U) + +#define S_CPKTOUT 9 +#define V_CPKTOUT(x) ((x) << S_CPKTOUT) +#define F_CPKTOUT V_CPKTOUT(1U) + +#define S_CMDBRSPSRDY 8 +#define V_CMDBRSPSRDY(x) ((x) << S_CMDBRSPSRDY) +#define F_CMDBRSPSRDY V_CMDBRSPSRDY(1U) + +#define S_RXPSTRUCTSFULL 6 +#define M_RXPSTRUCTSFULL 0x3U +#define V_RXPSTRUCTSFULL(x) ((x) << S_RXPSTRUCTSFULL) +#define G_RXPSTRUCTSFULL(x) (((x) >> S_RXPSTRUCTSFULL) & M_RXPSTRUCTSFULL) + +#define S_RXPAGEPOOLFULL 4 +#define M_RXPAGEPOOLFULL 0x3U +#define V_RXPAGEPOOLFULL(x) ((x) << S_RXPAGEPOOLFULL) +#define G_RXPAGEPOOLFULL(x) (((x) >> S_RXPAGEPOOLFULL) & M_RXPAGEPOOLFULL) + +#define S_RCFREASONOUT 0 +#define M_RCFREASONOUT 0xfU +#define V_RCFREASONOUT(x) ((x) << S_RCFREASONOUT) +#define G_RCFREASONOUT(x) (((x) >> S_RCFREASONOUT) & M_RCFREASONOUT) + +#define A_TP_DBG_CORE_PCMD 0x69 + +#define S_CPCMDEOPCNT 30 +#define M_CPCMDEOPCNT 0x3U +#define V_CPCMDEOPCNT(x) ((x) << S_CPCMDEOPCNT) +#define G_CPCMDEOPCNT(x) (((x) >> S_CPCMDEOPCNT) & M_CPCMDEOPCNT) + +#define S_CPCMDLENSAVE 16 +#define M_CPCMDLENSAVE 0x3fffU +#define V_CPCMDLENSAVE(x) ((x) << S_CPCMDLENSAVE) +#define G_CPCMDLENSAVE(x) (((x) >> S_CPCMDLENSAVE) & M_CPCMDLENSAVE) + +#define S_EPCMDEOPCNT 14 +#define M_EPCMDEOPCNT 0x3U +#define V_EPCMDEOPCNT(x) ((x) << S_EPCMDEOPCNT) +#define G_EPCMDEOPCNT(x) (((x) >> S_EPCMDEOPCNT) & M_EPCMDEOPCNT) + +#define S_EPCMDLENSAVE 0 +#define M_EPCMDLENSAVE 0x3fffU +#define V_EPCMDLENSAVE(x) ((x) << S_EPCMDLENSAVE) +#define G_EPCMDLENSAVE(x) (((x) >> S_EPCMDLENSAVE) & M_EPCMDLENSAVE) + +#define A_TP_DBG_SCHED_TX 0x6a + +#define S_TXCHNXOFF 28 +#define M_TXCHNXOFF 0xfU +#define V_TXCHNXOFF(x) ((x) << S_TXCHNXOFF) +#define G_TXCHNXOFF(x) (((x) >> S_TXCHNXOFF) & M_TXCHNXOFF) + +#define S_TXFIFOCNG 24 +#define M_TXFIFOCNG 0xfU +#define V_TXFIFOCNG(x) ((x) << S_TXFIFOCNG) +#define G_TXFIFOCNG(x) (((x) >> S_TXFIFOCNG) & M_TXFIFOCNG) + +#define S_TXPCMDCNG 20 +#define M_TXPCMDCNG 0xfU +#define V_TXPCMDCNG(x) ((x) << S_TXPCMDCNG) +#define G_TXPCMDCNG(x) (((x) >> S_TXPCMDCNG) & M_TXPCMDCNG) + +#define S_TXLPBKCNG 16 +#define M_TXLPBKCNG 0xfU +#define V_TXLPBKCNG(x) ((x) << S_TXLPBKCNG) +#define G_TXLPBKCNG(x) (((x) >> S_TXLPBKCNG) & M_TXLPBKCNG) + +#define S_TXHDRCNG 8 +#define M_TXHDRCNG 0xffU +#define V_TXHDRCNG(x) ((x) << S_TXHDRCNG) +#define G_TXHDRCNG(x) (((x) >> S_TXHDRCNG) & M_TXHDRCNG) + +#define S_TXMODXOFF 0 +#define M_TXMODXOFF 0xffU +#define V_TXMODXOFF(x) ((x) << S_TXMODXOFF) +#define G_TXMODXOFF(x) (((x) >> S_TXMODXOFF) & M_TXMODXOFF) + +#define A_TP_DBG_SCHED_RX 0x6b + +#define S_RXCHNXOFF 28 +#define M_RXCHNXOFF 0xfU +#define V_RXCHNXOFF(x) ((x) << S_RXCHNXOFF) +#define G_RXCHNXOFF(x) (((x) >> S_RXCHNXOFF) & M_RXCHNXOFF) + +#define S_RXSGECNG 24 +#define M_RXSGECNG 0xfU +#define V_RXSGECNG(x) ((x) << S_RXSGECNG) +#define G_RXSGECNG(x) (((x) >> S_RXSGECNG) & M_RXSGECNG) + +#define S_RXFIFOCNG 22 +#define M_RXFIFOCNG 0x3U +#define V_RXFIFOCNG(x) ((x) << S_RXFIFOCNG) +#define G_RXFIFOCNG(x) (((x) >> S_RXFIFOCNG) & M_RXFIFOCNG) + +#define S_RXPCMDCNG 20 +#define M_RXPCMDCNG 0x3U +#define V_RXPCMDCNG(x) ((x) << S_RXPCMDCNG) +#define G_RXPCMDCNG(x) (((x) >> S_RXPCMDCNG) & M_RXPCMDCNG) + +#define S_RXLPBKCNG 16 +#define M_RXLPBKCNG 0xfU +#define V_RXLPBKCNG(x) ((x) << S_RXLPBKCNG) +#define G_RXLPBKCNG(x) (((x) >> S_RXLPBKCNG) & M_RXLPBKCNG) + +#define S_RXHDRCNG 8 +#define M_RXHDRCNG 0xfU +#define V_RXHDRCNG(x) ((x) << S_RXHDRCNG) +#define G_RXHDRCNG(x) (((x) >> S_RXHDRCNG) & M_RXHDRCNG) + +#define S_RXMODXOFF 0 +#define M_RXMODXOFF 0x3U +#define V_RXMODXOFF(x) ((x) << S_RXMODXOFF) +#define G_RXMODXOFF(x) (((x) >> S_RXMODXOFF) & M_RXMODXOFF) + +#define A_TP_DBG_ERROR_CNT 0x6c +#define A_TP_MIB_DEBUG 0x6f + +#define S_SRC3 31 +#define V_SRC3(x) ((x) << S_SRC3) +#define F_SRC3 V_SRC3(1U) + +#define S_LINENUM3 24 +#define M_LINENUM3 0x7fU +#define V_LINENUM3(x) ((x) << S_LINENUM3) +#define G_LINENUM3(x) (((x) >> S_LINENUM3) & M_LINENUM3) + +#define S_SRC2 23 +#define V_SRC2(x) ((x) << S_SRC2) +#define F_SRC2 V_SRC2(1U) + +#define S_LINENUM2 16 +#define M_LINENUM2 0x7fU +#define V_LINENUM2(x) ((x) << S_LINENUM2) +#define G_LINENUM2(x) (((x) >> S_LINENUM2) & M_LINENUM2) + +#define S_SRC1 15 +#define V_SRC1(x) ((x) << S_SRC1) +#define F_SRC1 V_SRC1(1U) + +#define S_LINENUM1 8 +#define M_LINENUM1 0x7fU +#define V_LINENUM1(x) ((x) << S_LINENUM1) +#define G_LINENUM1(x) (((x) >> S_LINENUM1) & M_LINENUM1) + +#define S_SRC0 7 +#define V_SRC0(x) ((x) << S_SRC0) +#define F_SRC0 V_SRC0(1U) + +#define S_LINENUM0 0 +#define M_LINENUM0 0x7fU +#define V_LINENUM0(x) ((x) << S_LINENUM0) +#define G_LINENUM0(x) (((x) >> S_LINENUM0) & M_LINENUM0) + +#define A_TP_T5_TX_DROP_CNT_CH0 0x120 +#define A_TP_T5_TX_DROP_CNT_CH1 0x121 +#define A_TP_TX_DROP_CNT_CH2 0x122 +#define A_TP_TX_DROP_CNT_CH3 0x123 +#define A_TP_TX_DROP_CFG_CH0 0x12b + +#define S_TIMERENABLED 31 +#define V_TIMERENABLED(x) ((x) << S_TIMERENABLED) +#define F_TIMERENABLED V_TIMERENABLED(1U) + +#define S_TIMERERRORENABLE 30 +#define V_TIMERERRORENABLE(x) ((x) << S_TIMERERRORENABLE) +#define F_TIMERERRORENABLE V_TIMERERRORENABLE(1U) + +#define S_TIMERTHRESHOLD 4 +#define M_TIMERTHRESHOLD 0x3ffffffU +#define V_TIMERTHRESHOLD(x) ((x) << S_TIMERTHRESHOLD) +#define G_TIMERTHRESHOLD(x) (((x) >> S_TIMERTHRESHOLD) & M_TIMERTHRESHOLD) + +#define S_PACKETDROPS 0 +#define M_PACKETDROPS 0xfU +#define V_PACKETDROPS(x) ((x) << S_PACKETDROPS) +#define G_PACKETDROPS(x) (((x) >> S_PACKETDROPS) & M_PACKETDROPS) + +#define A_TP_TX_DROP_CFG_CH1 0x12c +#define A_TP_TX_DROP_CNT_CH0 0x12d + +#define S_TXDROPCNTCH0SENT 16 +#define M_TXDROPCNTCH0SENT 0xffffU +#define V_TXDROPCNTCH0SENT(x) ((x) << S_TXDROPCNTCH0SENT) +#define G_TXDROPCNTCH0SENT(x) (((x) >> S_TXDROPCNTCH0SENT) & M_TXDROPCNTCH0SENT) + +#define S_TXDROPCNTCH0RCVD 0 +#define M_TXDROPCNTCH0RCVD 0xffffU +#define V_TXDROPCNTCH0RCVD(x) ((x) << S_TXDROPCNTCH0RCVD) +#define G_TXDROPCNTCH0RCVD(x) (((x) >> S_TXDROPCNTCH0RCVD) & M_TXDROPCNTCH0RCVD) + +#define A_TP_TX_DROP_CNT_CH1 0x12e + +#define S_TXDROPCNTCH1SENT 16 +#define M_TXDROPCNTCH1SENT 0xffffU +#define V_TXDROPCNTCH1SENT(x) ((x) << S_TXDROPCNTCH1SENT) +#define G_TXDROPCNTCH1SENT(x) (((x) >> S_TXDROPCNTCH1SENT) & M_TXDROPCNTCH1SENT) + +#define S_TXDROPCNTCH1RCVD 0 +#define M_TXDROPCNTCH1RCVD 0xffffU +#define V_TXDROPCNTCH1RCVD(x) ((x) << S_TXDROPCNTCH1RCVD) +#define G_TXDROPCNTCH1RCVD(x) (((x) >> S_TXDROPCNTCH1RCVD) & M_TXDROPCNTCH1RCVD) + +#define A_TP_TX_DROP_MODE 0x12f + +#define S_TXDROPMODECH3 3 +#define V_TXDROPMODECH3(x) ((x) << S_TXDROPMODECH3) +#define F_TXDROPMODECH3 V_TXDROPMODECH3(1U) + +#define S_TXDROPMODECH2 2 +#define V_TXDROPMODECH2(x) ((x) << S_TXDROPMODECH2) +#define F_TXDROPMODECH2 V_TXDROPMODECH2(1U) + +#define S_TXDROPMODECH1 1 +#define V_TXDROPMODECH1(x) ((x) << S_TXDROPMODECH1) +#define F_TXDROPMODECH1 V_TXDROPMODECH1(1U) + +#define S_TXDROPMODECH0 0 +#define V_TXDROPMODECH0(x) ((x) << S_TXDROPMODECH0) +#define F_TXDROPMODECH0 V_TXDROPMODECH0(1U) + +#define A_TP_DBG_ESIDE_PKT0 0x130 + +#define S_ETXSOPCNT 28 +#define M_ETXSOPCNT 0xfU +#define V_ETXSOPCNT(x) ((x) << S_ETXSOPCNT) +#define G_ETXSOPCNT(x) (((x) >> S_ETXSOPCNT) & M_ETXSOPCNT) + +#define S_ETXEOPCNT 24 +#define M_ETXEOPCNT 0xfU +#define V_ETXEOPCNT(x) ((x) << S_ETXEOPCNT) +#define G_ETXEOPCNT(x) (((x) >> S_ETXEOPCNT) & M_ETXEOPCNT) + +#define S_ETXPLDSOPCNT 20 +#define M_ETXPLDSOPCNT 0xfU +#define V_ETXPLDSOPCNT(x) ((x) << S_ETXPLDSOPCNT) +#define G_ETXPLDSOPCNT(x) (((x) >> S_ETXPLDSOPCNT) & M_ETXPLDSOPCNT) + +#define S_ETXPLDEOPCNT 16 +#define M_ETXPLDEOPCNT 0xfU +#define V_ETXPLDEOPCNT(x) ((x) << S_ETXPLDEOPCNT) +#define G_ETXPLDEOPCNT(x) (((x) >> S_ETXPLDEOPCNT) & M_ETXPLDEOPCNT) + +#define S_ERXSOPCNT 12 +#define M_ERXSOPCNT 0xfU +#define V_ERXSOPCNT(x) ((x) << S_ERXSOPCNT) +#define G_ERXSOPCNT(x) (((x) >> S_ERXSOPCNT) & M_ERXSOPCNT) + +#define S_ERXEOPCNT 8 +#define M_ERXEOPCNT 0xfU +#define V_ERXEOPCNT(x) ((x) << S_ERXEOPCNT) +#define G_ERXEOPCNT(x) (((x) >> S_ERXEOPCNT) & M_ERXEOPCNT) + +#define S_ERXPLDSOPCNT 4 +#define M_ERXPLDSOPCNT 0xfU +#define V_ERXPLDSOPCNT(x) ((x) << S_ERXPLDSOPCNT) +#define G_ERXPLDSOPCNT(x) (((x) >> S_ERXPLDSOPCNT) & M_ERXPLDSOPCNT) + +#define S_ERXPLDEOPCNT 0 +#define M_ERXPLDEOPCNT 0xfU +#define V_ERXPLDEOPCNT(x) ((x) << S_ERXPLDEOPCNT) +#define G_ERXPLDEOPCNT(x) (((x) >> S_ERXPLDEOPCNT) & M_ERXPLDEOPCNT) + +#define A_TP_DBG_ESIDE_PKT1 0x131 +#define A_TP_DBG_ESIDE_PKT2 0x132 +#define A_TP_DBG_ESIDE_PKT3 0x133 +#define A_TP_DBG_ESIDE_FIFO0 0x134 + +#define S_PLDRXCSUMVALID1 31 +#define V_PLDRXCSUMVALID1(x) ((x) << S_PLDRXCSUMVALID1) +#define F_PLDRXCSUMVALID1 V_PLDRXCSUMVALID1(1U) + +#define S_PLDRXZEROPSRDY1 30 +#define V_PLDRXZEROPSRDY1(x) ((x) << S_PLDRXZEROPSRDY1) +#define F_PLDRXZEROPSRDY1 V_PLDRXZEROPSRDY1(1U) + +#define S_PLDRXVALID1 29 +#define V_PLDRXVALID1(x) ((x) << S_PLDRXVALID1) +#define F_PLDRXVALID1 V_PLDRXVALID1(1U) + +#define S_TCPRXVALID1 28 +#define V_TCPRXVALID1(x) ((x) << S_TCPRXVALID1) +#define F_TCPRXVALID1 V_TCPRXVALID1(1U) + +#define S_IPRXVALID1 27 +#define V_IPRXVALID1(x) ((x) << S_IPRXVALID1) +#define F_IPRXVALID1 V_IPRXVALID1(1U) + +#define S_ETHRXVALID1 26 +#define V_ETHRXVALID1(x) ((x) << S_ETHRXVALID1) +#define F_ETHRXVALID1 V_ETHRXVALID1(1U) + +#define S_CPLRXVALID1 25 +#define V_CPLRXVALID1(x) ((x) << S_CPLRXVALID1) +#define F_CPLRXVALID1 V_CPLRXVALID1(1U) + +#define S_FSTATIC1 24 +#define V_FSTATIC1(x) ((x) << S_FSTATIC1) +#define F_FSTATIC1 V_FSTATIC1(1U) + +#define S_ERRORSRDY1 23 +#define V_ERRORSRDY1(x) ((x) << S_ERRORSRDY1) +#define F_ERRORSRDY1 V_ERRORSRDY1(1U) + +#define S_PLDTXSRDY1 22 +#define V_PLDTXSRDY1(x) ((x) << S_PLDTXSRDY1) +#define F_PLDTXSRDY1 V_PLDTXSRDY1(1U) + +#define S_DBVLD1 21 +#define V_DBVLD1(x) ((x) << S_DBVLD1) +#define F_DBVLD1 V_DBVLD1(1U) + +#define S_PLDTXVALID1 20 +#define V_PLDTXVALID1(x) ((x) << S_PLDTXVALID1) +#define F_PLDTXVALID1 V_PLDTXVALID1(1U) + +#define S_ETXVALID1 19 +#define V_ETXVALID1(x) ((x) << S_ETXVALID1) +#define F_ETXVALID1 V_ETXVALID1(1U) + +#define S_ETXFULL1 18 +#define V_ETXFULL1(x) ((x) << S_ETXFULL1) +#define F_ETXFULL1 V_ETXFULL1(1U) + +#define S_ERXVALID1 17 +#define V_ERXVALID1(x) ((x) << S_ERXVALID1) +#define F_ERXVALID1 V_ERXVALID1(1U) + +#define S_ERXFULL1 16 +#define V_ERXFULL1(x) ((x) << S_ERXFULL1) +#define F_ERXFULL1 V_ERXFULL1(1U) + +#define S_PLDRXCSUMVALID0 15 +#define V_PLDRXCSUMVALID0(x) ((x) << S_PLDRXCSUMVALID0) +#define F_PLDRXCSUMVALID0 V_PLDRXCSUMVALID0(1U) + +#define S_PLDRXZEROPSRDY0 14 +#define V_PLDRXZEROPSRDY0(x) ((x) << S_PLDRXZEROPSRDY0) +#define F_PLDRXZEROPSRDY0 V_PLDRXZEROPSRDY0(1U) + +#define S_PLDRXVALID0 13 +#define V_PLDRXVALID0(x) ((x) << S_PLDRXVALID0) +#define F_PLDRXVALID0 V_PLDRXVALID0(1U) + +#define S_TCPRXVALID0 12 +#define V_TCPRXVALID0(x) ((x) << S_TCPRXVALID0) +#define F_TCPRXVALID0 V_TCPRXVALID0(1U) + +#define S_IPRXVALID0 11 +#define V_IPRXVALID0(x) ((x) << S_IPRXVALID0) +#define F_IPRXVALID0 V_IPRXVALID0(1U) + +#define S_ETHRXVALID0 10 +#define V_ETHRXVALID0(x) ((x) << S_ETHRXVALID0) +#define F_ETHRXVALID0 V_ETHRXVALID0(1U) + +#define S_CPLRXVALID0 9 +#define V_CPLRXVALID0(x) ((x) << S_CPLRXVALID0) +#define F_CPLRXVALID0 V_CPLRXVALID0(1U) + +#define S_FSTATIC0 8 +#define V_FSTATIC0(x) ((x) << S_FSTATIC0) +#define F_FSTATIC0 V_FSTATIC0(1U) + +#define S_ERRORSRDY0 7 +#define V_ERRORSRDY0(x) ((x) << S_ERRORSRDY0) +#define F_ERRORSRDY0 V_ERRORSRDY0(1U) + +#define S_PLDTXSRDY0 6 +#define V_PLDTXSRDY0(x) ((x) << S_PLDTXSRDY0) +#define F_PLDTXSRDY0 V_PLDTXSRDY0(1U) + +#define S_DBVLD0 5 +#define V_DBVLD0(x) ((x) << S_DBVLD0) +#define F_DBVLD0 V_DBVLD0(1U) + +#define S_PLDTXVALID0 4 +#define V_PLDTXVALID0(x) ((x) << S_PLDTXVALID0) +#define F_PLDTXVALID0 V_PLDTXVALID0(1U) + +#define S_ETXVALID0 3 +#define V_ETXVALID0(x) ((x) << S_ETXVALID0) +#define F_ETXVALID0 V_ETXVALID0(1U) + +#define S_ETXFULL0 2 +#define V_ETXFULL0(x) ((x) << S_ETXFULL0) +#define F_ETXFULL0 V_ETXFULL0(1U) + +#define S_ERXVALID0 1 +#define V_ERXVALID0(x) ((x) << S_ERXVALID0) +#define F_ERXVALID0 V_ERXVALID0(1U) + +#define S_ERXFULL0 0 +#define V_ERXFULL0(x) ((x) << S_ERXFULL0) +#define F_ERXFULL0 V_ERXFULL0(1U) + +#define A_TP_DBG_ESIDE_FIFO1 0x135 + +#define S_PLDRXCSUMVALID3 31 +#define V_PLDRXCSUMVALID3(x) ((x) << S_PLDRXCSUMVALID3) +#define F_PLDRXCSUMVALID3 V_PLDRXCSUMVALID3(1U) + +#define S_PLDRXZEROPSRDY3 30 +#define V_PLDRXZEROPSRDY3(x) ((x) << S_PLDRXZEROPSRDY3) +#define F_PLDRXZEROPSRDY3 V_PLDRXZEROPSRDY3(1U) + +#define S_PLDRXVALID3 29 +#define V_PLDRXVALID3(x) ((x) << S_PLDRXVALID3) +#define F_PLDRXVALID3 V_PLDRXVALID3(1U) + +#define S_TCPRXVALID3 28 +#define V_TCPRXVALID3(x) ((x) << S_TCPRXVALID3) +#define F_TCPRXVALID3 V_TCPRXVALID3(1U) + +#define S_IPRXVALID3 27 +#define V_IPRXVALID3(x) ((x) << S_IPRXVALID3) +#define F_IPRXVALID3 V_IPRXVALID3(1U) + +#define S_ETHRXVALID3 26 +#define V_ETHRXVALID3(x) ((x) << S_ETHRXVALID3) +#define F_ETHRXVALID3 V_ETHRXVALID3(1U) + +#define S_CPLRXVALID3 25 +#define V_CPLRXVALID3(x) ((x) << S_CPLRXVALID3) +#define F_CPLRXVALID3 V_CPLRXVALID3(1U) + +#define S_FSTATIC3 24 +#define V_FSTATIC3(x) ((x) << S_FSTATIC3) +#define F_FSTATIC3 V_FSTATIC3(1U) + +#define S_ERRORSRDY3 23 +#define V_ERRORSRDY3(x) ((x) << S_ERRORSRDY3) +#define F_ERRORSRDY3 V_ERRORSRDY3(1U) + +#define S_PLDTXSRDY3 22 +#define V_PLDTXSRDY3(x) ((x) << S_PLDTXSRDY3) +#define F_PLDTXSRDY3 V_PLDTXSRDY3(1U) + +#define S_DBVLD3 21 +#define V_DBVLD3(x) ((x) << S_DBVLD3) +#define F_DBVLD3 V_DBVLD3(1U) + +#define S_PLDTXVALID3 20 +#define V_PLDTXVALID3(x) ((x) << S_PLDTXVALID3) +#define F_PLDTXVALID3 V_PLDTXVALID3(1U) + +#define S_ETXVALID3 19 +#define V_ETXVALID3(x) ((x) << S_ETXVALID3) +#define F_ETXVALID3 V_ETXVALID3(1U) + +#define S_ETXFULL3 18 +#define V_ETXFULL3(x) ((x) << S_ETXFULL3) +#define F_ETXFULL3 V_ETXFULL3(1U) + +#define S_ERXVALID3 17 +#define V_ERXVALID3(x) ((x) << S_ERXVALID3) +#define F_ERXVALID3 V_ERXVALID3(1U) + +#define S_ERXFULL3 16 +#define V_ERXFULL3(x) ((x) << S_ERXFULL3) +#define F_ERXFULL3 V_ERXFULL3(1U) + +#define S_PLDRXCSUMVALID2 15 +#define V_PLDRXCSUMVALID2(x) ((x) << S_PLDRXCSUMVALID2) +#define F_PLDRXCSUMVALID2 V_PLDRXCSUMVALID2(1U) + +#define S_PLDRXZEROPSRDY2 14 +#define V_PLDRXZEROPSRDY2(x) ((x) << S_PLDRXZEROPSRDY2) +#define F_PLDRXZEROPSRDY2 V_PLDRXZEROPSRDY2(1U) + +#define S_PLDRXVALID2 13 +#define V_PLDRXVALID2(x) ((x) << S_PLDRXVALID2) +#define F_PLDRXVALID2 V_PLDRXVALID2(1U) + +#define S_TCPRXVALID2 12 +#define V_TCPRXVALID2(x) ((x) << S_TCPRXVALID2) +#define F_TCPRXVALID2 V_TCPRXVALID2(1U) + +#define S_IPRXVALID2 11 +#define V_IPRXVALID2(x) ((x) << S_IPRXVALID2) +#define F_IPRXVALID2 V_IPRXVALID2(1U) + +#define S_ETHRXVALID2 10 +#define V_ETHRXVALID2(x) ((x) << S_ETHRXVALID2) +#define F_ETHRXVALID2 V_ETHRXVALID2(1U) + +#define S_CPLRXVALID2 9 +#define V_CPLRXVALID2(x) ((x) << S_CPLRXVALID2) +#define F_CPLRXVALID2 V_CPLRXVALID2(1U) + +#define S_FSTATIC2 8 +#define V_FSTATIC2(x) ((x) << S_FSTATIC2) +#define F_FSTATIC2 V_FSTATIC2(1U) + +#define S_ERRORSRDY2 7 +#define V_ERRORSRDY2(x) ((x) << S_ERRORSRDY2) +#define F_ERRORSRDY2 V_ERRORSRDY2(1U) + +#define S_PLDTXSRDY2 6 +#define V_PLDTXSRDY2(x) ((x) << S_PLDTXSRDY2) +#define F_PLDTXSRDY2 V_PLDTXSRDY2(1U) + +#define S_DBVLD2 5 +#define V_DBVLD2(x) ((x) << S_DBVLD2) +#define F_DBVLD2 V_DBVLD2(1U) + +#define S_PLDTXVALID2 4 +#define V_PLDTXVALID2(x) ((x) << S_PLDTXVALID2) +#define F_PLDTXVALID2 V_PLDTXVALID2(1U) + +#define S_ETXVALID2 3 +#define V_ETXVALID2(x) ((x) << S_ETXVALID2) +#define F_ETXVALID2 V_ETXVALID2(1U) + +#define S_ETXFULL2 2 +#define V_ETXFULL2(x) ((x) << S_ETXFULL2) +#define F_ETXFULL2 V_ETXFULL2(1U) + +#define S_ERXVALID2 1 +#define V_ERXVALID2(x) ((x) << S_ERXVALID2) +#define F_ERXVALID2 V_ERXVALID2(1U) + +#define S_ERXFULL2 0 +#define V_ERXFULL2(x) ((x) << S_ERXFULL2) +#define F_ERXFULL2 V_ERXFULL2(1U) + +#define A_TP_DBG_ESIDE_DISP0 0x136 + +#define S_RESRDY 31 +#define V_RESRDY(x) ((x) << S_RESRDY) +#define F_RESRDY V_RESRDY(1U) + +#define S_STATE 28 +#define M_STATE 0x7U +#define V_STATE(x) ((x) << S_STATE) +#define G_STATE(x) (((x) >> S_STATE) & M_STATE) + +#define S_FIFOCPL5RXVALID 27 +#define V_FIFOCPL5RXVALID(x) ((x) << S_FIFOCPL5RXVALID) +#define F_FIFOCPL5RXVALID V_FIFOCPL5RXVALID(1U) + +#define S_FIFOETHRXVALID 26 +#define V_FIFOETHRXVALID(x) ((x) << S_FIFOETHRXVALID) +#define F_FIFOETHRXVALID V_FIFOETHRXVALID(1U) + +#define S_FIFOETHRXSOCP 25 +#define V_FIFOETHRXSOCP(x) ((x) << S_FIFOETHRXSOCP) +#define F_FIFOETHRXSOCP V_FIFOETHRXSOCP(1U) + +#define S_FIFOPLDRXZEROP 24 +#define V_FIFOPLDRXZEROP(x) ((x) << S_FIFOPLDRXZEROP) +#define F_FIFOPLDRXZEROP V_FIFOPLDRXZEROP(1U) + +#define S_PLDRXVALID 23 +#define V_PLDRXVALID(x) ((x) << S_PLDRXVALID) +#define F_PLDRXVALID V_PLDRXVALID(1U) + +#define S_FIFOPLDRXZEROP_SRDY 22 +#define V_FIFOPLDRXZEROP_SRDY(x) ((x) << S_FIFOPLDRXZEROP_SRDY) +#define F_FIFOPLDRXZEROP_SRDY V_FIFOPLDRXZEROP_SRDY(1U) + +#define S_FIFOIPRXVALID 21 +#define V_FIFOIPRXVALID(x) ((x) << S_FIFOIPRXVALID) +#define F_FIFOIPRXVALID V_FIFOIPRXVALID(1U) + +#define S_FIFOTCPRXVALID 20 +#define V_FIFOTCPRXVALID(x) ((x) << S_FIFOTCPRXVALID) +#define F_FIFOTCPRXVALID V_FIFOTCPRXVALID(1U) + +#define S_PLDRXCSUMVALID 19 +#define V_PLDRXCSUMVALID(x) ((x) << S_PLDRXCSUMVALID) +#define F_PLDRXCSUMVALID V_PLDRXCSUMVALID(1U) + +#define S_FIFOIPCSUMSRDY 18 +#define V_FIFOIPCSUMSRDY(x) ((x) << S_FIFOIPCSUMSRDY) +#define F_FIFOIPCSUMSRDY V_FIFOIPCSUMSRDY(1U) + +#define S_FIFOIPPSEUDOCSUMSRDY 17 +#define V_FIFOIPPSEUDOCSUMSRDY(x) ((x) << S_FIFOIPPSEUDOCSUMSRDY) +#define F_FIFOIPPSEUDOCSUMSRDY V_FIFOIPPSEUDOCSUMSRDY(1U) + +#define S_FIFOTCPCSUMSRDY 16 +#define V_FIFOTCPCSUMSRDY(x) ((x) << S_FIFOTCPCSUMSRDY) +#define F_FIFOTCPCSUMSRDY V_FIFOTCPCSUMSRDY(1U) + +#define S_ESTATIC4 12 +#define M_ESTATIC4 0xfU +#define V_ESTATIC4(x) ((x) << S_ESTATIC4) +#define G_ESTATIC4(x) (((x) >> S_ESTATIC4) & M_ESTATIC4) + +#define S_FIFOCPLSOCPCNT 10 +#define M_FIFOCPLSOCPCNT 0x3U +#define V_FIFOCPLSOCPCNT(x) ((x) << S_FIFOCPLSOCPCNT) +#define G_FIFOCPLSOCPCNT(x) (((x) >> S_FIFOCPLSOCPCNT) & M_FIFOCPLSOCPCNT) + +#define S_FIFOETHSOCPCNT 8 +#define M_FIFOETHSOCPCNT 0x3U +#define V_FIFOETHSOCPCNT(x) ((x) << S_FIFOETHSOCPCNT) +#define G_FIFOETHSOCPCNT(x) (((x) >> S_FIFOETHSOCPCNT) & M_FIFOETHSOCPCNT) + +#define S_FIFOIPSOCPCNT 6 +#define M_FIFOIPSOCPCNT 0x3U +#define V_FIFOIPSOCPCNT(x) ((x) << S_FIFOIPSOCPCNT) +#define G_FIFOIPSOCPCNT(x) (((x) >> S_FIFOIPSOCPCNT) & M_FIFOIPSOCPCNT) + +#define S_FIFOTCPSOCPCNT 4 +#define M_FIFOTCPSOCPCNT 0x3U +#define V_FIFOTCPSOCPCNT(x) ((x) << S_FIFOTCPSOCPCNT) +#define G_FIFOTCPSOCPCNT(x) (((x) >> S_FIFOTCPSOCPCNT) & M_FIFOTCPSOCPCNT) + +#define S_PLD_RXZEROP_CNT 2 +#define M_PLD_RXZEROP_CNT 0x3U +#define V_PLD_RXZEROP_CNT(x) ((x) << S_PLD_RXZEROP_CNT) +#define G_PLD_RXZEROP_CNT(x) (((x) >> S_PLD_RXZEROP_CNT) & M_PLD_RXZEROP_CNT) + +#define S_ESTATIC6 1 +#define V_ESTATIC6(x) ((x) << S_ESTATIC6) +#define F_ESTATIC6 V_ESTATIC6(1U) + +#define S_TXFULL 0 +#define V_TXFULL(x) ((x) << S_TXFULL) +#define F_TXFULL V_TXFULL(1U) + +#define A_TP_DBG_ESIDE_DISP1 0x137 +#define A_TP_MAC_MATCH_MAP0 0x138 + +#define S_MAPVALUEWR 16 +#define M_MAPVALUEWR 0xffU +#define V_MAPVALUEWR(x) ((x) << S_MAPVALUEWR) +#define G_MAPVALUEWR(x) (((x) >> S_MAPVALUEWR) & M_MAPVALUEWR) + +#define S_MAPINDEX 2 +#define M_MAPINDEX 0x1ffU +#define V_MAPINDEX(x) ((x) << S_MAPINDEX) +#define G_MAPINDEX(x) (((x) >> S_MAPINDEX) & M_MAPINDEX) + +#define S_MAPREAD 1 +#define V_MAPREAD(x) ((x) << S_MAPREAD) +#define F_MAPREAD V_MAPREAD(1U) + +#define S_MAPWRITE 0 +#define V_MAPWRITE(x) ((x) << S_MAPWRITE) +#define F_MAPWRITE V_MAPWRITE(1U) + +#define A_TP_MAC_MATCH_MAP1 0x139 + +#define S_MAPVALUERD 0 +#define M_MAPVALUERD 0x1ffU +#define V_MAPVALUERD(x) ((x) << S_MAPVALUERD) +#define G_MAPVALUERD(x) (((x) >> S_MAPVALUERD) & M_MAPVALUERD) + +#define A_TP_DBG_ESIDE_DISP2 0x13a +#define A_TP_DBG_ESIDE_DISP3 0x13b +#define A_TP_DBG_ESIDE_HDR0 0x13c + +#define S_TCPSOPCNT 28 +#define M_TCPSOPCNT 0xfU +#define V_TCPSOPCNT(x) ((x) << S_TCPSOPCNT) +#define G_TCPSOPCNT(x) (((x) >> S_TCPSOPCNT) & M_TCPSOPCNT) + +#define S_TCPEOPCNT 24 +#define M_TCPEOPCNT 0xfU +#define V_TCPEOPCNT(x) ((x) << S_TCPEOPCNT) +#define G_TCPEOPCNT(x) (((x) >> S_TCPEOPCNT) & M_TCPEOPCNT) + +#define S_IPSOPCNT 20 +#define M_IPSOPCNT 0xfU +#define V_IPSOPCNT(x) ((x) << S_IPSOPCNT) +#define G_IPSOPCNT(x) (((x) >> S_IPSOPCNT) & M_IPSOPCNT) + +#define S_IPEOPCNT 16 +#define M_IPEOPCNT 0xfU +#define V_IPEOPCNT(x) ((x) << S_IPEOPCNT) +#define G_IPEOPCNT(x) (((x) >> S_IPEOPCNT) & M_IPEOPCNT) + +#define S_ETHSOPCNT 12 +#define M_ETHSOPCNT 0xfU +#define V_ETHSOPCNT(x) ((x) << S_ETHSOPCNT) +#define G_ETHSOPCNT(x) (((x) >> S_ETHSOPCNT) & M_ETHSOPCNT) + +#define S_ETHEOPCNT 8 +#define M_ETHEOPCNT 0xfU +#define V_ETHEOPCNT(x) ((x) << S_ETHEOPCNT) +#define G_ETHEOPCNT(x) (((x) >> S_ETHEOPCNT) & M_ETHEOPCNT) + +#define S_CPLSOPCNT 4 +#define M_CPLSOPCNT 0xfU +#define V_CPLSOPCNT(x) ((x) << S_CPLSOPCNT) +#define G_CPLSOPCNT(x) (((x) >> S_CPLSOPCNT) & M_CPLSOPCNT) + +#define S_CPLEOPCNT 0 +#define M_CPLEOPCNT 0xfU +#define V_CPLEOPCNT(x) ((x) << S_CPLEOPCNT) +#define G_CPLEOPCNT(x) (((x) >> S_CPLEOPCNT) & M_CPLEOPCNT) + +#define A_TP_DBG_ESIDE_HDR1 0x13d +#define A_TP_DBG_ESIDE_HDR2 0x13e +#define A_TP_DBG_ESIDE_HDR3 0x13f +#define A_TP_VLAN_PRI_MAP 0x140 + +#define S_FRAGMENTATION 9 +#define V_FRAGMENTATION(x) ((x) << S_FRAGMENTATION) +#define F_FRAGMENTATION V_FRAGMENTATION(1U) + +#define S_MPSHITTYPE 8 +#define V_MPSHITTYPE(x) ((x) << S_MPSHITTYPE) +#define F_MPSHITTYPE V_MPSHITTYPE(1U) + +#define S_MACMATCH 7 +#define V_MACMATCH(x) ((x) << S_MACMATCH) +#define F_MACMATCH V_MACMATCH(1U) + +#define S_ETHERTYPE 6 +#define V_ETHERTYPE(x) ((x) << S_ETHERTYPE) +#define F_ETHERTYPE V_ETHERTYPE(1U) + +#define S_PROTOCOL 5 +#define V_PROTOCOL(x) ((x) << S_PROTOCOL) +#define F_PROTOCOL V_PROTOCOL(1U) + +#define S_TOS 4 +#define V_TOS(x) ((x) << S_TOS) +#define F_TOS V_TOS(1U) + +#define S_VLAN 3 +#define V_VLAN(x) ((x) << S_VLAN) +#define F_VLAN V_VLAN(1U) + +#define S_VNIC_ID 2 +#define V_VNIC_ID(x) ((x) << S_VNIC_ID) +#define F_VNIC_ID V_VNIC_ID(1U) + +#define S_PORT 1 +#define V_PORT(x) ((x) << S_PORT) +#define F_PORT V_PORT(1U) + +#define S_FCOE 0 +#define V_FCOE(x) ((x) << S_FCOE) +#define F_FCOE V_FCOE(1U) + +#define S_FILTERMODE 15 +#define V_FILTERMODE(x) ((x) << S_FILTERMODE) +#define F_FILTERMODE V_FILTERMODE(1U) + +#define S_FCOEMASK 14 +#define V_FCOEMASK(x) ((x) << S_FCOEMASK) +#define F_FCOEMASK V_FCOEMASK(1U) + +#define S_SRVRSRAM 13 +#define V_SRVRSRAM(x) ((x) << S_SRVRSRAM) +#define F_SRVRSRAM V_SRVRSRAM(1U) + +#define A_TP_INGRESS_CONFIG 0x141 + +#define S_OPAQUE_TYPE 16 +#define M_OPAQUE_TYPE 0xffffU +#define V_OPAQUE_TYPE(x) ((x) << S_OPAQUE_TYPE) +#define G_OPAQUE_TYPE(x) (((x) >> S_OPAQUE_TYPE) & M_OPAQUE_TYPE) + +#define S_OPAQUE_RM 15 +#define V_OPAQUE_RM(x) ((x) << S_OPAQUE_RM) +#define F_OPAQUE_RM V_OPAQUE_RM(1U) + +#define S_OPAQUE_HDR_SIZE 14 +#define V_OPAQUE_HDR_SIZE(x) ((x) << S_OPAQUE_HDR_SIZE) +#define F_OPAQUE_HDR_SIZE V_OPAQUE_HDR_SIZE(1U) + +#define S_OPAQUE_RM_MAC_IN_MAC 13 +#define V_OPAQUE_RM_MAC_IN_MAC(x) ((x) << S_OPAQUE_RM_MAC_IN_MAC) +#define F_OPAQUE_RM_MAC_IN_MAC V_OPAQUE_RM_MAC_IN_MAC(1U) + +#define S_FCOE_TARGET 12 +#define V_FCOE_TARGET(x) ((x) << S_FCOE_TARGET) +#define F_FCOE_TARGET V_FCOE_TARGET(1U) + +#define S_VNIC 11 +#define V_VNIC(x) ((x) << S_VNIC) +#define F_VNIC V_VNIC(1U) + +#define S_CSUM_HAS_PSEUDO_HDR 10 +#define V_CSUM_HAS_PSEUDO_HDR(x) ((x) << S_CSUM_HAS_PSEUDO_HDR) +#define F_CSUM_HAS_PSEUDO_HDR V_CSUM_HAS_PSEUDO_HDR(1U) + +#define S_RM_OVLAN 9 +#define V_RM_OVLAN(x) ((x) << S_RM_OVLAN) +#define F_RM_OVLAN V_RM_OVLAN(1U) + +#define S_LOOKUPEVERYPKT 8 +#define V_LOOKUPEVERYPKT(x) ((x) << S_LOOKUPEVERYPKT) +#define F_LOOKUPEVERYPKT V_LOOKUPEVERYPKT(1U) + +#define S_IPV6_EXT_HDR_SKIP 0 +#define M_IPV6_EXT_HDR_SKIP 0xffU +#define V_IPV6_EXT_HDR_SKIP(x) ((x) << S_IPV6_EXT_HDR_SKIP) +#define G_IPV6_EXT_HDR_SKIP(x) (((x) >> S_IPV6_EXT_HDR_SKIP) & M_IPV6_EXT_HDR_SKIP) + +#define S_FRAG_LEN_MOD8_COMPAT 12 +#define V_FRAG_LEN_MOD8_COMPAT(x) ((x) << S_FRAG_LEN_MOD8_COMPAT) +#define F_FRAG_LEN_MOD8_COMPAT V_FRAG_LEN_MOD8_COMPAT(1U) + +#define A_TP_TX_DROP_CFG_CH2 0x142 +#define A_TP_TX_DROP_CFG_CH3 0x143 +#define A_TP_EGRESS_CONFIG 0x145 + +#define S_REWRITEFORCETOSIZE 0 +#define V_REWRITEFORCETOSIZE(x) ((x) << S_REWRITEFORCETOSIZE) +#define F_REWRITEFORCETOSIZE V_REWRITEFORCETOSIZE(1U) + +#define A_TP_INGRESS_CONFIG2 0x145 + +#define S_IPV6_UDP_CSUM_COMPAT 31 +#define V_IPV6_UDP_CSUM_COMPAT(x) ((x) << S_IPV6_UDP_CSUM_COMPAT) +#define F_IPV6_UDP_CSUM_COMPAT V_IPV6_UDP_CSUM_COMPAT(1U) + +#define S_VNTAGPLDENABLE 30 +#define V_VNTAGPLDENABLE(x) ((x) << S_VNTAGPLDENABLE) +#define F_VNTAGPLDENABLE V_VNTAGPLDENABLE(1U) + +#define S_TCP_PLD_FILTER_OFFSET 20 +#define M_TCP_PLD_FILTER_OFFSET 0x3ffU +#define V_TCP_PLD_FILTER_OFFSET(x) ((x) << S_TCP_PLD_FILTER_OFFSET) +#define G_TCP_PLD_FILTER_OFFSET(x) (((x) >> S_TCP_PLD_FILTER_OFFSET) & M_TCP_PLD_FILTER_OFFSET) + +#define S_UDP_PLD_FILTER_OFFSET 10 +#define M_UDP_PLD_FILTER_OFFSET 0x3ffU +#define V_UDP_PLD_FILTER_OFFSET(x) ((x) << S_UDP_PLD_FILTER_OFFSET) +#define G_UDP_PLD_FILTER_OFFSET(x) (((x) >> S_UDP_PLD_FILTER_OFFSET) & M_UDP_PLD_FILTER_OFFSET) + +#define S_TNL_PLD_FILTER_OFFSET 0 +#define M_TNL_PLD_FILTER_OFFSET 0x3ffU +#define V_TNL_PLD_FILTER_OFFSET(x) ((x) << S_TNL_PLD_FILTER_OFFSET) +#define G_TNL_PLD_FILTER_OFFSET(x) (((x) >> S_TNL_PLD_FILTER_OFFSET) & M_TNL_PLD_FILTER_OFFSET) + +#define A_TP_EHDR_CONFIG_LO 0x146 + +#define S_CPLLIMIT 24 +#define M_CPLLIMIT 0xffU +#define V_CPLLIMIT(x) ((x) << S_CPLLIMIT) +#define G_CPLLIMIT(x) (((x) >> S_CPLLIMIT) & M_CPLLIMIT) + +#define S_ETHLIMIT 16 +#define M_ETHLIMIT 0xffU +#define V_ETHLIMIT(x) ((x) << S_ETHLIMIT) +#define G_ETHLIMIT(x) (((x) >> S_ETHLIMIT) & M_ETHLIMIT) + +#define S_IPLIMIT 8 +#define M_IPLIMIT 0xffU +#define V_IPLIMIT(x) ((x) << S_IPLIMIT) +#define G_IPLIMIT(x) (((x) >> S_IPLIMIT) & M_IPLIMIT) + +#define S_TCPLIMIT 0 +#define M_TCPLIMIT 0xffU +#define V_TCPLIMIT(x) ((x) << S_TCPLIMIT) +#define G_TCPLIMIT(x) (((x) >> S_TCPLIMIT) & M_TCPLIMIT) + +#define A_TP_EHDR_CONFIG_HI 0x147 +#define A_TP_DBG_ESIDE_INT 0x148 + +#define S_ERXSOP2X 28 +#define M_ERXSOP2X 0xfU +#define V_ERXSOP2X(x) ((x) << S_ERXSOP2X) +#define G_ERXSOP2X(x) (((x) >> S_ERXSOP2X) & M_ERXSOP2X) + +#define S_ERXEOP2X 24 +#define M_ERXEOP2X 0xfU +#define V_ERXEOP2X(x) ((x) << S_ERXEOP2X) +#define G_ERXEOP2X(x) (((x) >> S_ERXEOP2X) & M_ERXEOP2X) + +#define S_ERXVALID2X 20 +#define M_ERXVALID2X 0xfU +#define V_ERXVALID2X(x) ((x) << S_ERXVALID2X) +#define G_ERXVALID2X(x) (((x) >> S_ERXVALID2X) & M_ERXVALID2X) + +#define S_ERXAFULL2X 16 +#define M_ERXAFULL2X 0xfU +#define V_ERXAFULL2X(x) ((x) << S_ERXAFULL2X) +#define G_ERXAFULL2X(x) (((x) >> S_ERXAFULL2X) & M_ERXAFULL2X) + +#define S_PLD2XTXVALID 12 +#define M_PLD2XTXVALID 0xfU +#define V_PLD2XTXVALID(x) ((x) << S_PLD2XTXVALID) +#define G_PLD2XTXVALID(x) (((x) >> S_PLD2XTXVALID) & M_PLD2XTXVALID) + +#define S_PLD2XTXAFULL 8 +#define M_PLD2XTXAFULL 0xfU +#define V_PLD2XTXAFULL(x) ((x) << S_PLD2XTXAFULL) +#define G_PLD2XTXAFULL(x) (((x) >> S_PLD2XTXAFULL) & M_PLD2XTXAFULL) + +#define S_ERRORSRDY 7 +#define V_ERRORSRDY(x) ((x) << S_ERRORSRDY) +#define F_ERRORSRDY V_ERRORSRDY(1U) + +#define S_ERRORDRDY 6 +#define V_ERRORDRDY(x) ((x) << S_ERRORDRDY) +#define F_ERRORDRDY V_ERRORDRDY(1U) + +#define S_TCPOPSRDY 5 +#define V_TCPOPSRDY(x) ((x) << S_TCPOPSRDY) +#define F_TCPOPSRDY V_TCPOPSRDY(1U) + +#define S_TCPOPDRDY 4 +#define V_TCPOPDRDY(x) ((x) << S_TCPOPDRDY) +#define F_TCPOPDRDY V_TCPOPDRDY(1U) + +#define S_PLDTXSRDY 3 +#define V_PLDTXSRDY(x) ((x) << S_PLDTXSRDY) +#define F_PLDTXSRDY V_PLDTXSRDY(1U) + +#define S_PLDTXDRDY 2 +#define V_PLDTXDRDY(x) ((x) << S_PLDTXDRDY) +#define F_PLDTXDRDY V_PLDTXDRDY(1U) + +#define S_TCPOPTTXVALID 1 +#define V_TCPOPTTXVALID(x) ((x) << S_TCPOPTTXVALID) +#define F_TCPOPTTXVALID V_TCPOPTTXVALID(1U) + +#define S_TCPOPTTXFULL 0 +#define V_TCPOPTTXFULL(x) ((x) << S_TCPOPTTXFULL) +#define F_TCPOPTTXFULL V_TCPOPTTXFULL(1U) + +#define A_TP_DBG_ESIDE_DEMUX 0x149 + +#define S_EALLDONE 28 +#define M_EALLDONE 0xfU +#define V_EALLDONE(x) ((x) << S_EALLDONE) +#define G_EALLDONE(x) (((x) >> S_EALLDONE) & M_EALLDONE) + +#define S_EFIFOPLDDONE 24 +#define M_EFIFOPLDDONE 0xfU +#define V_EFIFOPLDDONE(x) ((x) << S_EFIFOPLDDONE) +#define G_EFIFOPLDDONE(x) (((x) >> S_EFIFOPLDDONE) & M_EFIFOPLDDONE) + +#define S_EDBDONE 20 +#define M_EDBDONE 0xfU +#define V_EDBDONE(x) ((x) << S_EDBDONE) +#define G_EDBDONE(x) (((x) >> S_EDBDONE) & M_EDBDONE) + +#define S_EISSFIFODONE 16 +#define M_EISSFIFODONE 0xfU +#define V_EISSFIFODONE(x) ((x) << S_EISSFIFODONE) +#define G_EISSFIFODONE(x) (((x) >> S_EISSFIFODONE) & M_EISSFIFODONE) + +#define S_EACKERRFIFODONE 12 +#define M_EACKERRFIFODONE 0xfU +#define V_EACKERRFIFODONE(x) ((x) << S_EACKERRFIFODONE) +#define G_EACKERRFIFODONE(x) (((x) >> S_EACKERRFIFODONE) & M_EACKERRFIFODONE) + +#define S_EFIFOERRORDONE 8 +#define M_EFIFOERRORDONE 0xfU +#define V_EFIFOERRORDONE(x) ((x) << S_EFIFOERRORDONE) +#define G_EFIFOERRORDONE(x) (((x) >> S_EFIFOERRORDONE) & M_EFIFOERRORDONE) + +#define S_ERXPKTATTRFIFOFDONE 4 +#define M_ERXPKTATTRFIFOFDONE 0xfU +#define V_ERXPKTATTRFIFOFDONE(x) ((x) << S_ERXPKTATTRFIFOFDONE) +#define G_ERXPKTATTRFIFOFDONE(x) (((x) >> S_ERXPKTATTRFIFOFDONE) & M_ERXPKTATTRFIFOFDONE) + +#define S_ETCPOPDONE 0 +#define M_ETCPOPDONE 0xfU +#define V_ETCPOPDONE(x) ((x) << S_ETCPOPDONE) +#define G_ETCPOPDONE(x) (((x) >> S_ETCPOPDONE) & M_ETCPOPDONE) + +#define A_TP_DBG_ESIDE_IN0 0x14a + +#define S_RXVALID 31 +#define V_RXVALID(x) ((x) << S_RXVALID) +#define F_RXVALID V_RXVALID(1U) + +#define S_RXFULL 30 +#define V_RXFULL(x) ((x) << S_RXFULL) +#define F_RXFULL V_RXFULL(1U) + +#define S_RXSOCP 29 +#define V_RXSOCP(x) ((x) << S_RXSOCP) +#define F_RXSOCP V_RXSOCP(1U) + +#define S_RXEOP 28 +#define V_RXEOP(x) ((x) << S_RXEOP) +#define F_RXEOP V_RXEOP(1U) + +#define S_RXVALID_I 27 +#define V_RXVALID_I(x) ((x) << S_RXVALID_I) +#define F_RXVALID_I V_RXVALID_I(1U) + +#define S_RXFULL_I 26 +#define V_RXFULL_I(x) ((x) << S_RXFULL_I) +#define F_RXFULL_I V_RXFULL_I(1U) + +#define S_RXSOCP_I 25 +#define V_RXSOCP_I(x) ((x) << S_RXSOCP_I) +#define F_RXSOCP_I V_RXSOCP_I(1U) + +#define S_RXEOP_I 24 +#define V_RXEOP_I(x) ((x) << S_RXEOP_I) +#define F_RXEOP_I V_RXEOP_I(1U) + +#define S_RXVALID_I2 23 +#define V_RXVALID_I2(x) ((x) << S_RXVALID_I2) +#define F_RXVALID_I2 V_RXVALID_I2(1U) + +#define S_RXFULL_I2 22 +#define V_RXFULL_I2(x) ((x) << S_RXFULL_I2) +#define F_RXFULL_I2 V_RXFULL_I2(1U) + +#define S_RXSOCP_I2 21 +#define V_RXSOCP_I2(x) ((x) << S_RXSOCP_I2) +#define F_RXSOCP_I2 V_RXSOCP_I2(1U) + +#define S_RXEOP_I2 20 +#define V_RXEOP_I2(x) ((x) << S_RXEOP_I2) +#define F_RXEOP_I2 V_RXEOP_I2(1U) + +#define S_CT_MPA_TXVALID_FIFO 19 +#define V_CT_MPA_TXVALID_FIFO(x) ((x) << S_CT_MPA_TXVALID_FIFO) +#define F_CT_MPA_TXVALID_FIFO V_CT_MPA_TXVALID_FIFO(1U) + +#define S_CT_MPA_TXFULL_FIFO 18 +#define V_CT_MPA_TXFULL_FIFO(x) ((x) << S_CT_MPA_TXFULL_FIFO) +#define F_CT_MPA_TXFULL_FIFO V_CT_MPA_TXFULL_FIFO(1U) + +#define S_CT_MPA_TXVALID 17 +#define V_CT_MPA_TXVALID(x) ((x) << S_CT_MPA_TXVALID) +#define F_CT_MPA_TXVALID V_CT_MPA_TXVALID(1U) + +#define S_CT_MPA_TXFULL 16 +#define V_CT_MPA_TXFULL(x) ((x) << S_CT_MPA_TXFULL) +#define F_CT_MPA_TXFULL V_CT_MPA_TXFULL(1U) + +#define S_RXVALID_BUF 15 +#define V_RXVALID_BUF(x) ((x) << S_RXVALID_BUF) +#define F_RXVALID_BUF V_RXVALID_BUF(1U) + +#define S_RXFULL_BUF 14 +#define V_RXFULL_BUF(x) ((x) << S_RXFULL_BUF) +#define F_RXFULL_BUF V_RXFULL_BUF(1U) + +#define S_PLD_TXVALID 13 +#define V_PLD_TXVALID(x) ((x) << S_PLD_TXVALID) +#define F_PLD_TXVALID V_PLD_TXVALID(1U) + +#define S_PLD_TXFULL 12 +#define V_PLD_TXFULL(x) ((x) << S_PLD_TXFULL) +#define F_PLD_TXFULL V_PLD_TXFULL(1U) + +#define S_ISS_FIFO_SRDY 11 +#define V_ISS_FIFO_SRDY(x) ((x) << S_ISS_FIFO_SRDY) +#define F_ISS_FIFO_SRDY V_ISS_FIFO_SRDY(1U) + +#define S_ISS_FIFO_DRDY 10 +#define V_ISS_FIFO_DRDY(x) ((x) << S_ISS_FIFO_DRDY) +#define F_ISS_FIFO_DRDY V_ISS_FIFO_DRDY(1U) + +#define S_CT_TCP_OP_ISS_SRDY 9 +#define V_CT_TCP_OP_ISS_SRDY(x) ((x) << S_CT_TCP_OP_ISS_SRDY) +#define F_CT_TCP_OP_ISS_SRDY V_CT_TCP_OP_ISS_SRDY(1U) + +#define S_CT_TCP_OP_ISS_DRDY 8 +#define V_CT_TCP_OP_ISS_DRDY(x) ((x) << S_CT_TCP_OP_ISS_DRDY) +#define F_CT_TCP_OP_ISS_DRDY V_CT_TCP_OP_ISS_DRDY(1U) + +#define S_P2CSUMERROR_SRDY 7 +#define V_P2CSUMERROR_SRDY(x) ((x) << S_P2CSUMERROR_SRDY) +#define F_P2CSUMERROR_SRDY V_P2CSUMERROR_SRDY(1U) + +#define S_P2CSUMERROR_DRDY 6 +#define V_P2CSUMERROR_DRDY(x) ((x) << S_P2CSUMERROR_DRDY) +#define F_P2CSUMERROR_DRDY V_P2CSUMERROR_DRDY(1U) + +#define S_FIFO_ERROR_SRDY 5 +#define V_FIFO_ERROR_SRDY(x) ((x) << S_FIFO_ERROR_SRDY) +#define F_FIFO_ERROR_SRDY V_FIFO_ERROR_SRDY(1U) + +#define S_FIFO_ERROR_DRDY 4 +#define V_FIFO_ERROR_DRDY(x) ((x) << S_FIFO_ERROR_DRDY) +#define F_FIFO_ERROR_DRDY V_FIFO_ERROR_DRDY(1U) + +#define S_PLD_SRDY 3 +#define V_PLD_SRDY(x) ((x) << S_PLD_SRDY) +#define F_PLD_SRDY V_PLD_SRDY(1U) + +#define S_PLD_DRDY 2 +#define V_PLD_DRDY(x) ((x) << S_PLD_DRDY) +#define F_PLD_DRDY V_PLD_DRDY(1U) + +#define S_RX_PKT_ATTR_SRDY 1 +#define V_RX_PKT_ATTR_SRDY(x) ((x) << S_RX_PKT_ATTR_SRDY) +#define F_RX_PKT_ATTR_SRDY V_RX_PKT_ATTR_SRDY(1U) + +#define S_RX_PKT_ATTR_DRDY 0 +#define V_RX_PKT_ATTR_DRDY(x) ((x) << S_RX_PKT_ATTR_DRDY) +#define F_RX_PKT_ATTR_DRDY V_RX_PKT_ATTR_DRDY(1U) + +#define S_RXRUNT 25 +#define V_RXRUNT(x) ((x) << S_RXRUNT) +#define F_RXRUNT V_RXRUNT(1U) + +#define S_RXRUNTPARSER 24 +#define V_RXRUNTPARSER(x) ((x) << S_RXRUNTPARSER) +#define F_RXRUNTPARSER V_RXRUNTPARSER(1U) + +#define S_ERROR_SRDY 5 +#define V_ERROR_SRDY(x) ((x) << S_ERROR_SRDY) +#define F_ERROR_SRDY V_ERROR_SRDY(1U) + +#define S_ERROR_DRDY 4 +#define V_ERROR_DRDY(x) ((x) << S_ERROR_DRDY) +#define F_ERROR_DRDY V_ERROR_DRDY(1U) + +#define A_TP_DBG_ESIDE_IN1 0x14b +#define A_TP_DBG_ESIDE_IN2 0x14c +#define A_TP_DBG_ESIDE_IN3 0x14d +#define A_TP_DBG_ESIDE_FRM 0x14e + +#define S_ERX2XERROR 28 +#define M_ERX2XERROR 0xfU +#define V_ERX2XERROR(x) ((x) << S_ERX2XERROR) +#define G_ERX2XERROR(x) (((x) >> S_ERX2XERROR) & M_ERX2XERROR) + +#define S_EPLDTX2XERROR 24 +#define M_EPLDTX2XERROR 0xfU +#define V_EPLDTX2XERROR(x) ((x) << S_EPLDTX2XERROR) +#define G_EPLDTX2XERROR(x) (((x) >> S_EPLDTX2XERROR) & M_EPLDTX2XERROR) + +#define S_ETXERROR 20 +#define M_ETXERROR 0xfU +#define V_ETXERROR(x) ((x) << S_ETXERROR) +#define G_ETXERROR(x) (((x) >> S_ETXERROR) & M_ETXERROR) + +#define S_EPLDRXERROR 16 +#define M_EPLDRXERROR 0xfU +#define V_EPLDRXERROR(x) ((x) << S_EPLDRXERROR) +#define G_EPLDRXERROR(x) (((x) >> S_EPLDRXERROR) & M_EPLDRXERROR) + +#define S_ERXSIZEERROR3 12 +#define M_ERXSIZEERROR3 0xfU +#define V_ERXSIZEERROR3(x) ((x) << S_ERXSIZEERROR3) +#define G_ERXSIZEERROR3(x) (((x) >> S_ERXSIZEERROR3) & M_ERXSIZEERROR3) + +#define S_ERXSIZEERROR2 8 +#define M_ERXSIZEERROR2 0xfU +#define V_ERXSIZEERROR2(x) ((x) << S_ERXSIZEERROR2) +#define G_ERXSIZEERROR2(x) (((x) >> S_ERXSIZEERROR2) & M_ERXSIZEERROR2) + +#define S_ERXSIZEERROR1 4 +#define M_ERXSIZEERROR1 0xfU +#define V_ERXSIZEERROR1(x) ((x) << S_ERXSIZEERROR1) +#define G_ERXSIZEERROR1(x) (((x) >> S_ERXSIZEERROR1) & M_ERXSIZEERROR1) + +#define S_ERXSIZEERROR0 0 +#define M_ERXSIZEERROR0 0xfU +#define V_ERXSIZEERROR0(x) ((x) << S_ERXSIZEERROR0) +#define G_ERXSIZEERROR0(x) (((x) >> S_ERXSIZEERROR0) & M_ERXSIZEERROR0) + +#define A_TP_DBG_ESIDE_DRP 0x14f + +#define S_RXDROP3 24 +#define M_RXDROP3 0xffU +#define V_RXDROP3(x) ((x) << S_RXDROP3) +#define G_RXDROP3(x) (((x) >> S_RXDROP3) & M_RXDROP3) + +#define S_RXDROP2 16 +#define M_RXDROP2 0xffU +#define V_RXDROP2(x) ((x) << S_RXDROP2) +#define G_RXDROP2(x) (((x) >> S_RXDROP2) & M_RXDROP2) + +#define S_RXDROP1 8 +#define M_RXDROP1 0xffU +#define V_RXDROP1(x) ((x) << S_RXDROP1) +#define G_RXDROP1(x) (((x) >> S_RXDROP1) & M_RXDROP1) + +#define S_RXDROP0 0 +#define M_RXDROP0 0xffU +#define V_RXDROP0(x) ((x) << S_RXDROP0) +#define G_RXDROP0(x) (((x) >> S_RXDROP0) & M_RXDROP0) + +#define A_TP_DBG_ESIDE_TX 0x150 + +#define S_ETXVALID 4 +#define M_ETXVALID 0xfU +#define V_ETXVALID(x) ((x) << S_ETXVALID) +#define G_ETXVALID(x) (((x) >> S_ETXVALID) & M_ETXVALID) + +#define S_ETXFULL 0 +#define M_ETXFULL 0xfU +#define V_ETXFULL(x) ((x) << S_ETXFULL) +#define G_ETXFULL(x) (((x) >> S_ETXFULL) & M_ETXFULL) + +#define A_TP_ESIDE_SVID_MASK 0x151 +#define A_TP_ESIDE_DVID_MASK 0x152 +#define A_TP_ESIDE_ALIGN_MASK 0x153 + +#define S_USE_LOOP_BIT 24 +#define V_USE_LOOP_BIT(x) ((x) << S_USE_LOOP_BIT) +#define F_USE_LOOP_BIT V_USE_LOOP_BIT(1U) + +#define S_LOOP_OFFSET 16 +#define M_LOOP_OFFSET 0xffU +#define V_LOOP_OFFSET(x) ((x) << S_LOOP_OFFSET) +#define G_LOOP_OFFSET(x) (((x) >> S_LOOP_OFFSET) & M_LOOP_OFFSET) + +#define S_DVID_ID_OFFSET 8 +#define M_DVID_ID_OFFSET 0xffU +#define V_DVID_ID_OFFSET(x) ((x) << S_DVID_ID_OFFSET) +#define G_DVID_ID_OFFSET(x) (((x) >> S_DVID_ID_OFFSET) & M_DVID_ID_OFFSET) + +#define S_SVID_ID_OFFSET 0 +#define M_SVID_ID_OFFSET 0xffU +#define V_SVID_ID_OFFSET(x) ((x) << S_SVID_ID_OFFSET) +#define G_SVID_ID_OFFSET(x) (((x) >> S_SVID_ID_OFFSET) & M_SVID_ID_OFFSET) + +#define A_TP_DBG_ESIDE_OP 0x154 + +#define S_OPT_PARSER_FATAL_CHANNEL0 29 +#define V_OPT_PARSER_FATAL_CHANNEL0(x) ((x) << S_OPT_PARSER_FATAL_CHANNEL0) +#define F_OPT_PARSER_FATAL_CHANNEL0 V_OPT_PARSER_FATAL_CHANNEL0(1U) + +#define S_OPT_PARSER_BUSY_CHANNEL0 28 +#define V_OPT_PARSER_BUSY_CHANNEL0(x) ((x) << S_OPT_PARSER_BUSY_CHANNEL0) +#define F_OPT_PARSER_BUSY_CHANNEL0 V_OPT_PARSER_BUSY_CHANNEL0(1U) + +#define S_OPT_PARSER_ITCP_STATE_CHANNEL0 26 +#define M_OPT_PARSER_ITCP_STATE_CHANNEL0 0x3U +#define V_OPT_PARSER_ITCP_STATE_CHANNEL0(x) ((x) << S_OPT_PARSER_ITCP_STATE_CHANNEL0) +#define G_OPT_PARSER_ITCP_STATE_CHANNEL0(x) (((x) >> S_OPT_PARSER_ITCP_STATE_CHANNEL0) & M_OPT_PARSER_ITCP_STATE_CHANNEL0) + +#define S_OPT_PARSER_OTK_STATE_CHANNEL0 24 +#define M_OPT_PARSER_OTK_STATE_CHANNEL0 0x3U +#define V_OPT_PARSER_OTK_STATE_CHANNEL0(x) ((x) << S_OPT_PARSER_OTK_STATE_CHANNEL0) +#define G_OPT_PARSER_OTK_STATE_CHANNEL0(x) (((x) >> S_OPT_PARSER_OTK_STATE_CHANNEL0) & M_OPT_PARSER_OTK_STATE_CHANNEL0) + +#define S_OPT_PARSER_FATAL_CHANNEL1 21 +#define V_OPT_PARSER_FATAL_CHANNEL1(x) ((x) << S_OPT_PARSER_FATAL_CHANNEL1) +#define F_OPT_PARSER_FATAL_CHANNEL1 V_OPT_PARSER_FATAL_CHANNEL1(1U) + +#define S_OPT_PARSER_BUSY_CHANNEL1 20 +#define V_OPT_PARSER_BUSY_CHANNEL1(x) ((x) << S_OPT_PARSER_BUSY_CHANNEL1) +#define F_OPT_PARSER_BUSY_CHANNEL1 V_OPT_PARSER_BUSY_CHANNEL1(1U) + +#define S_OPT_PARSER_ITCP_STATE_CHANNEL1 18 +#define M_OPT_PARSER_ITCP_STATE_CHANNEL1 0x3U +#define V_OPT_PARSER_ITCP_STATE_CHANNEL1(x) ((x) << S_OPT_PARSER_ITCP_STATE_CHANNEL1) +#define G_OPT_PARSER_ITCP_STATE_CHANNEL1(x) (((x) >> S_OPT_PARSER_ITCP_STATE_CHANNEL1) & M_OPT_PARSER_ITCP_STATE_CHANNEL1) + +#define S_OPT_PARSER_OTK_STATE_CHANNEL1 16 +#define M_OPT_PARSER_OTK_STATE_CHANNEL1 0x3U +#define V_OPT_PARSER_OTK_STATE_CHANNEL1(x) ((x) << S_OPT_PARSER_OTK_STATE_CHANNEL1) +#define G_OPT_PARSER_OTK_STATE_CHANNEL1(x) (((x) >> S_OPT_PARSER_OTK_STATE_CHANNEL1) & M_OPT_PARSER_OTK_STATE_CHANNEL1) + +#define S_OPT_PARSER_FATAL_CHANNEL2 13 +#define V_OPT_PARSER_FATAL_CHANNEL2(x) ((x) << S_OPT_PARSER_FATAL_CHANNEL2) +#define F_OPT_PARSER_FATAL_CHANNEL2 V_OPT_PARSER_FATAL_CHANNEL2(1U) + +#define S_OPT_PARSER_BUSY_CHANNEL2 12 +#define V_OPT_PARSER_BUSY_CHANNEL2(x) ((x) << S_OPT_PARSER_BUSY_CHANNEL2) +#define F_OPT_PARSER_BUSY_CHANNEL2 V_OPT_PARSER_BUSY_CHANNEL2(1U) + +#define S_OPT_PARSER_ITCP_STATE_CHANNEL2 10 +#define M_OPT_PARSER_ITCP_STATE_CHANNEL2 0x3U +#define V_OPT_PARSER_ITCP_STATE_CHANNEL2(x) ((x) << S_OPT_PARSER_ITCP_STATE_CHANNEL2) +#define G_OPT_PARSER_ITCP_STATE_CHANNEL2(x) (((x) >> S_OPT_PARSER_ITCP_STATE_CHANNEL2) & M_OPT_PARSER_ITCP_STATE_CHANNEL2) + +#define S_OPT_PARSER_OTK_STATE_CHANNEL2 8 +#define M_OPT_PARSER_OTK_STATE_CHANNEL2 0x3U +#define V_OPT_PARSER_OTK_STATE_CHANNEL2(x) ((x) << S_OPT_PARSER_OTK_STATE_CHANNEL2) +#define G_OPT_PARSER_OTK_STATE_CHANNEL2(x) (((x) >> S_OPT_PARSER_OTK_STATE_CHANNEL2) & M_OPT_PARSER_OTK_STATE_CHANNEL2) + +#define S_OPT_PARSER_FATAL_CHANNEL3 5 +#define V_OPT_PARSER_FATAL_CHANNEL3(x) ((x) << S_OPT_PARSER_FATAL_CHANNEL3) +#define F_OPT_PARSER_FATAL_CHANNEL3 V_OPT_PARSER_FATAL_CHANNEL3(1U) + +#define S_OPT_PARSER_BUSY_CHANNEL3 4 +#define V_OPT_PARSER_BUSY_CHANNEL3(x) ((x) << S_OPT_PARSER_BUSY_CHANNEL3) +#define F_OPT_PARSER_BUSY_CHANNEL3 V_OPT_PARSER_BUSY_CHANNEL3(1U) + +#define S_OPT_PARSER_ITCP_STATE_CHANNEL3 2 +#define M_OPT_PARSER_ITCP_STATE_CHANNEL3 0x3U +#define V_OPT_PARSER_ITCP_STATE_CHANNEL3(x) ((x) << S_OPT_PARSER_ITCP_STATE_CHANNEL3) +#define G_OPT_PARSER_ITCP_STATE_CHANNEL3(x) (((x) >> S_OPT_PARSER_ITCP_STATE_CHANNEL3) & M_OPT_PARSER_ITCP_STATE_CHANNEL3) + +#define S_OPT_PARSER_OTK_STATE_CHANNEL3 0 +#define M_OPT_PARSER_OTK_STATE_CHANNEL3 0x3U +#define V_OPT_PARSER_OTK_STATE_CHANNEL3(x) ((x) << S_OPT_PARSER_OTK_STATE_CHANNEL3) +#define G_OPT_PARSER_OTK_STATE_CHANNEL3(x) (((x) >> S_OPT_PARSER_OTK_STATE_CHANNEL3) & M_OPT_PARSER_OTK_STATE_CHANNEL3) + +#define A_TP_DBG_ESIDE_OP_ALT 0x155 + +#define S_OPT_PARSER_PSTATE_FATAL_CHANNEL0 29 +#define V_OPT_PARSER_PSTATE_FATAL_CHANNEL0(x) ((x) << S_OPT_PARSER_PSTATE_FATAL_CHANNEL0) +#define F_OPT_PARSER_PSTATE_FATAL_CHANNEL0 V_OPT_PARSER_PSTATE_FATAL_CHANNEL0(1U) + +#define S_OPT_PARSER_PSTATE_ERRNO_CHANNEL0 24 +#define M_OPT_PARSER_PSTATE_ERRNO_CHANNEL0 0x1fU +#define V_OPT_PARSER_PSTATE_ERRNO_CHANNEL0(x) ((x) << S_OPT_PARSER_PSTATE_ERRNO_CHANNEL0) +#define G_OPT_PARSER_PSTATE_ERRNO_CHANNEL0(x) (((x) >> S_OPT_PARSER_PSTATE_ERRNO_CHANNEL0) & M_OPT_PARSER_PSTATE_ERRNO_CHANNEL0) + +#define S_OPT_PARSER_PSTATE_FATAL_CHANNEL1 21 +#define V_OPT_PARSER_PSTATE_FATAL_CHANNEL1(x) ((x) << S_OPT_PARSER_PSTATE_FATAL_CHANNEL1) +#define F_OPT_PARSER_PSTATE_FATAL_CHANNEL1 V_OPT_PARSER_PSTATE_FATAL_CHANNEL1(1U) + +#define S_OPT_PARSER_PSTATE_ERRNO_CHANNEL1 16 +#define M_OPT_PARSER_PSTATE_ERRNO_CHANNEL1 0x1fU +#define V_OPT_PARSER_PSTATE_ERRNO_CHANNEL1(x) ((x) << S_OPT_PARSER_PSTATE_ERRNO_CHANNEL1) +#define G_OPT_PARSER_PSTATE_ERRNO_CHANNEL1(x) (((x) >> S_OPT_PARSER_PSTATE_ERRNO_CHANNEL1) & M_OPT_PARSER_PSTATE_ERRNO_CHANNEL1) + +#define S_OPT_PARSER_PSTATE_FATAL_CHANNEL2 13 +#define V_OPT_PARSER_PSTATE_FATAL_CHANNEL2(x) ((x) << S_OPT_PARSER_PSTATE_FATAL_CHANNEL2) +#define F_OPT_PARSER_PSTATE_FATAL_CHANNEL2 V_OPT_PARSER_PSTATE_FATAL_CHANNEL2(1U) + +#define S_OPT_PARSER_PSTATE_ERRNO_CHANNEL2 8 +#define M_OPT_PARSER_PSTATE_ERRNO_CHANNEL2 0x1fU +#define V_OPT_PARSER_PSTATE_ERRNO_CHANNEL2(x) ((x) << S_OPT_PARSER_PSTATE_ERRNO_CHANNEL2) +#define G_OPT_PARSER_PSTATE_ERRNO_CHANNEL2(x) (((x) >> S_OPT_PARSER_PSTATE_ERRNO_CHANNEL2) & M_OPT_PARSER_PSTATE_ERRNO_CHANNEL2) + +#define S_OPT_PARSER_PSTATE_FATAL_CHANNEL3 5 +#define V_OPT_PARSER_PSTATE_FATAL_CHANNEL3(x) ((x) << S_OPT_PARSER_PSTATE_FATAL_CHANNEL3) +#define F_OPT_PARSER_PSTATE_FATAL_CHANNEL3 V_OPT_PARSER_PSTATE_FATAL_CHANNEL3(1U) + +#define S_OPT_PARSER_PSTATE_ERRNO_CHANNEL3 0 +#define M_OPT_PARSER_PSTATE_ERRNO_CHANNEL3 0x1fU +#define V_OPT_PARSER_PSTATE_ERRNO_CHANNEL3(x) ((x) << S_OPT_PARSER_PSTATE_ERRNO_CHANNEL3) +#define G_OPT_PARSER_PSTATE_ERRNO_CHANNEL3(x) (((x) >> S_OPT_PARSER_PSTATE_ERRNO_CHANNEL3) & M_OPT_PARSER_PSTATE_ERRNO_CHANNEL3) + +#define A_TP_DBG_ESIDE_OP_BUSY 0x156 + +#define S_OPT_PARSER_BUSY_VEC_CHANNEL3 24 +#define M_OPT_PARSER_BUSY_VEC_CHANNEL3 0xffU +#define V_OPT_PARSER_BUSY_VEC_CHANNEL3(x) ((x) << S_OPT_PARSER_BUSY_VEC_CHANNEL3) +#define G_OPT_PARSER_BUSY_VEC_CHANNEL3(x) (((x) >> S_OPT_PARSER_BUSY_VEC_CHANNEL3) & M_OPT_PARSER_BUSY_VEC_CHANNEL3) + +#define S_OPT_PARSER_BUSY_VEC_CHANNEL2 16 +#define M_OPT_PARSER_BUSY_VEC_CHANNEL2 0xffU +#define V_OPT_PARSER_BUSY_VEC_CHANNEL2(x) ((x) << S_OPT_PARSER_BUSY_VEC_CHANNEL2) +#define G_OPT_PARSER_BUSY_VEC_CHANNEL2(x) (((x) >> S_OPT_PARSER_BUSY_VEC_CHANNEL2) & M_OPT_PARSER_BUSY_VEC_CHANNEL2) + +#define S_OPT_PARSER_BUSY_VEC_CHANNEL1 8 +#define M_OPT_PARSER_BUSY_VEC_CHANNEL1 0xffU +#define V_OPT_PARSER_BUSY_VEC_CHANNEL1(x) ((x) << S_OPT_PARSER_BUSY_VEC_CHANNEL1) +#define G_OPT_PARSER_BUSY_VEC_CHANNEL1(x) (((x) >> S_OPT_PARSER_BUSY_VEC_CHANNEL1) & M_OPT_PARSER_BUSY_VEC_CHANNEL1) + +#define S_OPT_PARSER_BUSY_VEC_CHANNEL0 0 +#define M_OPT_PARSER_BUSY_VEC_CHANNEL0 0xffU +#define V_OPT_PARSER_BUSY_VEC_CHANNEL0(x) ((x) << S_OPT_PARSER_BUSY_VEC_CHANNEL0) +#define G_OPT_PARSER_BUSY_VEC_CHANNEL0(x) (((x) >> S_OPT_PARSER_BUSY_VEC_CHANNEL0) & M_OPT_PARSER_BUSY_VEC_CHANNEL0) + +#define A_TP_DBG_ESIDE_OP_COOKIE 0x157 + +#define S_OPT_PARSER_COOKIE_CHANNEL3 24 +#define M_OPT_PARSER_COOKIE_CHANNEL3 0xffU +#define V_OPT_PARSER_COOKIE_CHANNEL3(x) ((x) << S_OPT_PARSER_COOKIE_CHANNEL3) +#define G_OPT_PARSER_COOKIE_CHANNEL3(x) (((x) >> S_OPT_PARSER_COOKIE_CHANNEL3) & M_OPT_PARSER_COOKIE_CHANNEL3) + +#define S_OPT_PARSER_COOKIE_CHANNEL2 16 +#define M_OPT_PARSER_COOKIE_CHANNEL2 0xffU +#define V_OPT_PARSER_COOKIE_CHANNEL2(x) ((x) << S_OPT_PARSER_COOKIE_CHANNEL2) +#define G_OPT_PARSER_COOKIE_CHANNEL2(x) (((x) >> S_OPT_PARSER_COOKIE_CHANNEL2) & M_OPT_PARSER_COOKIE_CHANNEL2) + +#define S_OPT_PARSER_COOKIE_CHANNEL1 8 +#define M_OPT_PARSER_COOKIE_CHANNEL1 0xffU +#define V_OPT_PARSER_COOKIE_CHANNEL1(x) ((x) << S_OPT_PARSER_COOKIE_CHANNEL1) +#define G_OPT_PARSER_COOKIE_CHANNEL1(x) (((x) >> S_OPT_PARSER_COOKIE_CHANNEL1) & M_OPT_PARSER_COOKIE_CHANNEL1) + +#define S_OPT_PARSER_COOKIE_CHANNEL0 0 +#define M_OPT_PARSER_COOKIE_CHANNEL0 0xffU +#define V_OPT_PARSER_COOKIE_CHANNEL0(x) ((x) << S_OPT_PARSER_COOKIE_CHANNEL0) +#define G_OPT_PARSER_COOKIE_CHANNEL0(x) (((x) >> S_OPT_PARSER_COOKIE_CHANNEL0) & M_OPT_PARSER_COOKIE_CHANNEL0) + +#define A_TP_DBG_CSIDE_RX0 0x230 + +#define S_CRXSOPCNT 28 +#define M_CRXSOPCNT 0xfU +#define V_CRXSOPCNT(x) ((x) << S_CRXSOPCNT) +#define G_CRXSOPCNT(x) (((x) >> S_CRXSOPCNT) & M_CRXSOPCNT) + +#define S_CRXEOPCNT 24 +#define M_CRXEOPCNT 0xfU +#define V_CRXEOPCNT(x) ((x) << S_CRXEOPCNT) +#define G_CRXEOPCNT(x) (((x) >> S_CRXEOPCNT) & M_CRXEOPCNT) + +#define S_CRXPLDSOPCNT 20 +#define M_CRXPLDSOPCNT 0xfU +#define V_CRXPLDSOPCNT(x) ((x) << S_CRXPLDSOPCNT) +#define G_CRXPLDSOPCNT(x) (((x) >> S_CRXPLDSOPCNT) & M_CRXPLDSOPCNT) + +#define S_CRXPLDEOPCNT 16 +#define M_CRXPLDEOPCNT 0xfU +#define V_CRXPLDEOPCNT(x) ((x) << S_CRXPLDEOPCNT) +#define G_CRXPLDEOPCNT(x) (((x) >> S_CRXPLDEOPCNT) & M_CRXPLDEOPCNT) + +#define S_CRXARBSOPCNT 12 +#define M_CRXARBSOPCNT 0xfU +#define V_CRXARBSOPCNT(x) ((x) << S_CRXARBSOPCNT) +#define G_CRXARBSOPCNT(x) (((x) >> S_CRXARBSOPCNT) & M_CRXARBSOPCNT) + +#define S_CRXARBEOPCNT 8 +#define M_CRXARBEOPCNT 0xfU +#define V_CRXARBEOPCNT(x) ((x) << S_CRXARBEOPCNT) +#define G_CRXARBEOPCNT(x) (((x) >> S_CRXARBEOPCNT) & M_CRXARBEOPCNT) + +#define S_CRXCPLSOPCNT 4 +#define M_CRXCPLSOPCNT 0xfU +#define V_CRXCPLSOPCNT(x) ((x) << S_CRXCPLSOPCNT) +#define G_CRXCPLSOPCNT(x) (((x) >> S_CRXCPLSOPCNT) & M_CRXCPLSOPCNT) + +#define S_CRXCPLEOPCNT 0 +#define M_CRXCPLEOPCNT 0xfU +#define V_CRXCPLEOPCNT(x) ((x) << S_CRXCPLEOPCNT) +#define G_CRXCPLEOPCNT(x) (((x) >> S_CRXCPLEOPCNT) & M_CRXCPLEOPCNT) + +#define A_TP_DBG_CSIDE_RX1 0x231 +#define A_TP_DBG_CSIDE_RX2 0x232 +#define A_TP_DBG_CSIDE_RX3 0x233 +#define A_TP_DBG_CSIDE_TX0 0x234 + +#define S_TXSOPCNT 28 +#define M_TXSOPCNT 0xfU +#define V_TXSOPCNT(x) ((x) << S_TXSOPCNT) +#define G_TXSOPCNT(x) (((x) >> S_TXSOPCNT) & M_TXSOPCNT) + +#define S_TXEOPCNT 24 +#define M_TXEOPCNT 0xfU +#define V_TXEOPCNT(x) ((x) << S_TXEOPCNT) +#define G_TXEOPCNT(x) (((x) >> S_TXEOPCNT) & M_TXEOPCNT) + +#define S_TXPLDSOPCNT 20 +#define M_TXPLDSOPCNT 0xfU +#define V_TXPLDSOPCNT(x) ((x) << S_TXPLDSOPCNT) +#define G_TXPLDSOPCNT(x) (((x) >> S_TXPLDSOPCNT) & M_TXPLDSOPCNT) + +#define S_TXPLDEOPCNT 16 +#define M_TXPLDEOPCNT 0xfU +#define V_TXPLDEOPCNT(x) ((x) << S_TXPLDEOPCNT) +#define G_TXPLDEOPCNT(x) (((x) >> S_TXPLDEOPCNT) & M_TXPLDEOPCNT) + +#define S_TXARBSOPCNT 12 +#define M_TXARBSOPCNT 0xfU +#define V_TXARBSOPCNT(x) ((x) << S_TXARBSOPCNT) +#define G_TXARBSOPCNT(x) (((x) >> S_TXARBSOPCNT) & M_TXARBSOPCNT) + +#define S_TXARBEOPCNT 8 +#define M_TXARBEOPCNT 0xfU +#define V_TXARBEOPCNT(x) ((x) << S_TXARBEOPCNT) +#define G_TXARBEOPCNT(x) (((x) >> S_TXARBEOPCNT) & M_TXARBEOPCNT) + +#define S_TXCPLSOPCNT 4 +#define M_TXCPLSOPCNT 0xfU +#define V_TXCPLSOPCNT(x) ((x) << S_TXCPLSOPCNT) +#define G_TXCPLSOPCNT(x) (((x) >> S_TXCPLSOPCNT) & M_TXCPLSOPCNT) + +#define S_TXCPLEOPCNT 0 +#define M_TXCPLEOPCNT 0xfU +#define V_TXCPLEOPCNT(x) ((x) << S_TXCPLEOPCNT) +#define G_TXCPLEOPCNT(x) (((x) >> S_TXCPLEOPCNT) & M_TXCPLEOPCNT) + +#define A_TP_DBG_CSIDE_TX1 0x235 +#define A_TP_DBG_CSIDE_TX2 0x236 +#define A_TP_DBG_CSIDE_TX3 0x237 +#define A_TP_DBG_CSIDE_FIFO0 0x238 + +#define S_PLD_RXZEROP_SRDY1 31 +#define V_PLD_RXZEROP_SRDY1(x) ((x) << S_PLD_RXZEROP_SRDY1) +#define F_PLD_RXZEROP_SRDY1 V_PLD_RXZEROP_SRDY1(1U) + +#define S_PLD_RXZEROP_DRDY1 30 +#define V_PLD_RXZEROP_DRDY1(x) ((x) << S_PLD_RXZEROP_DRDY1) +#define F_PLD_RXZEROP_DRDY1 V_PLD_RXZEROP_DRDY1(1U) + +#define S_PLD_TXZEROP_SRDY1 29 +#define V_PLD_TXZEROP_SRDY1(x) ((x) << S_PLD_TXZEROP_SRDY1) +#define F_PLD_TXZEROP_SRDY1 V_PLD_TXZEROP_SRDY1(1U) + +#define S_PLD_TXZEROP_DRDY1 28 +#define V_PLD_TXZEROP_DRDY1(x) ((x) << S_PLD_TXZEROP_DRDY1) +#define F_PLD_TXZEROP_DRDY1 V_PLD_TXZEROP_DRDY1(1U) + +#define S_PLD_TX_SRDY1 27 +#define V_PLD_TX_SRDY1(x) ((x) << S_PLD_TX_SRDY1) +#define F_PLD_TX_SRDY1 V_PLD_TX_SRDY1(1U) + +#define S_PLD_TX_DRDY1 26 +#define V_PLD_TX_DRDY1(x) ((x) << S_PLD_TX_DRDY1) +#define F_PLD_TX_DRDY1 V_PLD_TX_DRDY1(1U) + +#define S_ERROR_SRDY1 25 +#define V_ERROR_SRDY1(x) ((x) << S_ERROR_SRDY1) +#define F_ERROR_SRDY1 V_ERROR_SRDY1(1U) + +#define S_ERROR_DRDY1 24 +#define V_ERROR_DRDY1(x) ((x) << S_ERROR_DRDY1) +#define F_ERROR_DRDY1 V_ERROR_DRDY1(1U) + +#define S_DB_VLD1 23 +#define V_DB_VLD1(x) ((x) << S_DB_VLD1) +#define F_DB_VLD1 V_DB_VLD1(1U) + +#define S_DB_GT1 22 +#define V_DB_GT1(x) ((x) << S_DB_GT1) +#define F_DB_GT1 V_DB_GT1(1U) + +#define S_TXVALID1 21 +#define V_TXVALID1(x) ((x) << S_TXVALID1) +#define F_TXVALID1 V_TXVALID1(1U) + +#define S_TXFULL1 20 +#define V_TXFULL1(x) ((x) << S_TXFULL1) +#define F_TXFULL1 V_TXFULL1(1U) + +#define S_PLD_TXVALID1 19 +#define V_PLD_TXVALID1(x) ((x) << S_PLD_TXVALID1) +#define F_PLD_TXVALID1 V_PLD_TXVALID1(1U) + +#define S_PLD_TXFULL1 18 +#define V_PLD_TXFULL1(x) ((x) << S_PLD_TXFULL1) +#define F_PLD_TXFULL1 V_PLD_TXFULL1(1U) + +#define S_CPL5_TXVALID1 17 +#define V_CPL5_TXVALID1(x) ((x) << S_CPL5_TXVALID1) +#define F_CPL5_TXVALID1 V_CPL5_TXVALID1(1U) + +#define S_CPL5_TXFULL1 16 +#define V_CPL5_TXFULL1(x) ((x) << S_CPL5_TXFULL1) +#define F_CPL5_TXFULL1 V_CPL5_TXFULL1(1U) + +#define S_PLD_RXZEROP_SRDY0 15 +#define V_PLD_RXZEROP_SRDY0(x) ((x) << S_PLD_RXZEROP_SRDY0) +#define F_PLD_RXZEROP_SRDY0 V_PLD_RXZEROP_SRDY0(1U) + +#define S_PLD_RXZEROP_DRDY0 14 +#define V_PLD_RXZEROP_DRDY0(x) ((x) << S_PLD_RXZEROP_DRDY0) +#define F_PLD_RXZEROP_DRDY0 V_PLD_RXZEROP_DRDY0(1U) + +#define S_PLD_TXZEROP_SRDY0 13 +#define V_PLD_TXZEROP_SRDY0(x) ((x) << S_PLD_TXZEROP_SRDY0) +#define F_PLD_TXZEROP_SRDY0 V_PLD_TXZEROP_SRDY0(1U) + +#define S_PLD_TXZEROP_DRDY0 12 +#define V_PLD_TXZEROP_DRDY0(x) ((x) << S_PLD_TXZEROP_DRDY0) +#define F_PLD_TXZEROP_DRDY0 V_PLD_TXZEROP_DRDY0(1U) + +#define S_PLD_TX_SRDY0 11 +#define V_PLD_TX_SRDY0(x) ((x) << S_PLD_TX_SRDY0) +#define F_PLD_TX_SRDY0 V_PLD_TX_SRDY0(1U) + +#define S_PLD_TX_DRDY0 10 +#define V_PLD_TX_DRDY0(x) ((x) << S_PLD_TX_DRDY0) +#define F_PLD_TX_DRDY0 V_PLD_TX_DRDY0(1U) + +#define S_ERROR_SRDY0 9 +#define V_ERROR_SRDY0(x) ((x) << S_ERROR_SRDY0) +#define F_ERROR_SRDY0 V_ERROR_SRDY0(1U) + +#define S_ERROR_DRDY0 8 +#define V_ERROR_DRDY0(x) ((x) << S_ERROR_DRDY0) +#define F_ERROR_DRDY0 V_ERROR_DRDY0(1U) + +#define S_DB_VLD0 7 +#define V_DB_VLD0(x) ((x) << S_DB_VLD0) +#define F_DB_VLD0 V_DB_VLD0(1U) + +#define S_DB_GT0 6 +#define V_DB_GT0(x) ((x) << S_DB_GT0) +#define F_DB_GT0 V_DB_GT0(1U) + +#define S_TXVALID0 5 +#define V_TXVALID0(x) ((x) << S_TXVALID0) +#define F_TXVALID0 V_TXVALID0(1U) + +#define S_TXFULL0 4 +#define V_TXFULL0(x) ((x) << S_TXFULL0) +#define F_TXFULL0 V_TXFULL0(1U) + +#define S_PLD_TXVALID0 3 +#define V_PLD_TXVALID0(x) ((x) << S_PLD_TXVALID0) +#define F_PLD_TXVALID0 V_PLD_TXVALID0(1U) + +#define S_PLD_TXFULL0 2 +#define V_PLD_TXFULL0(x) ((x) << S_PLD_TXFULL0) +#define F_PLD_TXFULL0 V_PLD_TXFULL0(1U) + +#define S_CPL5_TXVALID0 1 +#define V_CPL5_TXVALID0(x) ((x) << S_CPL5_TXVALID0) +#define F_CPL5_TXVALID0 V_CPL5_TXVALID0(1U) + +#define S_CPL5_TXFULL0 0 +#define V_CPL5_TXFULL0(x) ((x) << S_CPL5_TXFULL0) +#define F_CPL5_TXFULL0 V_CPL5_TXFULL0(1U) + +#define A_TP_DBG_CSIDE_FIFO1 0x239 + +#define S_PLD_RXZEROP_SRDY3 31 +#define V_PLD_RXZEROP_SRDY3(x) ((x) << S_PLD_RXZEROP_SRDY3) +#define F_PLD_RXZEROP_SRDY3 V_PLD_RXZEROP_SRDY3(1U) + +#define S_PLD_RXZEROP_DRDY3 30 +#define V_PLD_RXZEROP_DRDY3(x) ((x) << S_PLD_RXZEROP_DRDY3) +#define F_PLD_RXZEROP_DRDY3 V_PLD_RXZEROP_DRDY3(1U) + +#define S_PLD_TXZEROP_SRDY3 29 +#define V_PLD_TXZEROP_SRDY3(x) ((x) << S_PLD_TXZEROP_SRDY3) +#define F_PLD_TXZEROP_SRDY3 V_PLD_TXZEROP_SRDY3(1U) + +#define S_PLD_TXZEROP_DRDY3 28 +#define V_PLD_TXZEROP_DRDY3(x) ((x) << S_PLD_TXZEROP_DRDY3) +#define F_PLD_TXZEROP_DRDY3 V_PLD_TXZEROP_DRDY3(1U) + +#define S_PLD_TX_SRDY3 27 +#define V_PLD_TX_SRDY3(x) ((x) << S_PLD_TX_SRDY3) +#define F_PLD_TX_SRDY3 V_PLD_TX_SRDY3(1U) + +#define S_PLD_TX_DRDY3 26 +#define V_PLD_TX_DRDY3(x) ((x) << S_PLD_TX_DRDY3) +#define F_PLD_TX_DRDY3 V_PLD_TX_DRDY3(1U) + +#define S_ERROR_SRDY3 25 +#define V_ERROR_SRDY3(x) ((x) << S_ERROR_SRDY3) +#define F_ERROR_SRDY3 V_ERROR_SRDY3(1U) + +#define S_ERROR_DRDY3 24 +#define V_ERROR_DRDY3(x) ((x) << S_ERROR_DRDY3) +#define F_ERROR_DRDY3 V_ERROR_DRDY3(1U) + +#define S_DB_VLD3 23 +#define V_DB_VLD3(x) ((x) << S_DB_VLD3) +#define F_DB_VLD3 V_DB_VLD3(1U) + +#define S_DB_GT3 22 +#define V_DB_GT3(x) ((x) << S_DB_GT3) +#define F_DB_GT3 V_DB_GT3(1U) + +#define S_TXVALID3 21 +#define V_TXVALID3(x) ((x) << S_TXVALID3) +#define F_TXVALID3 V_TXVALID3(1U) + +#define S_TXFULL3 20 +#define V_TXFULL3(x) ((x) << S_TXFULL3) +#define F_TXFULL3 V_TXFULL3(1U) + +#define S_PLD_TXVALID3 19 +#define V_PLD_TXVALID3(x) ((x) << S_PLD_TXVALID3) +#define F_PLD_TXVALID3 V_PLD_TXVALID3(1U) + +#define S_PLD_TXFULL3 18 +#define V_PLD_TXFULL3(x) ((x) << S_PLD_TXFULL3) +#define F_PLD_TXFULL3 V_PLD_TXFULL3(1U) + +#define S_CPL5_TXVALID3 17 +#define V_CPL5_TXVALID3(x) ((x) << S_CPL5_TXVALID3) +#define F_CPL5_TXVALID3 V_CPL5_TXVALID3(1U) + +#define S_CPL5_TXFULL3 16 +#define V_CPL5_TXFULL3(x) ((x) << S_CPL5_TXFULL3) +#define F_CPL5_TXFULL3 V_CPL5_TXFULL3(1U) + +#define S_PLD_RXZEROP_SRDY2 15 +#define V_PLD_RXZEROP_SRDY2(x) ((x) << S_PLD_RXZEROP_SRDY2) +#define F_PLD_RXZEROP_SRDY2 V_PLD_RXZEROP_SRDY2(1U) + +#define S_PLD_RXZEROP_DRDY2 14 +#define V_PLD_RXZEROP_DRDY2(x) ((x) << S_PLD_RXZEROP_DRDY2) +#define F_PLD_RXZEROP_DRDY2 V_PLD_RXZEROP_DRDY2(1U) + +#define S_PLD_TXZEROP_SRDY2 13 +#define V_PLD_TXZEROP_SRDY2(x) ((x) << S_PLD_TXZEROP_SRDY2) +#define F_PLD_TXZEROP_SRDY2 V_PLD_TXZEROP_SRDY2(1U) + +#define S_PLD_TXZEROP_DRDY2 12 +#define V_PLD_TXZEROP_DRDY2(x) ((x) << S_PLD_TXZEROP_DRDY2) +#define F_PLD_TXZEROP_DRDY2 V_PLD_TXZEROP_DRDY2(1U) + +#define S_PLD_TX_SRDY2 11 +#define V_PLD_TX_SRDY2(x) ((x) << S_PLD_TX_SRDY2) +#define F_PLD_TX_SRDY2 V_PLD_TX_SRDY2(1U) + +#define S_PLD_TX_DRDY2 10 +#define V_PLD_TX_DRDY2(x) ((x) << S_PLD_TX_DRDY2) +#define F_PLD_TX_DRDY2 V_PLD_TX_DRDY2(1U) + +#define S_ERROR_SRDY2 9 +#define V_ERROR_SRDY2(x) ((x) << S_ERROR_SRDY2) +#define F_ERROR_SRDY2 V_ERROR_SRDY2(1U) + +#define S_ERROR_DRDY2 8 +#define V_ERROR_DRDY2(x) ((x) << S_ERROR_DRDY2) +#define F_ERROR_DRDY2 V_ERROR_DRDY2(1U) + +#define S_DB_VLD2 7 +#define V_DB_VLD2(x) ((x) << S_DB_VLD2) +#define F_DB_VLD2 V_DB_VLD2(1U) + +#define S_DB_GT2 6 +#define V_DB_GT2(x) ((x) << S_DB_GT2) +#define F_DB_GT2 V_DB_GT2(1U) + +#define S_TXVALID2 5 +#define V_TXVALID2(x) ((x) << S_TXVALID2) +#define F_TXVALID2 V_TXVALID2(1U) + +#define S_TXFULL2 4 +#define V_TXFULL2(x) ((x) << S_TXFULL2) +#define F_TXFULL2 V_TXFULL2(1U) + +#define S_PLD_TXVALID2 3 +#define V_PLD_TXVALID2(x) ((x) << S_PLD_TXVALID2) +#define F_PLD_TXVALID2 V_PLD_TXVALID2(1U) + +#define S_PLD_TXFULL2 2 +#define V_PLD_TXFULL2(x) ((x) << S_PLD_TXFULL2) +#define F_PLD_TXFULL2 V_PLD_TXFULL2(1U) + +#define S_CPL5_TXVALID2 1 +#define V_CPL5_TXVALID2(x) ((x) << S_CPL5_TXVALID2) +#define F_CPL5_TXVALID2 V_CPL5_TXVALID2(1U) + +#define S_CPL5_TXFULL2 0 +#define V_CPL5_TXFULL2(x) ((x) << S_CPL5_TXFULL2) +#define F_CPL5_TXFULL2 V_CPL5_TXFULL2(1U) + +#define A_TP_DBG_CSIDE_DISP0 0x23a + +#define S_CPL5RXVALID 27 +#define V_CPL5RXVALID(x) ((x) << S_CPL5RXVALID) +#define F_CPL5RXVALID V_CPL5RXVALID(1U) + +#define S_CSTATIC1 26 +#define V_CSTATIC1(x) ((x) << S_CSTATIC1) +#define F_CSTATIC1 V_CSTATIC1(1U) + +#define S_CSTATIC2 25 +#define V_CSTATIC2(x) ((x) << S_CSTATIC2) +#define F_CSTATIC2 V_CSTATIC2(1U) + +#define S_PLD_RXZEROP 24 +#define V_PLD_RXZEROP(x) ((x) << S_PLD_RXZEROP) +#define F_PLD_RXZEROP V_PLD_RXZEROP(1U) + +#define S_DDP_IN_PROGRESS 23 +#define V_DDP_IN_PROGRESS(x) ((x) << S_DDP_IN_PROGRESS) +#define F_DDP_IN_PROGRESS V_DDP_IN_PROGRESS(1U) + +#define S_PLD_RXZEROP_SRDY 22 +#define V_PLD_RXZEROP_SRDY(x) ((x) << S_PLD_RXZEROP_SRDY) +#define F_PLD_RXZEROP_SRDY V_PLD_RXZEROP_SRDY(1U) + +#define S_CSTATIC3 21 +#define V_CSTATIC3(x) ((x) << S_CSTATIC3) +#define F_CSTATIC3 V_CSTATIC3(1U) + +#define S_DDP_DRDY 20 +#define V_DDP_DRDY(x) ((x) << S_DDP_DRDY) +#define F_DDP_DRDY V_DDP_DRDY(1U) + +#define S_DDP_PRE_STATE 17 +#define M_DDP_PRE_STATE 0x7U +#define V_DDP_PRE_STATE(x) ((x) << S_DDP_PRE_STATE) +#define G_DDP_PRE_STATE(x) (((x) >> S_DDP_PRE_STATE) & M_DDP_PRE_STATE) + +#define S_DDP_SRDY 16 +#define V_DDP_SRDY(x) ((x) << S_DDP_SRDY) +#define F_DDP_SRDY V_DDP_SRDY(1U) + +#define S_DDP_MSG_CODE 12 +#define M_DDP_MSG_CODE 0xfU +#define V_DDP_MSG_CODE(x) ((x) << S_DDP_MSG_CODE) +#define G_DDP_MSG_CODE(x) (((x) >> S_DDP_MSG_CODE) & M_DDP_MSG_CODE) + +#define S_CPL5_SOCP_CNT 10 +#define M_CPL5_SOCP_CNT 0x3U +#define V_CPL5_SOCP_CNT(x) ((x) << S_CPL5_SOCP_CNT) +#define G_CPL5_SOCP_CNT(x) (((x) >> S_CPL5_SOCP_CNT) & M_CPL5_SOCP_CNT) + +#define S_CSTATIC4 4 +#define M_CSTATIC4 0x3fU +#define V_CSTATIC4(x) ((x) << S_CSTATIC4) +#define G_CSTATIC4(x) (((x) >> S_CSTATIC4) & M_CSTATIC4) + +#define S_CMD_SEL 1 +#define V_CMD_SEL(x) ((x) << S_CMD_SEL) +#define F_CMD_SEL V_CMD_SEL(1U) + +#define S_CPL5RXFULL 26 +#define V_CPL5RXFULL(x) ((x) << S_CPL5RXFULL) +#define F_CPL5RXFULL V_CPL5RXFULL(1U) + +#define S_PLD2XRXVALID 23 +#define V_PLD2XRXVALID(x) ((x) << S_PLD2XRXVALID) +#define F_PLD2XRXVALID V_PLD2XRXVALID(1U) + +#define S_DDPSTATE 16 +#define M_DDPSTATE 0x1fU +#define V_DDPSTATE(x) ((x) << S_DDPSTATE) +#define G_DDPSTATE(x) (((x) >> S_DDPSTATE) & M_DDPSTATE) + +#define S_DDPMSGCODE 12 +#define M_DDPMSGCODE 0xfU +#define V_DDPMSGCODE(x) ((x) << S_DDPMSGCODE) +#define G_DDPMSGCODE(x) (((x) >> S_DDPMSGCODE) & M_DDPMSGCODE) + +#define S_CPL5SOCPCNT 8 +#define M_CPL5SOCPCNT 0xfU +#define V_CPL5SOCPCNT(x) ((x) << S_CPL5SOCPCNT) +#define G_CPL5SOCPCNT(x) (((x) >> S_CPL5SOCPCNT) & M_CPL5SOCPCNT) + +#define S_PLDRXZEROPCNT 4 +#define M_PLDRXZEROPCNT 0xfU +#define V_PLDRXZEROPCNT(x) ((x) << S_PLDRXZEROPCNT) +#define G_PLDRXZEROPCNT(x) (((x) >> S_PLDRXZEROPCNT) & M_PLDRXZEROPCNT) + +#define S_TXFRMERR2 3 +#define V_TXFRMERR2(x) ((x) << S_TXFRMERR2) +#define F_TXFRMERR2 V_TXFRMERR2(1U) + +#define S_TXFRMERR1 2 +#define V_TXFRMERR1(x) ((x) << S_TXFRMERR1) +#define F_TXFRMERR1 V_TXFRMERR1(1U) + +#define S_TXVALID2X 1 +#define V_TXVALID2X(x) ((x) << S_TXVALID2X) +#define F_TXVALID2X V_TXVALID2X(1U) + +#define S_TXFULL2X 0 +#define V_TXFULL2X(x) ((x) << S_TXFULL2X) +#define F_TXFULL2X V_TXFULL2X(1U) + +#define A_TP_DBG_CSIDE_DISP1 0x23b +#define A_TP_DBG_CSIDE_DDP0 0x23c + +#define S_DDPMSGLATEST7 28 +#define M_DDPMSGLATEST7 0xfU +#define V_DDPMSGLATEST7(x) ((x) << S_DDPMSGLATEST7) +#define G_DDPMSGLATEST7(x) (((x) >> S_DDPMSGLATEST7) & M_DDPMSGLATEST7) + +#define S_DDPMSGLATEST6 24 +#define M_DDPMSGLATEST6 0xfU +#define V_DDPMSGLATEST6(x) ((x) << S_DDPMSGLATEST6) +#define G_DDPMSGLATEST6(x) (((x) >> S_DDPMSGLATEST6) & M_DDPMSGLATEST6) + +#define S_DDPMSGLATEST5 20 +#define M_DDPMSGLATEST5 0xfU +#define V_DDPMSGLATEST5(x) ((x) << S_DDPMSGLATEST5) +#define G_DDPMSGLATEST5(x) (((x) >> S_DDPMSGLATEST5) & M_DDPMSGLATEST5) + +#define S_DDPMSGLATEST4 16 +#define M_DDPMSGLATEST4 0xfU +#define V_DDPMSGLATEST4(x) ((x) << S_DDPMSGLATEST4) +#define G_DDPMSGLATEST4(x) (((x) >> S_DDPMSGLATEST4) & M_DDPMSGLATEST4) + +#define S_DDPMSGLATEST3 12 +#define M_DDPMSGLATEST3 0xfU +#define V_DDPMSGLATEST3(x) ((x) << S_DDPMSGLATEST3) +#define G_DDPMSGLATEST3(x) (((x) >> S_DDPMSGLATEST3) & M_DDPMSGLATEST3) + +#define S_DDPMSGLATEST2 8 +#define M_DDPMSGLATEST2 0xfU +#define V_DDPMSGLATEST2(x) ((x) << S_DDPMSGLATEST2) +#define G_DDPMSGLATEST2(x) (((x) >> S_DDPMSGLATEST2) & M_DDPMSGLATEST2) + +#define S_DDPMSGLATEST1 4 +#define M_DDPMSGLATEST1 0xfU +#define V_DDPMSGLATEST1(x) ((x) << S_DDPMSGLATEST1) +#define G_DDPMSGLATEST1(x) (((x) >> S_DDPMSGLATEST1) & M_DDPMSGLATEST1) + +#define S_DDPMSGLATEST0 0 +#define M_DDPMSGLATEST0 0xfU +#define V_DDPMSGLATEST0(x) ((x) << S_DDPMSGLATEST0) +#define G_DDPMSGLATEST0(x) (((x) >> S_DDPMSGLATEST0) & M_DDPMSGLATEST0) + +#define A_TP_DBG_CSIDE_DDP1 0x23d +#define A_TP_DBG_CSIDE_FRM 0x23e + +#define S_CRX2XERROR 28 +#define M_CRX2XERROR 0xfU +#define V_CRX2XERROR(x) ((x) << S_CRX2XERROR) +#define G_CRX2XERROR(x) (((x) >> S_CRX2XERROR) & M_CRX2XERROR) + +#define S_CPLDTX2XERROR 24 +#define M_CPLDTX2XERROR 0xfU +#define V_CPLDTX2XERROR(x) ((x) << S_CPLDTX2XERROR) +#define G_CPLDTX2XERROR(x) (((x) >> S_CPLDTX2XERROR) & M_CPLDTX2XERROR) + +#define S_CTXERROR 22 +#define M_CTXERROR 0x3U +#define V_CTXERROR(x) ((x) << S_CTXERROR) +#define G_CTXERROR(x) (((x) >> S_CTXERROR) & M_CTXERROR) + +#define S_CPLDRXERROR 20 +#define M_CPLDRXERROR 0x3U +#define V_CPLDRXERROR(x) ((x) << S_CPLDRXERROR) +#define G_CPLDRXERROR(x) (((x) >> S_CPLDRXERROR) & M_CPLDRXERROR) + +#define S_CPLRXERROR 18 +#define M_CPLRXERROR 0x3U +#define V_CPLRXERROR(x) ((x) << S_CPLRXERROR) +#define G_CPLRXERROR(x) (((x) >> S_CPLRXERROR) & M_CPLRXERROR) + +#define S_CPLTXERROR 16 +#define M_CPLTXERROR 0x3U +#define V_CPLTXERROR(x) ((x) << S_CPLTXERROR) +#define G_CPLTXERROR(x) (((x) >> S_CPLTXERROR) & M_CPLTXERROR) + +#define S_CPRSERROR 0 +#define M_CPRSERROR 0xfU +#define V_CPRSERROR(x) ((x) << S_CPRSERROR) +#define G_CPRSERROR(x) (((x) >> S_CPRSERROR) & M_CPRSERROR) + +#define A_TP_DBG_CSIDE_INT 0x23f + +#define S_CRXVALID2X 28 +#define M_CRXVALID2X 0xfU +#define V_CRXVALID2X(x) ((x) << S_CRXVALID2X) +#define G_CRXVALID2X(x) (((x) >> S_CRXVALID2X) & M_CRXVALID2X) + +#define S_CRXAFULL2X 24 +#define M_CRXAFULL2X 0xfU +#define V_CRXAFULL2X(x) ((x) << S_CRXAFULL2X) +#define G_CRXAFULL2X(x) (((x) >> S_CRXAFULL2X) & M_CRXAFULL2X) + +#define S_CTXVALID2X 22 +#define M_CTXVALID2X 0x3U +#define V_CTXVALID2X(x) ((x) << S_CTXVALID2X) +#define G_CTXVALID2X(x) (((x) >> S_CTXVALID2X) & M_CTXVALID2X) + +#define S_CTXAFULL2X 20 +#define M_CTXAFULL2X 0x3U +#define V_CTXAFULL2X(x) ((x) << S_CTXAFULL2X) +#define G_CTXAFULL2X(x) (((x) >> S_CTXAFULL2X) & M_CTXAFULL2X) + +#define S_PLD2X_RXVALID 18 +#define M_PLD2X_RXVALID 0x3U +#define V_PLD2X_RXVALID(x) ((x) << S_PLD2X_RXVALID) +#define G_PLD2X_RXVALID(x) (((x) >> S_PLD2X_RXVALID) & M_PLD2X_RXVALID) + +#define S_PLD2X_RXAFULL 16 +#define M_PLD2X_RXAFULL 0x3U +#define V_PLD2X_RXAFULL(x) ((x) << S_PLD2X_RXAFULL) +#define G_PLD2X_RXAFULL(x) (((x) >> S_PLD2X_RXAFULL) & M_PLD2X_RXAFULL) + +#define S_CSIDE_DDP_VALID 14 +#define M_CSIDE_DDP_VALID 0x3U +#define V_CSIDE_DDP_VALID(x) ((x) << S_CSIDE_DDP_VALID) +#define G_CSIDE_DDP_VALID(x) (((x) >> S_CSIDE_DDP_VALID) & M_CSIDE_DDP_VALID) + +#define S_DDP_AFULL 12 +#define M_DDP_AFULL 0x3U +#define V_DDP_AFULL(x) ((x) << S_DDP_AFULL) +#define G_DDP_AFULL(x) (((x) >> S_DDP_AFULL) & M_DDP_AFULL) + +#define S_TRC_RXVALID 11 +#define V_TRC_RXVALID(x) ((x) << S_TRC_RXVALID) +#define F_TRC_RXVALID V_TRC_RXVALID(1U) + +#define S_TRC_RXFULL 10 +#define V_TRC_RXFULL(x) ((x) << S_TRC_RXFULL) +#define F_TRC_RXFULL V_TRC_RXFULL(1U) + +#define S_CPL5_TXVALID 9 +#define V_CPL5_TXVALID(x) ((x) << S_CPL5_TXVALID) +#define F_CPL5_TXVALID V_CPL5_TXVALID(1U) + +#define S_CPL5_TXFULL 8 +#define V_CPL5_TXFULL(x) ((x) << S_CPL5_TXFULL) +#define F_CPL5_TXFULL V_CPL5_TXFULL(1U) + +#define S_PLD2X_TXVALID 4 +#define M_PLD2X_TXVALID 0xfU +#define V_PLD2X_TXVALID(x) ((x) << S_PLD2X_TXVALID) +#define G_PLD2X_TXVALID(x) (((x) >> S_PLD2X_TXVALID) & M_PLD2X_TXVALID) + +#define S_PLD2X_TXAFULL 0 +#define M_PLD2X_TXAFULL 0xfU +#define V_PLD2X_TXAFULL(x) ((x) << S_PLD2X_TXAFULL) +#define G_PLD2X_TXAFULL(x) (((x) >> S_PLD2X_TXAFULL) & M_PLD2X_TXAFULL) + +#define A_TP_CHDR_CONFIG 0x240 + +#define S_CH1HIGH 24 +#define M_CH1HIGH 0xffU +#define V_CH1HIGH(x) ((x) << S_CH1HIGH) +#define G_CH1HIGH(x) (((x) >> S_CH1HIGH) & M_CH1HIGH) + +#define S_CH1LOW 16 +#define M_CH1LOW 0xffU +#define V_CH1LOW(x) ((x) << S_CH1LOW) +#define G_CH1LOW(x) (((x) >> S_CH1LOW) & M_CH1LOW) + +#define S_CH0HIGH 8 +#define M_CH0HIGH 0xffU +#define V_CH0HIGH(x) ((x) << S_CH0HIGH) +#define G_CH0HIGH(x) (((x) >> S_CH0HIGH) & M_CH0HIGH) + +#define S_CH0LOW 0 +#define M_CH0LOW 0xffU +#define V_CH0LOW(x) ((x) << S_CH0LOW) +#define G_CH0LOW(x) (((x) >> S_CH0LOW) & M_CH0LOW) + +#define A_TP_UTRN_CONFIG 0x241 + +#define S_CH2FIFOLIMIT 16 +#define M_CH2FIFOLIMIT 0xffU +#define V_CH2FIFOLIMIT(x) ((x) << S_CH2FIFOLIMIT) +#define G_CH2FIFOLIMIT(x) (((x) >> S_CH2FIFOLIMIT) & M_CH2FIFOLIMIT) + +#define S_CH1FIFOLIMIT 8 +#define M_CH1FIFOLIMIT 0xffU +#define V_CH1FIFOLIMIT(x) ((x) << S_CH1FIFOLIMIT) +#define G_CH1FIFOLIMIT(x) (((x) >> S_CH1FIFOLIMIT) & M_CH1FIFOLIMIT) + +#define S_CH0FIFOLIMIT 0 +#define M_CH0FIFOLIMIT 0xffU +#define V_CH0FIFOLIMIT(x) ((x) << S_CH0FIFOLIMIT) +#define G_CH0FIFOLIMIT(x) (((x) >> S_CH0FIFOLIMIT) & M_CH0FIFOLIMIT) + +#define A_TP_CDSP_CONFIG 0x242 + +#define S_WRITEZEROEN 4 +#define V_WRITEZEROEN(x) ((x) << S_WRITEZEROEN) +#define F_WRITEZEROEN V_WRITEZEROEN(1U) + +#define S_WRITEZEROOP 0 +#define M_WRITEZEROOP 0xfU +#define V_WRITEZEROOP(x) ((x) << S_WRITEZEROOP) +#define G_WRITEZEROOP(x) (((x) >> S_WRITEZEROOP) & M_WRITEZEROOP) + +#define S_STARTSKIPPLD 7 +#define V_STARTSKIPPLD(x) ((x) << S_STARTSKIPPLD) +#define F_STARTSKIPPLD V_STARTSKIPPLD(1U) + +#define S_ATOMICCMDEN 5 +#define V_ATOMICCMDEN(x) ((x) << S_ATOMICCMDEN) +#define F_ATOMICCMDEN V_ATOMICCMDEN(1U) + +#define A_TP_CSPI_POWER 0x243 + +#define S_GATECHNTX3 11 +#define V_GATECHNTX3(x) ((x) << S_GATECHNTX3) +#define F_GATECHNTX3 V_GATECHNTX3(1U) + +#define S_GATECHNTX2 10 +#define V_GATECHNTX2(x) ((x) << S_GATECHNTX2) +#define F_GATECHNTX2 V_GATECHNTX2(1U) + +#define S_GATECHNTX1 9 +#define V_GATECHNTX1(x) ((x) << S_GATECHNTX1) +#define F_GATECHNTX1 V_GATECHNTX1(1U) + +#define S_GATECHNTX0 8 +#define V_GATECHNTX0(x) ((x) << S_GATECHNTX0) +#define F_GATECHNTX0 V_GATECHNTX0(1U) + +#define S_GATECHNRX1 7 +#define V_GATECHNRX1(x) ((x) << S_GATECHNRX1) +#define F_GATECHNRX1 V_GATECHNRX1(1U) + +#define S_GATECHNRX0 6 +#define V_GATECHNRX0(x) ((x) << S_GATECHNRX0) +#define F_GATECHNRX0 V_GATECHNRX0(1U) + +#define S_SLEEPRDYUTRN 4 +#define V_SLEEPRDYUTRN(x) ((x) << S_SLEEPRDYUTRN) +#define F_SLEEPRDYUTRN V_SLEEPRDYUTRN(1U) + +#define S_SLEEPREQUTRN 0 +#define V_SLEEPREQUTRN(x) ((x) << S_SLEEPREQUTRN) +#define F_SLEEPREQUTRN V_SLEEPREQUTRN(1U) + +#define A_TP_TRC_CONFIG 0x244 + +#define S_TRCRR 1 +#define V_TRCRR(x) ((x) << S_TRCRR) +#define F_TRCRR V_TRCRR(1U) + +#define S_TRCCH 0 +#define V_TRCCH(x) ((x) << S_TRCCH) +#define F_TRCCH V_TRCCH(1U) + +#define A_TP_TAG_CONFIG 0x245 + +#define S_ETAGTYPE 16 +#define M_ETAGTYPE 0xffffU +#define V_ETAGTYPE(x) ((x) << S_ETAGTYPE) +#define G_ETAGTYPE(x) (((x) >> S_ETAGTYPE) & M_ETAGTYPE) + +#define A_TP_DBG_CSIDE_PRS 0x246 + +#define S_CPRSSTATE3 24 +#define M_CPRSSTATE3 0x7U +#define V_CPRSSTATE3(x) ((x) << S_CPRSSTATE3) +#define G_CPRSSTATE3(x) (((x) >> S_CPRSSTATE3) & M_CPRSSTATE3) + +#define S_CPRSSTATE2 16 +#define M_CPRSSTATE2 0x7U +#define V_CPRSSTATE2(x) ((x) << S_CPRSSTATE2) +#define G_CPRSSTATE2(x) (((x) >> S_CPRSSTATE2) & M_CPRSSTATE2) + +#define S_CPRSSTATE1 8 +#define M_CPRSSTATE1 0x7U +#define V_CPRSSTATE1(x) ((x) << S_CPRSSTATE1) +#define G_CPRSSTATE1(x) (((x) >> S_CPRSSTATE1) & M_CPRSSTATE1) + +#define S_CPRSSTATE0 0 +#define M_CPRSSTATE0 0x7U +#define V_CPRSSTATE0(x) ((x) << S_CPRSSTATE0) +#define G_CPRSSTATE0(x) (((x) >> S_CPRSSTATE0) & M_CPRSSTATE0) + +#define S_C4TUPBUSY3 31 +#define V_C4TUPBUSY3(x) ((x) << S_C4TUPBUSY3) +#define F_C4TUPBUSY3 V_C4TUPBUSY3(1U) + +#define S_CDBVALID3 30 +#define V_CDBVALID3(x) ((x) << S_CDBVALID3) +#define F_CDBVALID3 V_CDBVALID3(1U) + +#define S_CRXVALID3 29 +#define V_CRXVALID3(x) ((x) << S_CRXVALID3) +#define F_CRXVALID3 V_CRXVALID3(1U) + +#define S_CRXFULL3 28 +#define V_CRXFULL3(x) ((x) << S_CRXFULL3) +#define F_CRXFULL3 V_CRXFULL3(1U) + +#define S_C4TUPBUSY2 23 +#define V_C4TUPBUSY2(x) ((x) << S_C4TUPBUSY2) +#define F_C4TUPBUSY2 V_C4TUPBUSY2(1U) + +#define S_CDBVALID2 22 +#define V_CDBVALID2(x) ((x) << S_CDBVALID2) +#define F_CDBVALID2 V_CDBVALID2(1U) + +#define S_CRXVALID2 21 +#define V_CRXVALID2(x) ((x) << S_CRXVALID2) +#define F_CRXVALID2 V_CRXVALID2(1U) + +#define S_CRXFULL2 20 +#define V_CRXFULL2(x) ((x) << S_CRXFULL2) +#define F_CRXFULL2 V_CRXFULL2(1U) + +#define S_C4TUPBUSY1 15 +#define V_C4TUPBUSY1(x) ((x) << S_C4TUPBUSY1) +#define F_C4TUPBUSY1 V_C4TUPBUSY1(1U) + +#define S_CDBVALID1 14 +#define V_CDBVALID1(x) ((x) << S_CDBVALID1) +#define F_CDBVALID1 V_CDBVALID1(1U) + +#define S_CRXVALID1 13 +#define V_CRXVALID1(x) ((x) << S_CRXVALID1) +#define F_CRXVALID1 V_CRXVALID1(1U) + +#define S_CRXFULL1 12 +#define V_CRXFULL1(x) ((x) << S_CRXFULL1) +#define F_CRXFULL1 V_CRXFULL1(1U) + +#define S_C4TUPBUSY0 7 +#define V_C4TUPBUSY0(x) ((x) << S_C4TUPBUSY0) +#define F_C4TUPBUSY0 V_C4TUPBUSY0(1U) + +#define S_CDBVALID0 6 +#define V_CDBVALID0(x) ((x) << S_CDBVALID0) +#define F_CDBVALID0 V_CDBVALID0(1U) + +#define S_CRXVALID0 5 +#define V_CRXVALID0(x) ((x) << S_CRXVALID0) +#define F_CRXVALID0 V_CRXVALID0(1U) + +#define S_CRXFULL0 4 +#define V_CRXFULL0(x) ((x) << S_CRXFULL0) +#define F_CRXFULL0 V_CRXFULL0(1U) + +#define A_TP_DBG_CSIDE_DEMUX 0x247 + +#define S_CALLDONE 28 +#define M_CALLDONE 0xfU +#define V_CALLDONE(x) ((x) << S_CALLDONE) +#define G_CALLDONE(x) (((x) >> S_CALLDONE) & M_CALLDONE) + +#define S_CTCPL5DONE 24 +#define M_CTCPL5DONE 0xfU +#define V_CTCPL5DONE(x) ((x) << S_CTCPL5DONE) +#define G_CTCPL5DONE(x) (((x) >> S_CTCPL5DONE) & M_CTCPL5DONE) + +#define S_CTXZEROPDONE 20 +#define M_CTXZEROPDONE 0xfU +#define V_CTXZEROPDONE(x) ((x) << S_CTXZEROPDONE) +#define G_CTXZEROPDONE(x) (((x) >> S_CTXZEROPDONE) & M_CTXZEROPDONE) + +#define S_CPLDDONE 16 +#define M_CPLDDONE 0xfU +#define V_CPLDDONE(x) ((x) << S_CPLDDONE) +#define G_CPLDDONE(x) (((x) >> S_CPLDDONE) & M_CPLDDONE) + +#define S_CTTCPOPDONE 12 +#define M_CTTCPOPDONE 0xfU +#define V_CTTCPOPDONE(x) ((x) << S_CTTCPOPDONE) +#define G_CTTCPOPDONE(x) (((x) >> S_CTTCPOPDONE) & M_CTTCPOPDONE) + +#define S_CDBDONE 8 +#define M_CDBDONE 0xfU +#define V_CDBDONE(x) ((x) << S_CDBDONE) +#define G_CDBDONE(x) (((x) >> S_CDBDONE) & M_CDBDONE) + +#define S_CISSFIFODONE 4 +#define M_CISSFIFODONE 0xfU +#define V_CISSFIFODONE(x) ((x) << S_CISSFIFODONE) +#define G_CISSFIFODONE(x) (((x) >> S_CISSFIFODONE) & M_CISSFIFODONE) + +#define S_CTXPKTCSUMDONE 0 +#define M_CTXPKTCSUMDONE 0xfU +#define V_CTXPKTCSUMDONE(x) ((x) << S_CTXPKTCSUMDONE) +#define G_CTXPKTCSUMDONE(x) (((x) >> S_CTXPKTCSUMDONE) & M_CTXPKTCSUMDONE) + +#define S_CARBVALID 28 +#define M_CARBVALID 0xfU +#define V_CARBVALID(x) ((x) << S_CARBVALID) +#define G_CARBVALID(x) (((x) >> S_CARBVALID) & M_CARBVALID) + +#define S_CCPL5DONE 24 +#define M_CCPL5DONE 0xfU +#define V_CCPL5DONE(x) ((x) << S_CCPL5DONE) +#define G_CCPL5DONE(x) (((x) >> S_CCPL5DONE) & M_CCPL5DONE) + +#define S_CTCPOPDONE 12 +#define M_CTCPOPDONE 0xfU +#define V_CTCPOPDONE(x) ((x) << S_CTCPOPDONE) +#define G_CTCPOPDONE(x) (((x) >> S_CTCPOPDONE) & M_CTCPOPDONE) + +#define A_TP_DBG_CSIDE_ARBIT 0x248 + +#define S_CPLVALID3 31 +#define V_CPLVALID3(x) ((x) << S_CPLVALID3) +#define F_CPLVALID3 V_CPLVALID3(1U) + +#define S_PLDVALID3 30 +#define V_PLDVALID3(x) ((x) << S_PLDVALID3) +#define F_PLDVALID3 V_PLDVALID3(1U) + +#define S_CRCVALID3 29 +#define V_CRCVALID3(x) ((x) << S_CRCVALID3) +#define F_CRCVALID3 V_CRCVALID3(1U) + +#define S_ISSVALID3 28 +#define V_ISSVALID3(x) ((x) << S_ISSVALID3) +#define F_ISSVALID3 V_ISSVALID3(1U) + +#define S_DBVALID3 27 +#define V_DBVALID3(x) ((x) << S_DBVALID3) +#define F_DBVALID3 V_DBVALID3(1U) + +#define S_CHKVALID3 26 +#define V_CHKVALID3(x) ((x) << S_CHKVALID3) +#define F_CHKVALID3 V_CHKVALID3(1U) + +#define S_ZRPVALID3 25 +#define V_ZRPVALID3(x) ((x) << S_ZRPVALID3) +#define F_ZRPVALID3 V_ZRPVALID3(1U) + +#define S_ERRVALID3 24 +#define V_ERRVALID3(x) ((x) << S_ERRVALID3) +#define F_ERRVALID3 V_ERRVALID3(1U) + +#define S_CPLVALID2 23 +#define V_CPLVALID2(x) ((x) << S_CPLVALID2) +#define F_CPLVALID2 V_CPLVALID2(1U) + +#define S_PLDVALID2 22 +#define V_PLDVALID2(x) ((x) << S_PLDVALID2) +#define F_PLDVALID2 V_PLDVALID2(1U) + +#define S_CRCVALID2 21 +#define V_CRCVALID2(x) ((x) << S_CRCVALID2) +#define F_CRCVALID2 V_CRCVALID2(1U) + +#define S_ISSVALID2 20 +#define V_ISSVALID2(x) ((x) << S_ISSVALID2) +#define F_ISSVALID2 V_ISSVALID2(1U) + +#define S_DBVALID2 19 +#define V_DBVALID2(x) ((x) << S_DBVALID2) +#define F_DBVALID2 V_DBVALID2(1U) + +#define S_CHKVALID2 18 +#define V_CHKVALID2(x) ((x) << S_CHKVALID2) +#define F_CHKVALID2 V_CHKVALID2(1U) + +#define S_ZRPVALID2 17 +#define V_ZRPVALID2(x) ((x) << S_ZRPVALID2) +#define F_ZRPVALID2 V_ZRPVALID2(1U) + +#define S_ERRVALID2 16 +#define V_ERRVALID2(x) ((x) << S_ERRVALID2) +#define F_ERRVALID2 V_ERRVALID2(1U) + +#define S_CPLVALID1 15 +#define V_CPLVALID1(x) ((x) << S_CPLVALID1) +#define F_CPLVALID1 V_CPLVALID1(1U) + +#define S_PLDVALID1 14 +#define V_PLDVALID1(x) ((x) << S_PLDVALID1) +#define F_PLDVALID1 V_PLDVALID1(1U) + +#define S_CRCVALID1 13 +#define V_CRCVALID1(x) ((x) << S_CRCVALID1) +#define F_CRCVALID1 V_CRCVALID1(1U) + +#define S_ISSVALID1 12 +#define V_ISSVALID1(x) ((x) << S_ISSVALID1) +#define F_ISSVALID1 V_ISSVALID1(1U) + +#define S_DBVALID1 11 +#define V_DBVALID1(x) ((x) << S_DBVALID1) +#define F_DBVALID1 V_DBVALID1(1U) + +#define S_CHKVALID1 10 +#define V_CHKVALID1(x) ((x) << S_CHKVALID1) +#define F_CHKVALID1 V_CHKVALID1(1U) + +#define S_ZRPVALID1 9 +#define V_ZRPVALID1(x) ((x) << S_ZRPVALID1) +#define F_ZRPVALID1 V_ZRPVALID1(1U) + +#define S_ERRVALID1 8 +#define V_ERRVALID1(x) ((x) << S_ERRVALID1) +#define F_ERRVALID1 V_ERRVALID1(1U) + +#define S_CPLVALID0 7 +#define V_CPLVALID0(x) ((x) << S_CPLVALID0) +#define F_CPLVALID0 V_CPLVALID0(1U) + +#define S_PLDVALID0 6 +#define V_PLDVALID0(x) ((x) << S_PLDVALID0) +#define F_PLDVALID0 V_PLDVALID0(1U) + +#define S_CRCVALID0 5 +#define V_CRCVALID0(x) ((x) << S_CRCVALID0) +#define F_CRCVALID0 V_CRCVALID0(1U) + +#define S_ISSVALID0 4 +#define V_ISSVALID0(x) ((x) << S_ISSVALID0) +#define F_ISSVALID0 V_ISSVALID0(1U) + +#define S_DBVALID0 3 +#define V_DBVALID0(x) ((x) << S_DBVALID0) +#define F_DBVALID0 V_DBVALID0(1U) + +#define S_CHKVALID0 2 +#define V_CHKVALID0(x) ((x) << S_CHKVALID0) +#define F_CHKVALID0 V_CHKVALID0(1U) + +#define S_ZRPVALID0 1 +#define V_ZRPVALID0(x) ((x) << S_ZRPVALID0) +#define F_ZRPVALID0 V_ZRPVALID0(1U) + +#define S_ERRVALID0 0 +#define V_ERRVALID0(x) ((x) << S_ERRVALID0) +#define F_ERRVALID0 V_ERRVALID0(1U) + +#define A_TP_FIFO_CONFIG 0x8c0 + +#define S_CH1_OUTPUT 27 +#define M_CH1_OUTPUT 0x1fU +#define V_CH1_OUTPUT(x) ((x) << S_CH1_OUTPUT) +#define G_CH1_OUTPUT(x) (((x) >> S_CH1_OUTPUT) & M_CH1_OUTPUT) + +#define S_CH2_OUTPUT 22 +#define M_CH2_OUTPUT 0x1fU +#define V_CH2_OUTPUT(x) ((x) << S_CH2_OUTPUT) +#define G_CH2_OUTPUT(x) (((x) >> S_CH2_OUTPUT) & M_CH2_OUTPUT) + +#define S_STROBE1 16 +#define V_STROBE1(x) ((x) << S_STROBE1) +#define F_STROBE1 V_STROBE1(1U) + +#define S_CH1_INPUT 11 +#define M_CH1_INPUT 0x1fU +#define V_CH1_INPUT(x) ((x) << S_CH1_INPUT) +#define G_CH1_INPUT(x) (((x) >> S_CH1_INPUT) & M_CH1_INPUT) + +#define S_CH2_INPUT 6 +#define M_CH2_INPUT 0x1fU +#define V_CH2_INPUT(x) ((x) << S_CH2_INPUT) +#define G_CH2_INPUT(x) (((x) >> S_CH2_INPUT) & M_CH2_INPUT) + +#define S_CH3_INPUT 1 +#define M_CH3_INPUT 0x1fU +#define V_CH3_INPUT(x) ((x) << S_CH3_INPUT) +#define G_CH3_INPUT(x) (((x) >> S_CH3_INPUT) & M_CH3_INPUT) + +#define S_STROBE0 0 +#define V_STROBE0(x) ((x) << S_STROBE0) +#define F_STROBE0 V_STROBE0(1U) + +#define A_TP_MIB_MAC_IN_ERR_0 0x0 +#define A_TP_MIB_MAC_IN_ERR_1 0x1 +#define A_TP_MIB_MAC_IN_ERR_2 0x2 +#define A_TP_MIB_MAC_IN_ERR_3 0x3 +#define A_TP_MIB_HDR_IN_ERR_0 0x4 +#define A_TP_MIB_HDR_IN_ERR_1 0x5 +#define A_TP_MIB_HDR_IN_ERR_2 0x6 +#define A_TP_MIB_HDR_IN_ERR_3 0x7 +#define A_TP_MIB_TCP_IN_ERR_0 0x8 +#define A_TP_MIB_TCP_IN_ERR_1 0x9 +#define A_TP_MIB_TCP_IN_ERR_2 0xa +#define A_TP_MIB_TCP_IN_ERR_3 0xb +#define A_TP_MIB_TCP_OUT_RST 0xc +#define A_TP_MIB_TCP_IN_SEG_HI 0x10 +#define A_TP_MIB_TCP_IN_SEG_LO 0x11 +#define A_TP_MIB_TCP_OUT_SEG_HI 0x12 +#define A_TP_MIB_TCP_OUT_SEG_LO 0x13 +#define A_TP_MIB_TCP_RXT_SEG_HI 0x14 +#define A_TP_MIB_TCP_RXT_SEG_LO 0x15 +#define A_TP_MIB_TNL_CNG_DROP_0 0x18 +#define A_TP_MIB_TNL_CNG_DROP_1 0x19 +#define A_TP_MIB_TNL_CNG_DROP_2 0x1a +#define A_TP_MIB_TNL_CNG_DROP_3 0x1b +#define A_TP_MIB_OFD_CHN_DROP_0 0x1c +#define A_TP_MIB_OFD_CHN_DROP_1 0x1d +#define A_TP_MIB_OFD_CHN_DROP_2 0x1e +#define A_TP_MIB_OFD_CHN_DROP_3 0x1f +#define A_TP_MIB_TNL_OUT_PKT_0 0x20 +#define A_TP_MIB_TNL_OUT_PKT_1 0x21 +#define A_TP_MIB_TNL_OUT_PKT_2 0x22 +#define A_TP_MIB_TNL_OUT_PKT_3 0x23 +#define A_TP_MIB_TNL_IN_PKT_0 0x24 +#define A_TP_MIB_TNL_IN_PKT_1 0x25 +#define A_TP_MIB_TNL_IN_PKT_2 0x26 +#define A_TP_MIB_TNL_IN_PKT_3 0x27 +#define A_TP_MIB_TCP_V6IN_ERR_0 0x28 +#define A_TP_MIB_TCP_V6IN_ERR_1 0x29 +#define A_TP_MIB_TCP_V6IN_ERR_2 0x2a +#define A_TP_MIB_TCP_V6IN_ERR_3 0x2b +#define A_TP_MIB_TCP_V6OUT_RST 0x2c +#define A_TP_MIB_TCP_V6IN_SEG_HI 0x30 +#define A_TP_MIB_TCP_V6IN_SEG_LO 0x31 +#define A_TP_MIB_TCP_V6OUT_SEG_HI 0x32 +#define A_TP_MIB_TCP_V6OUT_SEG_LO 0x33 +#define A_TP_MIB_TCP_V6RXT_SEG_HI 0x34 +#define A_TP_MIB_TCP_V6RXT_SEG_LO 0x35 +#define A_TP_MIB_OFD_ARP_DROP 0x36 +#define A_TP_MIB_OFD_DFR_DROP 0x37 +#define A_TP_MIB_CPL_IN_REQ_0 0x38 +#define A_TP_MIB_CPL_IN_REQ_1 0x39 +#define A_TP_MIB_CPL_IN_REQ_2 0x3a +#define A_TP_MIB_CPL_IN_REQ_3 0x3b +#define A_TP_MIB_CPL_OUT_RSP_0 0x3c +#define A_TP_MIB_CPL_OUT_RSP_1 0x3d +#define A_TP_MIB_CPL_OUT_RSP_2 0x3e +#define A_TP_MIB_CPL_OUT_RSP_3 0x3f +#define A_TP_MIB_TNL_LPBK_0 0x40 +#define A_TP_MIB_TNL_LPBK_1 0x41 +#define A_TP_MIB_TNL_LPBK_2 0x42 +#define A_TP_MIB_TNL_LPBK_3 0x43 +#define A_TP_MIB_TNL_DROP_0 0x44 +#define A_TP_MIB_TNL_DROP_1 0x45 +#define A_TP_MIB_TNL_DROP_2 0x46 +#define A_TP_MIB_TNL_DROP_3 0x47 +#define A_TP_MIB_FCOE_DDP_0 0x48 +#define A_TP_MIB_FCOE_DDP_1 0x49 +#define A_TP_MIB_FCOE_DDP_2 0x4a +#define A_TP_MIB_FCOE_DDP_3 0x4b +#define A_TP_MIB_FCOE_DROP_0 0x4c +#define A_TP_MIB_FCOE_DROP_1 0x4d +#define A_TP_MIB_FCOE_DROP_2 0x4e +#define A_TP_MIB_FCOE_DROP_3 0x4f +#define A_TP_MIB_FCOE_BYTE_0_HI 0x50 +#define A_TP_MIB_FCOE_BYTE_0_LO 0x51 +#define A_TP_MIB_FCOE_BYTE_1_HI 0x52 +#define A_TP_MIB_FCOE_BYTE_1_LO 0x53 +#define A_TP_MIB_FCOE_BYTE_2_HI 0x54 +#define A_TP_MIB_FCOE_BYTE_2_LO 0x55 +#define A_TP_MIB_FCOE_BYTE_3_HI 0x56 +#define A_TP_MIB_FCOE_BYTE_3_LO 0x57 +#define A_TP_MIB_OFD_VLN_DROP_0 0x58 +#define A_TP_MIB_OFD_VLN_DROP_1 0x59 +#define A_TP_MIB_OFD_VLN_DROP_2 0x5a +#define A_TP_MIB_OFD_VLN_DROP_3 0x5b +#define A_TP_MIB_USM_PKTS 0x5c +#define A_TP_MIB_USM_DROP 0x5d +#define A_TP_MIB_USM_BYTES_HI 0x5e +#define A_TP_MIB_USM_BYTES_LO 0x5f +#define A_TP_MIB_TID_DEL 0x60 +#define A_TP_MIB_TID_INV 0x61 +#define A_TP_MIB_TID_ACT 0x62 +#define A_TP_MIB_TID_PAS 0x63 +#define A_TP_MIB_RQE_DFR_PKT 0x64 +#define A_TP_MIB_RQE_DFR_MOD 0x65 +#define A_TP_MIB_CPL_OUT_ERR_0 0x68 +#define A_TP_MIB_CPL_OUT_ERR_1 0x69 +#define A_TP_MIB_CPL_OUT_ERR_2 0x6a +#define A_TP_MIB_CPL_OUT_ERR_3 0x6b +#define A_TP_MIB_ENG_LINE_0 0x6c +#define A_TP_MIB_ENG_LINE_1 0x6d +#define A_TP_MIB_ENG_LINE_2 0x6e +#define A_TP_MIB_ENG_LINE_3 0x6f + +/* registers for module ULP_TX */ +#define ULP_TX_BASE_ADDR 0x8dc0 + +#define A_ULP_TX_CONFIG 0x8dc0 + +#define S_STAG_MIX_ENABLE 2 +#define V_STAG_MIX_ENABLE(x) ((x) << S_STAG_MIX_ENABLE) +#define F_STAG_MIX_ENABLE V_STAG_MIX_ENABLE(1U) + +#define S_STAGF_FIX_DISABLE 1 +#define V_STAGF_FIX_DISABLE(x) ((x) << S_STAGF_FIX_DISABLE) +#define F_STAGF_FIX_DISABLE V_STAGF_FIX_DISABLE(1U) + +#define S_EXTRA_TAG_INSERTION_ENABLE 0 +#define V_EXTRA_TAG_INSERTION_ENABLE(x) ((x) << S_EXTRA_TAG_INSERTION_ENABLE) +#define F_EXTRA_TAG_INSERTION_ENABLE V_EXTRA_TAG_INSERTION_ENABLE(1U) + +#define S_PHYS_ADDR_RESP_EN 6 +#define V_PHYS_ADDR_RESP_EN(x) ((x) << S_PHYS_ADDR_RESP_EN) +#define F_PHYS_ADDR_RESP_EN V_PHYS_ADDR_RESP_EN(1U) + +#define S_ENDIANESS_CHANGE 5 +#define V_ENDIANESS_CHANGE(x) ((x) << S_ENDIANESS_CHANGE) +#define F_ENDIANESS_CHANGE V_ENDIANESS_CHANGE(1U) + +#define S_ERR_RTAG_EN 4 +#define V_ERR_RTAG_EN(x) ((x) << S_ERR_RTAG_EN) +#define F_ERR_RTAG_EN V_ERR_RTAG_EN(1U) + +#define S_TSO_ETHLEN_EN 3 +#define V_TSO_ETHLEN_EN(x) ((x) << S_TSO_ETHLEN_EN) +#define F_TSO_ETHLEN_EN V_TSO_ETHLEN_EN(1U) + +#define S_EMSG_MORE_INFO 2 +#define V_EMSG_MORE_INFO(x) ((x) << S_EMSG_MORE_INFO) +#define F_EMSG_MORE_INFO V_EMSG_MORE_INFO(1U) + +#define S_LOSDR 1 +#define V_LOSDR(x) ((x) << S_LOSDR) +#define F_LOSDR V_LOSDR(1U) + +#define A_ULP_TX_PERR_INJECT 0x8dc4 +#define A_ULP_TX_INT_ENABLE 0x8dc8 + +#define S_PBL_BOUND_ERR_CH3 31 +#define V_PBL_BOUND_ERR_CH3(x) ((x) << S_PBL_BOUND_ERR_CH3) +#define F_PBL_BOUND_ERR_CH3 V_PBL_BOUND_ERR_CH3(1U) + +#define S_PBL_BOUND_ERR_CH2 30 +#define V_PBL_BOUND_ERR_CH2(x) ((x) << S_PBL_BOUND_ERR_CH2) +#define F_PBL_BOUND_ERR_CH2 V_PBL_BOUND_ERR_CH2(1U) + +#define S_PBL_BOUND_ERR_CH1 29 +#define V_PBL_BOUND_ERR_CH1(x) ((x) << S_PBL_BOUND_ERR_CH1) +#define F_PBL_BOUND_ERR_CH1 V_PBL_BOUND_ERR_CH1(1U) + +#define S_PBL_BOUND_ERR_CH0 28 +#define V_PBL_BOUND_ERR_CH0(x) ((x) << S_PBL_BOUND_ERR_CH0) +#define F_PBL_BOUND_ERR_CH0 V_PBL_BOUND_ERR_CH0(1U) + +#define S_SGE2ULP_FIFO_PERR_SET3 27 +#define V_SGE2ULP_FIFO_PERR_SET3(x) ((x) << S_SGE2ULP_FIFO_PERR_SET3) +#define F_SGE2ULP_FIFO_PERR_SET3 V_SGE2ULP_FIFO_PERR_SET3(1U) + +#define S_SGE2ULP_FIFO_PERR_SET2 26 +#define V_SGE2ULP_FIFO_PERR_SET2(x) ((x) << S_SGE2ULP_FIFO_PERR_SET2) +#define F_SGE2ULP_FIFO_PERR_SET2 V_SGE2ULP_FIFO_PERR_SET2(1U) + +#define S_SGE2ULP_FIFO_PERR_SET1 25 +#define V_SGE2ULP_FIFO_PERR_SET1(x) ((x) << S_SGE2ULP_FIFO_PERR_SET1) +#define F_SGE2ULP_FIFO_PERR_SET1 V_SGE2ULP_FIFO_PERR_SET1(1U) + +#define S_SGE2ULP_FIFO_PERR_SET0 24 +#define V_SGE2ULP_FIFO_PERR_SET0(x) ((x) << S_SGE2ULP_FIFO_PERR_SET0) +#define F_SGE2ULP_FIFO_PERR_SET0 V_SGE2ULP_FIFO_PERR_SET0(1U) + +#define S_CIM2ULP_FIFO_PERR_SET3 23 +#define V_CIM2ULP_FIFO_PERR_SET3(x) ((x) << S_CIM2ULP_FIFO_PERR_SET3) +#define F_CIM2ULP_FIFO_PERR_SET3 V_CIM2ULP_FIFO_PERR_SET3(1U) + +#define S_CIM2ULP_FIFO_PERR_SET2 22 +#define V_CIM2ULP_FIFO_PERR_SET2(x) ((x) << S_CIM2ULP_FIFO_PERR_SET2) +#define F_CIM2ULP_FIFO_PERR_SET2 V_CIM2ULP_FIFO_PERR_SET2(1U) + +#define S_CIM2ULP_FIFO_PERR_SET1 21 +#define V_CIM2ULP_FIFO_PERR_SET1(x) ((x) << S_CIM2ULP_FIFO_PERR_SET1) +#define F_CIM2ULP_FIFO_PERR_SET1 V_CIM2ULP_FIFO_PERR_SET1(1U) + +#define S_CIM2ULP_FIFO_PERR_SET0 20 +#define V_CIM2ULP_FIFO_PERR_SET0(x) ((x) << S_CIM2ULP_FIFO_PERR_SET0) +#define F_CIM2ULP_FIFO_PERR_SET0 V_CIM2ULP_FIFO_PERR_SET0(1U) + +#define S_CQE_FIFO_PERR_SET3 19 +#define V_CQE_FIFO_PERR_SET3(x) ((x) << S_CQE_FIFO_PERR_SET3) +#define F_CQE_FIFO_PERR_SET3 V_CQE_FIFO_PERR_SET3(1U) + +#define S_CQE_FIFO_PERR_SET2 18 +#define V_CQE_FIFO_PERR_SET2(x) ((x) << S_CQE_FIFO_PERR_SET2) +#define F_CQE_FIFO_PERR_SET2 V_CQE_FIFO_PERR_SET2(1U) + +#define S_CQE_FIFO_PERR_SET1 17 +#define V_CQE_FIFO_PERR_SET1(x) ((x) << S_CQE_FIFO_PERR_SET1) +#define F_CQE_FIFO_PERR_SET1 V_CQE_FIFO_PERR_SET1(1U) + +#define S_CQE_FIFO_PERR_SET0 16 +#define V_CQE_FIFO_PERR_SET0(x) ((x) << S_CQE_FIFO_PERR_SET0) +#define F_CQE_FIFO_PERR_SET0 V_CQE_FIFO_PERR_SET0(1U) + +#define S_PBL_FIFO_PERR_SET3 15 +#define V_PBL_FIFO_PERR_SET3(x) ((x) << S_PBL_FIFO_PERR_SET3) +#define F_PBL_FIFO_PERR_SET3 V_PBL_FIFO_PERR_SET3(1U) + +#define S_PBL_FIFO_PERR_SET2 14 +#define V_PBL_FIFO_PERR_SET2(x) ((x) << S_PBL_FIFO_PERR_SET2) +#define F_PBL_FIFO_PERR_SET2 V_PBL_FIFO_PERR_SET2(1U) + +#define S_PBL_FIFO_PERR_SET1 13 +#define V_PBL_FIFO_PERR_SET1(x) ((x) << S_PBL_FIFO_PERR_SET1) +#define F_PBL_FIFO_PERR_SET1 V_PBL_FIFO_PERR_SET1(1U) + +#define S_PBL_FIFO_PERR_SET0 12 +#define V_PBL_FIFO_PERR_SET0(x) ((x) << S_PBL_FIFO_PERR_SET0) +#define F_PBL_FIFO_PERR_SET0 V_PBL_FIFO_PERR_SET0(1U) + +#define S_CMD_FIFO_PERR_SET3 11 +#define V_CMD_FIFO_PERR_SET3(x) ((x) << S_CMD_FIFO_PERR_SET3) +#define F_CMD_FIFO_PERR_SET3 V_CMD_FIFO_PERR_SET3(1U) + +#define S_CMD_FIFO_PERR_SET2 10 +#define V_CMD_FIFO_PERR_SET2(x) ((x) << S_CMD_FIFO_PERR_SET2) +#define F_CMD_FIFO_PERR_SET2 V_CMD_FIFO_PERR_SET2(1U) + +#define S_CMD_FIFO_PERR_SET1 9 +#define V_CMD_FIFO_PERR_SET1(x) ((x) << S_CMD_FIFO_PERR_SET1) +#define F_CMD_FIFO_PERR_SET1 V_CMD_FIFO_PERR_SET1(1U) + +#define S_CMD_FIFO_PERR_SET0 8 +#define V_CMD_FIFO_PERR_SET0(x) ((x) << S_CMD_FIFO_PERR_SET0) +#define F_CMD_FIFO_PERR_SET0 V_CMD_FIFO_PERR_SET0(1U) + +#define S_LSO_HDR_SRAM_PERR_SET3 7 +#define V_LSO_HDR_SRAM_PERR_SET3(x) ((x) << S_LSO_HDR_SRAM_PERR_SET3) +#define F_LSO_HDR_SRAM_PERR_SET3 V_LSO_HDR_SRAM_PERR_SET3(1U) + +#define S_LSO_HDR_SRAM_PERR_SET2 6 +#define V_LSO_HDR_SRAM_PERR_SET2(x) ((x) << S_LSO_HDR_SRAM_PERR_SET2) +#define F_LSO_HDR_SRAM_PERR_SET2 V_LSO_HDR_SRAM_PERR_SET2(1U) + +#define S_LSO_HDR_SRAM_PERR_SET1 5 +#define V_LSO_HDR_SRAM_PERR_SET1(x) ((x) << S_LSO_HDR_SRAM_PERR_SET1) +#define F_LSO_HDR_SRAM_PERR_SET1 V_LSO_HDR_SRAM_PERR_SET1(1U) + +#define S_LSO_HDR_SRAM_PERR_SET0 4 +#define V_LSO_HDR_SRAM_PERR_SET0(x) ((x) << S_LSO_HDR_SRAM_PERR_SET0) +#define F_LSO_HDR_SRAM_PERR_SET0 V_LSO_HDR_SRAM_PERR_SET0(1U) + +#define S_IMM_DATA_PERR_SET_CH3 3 +#define V_IMM_DATA_PERR_SET_CH3(x) ((x) << S_IMM_DATA_PERR_SET_CH3) +#define F_IMM_DATA_PERR_SET_CH3 V_IMM_DATA_PERR_SET_CH3(1U) + +#define S_IMM_DATA_PERR_SET_CH2 2 +#define V_IMM_DATA_PERR_SET_CH2(x) ((x) << S_IMM_DATA_PERR_SET_CH2) +#define F_IMM_DATA_PERR_SET_CH2 V_IMM_DATA_PERR_SET_CH2(1U) + +#define S_IMM_DATA_PERR_SET_CH1 1 +#define V_IMM_DATA_PERR_SET_CH1(x) ((x) << S_IMM_DATA_PERR_SET_CH1) +#define F_IMM_DATA_PERR_SET_CH1 V_IMM_DATA_PERR_SET_CH1(1U) + +#define S_IMM_DATA_PERR_SET_CH0 0 +#define V_IMM_DATA_PERR_SET_CH0(x) ((x) << S_IMM_DATA_PERR_SET_CH0) +#define F_IMM_DATA_PERR_SET_CH0 V_IMM_DATA_PERR_SET_CH0(1U) + +#define A_ULP_TX_INT_CAUSE 0x8dcc +#define A_ULP_TX_PERR_ENABLE 0x8dd0 +#define A_ULP_TX_TPT_LLIMIT 0x8dd4 +#define A_ULP_TX_TPT_ULIMIT 0x8dd8 +#define A_ULP_TX_PBL_LLIMIT 0x8ddc +#define A_ULP_TX_PBL_ULIMIT 0x8de0 +#define A_ULP_TX_CPL_ERR_OFFSET 0x8de4 +#define A_ULP_TX_CPL_ERR_MASK_L 0x8de8 +#define A_ULP_TX_CPL_ERR_MASK_H 0x8dec +#define A_ULP_TX_CPL_ERR_VALUE_L 0x8df0 +#define A_ULP_TX_CPL_ERR_VALUE_H 0x8df4 +#define A_ULP_TX_CPL_PACK_SIZE1 0x8df8 + +#define S_CH3SIZE1 24 +#define M_CH3SIZE1 0xffU +#define V_CH3SIZE1(x) ((x) << S_CH3SIZE1) +#define G_CH3SIZE1(x) (((x) >> S_CH3SIZE1) & M_CH3SIZE1) + +#define S_CH2SIZE1 16 +#define M_CH2SIZE1 0xffU +#define V_CH2SIZE1(x) ((x) << S_CH2SIZE1) +#define G_CH2SIZE1(x) (((x) >> S_CH2SIZE1) & M_CH2SIZE1) + +#define S_CH1SIZE1 8 +#define M_CH1SIZE1 0xffU +#define V_CH1SIZE1(x) ((x) << S_CH1SIZE1) +#define G_CH1SIZE1(x) (((x) >> S_CH1SIZE1) & M_CH1SIZE1) + +#define S_CH0SIZE1 0 +#define M_CH0SIZE1 0xffU +#define V_CH0SIZE1(x) ((x) << S_CH0SIZE1) +#define G_CH0SIZE1(x) (((x) >> S_CH0SIZE1) & M_CH0SIZE1) + +#define A_ULP_TX_CPL_PACK_SIZE2 0x8dfc + +#define S_CH3SIZE2 24 +#define M_CH3SIZE2 0xffU +#define V_CH3SIZE2(x) ((x) << S_CH3SIZE2) +#define G_CH3SIZE2(x) (((x) >> S_CH3SIZE2) & M_CH3SIZE2) + +#define S_CH2SIZE2 16 +#define M_CH2SIZE2 0xffU +#define V_CH2SIZE2(x) ((x) << S_CH2SIZE2) +#define G_CH2SIZE2(x) (((x) >> S_CH2SIZE2) & M_CH2SIZE2) + +#define S_CH1SIZE2 8 +#define M_CH1SIZE2 0xffU +#define V_CH1SIZE2(x) ((x) << S_CH1SIZE2) +#define G_CH1SIZE2(x) (((x) >> S_CH1SIZE2) & M_CH1SIZE2) + +#define S_CH0SIZE2 0 +#define M_CH0SIZE2 0xffU +#define V_CH0SIZE2(x) ((x) << S_CH0SIZE2) +#define G_CH0SIZE2(x) (((x) >> S_CH0SIZE2) & M_CH0SIZE2) + +#define A_ULP_TX_ERR_MSG2CIM 0x8e00 +#define A_ULP_TX_ERR_TABLE_BASE 0x8e04 +#define A_ULP_TX_ERR_CNT_CH0 0x8e10 + +#define S_ERR_CNT0 0 +#define M_ERR_CNT0 0xfffffU +#define V_ERR_CNT0(x) ((x) << S_ERR_CNT0) +#define G_ERR_CNT0(x) (((x) >> S_ERR_CNT0) & M_ERR_CNT0) + +#define A_ULP_TX_ERR_CNT_CH1 0x8e14 + +#define S_ERR_CNT1 0 +#define M_ERR_CNT1 0xfffffU +#define V_ERR_CNT1(x) ((x) << S_ERR_CNT1) +#define G_ERR_CNT1(x) (((x) >> S_ERR_CNT1) & M_ERR_CNT1) + +#define A_ULP_TX_ERR_CNT_CH2 0x8e18 + +#define S_ERR_CNT2 0 +#define M_ERR_CNT2 0xfffffU +#define V_ERR_CNT2(x) ((x) << S_ERR_CNT2) +#define G_ERR_CNT2(x) (((x) >> S_ERR_CNT2) & M_ERR_CNT2) + +#define A_ULP_TX_ERR_CNT_CH3 0x8e1c + +#define S_ERR_CNT3 0 +#define M_ERR_CNT3 0xfffffU +#define V_ERR_CNT3(x) ((x) << S_ERR_CNT3) +#define G_ERR_CNT3(x) (((x) >> S_ERR_CNT3) & M_ERR_CNT3) + +#define A_ULP_TX_FC_SOF 0x8e20 + +#define S_SOF_FS3 24 +#define M_SOF_FS3 0xffU +#define V_SOF_FS3(x) ((x) << S_SOF_FS3) +#define G_SOF_FS3(x) (((x) >> S_SOF_FS3) & M_SOF_FS3) + +#define S_SOF_FS2 16 +#define M_SOF_FS2 0xffU +#define V_SOF_FS2(x) ((x) << S_SOF_FS2) +#define G_SOF_FS2(x) (((x) >> S_SOF_FS2) & M_SOF_FS2) + +#define S_SOF_3 8 +#define M_SOF_3 0xffU +#define V_SOF_3(x) ((x) << S_SOF_3) +#define G_SOF_3(x) (((x) >> S_SOF_3) & M_SOF_3) + +#define S_SOF_2 0 +#define M_SOF_2 0xffU +#define V_SOF_2(x) ((x) << S_SOF_2) +#define G_SOF_2(x) (((x) >> S_SOF_2) & M_SOF_2) + +#define A_ULP_TX_FC_EOF 0x8e24 + +#define S_EOF_LS3 24 +#define M_EOF_LS3 0xffU +#define V_EOF_LS3(x) ((x) << S_EOF_LS3) +#define G_EOF_LS3(x) (((x) >> S_EOF_LS3) & M_EOF_LS3) + +#define S_EOF_LS2 16 +#define M_EOF_LS2 0xffU +#define V_EOF_LS2(x) ((x) << S_EOF_LS2) +#define G_EOF_LS2(x) (((x) >> S_EOF_LS2) & M_EOF_LS2) + +#define S_EOF_3 8 +#define M_EOF_3 0xffU +#define V_EOF_3(x) ((x) << S_EOF_3) +#define G_EOF_3(x) (((x) >> S_EOF_3) & M_EOF_3) + +#define S_EOF_2 0 +#define M_EOF_2 0xffU +#define V_EOF_2(x) ((x) << S_EOF_2) +#define G_EOF_2(x) (((x) >> S_EOF_2) & M_EOF_2) + +#define A_ULP_TX_CGEN_GLOBAL 0x8e28 + +#define S_ULP_TX_GLOBAL_CGEN 0 +#define V_ULP_TX_GLOBAL_CGEN(x) ((x) << S_ULP_TX_GLOBAL_CGEN) +#define F_ULP_TX_GLOBAL_CGEN V_ULP_TX_GLOBAL_CGEN(1U) + +#define A_ULP_TX_CGEN 0x8e2c + +#define S_ULP_TX_CGEN_STORAGE 8 +#define M_ULP_TX_CGEN_STORAGE 0xfU +#define V_ULP_TX_CGEN_STORAGE(x) ((x) << S_ULP_TX_CGEN_STORAGE) +#define G_ULP_TX_CGEN_STORAGE(x) (((x) >> S_ULP_TX_CGEN_STORAGE) & M_ULP_TX_CGEN_STORAGE) + +#define S_ULP_TX_CGEN_RDMA 4 +#define M_ULP_TX_CGEN_RDMA 0xfU +#define V_ULP_TX_CGEN_RDMA(x) ((x) << S_ULP_TX_CGEN_RDMA) +#define G_ULP_TX_CGEN_RDMA(x) (((x) >> S_ULP_TX_CGEN_RDMA) & M_ULP_TX_CGEN_RDMA) + +#define S_ULP_TX_CGEN_CHANNEL 0 +#define M_ULP_TX_CGEN_CHANNEL 0xfU +#define V_ULP_TX_CGEN_CHANNEL(x) ((x) << S_ULP_TX_CGEN_CHANNEL) +#define G_ULP_TX_CGEN_CHANNEL(x) (((x) >> S_ULP_TX_CGEN_CHANNEL) & M_ULP_TX_CGEN_CHANNEL) + +#define A_ULP_TX_ULP2TP_BIST_CMD 0x8e30 +#define A_ULP_TX_MEM_CFG 0x8e30 + +#define S_WRREQ_SZ 0 +#define M_WRREQ_SZ 0x7U +#define V_WRREQ_SZ(x) ((x) << S_WRREQ_SZ) +#define G_WRREQ_SZ(x) (((x) >> S_WRREQ_SZ) & M_WRREQ_SZ) + +#define A_ULP_TX_ULP2TP_BIST_ERROR_CNT 0x8e34 +#define A_ULP_TX_PERR_INJECT_2 0x8e34 +#define A_ULP_TX_FPGA_CMD_CTRL 0x8e38 +#define A_ULP_TX_T5_FPGA_CMD_CTRL 0x8e38 + +#define S_CHANNEL_SEL 12 +#define M_CHANNEL_SEL 0x3U +#define V_CHANNEL_SEL(x) ((x) << S_CHANNEL_SEL) +#define G_CHANNEL_SEL(x) (((x) >> S_CHANNEL_SEL) & M_CHANNEL_SEL) + +#define S_INTF_SEL 4 +#define M_INTF_SEL 0xfU +#define V_INTF_SEL(x) ((x) << S_INTF_SEL) +#define G_INTF_SEL(x) (((x) >> S_INTF_SEL) & M_INTF_SEL) + +#define S_NUM_FLITS 1 +#define M_NUM_FLITS 0x7U +#define V_NUM_FLITS(x) ((x) << S_NUM_FLITS) +#define G_NUM_FLITS(x) (((x) >> S_NUM_FLITS) & M_NUM_FLITS) + +#define S_CMD_GEN_EN 0 +#define V_CMD_GEN_EN(x) ((x) << S_CMD_GEN_EN) +#define F_CMD_GEN_EN V_CMD_GEN_EN(1U) + +#define A_ULP_TX_FPGA_CMD_0 0x8e3c +#define A_ULP_TX_T5_FPGA_CMD_0 0x8e3c +#define A_ULP_TX_FPGA_CMD_1 0x8e40 +#define A_ULP_TX_T5_FPGA_CMD_1 0x8e40 +#define A_ULP_TX_FPGA_CMD_2 0x8e44 +#define A_ULP_TX_T5_FPGA_CMD_2 0x8e44 +#define A_ULP_TX_FPGA_CMD_3 0x8e48 +#define A_ULP_TX_T5_FPGA_CMD_3 0x8e48 +#define A_ULP_TX_FPGA_CMD_4 0x8e4c +#define A_ULP_TX_T5_FPGA_CMD_4 0x8e4c +#define A_ULP_TX_FPGA_CMD_5 0x8e50 +#define A_ULP_TX_T5_FPGA_CMD_5 0x8e50 +#define A_ULP_TX_FPGA_CMD_6 0x8e54 +#define A_ULP_TX_T5_FPGA_CMD_6 0x8e54 +#define A_ULP_TX_FPGA_CMD_7 0x8e58 +#define A_ULP_TX_T5_FPGA_CMD_7 0x8e58 +#define A_ULP_TX_FPGA_CMD_8 0x8e5c +#define A_ULP_TX_T5_FPGA_CMD_8 0x8e5c +#define A_ULP_TX_FPGA_CMD_9 0x8e60 +#define A_ULP_TX_T5_FPGA_CMD_9 0x8e60 +#define A_ULP_TX_FPGA_CMD_10 0x8e64 +#define A_ULP_TX_T5_FPGA_CMD_10 0x8e64 +#define A_ULP_TX_FPGA_CMD_11 0x8e68 +#define A_ULP_TX_T5_FPGA_CMD_11 0x8e68 +#define A_ULP_TX_FPGA_CMD_12 0x8e6c +#define A_ULP_TX_T5_FPGA_CMD_12 0x8e6c +#define A_ULP_TX_FPGA_CMD_13 0x8e70 +#define A_ULP_TX_T5_FPGA_CMD_13 0x8e70 +#define A_ULP_TX_FPGA_CMD_14 0x8e74 +#define A_ULP_TX_T5_FPGA_CMD_14 0x8e74 +#define A_ULP_TX_FPGA_CMD_15 0x8e78 +#define A_ULP_TX_T5_FPGA_CMD_15 0x8e78 +#define A_ULP_TX_INT_ENABLE_2 0x8e7c + +#define S_SMARBT2ULP_DATA_PERR_SET 12 +#define V_SMARBT2ULP_DATA_PERR_SET(x) ((x) << S_SMARBT2ULP_DATA_PERR_SET) +#define F_SMARBT2ULP_DATA_PERR_SET V_SMARBT2ULP_DATA_PERR_SET(1U) + +#define S_ULP2TP_DATA_PERR_SET 11 +#define V_ULP2TP_DATA_PERR_SET(x) ((x) << S_ULP2TP_DATA_PERR_SET) +#define F_ULP2TP_DATA_PERR_SET V_ULP2TP_DATA_PERR_SET(1U) + +#define S_MA2ULP_DATA_PERR_SET 10 +#define V_MA2ULP_DATA_PERR_SET(x) ((x) << S_MA2ULP_DATA_PERR_SET) +#define F_MA2ULP_DATA_PERR_SET V_MA2ULP_DATA_PERR_SET(1U) + +#define S_SGE2ULP_DATA_PERR_SET 9 +#define V_SGE2ULP_DATA_PERR_SET(x) ((x) << S_SGE2ULP_DATA_PERR_SET) +#define F_SGE2ULP_DATA_PERR_SET V_SGE2ULP_DATA_PERR_SET(1U) + +#define S_CIM2ULP_DATA_PERR_SET 8 +#define V_CIM2ULP_DATA_PERR_SET(x) ((x) << S_CIM2ULP_DATA_PERR_SET) +#define F_CIM2ULP_DATA_PERR_SET V_CIM2ULP_DATA_PERR_SET(1U) + +#define S_FSO_HDR_SRAM_PERR_SET3 7 +#define V_FSO_HDR_SRAM_PERR_SET3(x) ((x) << S_FSO_HDR_SRAM_PERR_SET3) +#define F_FSO_HDR_SRAM_PERR_SET3 V_FSO_HDR_SRAM_PERR_SET3(1U) + +#define S_FSO_HDR_SRAM_PERR_SET2 6 +#define V_FSO_HDR_SRAM_PERR_SET2(x) ((x) << S_FSO_HDR_SRAM_PERR_SET2) +#define F_FSO_HDR_SRAM_PERR_SET2 V_FSO_HDR_SRAM_PERR_SET2(1U) + +#define S_FSO_HDR_SRAM_PERR_SET1 5 +#define V_FSO_HDR_SRAM_PERR_SET1(x) ((x) << S_FSO_HDR_SRAM_PERR_SET1) +#define F_FSO_HDR_SRAM_PERR_SET1 V_FSO_HDR_SRAM_PERR_SET1(1U) + +#define S_FSO_HDR_SRAM_PERR_SET0 4 +#define V_FSO_HDR_SRAM_PERR_SET0(x) ((x) << S_FSO_HDR_SRAM_PERR_SET0) +#define F_FSO_HDR_SRAM_PERR_SET0 V_FSO_HDR_SRAM_PERR_SET0(1U) + +#define S_T10_PI_SRAM_PERR_SET3 3 +#define V_T10_PI_SRAM_PERR_SET3(x) ((x) << S_T10_PI_SRAM_PERR_SET3) +#define F_T10_PI_SRAM_PERR_SET3 V_T10_PI_SRAM_PERR_SET3(1U) + +#define S_T10_PI_SRAM_PERR_SET2 2 +#define V_T10_PI_SRAM_PERR_SET2(x) ((x) << S_T10_PI_SRAM_PERR_SET2) +#define F_T10_PI_SRAM_PERR_SET2 V_T10_PI_SRAM_PERR_SET2(1U) + +#define S_T10_PI_SRAM_PERR_SET1 1 +#define V_T10_PI_SRAM_PERR_SET1(x) ((x) << S_T10_PI_SRAM_PERR_SET1) +#define F_T10_PI_SRAM_PERR_SET1 V_T10_PI_SRAM_PERR_SET1(1U) + +#define S_T10_PI_SRAM_PERR_SET0 0 +#define V_T10_PI_SRAM_PERR_SET0(x) ((x) << S_T10_PI_SRAM_PERR_SET0) +#define F_T10_PI_SRAM_PERR_SET0 V_T10_PI_SRAM_PERR_SET0(1U) + +#define A_ULP_TX_INT_CAUSE_2 0x8e80 +#define A_ULP_TX_PERR_ENABLE_2 0x8e84 +#define A_ULP_TX_SE_CNT_ERR 0x8ea0 + +#define S_ERR_CH3 12 +#define M_ERR_CH3 0xfU +#define V_ERR_CH3(x) ((x) << S_ERR_CH3) +#define G_ERR_CH3(x) (((x) >> S_ERR_CH3) & M_ERR_CH3) + +#define S_ERR_CH2 8 +#define M_ERR_CH2 0xfU +#define V_ERR_CH2(x) ((x) << S_ERR_CH2) +#define G_ERR_CH2(x) (((x) >> S_ERR_CH2) & M_ERR_CH2) + +#define S_ERR_CH1 4 +#define M_ERR_CH1 0xfU +#define V_ERR_CH1(x) ((x) << S_ERR_CH1) +#define G_ERR_CH1(x) (((x) >> S_ERR_CH1) & M_ERR_CH1) + +#define S_ERR_CH0 0 +#define M_ERR_CH0 0xfU +#define V_ERR_CH0(x) ((x) << S_ERR_CH0) +#define G_ERR_CH0(x) (((x) >> S_ERR_CH0) & M_ERR_CH0) + +#define A_ULP_TX_T5_SE_CNT_ERR 0x8ea0 +#define A_ULP_TX_SE_CNT_CLR 0x8ea4 + +#define S_CLR_DROP 16 +#define M_CLR_DROP 0xfU +#define V_CLR_DROP(x) ((x) << S_CLR_DROP) +#define G_CLR_DROP(x) (((x) >> S_CLR_DROP) & M_CLR_DROP) + +#define S_CLR_CH3 12 +#define M_CLR_CH3 0xfU +#define V_CLR_CH3(x) ((x) << S_CLR_CH3) +#define G_CLR_CH3(x) (((x) >> S_CLR_CH3) & M_CLR_CH3) + +#define S_CLR_CH2 8 +#define M_CLR_CH2 0xfU +#define V_CLR_CH2(x) ((x) << S_CLR_CH2) +#define G_CLR_CH2(x) (((x) >> S_CLR_CH2) & M_CLR_CH2) + +#define S_CLR_CH1 4 +#define M_CLR_CH1 0xfU +#define V_CLR_CH1(x) ((x) << S_CLR_CH1) +#define G_CLR_CH1(x) (((x) >> S_CLR_CH1) & M_CLR_CH1) + +#define S_CLR_CH0 0 +#define M_CLR_CH0 0xfU +#define V_CLR_CH0(x) ((x) << S_CLR_CH0) +#define G_CLR_CH0(x) (((x) >> S_CLR_CH0) & M_CLR_CH0) + +#define A_ULP_TX_T5_SE_CNT_CLR 0x8ea4 +#define A_ULP_TX_SE_CNT_CH0 0x8ea8 + +#define S_SOP_CNT_ULP2TP 28 +#define M_SOP_CNT_ULP2TP 0xfU +#define V_SOP_CNT_ULP2TP(x) ((x) << S_SOP_CNT_ULP2TP) +#define G_SOP_CNT_ULP2TP(x) (((x) >> S_SOP_CNT_ULP2TP) & M_SOP_CNT_ULP2TP) + +#define S_EOP_CNT_ULP2TP 24 +#define M_EOP_CNT_ULP2TP 0xfU +#define V_EOP_CNT_ULP2TP(x) ((x) << S_EOP_CNT_ULP2TP) +#define G_EOP_CNT_ULP2TP(x) (((x) >> S_EOP_CNT_ULP2TP) & M_EOP_CNT_ULP2TP) + +#define S_SOP_CNT_LSO_IN 20 +#define M_SOP_CNT_LSO_IN 0xfU +#define V_SOP_CNT_LSO_IN(x) ((x) << S_SOP_CNT_LSO_IN) +#define G_SOP_CNT_LSO_IN(x) (((x) >> S_SOP_CNT_LSO_IN) & M_SOP_CNT_LSO_IN) + +#define S_EOP_CNT_LSO_IN 16 +#define M_EOP_CNT_LSO_IN 0xfU +#define V_EOP_CNT_LSO_IN(x) ((x) << S_EOP_CNT_LSO_IN) +#define G_EOP_CNT_LSO_IN(x) (((x) >> S_EOP_CNT_LSO_IN) & M_EOP_CNT_LSO_IN) + +#define S_SOP_CNT_ALG_IN 12 +#define M_SOP_CNT_ALG_IN 0xfU +#define V_SOP_CNT_ALG_IN(x) ((x) << S_SOP_CNT_ALG_IN) +#define G_SOP_CNT_ALG_IN(x) (((x) >> S_SOP_CNT_ALG_IN) & M_SOP_CNT_ALG_IN) + +#define S_EOP_CNT_ALG_IN 8 +#define M_EOP_CNT_ALG_IN 0xfU +#define V_EOP_CNT_ALG_IN(x) ((x) << S_EOP_CNT_ALG_IN) +#define G_EOP_CNT_ALG_IN(x) (((x) >> S_EOP_CNT_ALG_IN) & M_EOP_CNT_ALG_IN) + +#define S_SOP_CNT_CIM2ULP 4 +#define M_SOP_CNT_CIM2ULP 0xfU +#define V_SOP_CNT_CIM2ULP(x) ((x) << S_SOP_CNT_CIM2ULP) +#define G_SOP_CNT_CIM2ULP(x) (((x) >> S_SOP_CNT_CIM2ULP) & M_SOP_CNT_CIM2ULP) + +#define S_EOP_CNT_CIM2ULP 0 +#define M_EOP_CNT_CIM2ULP 0xfU +#define V_EOP_CNT_CIM2ULP(x) ((x) << S_EOP_CNT_CIM2ULP) +#define G_EOP_CNT_CIM2ULP(x) (((x) >> S_EOP_CNT_CIM2ULP) & M_EOP_CNT_CIM2ULP) + +#define A_ULP_TX_T5_SE_CNT_CH0 0x8ea8 +#define A_ULP_TX_SE_CNT_CH1 0x8eac +#define A_ULP_TX_T5_SE_CNT_CH1 0x8eac +#define A_ULP_TX_SE_CNT_CH2 0x8eb0 +#define A_ULP_TX_T5_SE_CNT_CH2 0x8eb0 +#define A_ULP_TX_SE_CNT_CH3 0x8eb4 +#define A_ULP_TX_T5_SE_CNT_CH3 0x8eb4 +#define A_ULP_TX_DROP_CNT 0x8eb8 + +#define S_DROP_CH3 12 +#define M_DROP_CH3 0xfU +#define V_DROP_CH3(x) ((x) << S_DROP_CH3) +#define G_DROP_CH3(x) (((x) >> S_DROP_CH3) & M_DROP_CH3) + +#define S_DROP_CH2 8 +#define M_DROP_CH2 0xfU +#define V_DROP_CH2(x) ((x) << S_DROP_CH2) +#define G_DROP_CH2(x) (((x) >> S_DROP_CH2) & M_DROP_CH2) + +#define S_DROP_CH1 4 +#define M_DROP_CH1 0xfU +#define V_DROP_CH1(x) ((x) << S_DROP_CH1) +#define G_DROP_CH1(x) (((x) >> S_DROP_CH1) & M_DROP_CH1) + +#define S_DROP_CH0 0 +#define M_DROP_CH0 0xfU +#define V_DROP_CH0(x) ((x) << S_DROP_CH0) +#define G_DROP_CH0(x) (((x) >> S_DROP_CH0) & M_DROP_CH0) + +#define A_ULP_TX_T5_DROP_CNT 0x8eb8 +#define A_ULP_TX_CSU_REVISION 0x8ebc +#define A_ULP_TX_LA_RDPTR_0 0x8ec0 +#define A_ULP_TX_LA_RDDATA_0 0x8ec4 +#define A_ULP_TX_LA_WRPTR_0 0x8ec8 +#define A_ULP_TX_LA_RESERVED_0 0x8ecc +#define A_ULP_TX_LA_RDPTR_1 0x8ed0 +#define A_ULP_TX_LA_RDDATA_1 0x8ed4 +#define A_ULP_TX_LA_WRPTR_1 0x8ed8 +#define A_ULP_TX_LA_RESERVED_1 0x8edc +#define A_ULP_TX_LA_RDPTR_2 0x8ee0 +#define A_ULP_TX_LA_RDDATA_2 0x8ee4 +#define A_ULP_TX_LA_WRPTR_2 0x8ee8 +#define A_ULP_TX_LA_RESERVED_2 0x8eec +#define A_ULP_TX_LA_RDPTR_3 0x8ef0 +#define A_ULP_TX_LA_RDDATA_3 0x8ef4 +#define A_ULP_TX_LA_WRPTR_3 0x8ef8 +#define A_ULP_TX_LA_RESERVED_3 0x8efc +#define A_ULP_TX_LA_RDPTR_4 0x8f00 +#define A_ULP_TX_LA_RDDATA_4 0x8f04 +#define A_ULP_TX_LA_WRPTR_4 0x8f08 +#define A_ULP_TX_LA_RESERVED_4 0x8f0c +#define A_ULP_TX_LA_RDPTR_5 0x8f10 +#define A_ULP_TX_LA_RDDATA_5 0x8f14 +#define A_ULP_TX_LA_WRPTR_5 0x8f18 +#define A_ULP_TX_LA_RESERVED_5 0x8f1c +#define A_ULP_TX_LA_RDPTR_6 0x8f20 +#define A_ULP_TX_LA_RDDATA_6 0x8f24 +#define A_ULP_TX_LA_WRPTR_6 0x8f28 +#define A_ULP_TX_LA_RESERVED_6 0x8f2c +#define A_ULP_TX_LA_RDPTR_7 0x8f30 +#define A_ULP_TX_LA_RDDATA_7 0x8f34 +#define A_ULP_TX_LA_WRPTR_7 0x8f38 +#define A_ULP_TX_LA_RESERVED_7 0x8f3c +#define A_ULP_TX_LA_RDPTR_8 0x8f40 +#define A_ULP_TX_LA_RDDATA_8 0x8f44 +#define A_ULP_TX_LA_WRPTR_8 0x8f48 +#define A_ULP_TX_LA_RESERVED_8 0x8f4c +#define A_ULP_TX_LA_RDPTR_9 0x8f50 +#define A_ULP_TX_LA_RDDATA_9 0x8f54 +#define A_ULP_TX_LA_WRPTR_9 0x8f58 +#define A_ULP_TX_LA_RESERVED_9 0x8f5c +#define A_ULP_TX_LA_RDPTR_10 0x8f60 +#define A_ULP_TX_LA_RDDATA_10 0x8f64 +#define A_ULP_TX_LA_WRPTR_10 0x8f68 +#define A_ULP_TX_LA_RESERVED_10 0x8f6c +#define A_ULP_TX_ASIC_DEBUG_CTRL 0x8f70 + +#define S_LA_WR0 0 +#define V_LA_WR0(x) ((x) << S_LA_WR0) +#define F_LA_WR0 V_LA_WR0(1U) + +#define A_ULP_TX_ASIC_DEBUG_0 0x8f74 +#define A_ULP_TX_ASIC_DEBUG_1 0x8f78 +#define A_ULP_TX_ASIC_DEBUG_2 0x8f7c +#define A_ULP_TX_ASIC_DEBUG_3 0x8f80 +#define A_ULP_TX_ASIC_DEBUG_4 0x8f84 + +/* registers for module PM_RX */ +#define PM_RX_BASE_ADDR 0x8fc0 + +#define A_PM_RX_CFG 0x8fc0 +#define A_PM_RX_MODE 0x8fc4 + +#define S_RX_USE_BUNDLE_LEN 4 +#define V_RX_USE_BUNDLE_LEN(x) ((x) << S_RX_USE_BUNDLE_LEN) +#define F_RX_USE_BUNDLE_LEN V_RX_USE_BUNDLE_LEN(1U) + +#define S_STAT_TO_CH 3 +#define V_STAT_TO_CH(x) ((x) << S_STAT_TO_CH) +#define F_STAT_TO_CH V_STAT_TO_CH(1U) + +#define S_STAT_FROM_CH 1 +#define M_STAT_FROM_CH 0x3U +#define V_STAT_FROM_CH(x) ((x) << S_STAT_FROM_CH) +#define G_STAT_FROM_CH(x) (((x) >> S_STAT_FROM_CH) & M_STAT_FROM_CH) + +#define S_PREFETCH_ENABLE 0 +#define V_PREFETCH_ENABLE(x) ((x) << S_PREFETCH_ENABLE) +#define F_PREFETCH_ENABLE V_PREFETCH_ENABLE(1U) + +#define A_PM_RX_STAT_CONFIG 0x8fc8 +#define A_PM_RX_STAT_COUNT 0x8fcc +#define A_PM_RX_STAT_LSB 0x8fd0 +#define A_PM_RX_DBG_CTRL 0x8fd0 + +#define S_OSPIWRBUSY_T5 21 +#define M_OSPIWRBUSY_T5 0x3U +#define V_OSPIWRBUSY_T5(x) ((x) << S_OSPIWRBUSY_T5) +#define G_OSPIWRBUSY_T5(x) (((x) >> S_OSPIWRBUSY_T5) & M_OSPIWRBUSY_T5) + +#define S_ISPIWRBUSY 17 +#define M_ISPIWRBUSY 0xfU +#define V_ISPIWRBUSY(x) ((x) << S_ISPIWRBUSY) +#define G_ISPIWRBUSY(x) (((x) >> S_ISPIWRBUSY) & M_ISPIWRBUSY) + +#define S_PMDBGADDR 0 +#define M_PMDBGADDR 0x1ffffU +#define V_PMDBGADDR(x) ((x) << S_PMDBGADDR) +#define G_PMDBGADDR(x) (((x) >> S_PMDBGADDR) & M_PMDBGADDR) + +#define A_PM_RX_STAT_MSB 0x8fd4 +#define A_PM_RX_DBG_DATA 0x8fd4 +#define A_PM_RX_INT_ENABLE 0x8fd8 + +#define S_ZERO_E_CMD_ERROR 22 +#define V_ZERO_E_CMD_ERROR(x) ((x) << S_ZERO_E_CMD_ERROR) +#define F_ZERO_E_CMD_ERROR V_ZERO_E_CMD_ERROR(1U) + +#define S_IESPI0_FIFO2X_RX_FRAMING_ERROR 21 +#define V_IESPI0_FIFO2X_RX_FRAMING_ERROR(x) ((x) << S_IESPI0_FIFO2X_RX_FRAMING_ERROR) +#define F_IESPI0_FIFO2X_RX_FRAMING_ERROR V_IESPI0_FIFO2X_RX_FRAMING_ERROR(1U) + +#define S_IESPI1_FIFO2X_RX_FRAMING_ERROR 20 +#define V_IESPI1_FIFO2X_RX_FRAMING_ERROR(x) ((x) << S_IESPI1_FIFO2X_RX_FRAMING_ERROR) +#define F_IESPI1_FIFO2X_RX_FRAMING_ERROR V_IESPI1_FIFO2X_RX_FRAMING_ERROR(1U) + +#define S_IESPI2_FIFO2X_RX_FRAMING_ERROR 19 +#define V_IESPI2_FIFO2X_RX_FRAMING_ERROR(x) ((x) << S_IESPI2_FIFO2X_RX_FRAMING_ERROR) +#define F_IESPI2_FIFO2X_RX_FRAMING_ERROR V_IESPI2_FIFO2X_RX_FRAMING_ERROR(1U) + +#define S_IESPI3_FIFO2X_RX_FRAMING_ERROR 18 +#define V_IESPI3_FIFO2X_RX_FRAMING_ERROR(x) ((x) << S_IESPI3_FIFO2X_RX_FRAMING_ERROR) +#define F_IESPI3_FIFO2X_RX_FRAMING_ERROR V_IESPI3_FIFO2X_RX_FRAMING_ERROR(1U) + +#define S_IESPI0_RX_FRAMING_ERROR 17 +#define V_IESPI0_RX_FRAMING_ERROR(x) ((x) << S_IESPI0_RX_FRAMING_ERROR) +#define F_IESPI0_RX_FRAMING_ERROR V_IESPI0_RX_FRAMING_ERROR(1U) + +#define S_IESPI1_RX_FRAMING_ERROR 16 +#define V_IESPI1_RX_FRAMING_ERROR(x) ((x) << S_IESPI1_RX_FRAMING_ERROR) +#define F_IESPI1_RX_FRAMING_ERROR V_IESPI1_RX_FRAMING_ERROR(1U) + +#define S_IESPI2_RX_FRAMING_ERROR 15 +#define V_IESPI2_RX_FRAMING_ERROR(x) ((x) << S_IESPI2_RX_FRAMING_ERROR) +#define F_IESPI2_RX_FRAMING_ERROR V_IESPI2_RX_FRAMING_ERROR(1U) + +#define S_IESPI3_RX_FRAMING_ERROR 14 +#define V_IESPI3_RX_FRAMING_ERROR(x) ((x) << S_IESPI3_RX_FRAMING_ERROR) +#define F_IESPI3_RX_FRAMING_ERROR V_IESPI3_RX_FRAMING_ERROR(1U) + +#define S_IESPI0_TX_FRAMING_ERROR 13 +#define V_IESPI0_TX_FRAMING_ERROR(x) ((x) << S_IESPI0_TX_FRAMING_ERROR) +#define F_IESPI0_TX_FRAMING_ERROR V_IESPI0_TX_FRAMING_ERROR(1U) + +#define S_IESPI1_TX_FRAMING_ERROR 12 +#define V_IESPI1_TX_FRAMING_ERROR(x) ((x) << S_IESPI1_TX_FRAMING_ERROR) +#define F_IESPI1_TX_FRAMING_ERROR V_IESPI1_TX_FRAMING_ERROR(1U) + +#define S_IESPI2_TX_FRAMING_ERROR 11 +#define V_IESPI2_TX_FRAMING_ERROR(x) ((x) << S_IESPI2_TX_FRAMING_ERROR) +#define F_IESPI2_TX_FRAMING_ERROR V_IESPI2_TX_FRAMING_ERROR(1U) + +#define S_IESPI3_TX_FRAMING_ERROR 10 +#define V_IESPI3_TX_FRAMING_ERROR(x) ((x) << S_IESPI3_TX_FRAMING_ERROR) +#define F_IESPI3_TX_FRAMING_ERROR V_IESPI3_TX_FRAMING_ERROR(1U) + +#define S_OCSPI0_RX_FRAMING_ERROR 9 +#define V_OCSPI0_RX_FRAMING_ERROR(x) ((x) << S_OCSPI0_RX_FRAMING_ERROR) +#define F_OCSPI0_RX_FRAMING_ERROR V_OCSPI0_RX_FRAMING_ERROR(1U) + +#define S_OCSPI1_RX_FRAMING_ERROR 8 +#define V_OCSPI1_RX_FRAMING_ERROR(x) ((x) << S_OCSPI1_RX_FRAMING_ERROR) +#define F_OCSPI1_RX_FRAMING_ERROR V_OCSPI1_RX_FRAMING_ERROR(1U) + +#define S_OCSPI0_TX_FRAMING_ERROR 7 +#define V_OCSPI0_TX_FRAMING_ERROR(x) ((x) << S_OCSPI0_TX_FRAMING_ERROR) +#define F_OCSPI0_TX_FRAMING_ERROR V_OCSPI0_TX_FRAMING_ERROR(1U) + +#define S_OCSPI1_TX_FRAMING_ERROR 6 +#define V_OCSPI1_TX_FRAMING_ERROR(x) ((x) << S_OCSPI1_TX_FRAMING_ERROR) +#define F_OCSPI1_TX_FRAMING_ERROR V_OCSPI1_TX_FRAMING_ERROR(1U) + +#define S_OCSPI0_OFIFO2X_TX_FRAMING_ERROR 5 +#define V_OCSPI0_OFIFO2X_TX_FRAMING_ERROR(x) ((x) << S_OCSPI0_OFIFO2X_TX_FRAMING_ERROR) +#define F_OCSPI0_OFIFO2X_TX_FRAMING_ERROR V_OCSPI0_OFIFO2X_TX_FRAMING_ERROR(1U) + +#define S_OCSPI1_OFIFO2X_TX_FRAMING_ERROR 4 +#define V_OCSPI1_OFIFO2X_TX_FRAMING_ERROR(x) ((x) << S_OCSPI1_OFIFO2X_TX_FRAMING_ERROR) +#define F_OCSPI1_OFIFO2X_TX_FRAMING_ERROR V_OCSPI1_OFIFO2X_TX_FRAMING_ERROR(1U) + +#define S_OCSPI_PAR_ERROR 3 +#define V_OCSPI_PAR_ERROR(x) ((x) << S_OCSPI_PAR_ERROR) +#define F_OCSPI_PAR_ERROR V_OCSPI_PAR_ERROR(1U) + +#define S_DB_OPTIONS_PAR_ERROR 2 +#define V_DB_OPTIONS_PAR_ERROR(x) ((x) << S_DB_OPTIONS_PAR_ERROR) +#define F_DB_OPTIONS_PAR_ERROR V_DB_OPTIONS_PAR_ERROR(1U) + +#define S_IESPI_PAR_ERROR 1 +#define V_IESPI_PAR_ERROR(x) ((x) << S_IESPI_PAR_ERROR) +#define F_IESPI_PAR_ERROR V_IESPI_PAR_ERROR(1U) + +#define S_E_PCMD_PAR_ERROR 0 +#define V_E_PCMD_PAR_ERROR(x) ((x) << S_E_PCMD_PAR_ERROR) +#define F_E_PCMD_PAR_ERROR V_E_PCMD_PAR_ERROR(1U) + +#define S_OSPI_OVERFLOW1 28 +#define V_OSPI_OVERFLOW1(x) ((x) << S_OSPI_OVERFLOW1) +#define F_OSPI_OVERFLOW1 V_OSPI_OVERFLOW1(1U) + +#define S_OSPI_OVERFLOW0 27 +#define V_OSPI_OVERFLOW0(x) ((x) << S_OSPI_OVERFLOW0) +#define F_OSPI_OVERFLOW0 V_OSPI_OVERFLOW0(1U) + +#define S_MA_INTF_SDC_ERR 26 +#define V_MA_INTF_SDC_ERR(x) ((x) << S_MA_INTF_SDC_ERR) +#define F_MA_INTF_SDC_ERR V_MA_INTF_SDC_ERR(1U) + +#define S_BUNDLE_LEN_PARERR 25 +#define V_BUNDLE_LEN_PARERR(x) ((x) << S_BUNDLE_LEN_PARERR) +#define F_BUNDLE_LEN_PARERR V_BUNDLE_LEN_PARERR(1U) + +#define S_BUNDLE_LEN_OVFL 24 +#define V_BUNDLE_LEN_OVFL(x) ((x) << S_BUNDLE_LEN_OVFL) +#define F_BUNDLE_LEN_OVFL V_BUNDLE_LEN_OVFL(1U) + +#define S_SDC_ERR 23 +#define V_SDC_ERR(x) ((x) << S_SDC_ERR) +#define F_SDC_ERR V_SDC_ERR(1U) + +#define A_PM_RX_INT_CAUSE 0x8fdc +#define A_PM_RX_ISPI_DBG_4B_DATA0 0x10000 +#define A_PM_RX_ISPI_DBG_4B_DATA1 0x10001 +#define A_PM_RX_ISPI_DBG_4B_DATA2 0x10002 +#define A_PM_RX_ISPI_DBG_4B_DATA3 0x10003 +#define A_PM_RX_ISPI_DBG_4B_DATA4 0x10004 +#define A_PM_RX_ISPI_DBG_4B_DATA5 0x10005 +#define A_PM_RX_ISPI_DBG_4B_DATA6 0x10006 +#define A_PM_RX_ISPI_DBG_4B_DATA7 0x10007 +#define A_PM_RX_ISPI_DBG_4B_DATA8 0x10008 +#define A_PM_RX_OSPI_DBG_4B_DATA0 0x10009 +#define A_PM_RX_OSPI_DBG_4B_DATA1 0x1000a +#define A_PM_RX_OSPI_DBG_4B_DATA2 0x1000b +#define A_PM_RX_OSPI_DBG_4B_DATA3 0x1000c +#define A_PM_RX_OSPI_DBG_4B_DATA4 0x1000d +#define A_PM_RX_OSPI_DBG_4B_DATA5 0x1000e +#define A_PM_RX_OSPI_DBG_4B_DATA6 0x1000f +#define A_PM_RX_OSPI_DBG_4B_DATA7 0x10010 +#define A_PM_RX_OSPI_DBG_4B_DATA8 0x10011 +#define A_PM_RX_OSPI_DBG_4B_DATA9 0x10012 +#define A_PM_RX_DBG_STAT_MSB 0x10013 +#define A_PM_RX_DBG_STAT_LSB 0x10014 +#define A_PM_RX_DBG_RSVD_FLIT_CNT 0x10015 + +#define S_I_TO_O_PATH_RSVD_FLIT_BACKUP 12 +#define M_I_TO_O_PATH_RSVD_FLIT_BACKUP 0xfU +#define V_I_TO_O_PATH_RSVD_FLIT_BACKUP(x) ((x) << S_I_TO_O_PATH_RSVD_FLIT_BACKUP) +#define G_I_TO_O_PATH_RSVD_FLIT_BACKUP(x) (((x) >> S_I_TO_O_PATH_RSVD_FLIT_BACKUP) & M_I_TO_O_PATH_RSVD_FLIT_BACKUP) + +#define S_I_TO_O_PATH_RSVD_FLIT 8 +#define M_I_TO_O_PATH_RSVD_FLIT 0xfU +#define V_I_TO_O_PATH_RSVD_FLIT(x) ((x) << S_I_TO_O_PATH_RSVD_FLIT) +#define G_I_TO_O_PATH_RSVD_FLIT(x) (((x) >> S_I_TO_O_PATH_RSVD_FLIT) & M_I_TO_O_PATH_RSVD_FLIT) + +#define S_PRFCH_RSVD_FLIT 4 +#define M_PRFCH_RSVD_FLIT 0xfU +#define V_PRFCH_RSVD_FLIT(x) ((x) << S_PRFCH_RSVD_FLIT) +#define G_PRFCH_RSVD_FLIT(x) (((x) >> S_PRFCH_RSVD_FLIT) & M_PRFCH_RSVD_FLIT) + +#define S_OSPI_RSVD_FLIT 0 +#define M_OSPI_RSVD_FLIT 0xfU +#define V_OSPI_RSVD_FLIT(x) ((x) << S_OSPI_RSVD_FLIT) +#define G_OSPI_RSVD_FLIT(x) (((x) >> S_OSPI_RSVD_FLIT) & M_OSPI_RSVD_FLIT) + +#define A_PM_RX_SDC_EN 0x10016 + +#define S_SDC_EN 0 +#define V_SDC_EN(x) ((x) << S_SDC_EN) +#define F_SDC_EN V_SDC_EN(1U) + +#define A_PM_RX_INOUT_FIFO_DBG_CHNL_SEL 0x10017 + +#define S_CHNL_3_SEL 3 +#define V_CHNL_3_SEL(x) ((x) << S_CHNL_3_SEL) +#define F_CHNL_3_SEL V_CHNL_3_SEL(1U) + +#define S_CHNL_2_SEL 2 +#define V_CHNL_2_SEL(x) ((x) << S_CHNL_2_SEL) +#define F_CHNL_2_SEL V_CHNL_2_SEL(1U) + +#define S_CHNL_1_SEL 1 +#define V_CHNL_1_SEL(x) ((x) << S_CHNL_1_SEL) +#define F_CHNL_1_SEL V_CHNL_1_SEL(1U) + +#define S_CHNL_0_SEL 0 +#define V_CHNL_0_SEL(x) ((x) << S_CHNL_0_SEL) +#define F_CHNL_0_SEL V_CHNL_0_SEL(1U) + +#define A_PM_RX_INOUT_FIFO_DBG_WR 0x10018 + +#define S_O_FIFO_WRITE 3 +#define V_O_FIFO_WRITE(x) ((x) << S_O_FIFO_WRITE) +#define F_O_FIFO_WRITE V_O_FIFO_WRITE(1U) + +#define S_I_FIFO_WRITE 2 +#define V_I_FIFO_WRITE(x) ((x) << S_I_FIFO_WRITE) +#define F_I_FIFO_WRITE V_I_FIFO_WRITE(1U) + +#define S_O_FIFO_READ 1 +#define V_O_FIFO_READ(x) ((x) << S_O_FIFO_READ) +#define F_O_FIFO_READ V_O_FIFO_READ(1U) + +#define S_I_FIFO_READ 0 +#define V_I_FIFO_READ(x) ((x) << S_I_FIFO_READ) +#define F_I_FIFO_READ V_I_FIFO_READ(1U) + +#define A_PM_RX_INPUT_FIFO_STR_FWD_EN 0x10019 + +#define S_ISPI_STR_FWD_EN 0 +#define V_ISPI_STR_FWD_EN(x) ((x) << S_ISPI_STR_FWD_EN) +#define F_ISPI_STR_FWD_EN V_ISPI_STR_FWD_EN(1U) + +#define A_PM_RX_PRFTCH_ACROSS_BNDLE_EN 0x1001a + +#define S_PRFTCH_ACROSS_BNDLE_EN 0 +#define V_PRFTCH_ACROSS_BNDLE_EN(x) ((x) << S_PRFTCH_ACROSS_BNDLE_EN) +#define F_PRFTCH_ACROSS_BNDLE_EN V_PRFTCH_ACROSS_BNDLE_EN(1U) + +#define A_PM_RX_PRFTCH_WRR_ENABLE 0x1001b + +#define S_PRFTCH_WRR_ENABLE 0 +#define V_PRFTCH_WRR_ENABLE(x) ((x) << S_PRFTCH_WRR_ENABLE) +#define F_PRFTCH_WRR_ENABLE V_PRFTCH_WRR_ENABLE(1U) + +#define A_PM_RX_PRFTCH_WRR_MAX_DEFICIT_CNT 0x1001c + +#define S_CHNL1_MAX_DEFICIT_CNT 16 +#define M_CHNL1_MAX_DEFICIT_CNT 0xffffU +#define V_CHNL1_MAX_DEFICIT_CNT(x) ((x) << S_CHNL1_MAX_DEFICIT_CNT) +#define G_CHNL1_MAX_DEFICIT_CNT(x) (((x) >> S_CHNL1_MAX_DEFICIT_CNT) & M_CHNL1_MAX_DEFICIT_CNT) + +#define S_CHNL0_MAX_DEFICIT_CNT 0 +#define M_CHNL0_MAX_DEFICIT_CNT 0xffffU +#define V_CHNL0_MAX_DEFICIT_CNT(x) ((x) << S_CHNL0_MAX_DEFICIT_CNT) +#define G_CHNL0_MAX_DEFICIT_CNT(x) (((x) >> S_CHNL0_MAX_DEFICIT_CNT) & M_CHNL0_MAX_DEFICIT_CNT) + +#define A_PM_RX_FEATURE_EN 0x1001d + +#define S_PIO_CH_DEFICIT_CTL_EN_RX 0 +#define V_PIO_CH_DEFICIT_CTL_EN_RX(x) ((x) << S_PIO_CH_DEFICIT_CTL_EN_RX) +#define F_PIO_CH_DEFICIT_CTL_EN_RX V_PIO_CH_DEFICIT_CTL_EN_RX(1U) + +#define A_PM_RX_CH0_OSPI_DEFICIT_THRSHLD 0x1001e + +#define S_CH0_OSPI_DEFICIT_THRSHLD 0 +#define M_CH0_OSPI_DEFICIT_THRSHLD 0xfffU +#define V_CH0_OSPI_DEFICIT_THRSHLD(x) ((x) << S_CH0_OSPI_DEFICIT_THRSHLD) +#define G_CH0_OSPI_DEFICIT_THRSHLD(x) (((x) >> S_CH0_OSPI_DEFICIT_THRSHLD) & M_CH0_OSPI_DEFICIT_THRSHLD) + +#define A_PM_RX_CH1_OSPI_DEFICIT_THRSHLD 0x1001f + +#define S_CH1_OSPI_DEFICIT_THRSHLD 0 +#define M_CH1_OSPI_DEFICIT_THRSHLD 0xfffU +#define V_CH1_OSPI_DEFICIT_THRSHLD(x) ((x) << S_CH1_OSPI_DEFICIT_THRSHLD) +#define G_CH1_OSPI_DEFICIT_THRSHLD(x) (((x) >> S_CH1_OSPI_DEFICIT_THRSHLD) & M_CH1_OSPI_DEFICIT_THRSHLD) + +#define A_PM_RX_INT_CAUSE_MASK_HALT 0x10020 +#define A_PM_RX_DBG_STAT0 0x10021 + +#define S_RX_RD_I_BUSY 29 +#define V_RX_RD_I_BUSY(x) ((x) << S_RX_RD_I_BUSY) +#define F_RX_RD_I_BUSY V_RX_RD_I_BUSY(1U) + +#define S_RX_WR_TO_O_BUSY 28 +#define V_RX_WR_TO_O_BUSY(x) ((x) << S_RX_WR_TO_O_BUSY) +#define F_RX_WR_TO_O_BUSY V_RX_WR_TO_O_BUSY(1U) + +#define S_RX_M_TO_O_BUSY 27 +#define V_RX_M_TO_O_BUSY(x) ((x) << S_RX_M_TO_O_BUSY) +#define F_RX_M_TO_O_BUSY V_RX_M_TO_O_BUSY(1U) + +#define S_RX_I_TO_M_BUSY 26 +#define V_RX_I_TO_M_BUSY(x) ((x) << S_RX_I_TO_M_BUSY) +#define F_RX_I_TO_M_BUSY V_RX_I_TO_M_BUSY(1U) + +#define S_RX_PCMD_FB_ONLY 25 +#define V_RX_PCMD_FB_ONLY(x) ((x) << S_RX_PCMD_FB_ONLY) +#define F_RX_PCMD_FB_ONLY V_RX_PCMD_FB_ONLY(1U) + +#define S_RX_PCMD_MEM 24 +#define V_RX_PCMD_MEM(x) ((x) << S_RX_PCMD_MEM) +#define F_RX_PCMD_MEM V_RX_PCMD_MEM(1U) + +#define S_RX_PCMD_BYPASS 23 +#define V_RX_PCMD_BYPASS(x) ((x) << S_RX_PCMD_BYPASS) +#define F_RX_PCMD_BYPASS V_RX_PCMD_BYPASS(1U) + +#define S_RX_PCMD_EOP 22 +#define V_RX_PCMD_EOP(x) ((x) << S_RX_PCMD_EOP) +#define F_RX_PCMD_EOP V_RX_PCMD_EOP(1U) + +#define S_RX_DUMPLICATE_PCMD_EOP 21 +#define V_RX_DUMPLICATE_PCMD_EOP(x) ((x) << S_RX_DUMPLICATE_PCMD_EOP) +#define F_RX_DUMPLICATE_PCMD_EOP V_RX_DUMPLICATE_PCMD_EOP(1U) + +#define S_RX_PCMD_EOB 20 +#define V_RX_PCMD_EOB(x) ((x) << S_RX_PCMD_EOB) +#define F_RX_PCMD_EOB V_RX_PCMD_EOB(1U) + +#define S_RX_PCMD_FB 16 +#define M_RX_PCMD_FB 0xfU +#define V_RX_PCMD_FB(x) ((x) << S_RX_PCMD_FB) +#define G_RX_PCMD_FB(x) (((x) >> S_RX_PCMD_FB) & M_RX_PCMD_FB) + +#define S_RX_PCMD_LEN 0 +#define M_RX_PCMD_LEN 0xffffU +#define V_RX_PCMD_LEN(x) ((x) << S_RX_PCMD_LEN) +#define G_RX_PCMD_LEN(x) (((x) >> S_RX_PCMD_LEN) & M_RX_PCMD_LEN) + +#define A_PM_RX_DBG_STAT1 0x10022 + +#define S_RX_PCMD0_MEM 30 +#define V_RX_PCMD0_MEM(x) ((x) << S_RX_PCMD0_MEM) +#define F_RX_PCMD0_MEM V_RX_PCMD0_MEM(1U) + +#define S_RX_FREE_OSPI_CNT0 18 +#define M_RX_FREE_OSPI_CNT0 0xfffU +#define V_RX_FREE_OSPI_CNT0(x) ((x) << S_RX_FREE_OSPI_CNT0) +#define G_RX_FREE_OSPI_CNT0(x) (((x) >> S_RX_FREE_OSPI_CNT0) & M_RX_FREE_OSPI_CNT0) + +#define S_RX_PCMD0_FLIT_LEN 6 +#define M_RX_PCMD0_FLIT_LEN 0xfffU +#define V_RX_PCMD0_FLIT_LEN(x) ((x) << S_RX_PCMD0_FLIT_LEN) +#define G_RX_PCMD0_FLIT_LEN(x) (((x) >> S_RX_PCMD0_FLIT_LEN) & M_RX_PCMD0_FLIT_LEN) + +#define S_RX_PCMD0_CMD 2 +#define M_RX_PCMD0_CMD 0xfU +#define V_RX_PCMD0_CMD(x) ((x) << S_RX_PCMD0_CMD) +#define G_RX_PCMD0_CMD(x) (((x) >> S_RX_PCMD0_CMD) & M_RX_PCMD0_CMD) + +#define S_RX_OFIFO_FULL0 1 +#define V_RX_OFIFO_FULL0(x) ((x) << S_RX_OFIFO_FULL0) +#define F_RX_OFIFO_FULL0 V_RX_OFIFO_FULL0(1U) + +#define S_RX_PCMD0_BYPASS 0 +#define V_RX_PCMD0_BYPASS(x) ((x) << S_RX_PCMD0_BYPASS) +#define F_RX_PCMD0_BYPASS V_RX_PCMD0_BYPASS(1U) + +#define A_PM_RX_DBG_STAT2 0x10023 + +#define S_RX_PCMD1_MEM 30 +#define V_RX_PCMD1_MEM(x) ((x) << S_RX_PCMD1_MEM) +#define F_RX_PCMD1_MEM V_RX_PCMD1_MEM(1U) + +#define S_RX_FREE_OSPI_CNT1 18 +#define M_RX_FREE_OSPI_CNT1 0xfffU +#define V_RX_FREE_OSPI_CNT1(x) ((x) << S_RX_FREE_OSPI_CNT1) +#define G_RX_FREE_OSPI_CNT1(x) (((x) >> S_RX_FREE_OSPI_CNT1) & M_RX_FREE_OSPI_CNT1) + +#define S_RX_PCMD1_FLIT_LEN 6 +#define M_RX_PCMD1_FLIT_LEN 0xfffU +#define V_RX_PCMD1_FLIT_LEN(x) ((x) << S_RX_PCMD1_FLIT_LEN) +#define G_RX_PCMD1_FLIT_LEN(x) (((x) >> S_RX_PCMD1_FLIT_LEN) & M_RX_PCMD1_FLIT_LEN) + +#define S_RX_PCMD1_CMD 2 +#define M_RX_PCMD1_CMD 0xfU +#define V_RX_PCMD1_CMD(x) ((x) << S_RX_PCMD1_CMD) +#define G_RX_PCMD1_CMD(x) (((x) >> S_RX_PCMD1_CMD) & M_RX_PCMD1_CMD) + +#define S_RX_OFIFO_FULL1 1 +#define V_RX_OFIFO_FULL1(x) ((x) << S_RX_OFIFO_FULL1) +#define F_RX_OFIFO_FULL1 V_RX_OFIFO_FULL1(1U) + +#define S_RX_PCMD1_BYPASS 0 +#define V_RX_PCMD1_BYPASS(x) ((x) << S_RX_PCMD1_BYPASS) +#define F_RX_PCMD1_BYPASS V_RX_PCMD1_BYPASS(1U) + +#define A_PM_RX_DBG_STAT3 0x10024 + +#define S_RX_SET_PCMD_RES_RDY_RD 10 +#define M_RX_SET_PCMD_RES_RDY_RD 0x3U +#define V_RX_SET_PCMD_RES_RDY_RD(x) ((x) << S_RX_SET_PCMD_RES_RDY_RD) +#define G_RX_SET_PCMD_RES_RDY_RD(x) (((x) >> S_RX_SET_PCMD_RES_RDY_RD) & M_RX_SET_PCMD_RES_RDY_RD) + +#define S_RX_ISSUED_PREFETCH_RD_E_CLR 8 +#define M_RX_ISSUED_PREFETCH_RD_E_CLR 0x3U +#define V_RX_ISSUED_PREFETCH_RD_E_CLR(x) ((x) << S_RX_ISSUED_PREFETCH_RD_E_CLR) +#define G_RX_ISSUED_PREFETCH_RD_E_CLR(x) (((x) >> S_RX_ISSUED_PREFETCH_RD_E_CLR) & M_RX_ISSUED_PREFETCH_RD_E_CLR) + +#define S_RX_ISSUED_PREFETCH_RD 6 +#define M_RX_ISSUED_PREFETCH_RD 0x3U +#define V_RX_ISSUED_PREFETCH_RD(x) ((x) << S_RX_ISSUED_PREFETCH_RD) +#define G_RX_ISSUED_PREFETCH_RD(x) (((x) >> S_RX_ISSUED_PREFETCH_RD) & M_RX_ISSUED_PREFETCH_RD) + +#define S_RX_PCMD_RES_RDY 4 +#define M_RX_PCMD_RES_RDY 0x3U +#define V_RX_PCMD_RES_RDY(x) ((x) << S_RX_PCMD_RES_RDY) +#define G_RX_PCMD_RES_RDY(x) (((x) >> S_RX_PCMD_RES_RDY) & M_RX_PCMD_RES_RDY) + +#define S_RX_DB_VLD 3 +#define V_RX_DB_VLD(x) ((x) << S_RX_DB_VLD) +#define F_RX_DB_VLD V_RX_DB_VLD(1U) + +#define S_RX_FIRST_BUNDLE 1 +#define M_RX_FIRST_BUNDLE 0x3U +#define V_RX_FIRST_BUNDLE(x) ((x) << S_RX_FIRST_BUNDLE) +#define G_RX_FIRST_BUNDLE(x) (((x) >> S_RX_FIRST_BUNDLE) & M_RX_FIRST_BUNDLE) + +#define S_RX_SDC_DRDY 0 +#define V_RX_SDC_DRDY(x) ((x) << S_RX_SDC_DRDY) +#define F_RX_SDC_DRDY V_RX_SDC_DRDY(1U) + +#define A_PM_RX_DBG_STAT4 0x10025 + +#define S_RX_PCMD_VLD 26 +#define V_RX_PCMD_VLD(x) ((x) << S_RX_PCMD_VLD) +#define F_RX_PCMD_VLD V_RX_PCMD_VLD(1U) + +#define S_RX_PCMD_TO_CH 25 +#define V_RX_PCMD_TO_CH(x) ((x) << S_RX_PCMD_TO_CH) +#define F_RX_PCMD_TO_CH V_RX_PCMD_TO_CH(1U) + +#define S_RX_PCMD_FROM_CH 23 +#define M_RX_PCMD_FROM_CH 0x3U +#define V_RX_PCMD_FROM_CH(x) ((x) << S_RX_PCMD_FROM_CH) +#define G_RX_PCMD_FROM_CH(x) (((x) >> S_RX_PCMD_FROM_CH) & M_RX_PCMD_FROM_CH) + +#define S_RX_LINE 18 +#define M_RX_LINE 0x1fU +#define V_RX_LINE(x) ((x) << S_RX_LINE) +#define G_RX_LINE(x) (((x) >> S_RX_LINE) & M_RX_LINE) + +#define S_RX_IESPI_TXVALID 14 +#define M_RX_IESPI_TXVALID 0xfU +#define V_RX_IESPI_TXVALID(x) ((x) << S_RX_IESPI_TXVALID) +#define G_RX_IESPI_TXVALID(x) (((x) >> S_RX_IESPI_TXVALID) & M_RX_IESPI_TXVALID) + +#define S_RX_IESPI_TXFULL 10 +#define M_RX_IESPI_TXFULL 0xfU +#define V_RX_IESPI_TXFULL(x) ((x) << S_RX_IESPI_TXFULL) +#define G_RX_IESPI_TXFULL(x) (((x) >> S_RX_IESPI_TXFULL) & M_RX_IESPI_TXFULL) + +#define S_RX_PCMD_SRDY 8 +#define M_RX_PCMD_SRDY 0x3U +#define V_RX_PCMD_SRDY(x) ((x) << S_RX_PCMD_SRDY) +#define G_RX_PCMD_SRDY(x) (((x) >> S_RX_PCMD_SRDY) & M_RX_PCMD_SRDY) + +#define S_RX_PCMD_DRDY 6 +#define M_RX_PCMD_DRDY 0x3U +#define V_RX_PCMD_DRDY(x) ((x) << S_RX_PCMD_DRDY) +#define G_RX_PCMD_DRDY(x) (((x) >> S_RX_PCMD_DRDY) & M_RX_PCMD_DRDY) + +#define S_RX_PCMD_CMD 2 +#define M_RX_PCMD_CMD 0xfU +#define V_RX_PCMD_CMD(x) ((x) << S_RX_PCMD_CMD) +#define G_RX_PCMD_CMD(x) (((x) >> S_RX_PCMD_CMD) & M_RX_PCMD_CMD) + +#define S_DUPLICATE 0 +#define M_DUPLICATE 0x3U +#define V_DUPLICATE(x) ((x) << S_DUPLICATE) +#define G_DUPLICATE(x) (((x) >> S_DUPLICATE) & M_DUPLICATE) + +#define A_PM_RX_DBG_STAT5 0x10026 + +#define S_RX_ATLST_1_PCMD_CH1 29 +#define V_RX_ATLST_1_PCMD_CH1(x) ((x) << S_RX_ATLST_1_PCMD_CH1) +#define F_RX_ATLST_1_PCMD_CH1 V_RX_ATLST_1_PCMD_CH1(1U) + +#define S_RX_ATLST_1_PCMD_CH0 28 +#define V_RX_ATLST_1_PCMD_CH0(x) ((x) << S_RX_ATLST_1_PCMD_CH0) +#define F_RX_ATLST_1_PCMD_CH0 V_RX_ATLST_1_PCMD_CH0(1U) + +#define S_RX_ISPI_TXVALID 20 +#define M_RX_ISPI_TXVALID 0xfU +#define V_RX_ISPI_TXVALID(x) ((x) << S_RX_ISPI_TXVALID) +#define G_RX_ISPI_TXVALID(x) (((x) >> S_RX_ISPI_TXVALID) & M_RX_ISPI_TXVALID) + +#define S_RX_ISPI_FULL 16 +#define M_RX_ISPI_FULL 0xfU +#define V_RX_ISPI_FULL(x) ((x) << S_RX_ISPI_FULL) +#define G_RX_ISPI_FULL(x) (((x) >> S_RX_ISPI_FULL) & M_RX_ISPI_FULL) + +#define S_RX_OSPI_TXVALID 14 +#define M_RX_OSPI_TXVALID 0x3U +#define V_RX_OSPI_TXVALID(x) ((x) << S_RX_OSPI_TXVALID) +#define G_RX_OSPI_TXVALID(x) (((x) >> S_RX_OSPI_TXVALID) & M_RX_OSPI_TXVALID) + +#define S_RX_OSPI_FULL 12 +#define M_RX_OSPI_FULL 0x3U +#define V_RX_OSPI_FULL(x) ((x) << S_RX_OSPI_FULL) +#define G_RX_OSPI_FULL(x) (((x) >> S_RX_OSPI_FULL) & M_RX_OSPI_FULL) + +#define S_RX_E_RXVALID 8 +#define M_RX_E_RXVALID 0xfU +#define V_RX_E_RXVALID(x) ((x) << S_RX_E_RXVALID) +#define G_RX_E_RXVALID(x) (((x) >> S_RX_E_RXVALID) & M_RX_E_RXVALID) + +#define S_RX_E_RXAFULL 4 +#define M_RX_E_RXAFULL 0xfU +#define V_RX_E_RXAFULL(x) ((x) << S_RX_E_RXAFULL) +#define G_RX_E_RXAFULL(x) (((x) >> S_RX_E_RXAFULL) & M_RX_E_RXAFULL) + +#define S_RX_C_TXVALID 2 +#define M_RX_C_TXVALID 0x3U +#define V_RX_C_TXVALID(x) ((x) << S_RX_C_TXVALID) +#define G_RX_C_TXVALID(x) (((x) >> S_RX_C_TXVALID) & M_RX_C_TXVALID) + +#define S_RX_C_TXAFULL 0 +#define M_RX_C_TXAFULL 0x3U +#define V_RX_C_TXAFULL(x) ((x) << S_RX_C_TXAFULL) +#define G_RX_C_TXAFULL(x) (((x) >> S_RX_C_TXAFULL) & M_RX_C_TXAFULL) + +#define A_PM_RX_DBG_STAT6 0x10027 + +#define S_RX_M_INTRNL_FIFO_CNT 4 +#define M_RX_M_INTRNL_FIFO_CNT 0x3U +#define V_RX_M_INTRNL_FIFO_CNT(x) ((x) << S_RX_M_INTRNL_FIFO_CNT) +#define G_RX_M_INTRNL_FIFO_CNT(x) (((x) >> S_RX_M_INTRNL_FIFO_CNT) & M_RX_M_INTRNL_FIFO_CNT) + +#define S_RX_M_REQADDRRDY 3 +#define V_RX_M_REQADDRRDY(x) ((x) << S_RX_M_REQADDRRDY) +#define F_RX_M_REQADDRRDY V_RX_M_REQADDRRDY(1U) + +#define S_RX_M_REQWRITE 2 +#define V_RX_M_REQWRITE(x) ((x) << S_RX_M_REQWRITE) +#define F_RX_M_REQWRITE V_RX_M_REQWRITE(1U) + +#define S_RX_M_REQDATAVLD 1 +#define V_RX_M_REQDATAVLD(x) ((x) << S_RX_M_REQDATAVLD) +#define F_RX_M_REQDATAVLD V_RX_M_REQDATAVLD(1U) + +#define S_RX_M_REQDATARDY 0 +#define V_RX_M_REQDATARDY(x) ((x) << S_RX_M_REQDATARDY) +#define F_RX_M_REQDATARDY V_RX_M_REQDATARDY(1U) + +#define A_PM_RX_DBG_STAT7 0x10028 + +#define S_RX_PCMD1_FREE_CNT 7 +#define M_RX_PCMD1_FREE_CNT 0x7fU +#define V_RX_PCMD1_FREE_CNT(x) ((x) << S_RX_PCMD1_FREE_CNT) +#define G_RX_PCMD1_FREE_CNT(x) (((x) >> S_RX_PCMD1_FREE_CNT) & M_RX_PCMD1_FREE_CNT) + +#define S_RX_PCMD0_FREE_CNT 0 +#define M_RX_PCMD0_FREE_CNT 0x7fU +#define V_RX_PCMD0_FREE_CNT(x) ((x) << S_RX_PCMD0_FREE_CNT) +#define G_RX_PCMD0_FREE_CNT(x) (((x) >> S_RX_PCMD0_FREE_CNT) & M_RX_PCMD0_FREE_CNT) + +#define A_PM_RX_DBG_STAT8 0x10029 + +#define S_RX_IN_EOP_CNT3 28 +#define M_RX_IN_EOP_CNT3 0xfU +#define V_RX_IN_EOP_CNT3(x) ((x) << S_RX_IN_EOP_CNT3) +#define G_RX_IN_EOP_CNT3(x) (((x) >> S_RX_IN_EOP_CNT3) & M_RX_IN_EOP_CNT3) + +#define S_RX_IN_EOP_CNT2 24 +#define M_RX_IN_EOP_CNT2 0xfU +#define V_RX_IN_EOP_CNT2(x) ((x) << S_RX_IN_EOP_CNT2) +#define G_RX_IN_EOP_CNT2(x) (((x) >> S_RX_IN_EOP_CNT2) & M_RX_IN_EOP_CNT2) + +#define S_RX_IN_EOP_CNT1 20 +#define M_RX_IN_EOP_CNT1 0xfU +#define V_RX_IN_EOP_CNT1(x) ((x) << S_RX_IN_EOP_CNT1) +#define G_RX_IN_EOP_CNT1(x) (((x) >> S_RX_IN_EOP_CNT1) & M_RX_IN_EOP_CNT1) + +#define S_RX_IN_EOP_CNT0 16 +#define M_RX_IN_EOP_CNT0 0xfU +#define V_RX_IN_EOP_CNT0(x) ((x) << S_RX_IN_EOP_CNT0) +#define G_RX_IN_EOP_CNT0(x) (((x) >> S_RX_IN_EOP_CNT0) & M_RX_IN_EOP_CNT0) + +#define S_RX_IN_SOP_CNT3 12 +#define M_RX_IN_SOP_CNT3 0xfU +#define V_RX_IN_SOP_CNT3(x) ((x) << S_RX_IN_SOP_CNT3) +#define G_RX_IN_SOP_CNT3(x) (((x) >> S_RX_IN_SOP_CNT3) & M_RX_IN_SOP_CNT3) + +#define S_RX_IN_SOP_CNT2 8 +#define M_RX_IN_SOP_CNT2 0xfU +#define V_RX_IN_SOP_CNT2(x) ((x) << S_RX_IN_SOP_CNT2) +#define G_RX_IN_SOP_CNT2(x) (((x) >> S_RX_IN_SOP_CNT2) & M_RX_IN_SOP_CNT2) + +#define S_RX_IN_SOP_CNT1 4 +#define M_RX_IN_SOP_CNT1 0xfU +#define V_RX_IN_SOP_CNT1(x) ((x) << S_RX_IN_SOP_CNT1) +#define G_RX_IN_SOP_CNT1(x) (((x) >> S_RX_IN_SOP_CNT1) & M_RX_IN_SOP_CNT1) + +#define S_RX_IN_SOP_CNT0 0 +#define M_RX_IN_SOP_CNT0 0xfU +#define V_RX_IN_SOP_CNT0(x) ((x) << S_RX_IN_SOP_CNT0) +#define G_RX_IN_SOP_CNT0(x) (((x) >> S_RX_IN_SOP_CNT0) & M_RX_IN_SOP_CNT0) + +#define A_PM_RX_DBG_STAT9 0x1002a + +#define S_RX_RSVD0 28 +#define M_RX_RSVD0 0xfU +#define V_RX_RSVD0(x) ((x) << S_RX_RSVD0) +#define G_RX_RSVD0(x) (((x) >> S_RX_RSVD0) & M_RX_RSVD0) + +#define S_RX_RSVD1 24 +#define M_RX_RSVD1 0xfU +#define V_RX_RSVD1(x) ((x) << S_RX_RSVD1) +#define G_RX_RSVD1(x) (((x) >> S_RX_RSVD1) & M_RX_RSVD1) + +#define S_RX_OUT_EOP_CNT1 20 +#define M_RX_OUT_EOP_CNT1 0xfU +#define V_RX_OUT_EOP_CNT1(x) ((x) << S_RX_OUT_EOP_CNT1) +#define G_RX_OUT_EOP_CNT1(x) (((x) >> S_RX_OUT_EOP_CNT1) & M_RX_OUT_EOP_CNT1) + +#define S_RX_OUT_EOP_CNT0 16 +#define M_RX_OUT_EOP_CNT0 0xfU +#define V_RX_OUT_EOP_CNT0(x) ((x) << S_RX_OUT_EOP_CNT0) +#define G_RX_OUT_EOP_CNT0(x) (((x) >> S_RX_OUT_EOP_CNT0) & M_RX_OUT_EOP_CNT0) + +#define S_RX_RSVD2 12 +#define M_RX_RSVD2 0xfU +#define V_RX_RSVD2(x) ((x) << S_RX_RSVD2) +#define G_RX_RSVD2(x) (((x) >> S_RX_RSVD2) & M_RX_RSVD2) + +#define S_RX_RSVD3 8 +#define M_RX_RSVD3 0xfU +#define V_RX_RSVD3(x) ((x) << S_RX_RSVD3) +#define G_RX_RSVD3(x) (((x) >> S_RX_RSVD3) & M_RX_RSVD3) + +#define S_RX_OUT_SOP_CNT1 4 +#define M_RX_OUT_SOP_CNT1 0xfU +#define V_RX_OUT_SOP_CNT1(x) ((x) << S_RX_OUT_SOP_CNT1) +#define G_RX_OUT_SOP_CNT1(x) (((x) >> S_RX_OUT_SOP_CNT1) & M_RX_OUT_SOP_CNT1) + +#define S_RX_OUT_SOP_CNT0 0 +#define M_RX_OUT_SOP_CNT0 0xfU +#define V_RX_OUT_SOP_CNT0(x) ((x) << S_RX_OUT_SOP_CNT0) +#define G_RX_OUT_SOP_CNT0(x) (((x) >> S_RX_OUT_SOP_CNT0) & M_RX_OUT_SOP_CNT0) + +#define A_PM_RX_DBG_STAT10 0x1002b + +#define S_RX_CH_DEFICIT_BLOWED 24 +#define V_RX_CH_DEFICIT_BLOWED(x) ((x) << S_RX_CH_DEFICIT_BLOWED) +#define F_RX_CH_DEFICIT_BLOWED V_RX_CH_DEFICIT_BLOWED(1U) + +#define S_RX_CH1_DEFICIT 12 +#define M_RX_CH1_DEFICIT 0xfffU +#define V_RX_CH1_DEFICIT(x) ((x) << S_RX_CH1_DEFICIT) +#define G_RX_CH1_DEFICIT(x) (((x) >> S_RX_CH1_DEFICIT) & M_RX_CH1_DEFICIT) + +#define S_RX_CH0_DEFICIT 0 +#define M_RX_CH0_DEFICIT 0xfffU +#define V_RX_CH0_DEFICIT(x) ((x) << S_RX_CH0_DEFICIT) +#define G_RX_CH0_DEFICIT(x) (((x) >> S_RX_CH0_DEFICIT) & M_RX_CH0_DEFICIT) + +#define A_PM_RX_DBG_STAT11 0x1002c + +#define S_RX_BUNDLE_LEN_SRDY 30 +#define M_RX_BUNDLE_LEN_SRDY 0x3U +#define V_RX_BUNDLE_LEN_SRDY(x) ((x) << S_RX_BUNDLE_LEN_SRDY) +#define G_RX_BUNDLE_LEN_SRDY(x) (((x) >> S_RX_BUNDLE_LEN_SRDY) & M_RX_BUNDLE_LEN_SRDY) + +#define S_RX_RSVD11_1 28 +#define M_RX_RSVD11_1 0x3U +#define V_RX_RSVD11_1(x) ((x) << S_RX_RSVD11_1) +#define G_RX_RSVD11_1(x) (((x) >> S_RX_RSVD11_1) & M_RX_RSVD11_1) + +#define S_RX_BUNDLE_LEN1 16 +#define M_RX_BUNDLE_LEN1 0xfffU +#define V_RX_BUNDLE_LEN1(x) ((x) << S_RX_BUNDLE_LEN1) +#define G_RX_BUNDLE_LEN1(x) (((x) >> S_RX_BUNDLE_LEN1) & M_RX_BUNDLE_LEN1) + +#define S_RX_RSVD11 12 +#define M_RX_RSVD11 0xfU +#define V_RX_RSVD11(x) ((x) << S_RX_RSVD11) +#define G_RX_RSVD11(x) (((x) >> S_RX_RSVD11) & M_RX_RSVD11) + +#define S_RX_BUNDLE_LEN0 0 +#define M_RX_BUNDLE_LEN0 0xfffU +#define V_RX_BUNDLE_LEN0(x) ((x) << S_RX_BUNDLE_LEN0) +#define G_RX_BUNDLE_LEN0(x) (((x) >> S_RX_BUNDLE_LEN0) & M_RX_BUNDLE_LEN0) + +/* registers for module PM_TX */ +#define PM_TX_BASE_ADDR 0x8fe0 + +#define A_PM_TX_CFG 0x8fe0 + +#define S_CH3_OUTPUT 17 +#define M_CH3_OUTPUT 0x1fU +#define V_CH3_OUTPUT(x) ((x) << S_CH3_OUTPUT) +#define G_CH3_OUTPUT(x) (((x) >> S_CH3_OUTPUT) & M_CH3_OUTPUT) + +#define A_PM_TX_MODE 0x8fe4 + +#define S_CONG_THRESH3 25 +#define M_CONG_THRESH3 0x7fU +#define V_CONG_THRESH3(x) ((x) << S_CONG_THRESH3) +#define G_CONG_THRESH3(x) (((x) >> S_CONG_THRESH3) & M_CONG_THRESH3) + +#define S_CONG_THRESH2 18 +#define M_CONG_THRESH2 0x7fU +#define V_CONG_THRESH2(x) ((x) << S_CONG_THRESH2) +#define G_CONG_THRESH2(x) (((x) >> S_CONG_THRESH2) & M_CONG_THRESH2) + +#define S_CONG_THRESH1 11 +#define M_CONG_THRESH1 0x7fU +#define V_CONG_THRESH1(x) ((x) << S_CONG_THRESH1) +#define G_CONG_THRESH1(x) (((x) >> S_CONG_THRESH1) & M_CONG_THRESH1) + +#define S_CONG_THRESH0 4 +#define M_CONG_THRESH0 0x7fU +#define V_CONG_THRESH0(x) ((x) << S_CONG_THRESH0) +#define G_CONG_THRESH0(x) (((x) >> S_CONG_THRESH0) & M_CONG_THRESH0) + +#define S_TX_USE_BUNDLE_LEN 3 +#define V_TX_USE_BUNDLE_LEN(x) ((x) << S_TX_USE_BUNDLE_LEN) +#define F_TX_USE_BUNDLE_LEN V_TX_USE_BUNDLE_LEN(1U) + +#define S_STAT_CHANNEL 1 +#define M_STAT_CHANNEL 0x3U +#define V_STAT_CHANNEL(x) ((x) << S_STAT_CHANNEL) +#define G_STAT_CHANNEL(x) (((x) >> S_STAT_CHANNEL) & M_STAT_CHANNEL) + +#define A_PM_TX_STAT_CONFIG 0x8fe8 +#define A_PM_TX_STAT_COUNT 0x8fec +#define A_PM_TX_STAT_LSB 0x8ff0 +#define A_PM_TX_DBG_CTRL 0x8ff0 + +#define S_OSPIWRBUSY 21 +#define M_OSPIWRBUSY 0xfU +#define V_OSPIWRBUSY(x) ((x) << S_OSPIWRBUSY) +#define G_OSPIWRBUSY(x) (((x) >> S_OSPIWRBUSY) & M_OSPIWRBUSY) + +#define A_PM_TX_STAT_MSB 0x8ff4 +#define A_PM_TX_DBG_DATA 0x8ff4 +#define A_PM_TX_INT_ENABLE 0x8ff8 + +#define S_PCMD_LEN_OVFL0 31 +#define V_PCMD_LEN_OVFL0(x) ((x) << S_PCMD_LEN_OVFL0) +#define F_PCMD_LEN_OVFL0 V_PCMD_LEN_OVFL0(1U) + +#define S_PCMD_LEN_OVFL1 30 +#define V_PCMD_LEN_OVFL1(x) ((x) << S_PCMD_LEN_OVFL1) +#define F_PCMD_LEN_OVFL1 V_PCMD_LEN_OVFL1(1U) + +#define S_PCMD_LEN_OVFL2 29 +#define V_PCMD_LEN_OVFL2(x) ((x) << S_PCMD_LEN_OVFL2) +#define F_PCMD_LEN_OVFL2 V_PCMD_LEN_OVFL2(1U) + +#define S_ZERO_C_CMD_ERRO 28 +#define V_ZERO_C_CMD_ERRO(x) ((x) << S_ZERO_C_CMD_ERRO) +#define F_ZERO_C_CMD_ERRO V_ZERO_C_CMD_ERRO(1U) + +#define S_ICSPI0_FIFO2X_RX_FRAMING_ERROR 27 +#define V_ICSPI0_FIFO2X_RX_FRAMING_ERROR(x) ((x) << S_ICSPI0_FIFO2X_RX_FRAMING_ERROR) +#define F_ICSPI0_FIFO2X_RX_FRAMING_ERROR V_ICSPI0_FIFO2X_RX_FRAMING_ERROR(1U) + +#define S_ICSPI1_FIFO2X_RX_FRAMING_ERROR 26 +#define V_ICSPI1_FIFO2X_RX_FRAMING_ERROR(x) ((x) << S_ICSPI1_FIFO2X_RX_FRAMING_ERROR) +#define F_ICSPI1_FIFO2X_RX_FRAMING_ERROR V_ICSPI1_FIFO2X_RX_FRAMING_ERROR(1U) + +#define S_ICSPI2_FIFO2X_RX_FRAMING_ERROR 25 +#define V_ICSPI2_FIFO2X_RX_FRAMING_ERROR(x) ((x) << S_ICSPI2_FIFO2X_RX_FRAMING_ERROR) +#define F_ICSPI2_FIFO2X_RX_FRAMING_ERROR V_ICSPI2_FIFO2X_RX_FRAMING_ERROR(1U) + +#define S_ICSPI3_FIFO2X_RX_FRAMING_ERROR 24 +#define V_ICSPI3_FIFO2X_RX_FRAMING_ERROR(x) ((x) << S_ICSPI3_FIFO2X_RX_FRAMING_ERROR) +#define F_ICSPI3_FIFO2X_RX_FRAMING_ERROR V_ICSPI3_FIFO2X_RX_FRAMING_ERROR(1U) + +#define S_ICSPI0_RX_FRAMING_ERROR 23 +#define V_ICSPI0_RX_FRAMING_ERROR(x) ((x) << S_ICSPI0_RX_FRAMING_ERROR) +#define F_ICSPI0_RX_FRAMING_ERROR V_ICSPI0_RX_FRAMING_ERROR(1U) + +#define S_ICSPI1_RX_FRAMING_ERROR 22 +#define V_ICSPI1_RX_FRAMING_ERROR(x) ((x) << S_ICSPI1_RX_FRAMING_ERROR) +#define F_ICSPI1_RX_FRAMING_ERROR V_ICSPI1_RX_FRAMING_ERROR(1U) + +#define S_ICSPI2_RX_FRAMING_ERROR 21 +#define V_ICSPI2_RX_FRAMING_ERROR(x) ((x) << S_ICSPI2_RX_FRAMING_ERROR) +#define F_ICSPI2_RX_FRAMING_ERROR V_ICSPI2_RX_FRAMING_ERROR(1U) + +#define S_ICSPI3_RX_FRAMING_ERROR 20 +#define V_ICSPI3_RX_FRAMING_ERROR(x) ((x) << S_ICSPI3_RX_FRAMING_ERROR) +#define F_ICSPI3_RX_FRAMING_ERROR V_ICSPI3_RX_FRAMING_ERROR(1U) + +#define S_ICSPI0_TX_FRAMING_ERROR 19 +#define V_ICSPI0_TX_FRAMING_ERROR(x) ((x) << S_ICSPI0_TX_FRAMING_ERROR) +#define F_ICSPI0_TX_FRAMING_ERROR V_ICSPI0_TX_FRAMING_ERROR(1U) + +#define S_ICSPI1_TX_FRAMING_ERROR 18 +#define V_ICSPI1_TX_FRAMING_ERROR(x) ((x) << S_ICSPI1_TX_FRAMING_ERROR) +#define F_ICSPI1_TX_FRAMING_ERROR V_ICSPI1_TX_FRAMING_ERROR(1U) + +#define S_ICSPI2_TX_FRAMING_ERROR 17 +#define V_ICSPI2_TX_FRAMING_ERROR(x) ((x) << S_ICSPI2_TX_FRAMING_ERROR) +#define F_ICSPI2_TX_FRAMING_ERROR V_ICSPI2_TX_FRAMING_ERROR(1U) + +#define S_ICSPI3_TX_FRAMING_ERROR 16 +#define V_ICSPI3_TX_FRAMING_ERROR(x) ((x) << S_ICSPI3_TX_FRAMING_ERROR) +#define F_ICSPI3_TX_FRAMING_ERROR V_ICSPI3_TX_FRAMING_ERROR(1U) + +#define S_OESPI0_RX_FRAMING_ERROR 15 +#define V_OESPI0_RX_FRAMING_ERROR(x) ((x) << S_OESPI0_RX_FRAMING_ERROR) +#define F_OESPI0_RX_FRAMING_ERROR V_OESPI0_RX_FRAMING_ERROR(1U) + +#define S_OESPI1_RX_FRAMING_ERROR 14 +#define V_OESPI1_RX_FRAMING_ERROR(x) ((x) << S_OESPI1_RX_FRAMING_ERROR) +#define F_OESPI1_RX_FRAMING_ERROR V_OESPI1_RX_FRAMING_ERROR(1U) + +#define S_OESPI2_RX_FRAMING_ERROR 13 +#define V_OESPI2_RX_FRAMING_ERROR(x) ((x) << S_OESPI2_RX_FRAMING_ERROR) +#define F_OESPI2_RX_FRAMING_ERROR V_OESPI2_RX_FRAMING_ERROR(1U) + +#define S_OESPI3_RX_FRAMING_ERROR 12 +#define V_OESPI3_RX_FRAMING_ERROR(x) ((x) << S_OESPI3_RX_FRAMING_ERROR) +#define F_OESPI3_RX_FRAMING_ERROR V_OESPI3_RX_FRAMING_ERROR(1U) + +#define S_OESPI0_TX_FRAMING_ERROR 11 +#define V_OESPI0_TX_FRAMING_ERROR(x) ((x) << S_OESPI0_TX_FRAMING_ERROR) +#define F_OESPI0_TX_FRAMING_ERROR V_OESPI0_TX_FRAMING_ERROR(1U) + +#define S_OESPI1_TX_FRAMING_ERROR 10 +#define V_OESPI1_TX_FRAMING_ERROR(x) ((x) << S_OESPI1_TX_FRAMING_ERROR) +#define F_OESPI1_TX_FRAMING_ERROR V_OESPI1_TX_FRAMING_ERROR(1U) + +#define S_OESPI2_TX_FRAMING_ERROR 9 +#define V_OESPI2_TX_FRAMING_ERROR(x) ((x) << S_OESPI2_TX_FRAMING_ERROR) +#define F_OESPI2_TX_FRAMING_ERROR V_OESPI2_TX_FRAMING_ERROR(1U) + +#define S_OESPI3_TX_FRAMING_ERROR 8 +#define V_OESPI3_TX_FRAMING_ERROR(x) ((x) << S_OESPI3_TX_FRAMING_ERROR) +#define F_OESPI3_TX_FRAMING_ERROR V_OESPI3_TX_FRAMING_ERROR(1U) + +#define S_OESPI0_OFIFO2X_TX_FRAMING_ERROR 7 +#define V_OESPI0_OFIFO2X_TX_FRAMING_ERROR(x) ((x) << S_OESPI0_OFIFO2X_TX_FRAMING_ERROR) +#define F_OESPI0_OFIFO2X_TX_FRAMING_ERROR V_OESPI0_OFIFO2X_TX_FRAMING_ERROR(1U) + +#define S_OESPI1_OFIFO2X_TX_FRAMING_ERROR 6 +#define V_OESPI1_OFIFO2X_TX_FRAMING_ERROR(x) ((x) << S_OESPI1_OFIFO2X_TX_FRAMING_ERROR) +#define F_OESPI1_OFIFO2X_TX_FRAMING_ERROR V_OESPI1_OFIFO2X_TX_FRAMING_ERROR(1U) + +#define S_OESPI2_OFIFO2X_TX_FRAMING_ERROR 5 +#define V_OESPI2_OFIFO2X_TX_FRAMING_ERROR(x) ((x) << S_OESPI2_OFIFO2X_TX_FRAMING_ERROR) +#define F_OESPI2_OFIFO2X_TX_FRAMING_ERROR V_OESPI2_OFIFO2X_TX_FRAMING_ERROR(1U) + +#define S_OESPI3_OFIFO2X_TX_FRAMING_ERROR 4 +#define V_OESPI3_OFIFO2X_TX_FRAMING_ERROR(x) ((x) << S_OESPI3_OFIFO2X_TX_FRAMING_ERROR) +#define F_OESPI3_OFIFO2X_TX_FRAMING_ERROR V_OESPI3_OFIFO2X_TX_FRAMING_ERROR(1U) + +#define S_OESPI_PAR_ERROR 3 +#define V_OESPI_PAR_ERROR(x) ((x) << S_OESPI_PAR_ERROR) +#define F_OESPI_PAR_ERROR V_OESPI_PAR_ERROR(1U) + +#define S_ICSPI_PAR_ERROR 1 +#define V_ICSPI_PAR_ERROR(x) ((x) << S_ICSPI_PAR_ERROR) +#define F_ICSPI_PAR_ERROR V_ICSPI_PAR_ERROR(1U) + +#define S_C_PCMD_PAR_ERROR 0 +#define V_C_PCMD_PAR_ERROR(x) ((x) << S_C_PCMD_PAR_ERROR) +#define F_C_PCMD_PAR_ERROR V_C_PCMD_PAR_ERROR(1U) + +#define A_PM_TX_INT_CAUSE 0x8ffc + +#define S_ZERO_C_CMD_ERROR 28 +#define V_ZERO_C_CMD_ERROR(x) ((x) << S_ZERO_C_CMD_ERROR) +#define F_ZERO_C_CMD_ERROR V_ZERO_C_CMD_ERROR(1U) + +#define S_OSPI_OR_BUNDLE_LEN_PAR_ERR 3 +#define V_OSPI_OR_BUNDLE_LEN_PAR_ERR(x) ((x) << S_OSPI_OR_BUNDLE_LEN_PAR_ERR) +#define F_OSPI_OR_BUNDLE_LEN_PAR_ERR V_OSPI_OR_BUNDLE_LEN_PAR_ERR(1U) + +#define A_PM_TX_ISPI_DBG_4B_DATA0 0x10000 +#define A_PM_TX_ISPI_DBG_4B_DATA1 0x10001 +#define A_PM_TX_ISPI_DBG_4B_DATA2 0x10002 +#define A_PM_TX_ISPI_DBG_4B_DATA3 0x10003 +#define A_PM_TX_ISPI_DBG_4B_DATA4 0x10004 +#define A_PM_TX_ISPI_DBG_4B_DATA5 0x10005 +#define A_PM_TX_ISPI_DBG_4B_DATA6 0x10006 +#define A_PM_TX_ISPI_DBG_4B_DATA7 0x10007 +#define A_PM_TX_ISPI_DBG_4B_DATA8 0x10008 +#define A_PM_TX_OSPI_DBG_4B_DATA0 0x10009 +#define A_PM_TX_OSPI_DBG_4B_DATA1 0x1000a +#define A_PM_TX_OSPI_DBG_4B_DATA2 0x1000b +#define A_PM_TX_OSPI_DBG_4B_DATA3 0x1000c +#define A_PM_TX_OSPI_DBG_4B_DATA4 0x1000d +#define A_PM_TX_OSPI_DBG_4B_DATA5 0x1000e +#define A_PM_TX_OSPI_DBG_4B_DATA6 0x1000f +#define A_PM_TX_OSPI_DBG_4B_DATA7 0x10010 +#define A_PM_TX_OSPI_DBG_4B_DATA8 0x10011 +#define A_PM_TX_OSPI_DBG_4B_DATA9 0x10012 +#define A_PM_TX_OSPI_DBG_4B_DATA10 0x10013 +#define A_PM_TX_OSPI_DBG_4B_DATA11 0x10014 +#define A_PM_TX_OSPI_DBG_4B_DATA12 0x10015 +#define A_PM_TX_OSPI_DBG_4B_DATA13 0x10016 +#define A_PM_TX_OSPI_DBG_4B_DATA14 0x10017 +#define A_PM_TX_OSPI_DBG_4B_DATA15 0x10018 +#define A_PM_TX_OSPI_DBG_4B_DATA16 0x10019 +#define A_PM_TX_DBG_STAT_MSB 0x1001a +#define A_PM_TX_DBG_STAT_LSB 0x1001b +#define A_PM_TX_DBG_RSVD_FLIT_CNT 0x1001c +#define A_PM_TX_SDC_EN 0x1001d +#define A_PM_TX_INOUT_FIFO_DBG_CHNL_SEL 0x1001e +#define A_PM_TX_INOUT_FIFO_DBG_WR 0x1001f +#define A_PM_TX_INPUT_FIFO_STR_FWD_EN 0x10020 +#define A_PM_TX_FEATURE_EN 0x10021 + +#define S_PIO_CH_DEFICIT_CTL_EN 2 +#define V_PIO_CH_DEFICIT_CTL_EN(x) ((x) << S_PIO_CH_DEFICIT_CTL_EN) +#define F_PIO_CH_DEFICIT_CTL_EN V_PIO_CH_DEFICIT_CTL_EN(1U) + +#define S_PIO_WRR_BASED_PRFTCH_EN 1 +#define V_PIO_WRR_BASED_PRFTCH_EN(x) ((x) << S_PIO_WRR_BASED_PRFTCH_EN) +#define F_PIO_WRR_BASED_PRFTCH_EN V_PIO_WRR_BASED_PRFTCH_EN(1U) + +#define A_PM_TX_T5_PM_TX_INT_ENABLE 0x10022 + +#define S_OSPI_OVERFLOW3 7 +#define V_OSPI_OVERFLOW3(x) ((x) << S_OSPI_OVERFLOW3) +#define F_OSPI_OVERFLOW3 V_OSPI_OVERFLOW3(1U) + +#define S_OSPI_OVERFLOW2 6 +#define V_OSPI_OVERFLOW2(x) ((x) << S_OSPI_OVERFLOW2) +#define F_OSPI_OVERFLOW2 V_OSPI_OVERFLOW2(1U) + +#define S_M_INTFPERREN 3 +#define V_M_INTFPERREN(x) ((x) << S_M_INTFPERREN) +#define F_M_INTFPERREN V_M_INTFPERREN(1U) + +#define S_BUNDLE_LEN_PARERR_EN 2 +#define V_BUNDLE_LEN_PARERR_EN(x) ((x) << S_BUNDLE_LEN_PARERR_EN) +#define F_BUNDLE_LEN_PARERR_EN V_BUNDLE_LEN_PARERR_EN(1U) + +#define S_BUNDLE_LEN_OVFL_EN 1 +#define V_BUNDLE_LEN_OVFL_EN(x) ((x) << S_BUNDLE_LEN_OVFL_EN) +#define F_BUNDLE_LEN_OVFL_EN V_BUNDLE_LEN_OVFL_EN(1U) + +#define S_SDC_ERR_EN 0 +#define V_SDC_ERR_EN(x) ((x) << S_SDC_ERR_EN) +#define F_SDC_ERR_EN V_SDC_ERR_EN(1U) + +#define A_PM_TX_PRFTCH_WRR_WAIT_CNT_THRSHLD0 0x10023 +#define A_PM_TX_PRFTCH_WRR_WAIT_CNT_THRSHLD1 0x10024 +#define A_PM_TX_PRFTCH_WRR_WAIT_CNT_THRSHLD2 0x10025 +#define A_PM_TX_PRFTCH_WRR_WAIT_CNT_THRSHLD3 0x10026 +#define A_PM_TX_CH0_OSPI_DEFICIT_THRSHLD 0x10027 +#define A_PM_TX_CH1_OSPI_DEFICIT_THRSHLD 0x10028 +#define A_PM_TX_CH2_OSPI_DEFICIT_THRSHLD 0x10029 + +#define S_CH2_OSPI_DEFICIT_THRSHLD 0 +#define M_CH2_OSPI_DEFICIT_THRSHLD 0xfffU +#define V_CH2_OSPI_DEFICIT_THRSHLD(x) ((x) << S_CH2_OSPI_DEFICIT_THRSHLD) +#define G_CH2_OSPI_DEFICIT_THRSHLD(x) (((x) >> S_CH2_OSPI_DEFICIT_THRSHLD) & M_CH2_OSPI_DEFICIT_THRSHLD) + +#define A_PM_TX_CH3_OSPI_DEFICIT_THRSHLD 0x1002a + +#define S_CH3_OSPI_DEFICIT_THRSHLD 0 +#define M_CH3_OSPI_DEFICIT_THRSHLD 0xfffU +#define V_CH3_OSPI_DEFICIT_THRSHLD(x) ((x) << S_CH3_OSPI_DEFICIT_THRSHLD) +#define G_CH3_OSPI_DEFICIT_THRSHLD(x) (((x) >> S_CH3_OSPI_DEFICIT_THRSHLD) & M_CH3_OSPI_DEFICIT_THRSHLD) + +#define A_PM_TX_INT_CAUSE_MASK_HALT 0x1002b +#define A_PM_TX_DBG_STAT0 0x1002c + +#define S_RD_I_BUSY 28 +#define V_RD_I_BUSY(x) ((x) << S_RD_I_BUSY) +#define F_RD_I_BUSY V_RD_I_BUSY(1U) + +#define S_WR_O_ONLY 27 +#define V_WR_O_ONLY(x) ((x) << S_WR_O_ONLY) +#define F_WR_O_ONLY V_WR_O_ONLY(1U) + +#define S_M_TO_BUSY 26 +#define V_M_TO_BUSY(x) ((x) << S_M_TO_BUSY) +#define F_M_TO_BUSY V_M_TO_BUSY(1U) + +#define S_I_TO_M_BUSY 25 +#define V_I_TO_M_BUSY(x) ((x) << S_I_TO_M_BUSY) +#define F_I_TO_M_BUSY V_I_TO_M_BUSY(1U) + +#define S_PCMD_FB_ONLY 24 +#define V_PCMD_FB_ONLY(x) ((x) << S_PCMD_FB_ONLY) +#define F_PCMD_FB_ONLY V_PCMD_FB_ONLY(1U) + +#define S_PCMD_MEM 23 +#define V_PCMD_MEM(x) ((x) << S_PCMD_MEM) +#define F_PCMD_MEM V_PCMD_MEM(1U) + +#define S_PCMD_BYPASS 22 +#define V_PCMD_BYPASS(x) ((x) << S_PCMD_BYPASS) +#define F_PCMD_BYPASS V_PCMD_BYPASS(1U) + +#define S_PCMD_EOP 21 +#define V_PCMD_EOP(x) ((x) << S_PCMD_EOP) +#define F_PCMD_EOP V_PCMD_EOP(1U) + +#define S_PCMD_END_BUNDLE 20 +#define V_PCMD_END_BUNDLE(x) ((x) << S_PCMD_END_BUNDLE) +#define F_PCMD_END_BUNDLE V_PCMD_END_BUNDLE(1U) + +#define S_PCMD_FB_CMD 16 +#define M_PCMD_FB_CMD 0xfU +#define V_PCMD_FB_CMD(x) ((x) << S_PCMD_FB_CMD) +#define G_PCMD_FB_CMD(x) (((x) >> S_PCMD_FB_CMD) & M_PCMD_FB_CMD) + +#define S_CUR_PCMD_LEN 0 +#define M_CUR_PCMD_LEN 0xffffU +#define V_CUR_PCMD_LEN(x) ((x) << S_CUR_PCMD_LEN) +#define G_CUR_PCMD_LEN(x) (((x) >> S_CUR_PCMD_LEN) & M_CUR_PCMD_LEN) + +#define A_PM_TX_DBG_STAT1 0x1002d + +#define S_PCMD_MEM0 31 +#define V_PCMD_MEM0(x) ((x) << S_PCMD_MEM0) +#define F_PCMD_MEM0 V_PCMD_MEM0(1U) + +#define S_FREE_OESPI_CNT0 19 +#define M_FREE_OESPI_CNT0 0xfffU +#define V_FREE_OESPI_CNT0(x) ((x) << S_FREE_OESPI_CNT0) +#define G_FREE_OESPI_CNT0(x) (((x) >> S_FREE_OESPI_CNT0) & M_FREE_OESPI_CNT0) + +#define S_PCMD_FLIT_LEN0 7 +#define M_PCMD_FLIT_LEN0 0xfffU +#define V_PCMD_FLIT_LEN0(x) ((x) << S_PCMD_FLIT_LEN0) +#define G_PCMD_FLIT_LEN0(x) (((x) >> S_PCMD_FLIT_LEN0) & M_PCMD_FLIT_LEN0) + +#define S_PCMD_CMD0 3 +#define M_PCMD_CMD0 0xfU +#define V_PCMD_CMD0(x) ((x) << S_PCMD_CMD0) +#define G_PCMD_CMD0(x) (((x) >> S_PCMD_CMD0) & M_PCMD_CMD0) + +#define S_OFIFO_FULL0 2 +#define V_OFIFO_FULL0(x) ((x) << S_OFIFO_FULL0) +#define F_OFIFO_FULL0 V_OFIFO_FULL0(1U) + +#define S_GCSUM_DRDY0 1 +#define V_GCSUM_DRDY0(x) ((x) << S_GCSUM_DRDY0) +#define F_GCSUM_DRDY0 V_GCSUM_DRDY0(1U) + +#define S_BYPASS0 0 +#define V_BYPASS0(x) ((x) << S_BYPASS0) +#define F_BYPASS0 V_BYPASS0(1U) + +#define A_PM_TX_DBG_STAT2 0x1002e + +#define S_PCMD_MEM1 31 +#define V_PCMD_MEM1(x) ((x) << S_PCMD_MEM1) +#define F_PCMD_MEM1 V_PCMD_MEM1(1U) + +#define S_FREE_OESPI_CNT1 19 +#define M_FREE_OESPI_CNT1 0xfffU +#define V_FREE_OESPI_CNT1(x) ((x) << S_FREE_OESPI_CNT1) +#define G_FREE_OESPI_CNT1(x) (((x) >> S_FREE_OESPI_CNT1) & M_FREE_OESPI_CNT1) + +#define S_PCMD_FLIT_LEN1 7 +#define M_PCMD_FLIT_LEN1 0xfffU +#define V_PCMD_FLIT_LEN1(x) ((x) << S_PCMD_FLIT_LEN1) +#define G_PCMD_FLIT_LEN1(x) (((x) >> S_PCMD_FLIT_LEN1) & M_PCMD_FLIT_LEN1) + +#define S_PCMD_CMD1 3 +#define M_PCMD_CMD1 0xfU +#define V_PCMD_CMD1(x) ((x) << S_PCMD_CMD1) +#define G_PCMD_CMD1(x) (((x) >> S_PCMD_CMD1) & M_PCMD_CMD1) + +#define S_OFIFO_FULL1 2 +#define V_OFIFO_FULL1(x) ((x) << S_OFIFO_FULL1) +#define F_OFIFO_FULL1 V_OFIFO_FULL1(1U) + +#define S_GCSUM_DRDY1 1 +#define V_GCSUM_DRDY1(x) ((x) << S_GCSUM_DRDY1) +#define F_GCSUM_DRDY1 V_GCSUM_DRDY1(1U) + +#define S_BYPASS1 0 +#define V_BYPASS1(x) ((x) << S_BYPASS1) +#define F_BYPASS1 V_BYPASS1(1U) + +#define A_PM_TX_DBG_STAT3 0x1002f + +#define S_PCMD_MEM2 31 +#define V_PCMD_MEM2(x) ((x) << S_PCMD_MEM2) +#define F_PCMD_MEM2 V_PCMD_MEM2(1U) + +#define S_FREE_OESPI_CNT2 19 +#define M_FREE_OESPI_CNT2 0xfffU +#define V_FREE_OESPI_CNT2(x) ((x) << S_FREE_OESPI_CNT2) +#define G_FREE_OESPI_CNT2(x) (((x) >> S_FREE_OESPI_CNT2) & M_FREE_OESPI_CNT2) + +#define S_PCMD_FLIT_LEN2 7 +#define M_PCMD_FLIT_LEN2 0xfffU +#define V_PCMD_FLIT_LEN2(x) ((x) << S_PCMD_FLIT_LEN2) +#define G_PCMD_FLIT_LEN2(x) (((x) >> S_PCMD_FLIT_LEN2) & M_PCMD_FLIT_LEN2) + +#define S_PCMD_CMD2 3 +#define M_PCMD_CMD2 0xfU +#define V_PCMD_CMD2(x) ((x) << S_PCMD_CMD2) +#define G_PCMD_CMD2(x) (((x) >> S_PCMD_CMD2) & M_PCMD_CMD2) + +#define S_OFIFO_FULL2 2 +#define V_OFIFO_FULL2(x) ((x) << S_OFIFO_FULL2) +#define F_OFIFO_FULL2 V_OFIFO_FULL2(1U) + +#define S_GCSUM_DRDY2 1 +#define V_GCSUM_DRDY2(x) ((x) << S_GCSUM_DRDY2) +#define F_GCSUM_DRDY2 V_GCSUM_DRDY2(1U) + +#define S_BYPASS2 0 +#define V_BYPASS2(x) ((x) << S_BYPASS2) +#define F_BYPASS2 V_BYPASS2(1U) + +#define A_PM_TX_DBG_STAT4 0x10030 + +#define S_PCMD_MEM3 31 +#define V_PCMD_MEM3(x) ((x) << S_PCMD_MEM3) +#define F_PCMD_MEM3 V_PCMD_MEM3(1U) + +#define S_FREE_OESPI_CNT3 19 +#define M_FREE_OESPI_CNT3 0xfffU +#define V_FREE_OESPI_CNT3(x) ((x) << S_FREE_OESPI_CNT3) +#define G_FREE_OESPI_CNT3(x) (((x) >> S_FREE_OESPI_CNT3) & M_FREE_OESPI_CNT3) + +#define S_PCMD_FLIT_LEN3 7 +#define M_PCMD_FLIT_LEN3 0xfffU +#define V_PCMD_FLIT_LEN3(x) ((x) << S_PCMD_FLIT_LEN3) +#define G_PCMD_FLIT_LEN3(x) (((x) >> S_PCMD_FLIT_LEN3) & M_PCMD_FLIT_LEN3) + +#define S_PCMD_CMD3 3 +#define M_PCMD_CMD3 0xfU +#define V_PCMD_CMD3(x) ((x) << S_PCMD_CMD3) +#define G_PCMD_CMD3(x) (((x) >> S_PCMD_CMD3) & M_PCMD_CMD3) + +#define S_OFIFO_FULL3 2 +#define V_OFIFO_FULL3(x) ((x) << S_OFIFO_FULL3) +#define F_OFIFO_FULL3 V_OFIFO_FULL3(1U) + +#define S_GCSUM_DRDY3 1 +#define V_GCSUM_DRDY3(x) ((x) << S_GCSUM_DRDY3) +#define F_GCSUM_DRDY3 V_GCSUM_DRDY3(1U) + +#define S_BYPASS3 0 +#define V_BYPASS3(x) ((x) << S_BYPASS3) +#define F_BYPASS3 V_BYPASS3(1U) + +#define A_PM_TX_DBG_STAT5 0x10031 + +#define S_SET_PCMD_RES_RDY_RD 24 +#define M_SET_PCMD_RES_RDY_RD 0xfU +#define V_SET_PCMD_RES_RDY_RD(x) ((x) << S_SET_PCMD_RES_RDY_RD) +#define G_SET_PCMD_RES_RDY_RD(x) (((x) >> S_SET_PCMD_RES_RDY_RD) & M_SET_PCMD_RES_RDY_RD) + +#define S_ISSUED_PREF_RD_ER_CLR 20 +#define M_ISSUED_PREF_RD_ER_CLR 0xfU +#define V_ISSUED_PREF_RD_ER_CLR(x) ((x) << S_ISSUED_PREF_RD_ER_CLR) +#define G_ISSUED_PREF_RD_ER_CLR(x) (((x) >> S_ISSUED_PREF_RD_ER_CLR) & M_ISSUED_PREF_RD_ER_CLR) + +#define S_ISSUED_PREF_RD 16 +#define M_ISSUED_PREF_RD 0xfU +#define V_ISSUED_PREF_RD(x) ((x) << S_ISSUED_PREF_RD) +#define G_ISSUED_PREF_RD(x) (((x) >> S_ISSUED_PREF_RD) & M_ISSUED_PREF_RD) + +#define S_PCMD_RES_RDY 12 +#define M_PCMD_RES_RDY 0xfU +#define V_PCMD_RES_RDY(x) ((x) << S_PCMD_RES_RDY) +#define G_PCMD_RES_RDY(x) (((x) >> S_PCMD_RES_RDY) & M_PCMD_RES_RDY) + +#define S_DB_VLD 11 +#define V_DB_VLD(x) ((x) << S_DB_VLD) +#define F_DB_VLD V_DB_VLD(1U) + +#define S_INJECT0_DRDY 10 +#define V_INJECT0_DRDY(x) ((x) << S_INJECT0_DRDY) +#define F_INJECT0_DRDY V_INJECT0_DRDY(1U) + +#define S_INJECT1_DRDY 9 +#define V_INJECT1_DRDY(x) ((x) << S_INJECT1_DRDY) +#define F_INJECT1_DRDY V_INJECT1_DRDY(1U) + +#define S_FIRST_BUNDLE 5 +#define M_FIRST_BUNDLE 0xfU +#define V_FIRST_BUNDLE(x) ((x) << S_FIRST_BUNDLE) +#define G_FIRST_BUNDLE(x) (((x) >> S_FIRST_BUNDLE) & M_FIRST_BUNDLE) + +#define S_GCSUM_MORE_THAN_2_LEFT 1 +#define M_GCSUM_MORE_THAN_2_LEFT 0xfU +#define V_GCSUM_MORE_THAN_2_LEFT(x) ((x) << S_GCSUM_MORE_THAN_2_LEFT) +#define G_GCSUM_MORE_THAN_2_LEFT(x) (((x) >> S_GCSUM_MORE_THAN_2_LEFT) & M_GCSUM_MORE_THAN_2_LEFT) + +#define S_SDC_DRDY 0 +#define V_SDC_DRDY(x) ((x) << S_SDC_DRDY) +#define F_SDC_DRDY V_SDC_DRDY(1U) + +#define A_PM_TX_DBG_STAT6 0x10032 + +#define S_PCMD_VLD 31 +#define V_PCMD_VLD(x) ((x) << S_PCMD_VLD) +#define F_PCMD_VLD V_PCMD_VLD(1U) + +#define S_PCMD_CH 29 +#define M_PCMD_CH 0x3U +#define V_PCMD_CH(x) ((x) << S_PCMD_CH) +#define G_PCMD_CH(x) (((x) >> S_PCMD_CH) & M_PCMD_CH) + +#define S_STATE_MACHINE_LOC 24 +#define M_STATE_MACHINE_LOC 0x1fU +#define V_STATE_MACHINE_LOC(x) ((x) << S_STATE_MACHINE_LOC) +#define G_STATE_MACHINE_LOC(x) (((x) >> S_STATE_MACHINE_LOC) & M_STATE_MACHINE_LOC) + +#define S_ICSPI_TXVALID 20 +#define M_ICSPI_TXVALID 0xfU +#define V_ICSPI_TXVALID(x) ((x) << S_ICSPI_TXVALID) +#define G_ICSPI_TXVALID(x) (((x) >> S_ICSPI_TXVALID) & M_ICSPI_TXVALID) + +#define S_ICSPI_TXFULL 16 +#define M_ICSPI_TXFULL 0xfU +#define V_ICSPI_TXFULL(x) ((x) << S_ICSPI_TXFULL) +#define G_ICSPI_TXFULL(x) (((x) >> S_ICSPI_TXFULL) & M_ICSPI_TXFULL) + +#define S_PCMD_SRDY 12 +#define M_PCMD_SRDY 0xfU +#define V_PCMD_SRDY(x) ((x) << S_PCMD_SRDY) +#define G_PCMD_SRDY(x) (((x) >> S_PCMD_SRDY) & M_PCMD_SRDY) + +#define S_PCMD_DRDY 8 +#define M_PCMD_DRDY 0xfU +#define V_PCMD_DRDY(x) ((x) << S_PCMD_DRDY) +#define G_PCMD_DRDY(x) (((x) >> S_PCMD_DRDY) & M_PCMD_DRDY) + +#define S_PCMD_CMD 4 +#define M_PCMD_CMD 0xfU +#define V_PCMD_CMD(x) ((x) << S_PCMD_CMD) +#define G_PCMD_CMD(x) (((x) >> S_PCMD_CMD) & M_PCMD_CMD) + +#define S_OEFIFO_FULL3 3 +#define V_OEFIFO_FULL3(x) ((x) << S_OEFIFO_FULL3) +#define F_OEFIFO_FULL3 V_OEFIFO_FULL3(1U) + +#define S_OEFIFO_FULL2 2 +#define V_OEFIFO_FULL2(x) ((x) << S_OEFIFO_FULL2) +#define F_OEFIFO_FULL2 V_OEFIFO_FULL2(1U) + +#define S_OEFIFO_FULL1 1 +#define V_OEFIFO_FULL1(x) ((x) << S_OEFIFO_FULL1) +#define F_OEFIFO_FULL1 V_OEFIFO_FULL1(1U) + +#define S_OEFIFO_FULL0 0 +#define V_OEFIFO_FULL0(x) ((x) << S_OEFIFO_FULL0) +#define F_OEFIFO_FULL0 V_OEFIFO_FULL0(1U) + +#define A_PM_TX_DBG_STAT7 0x10033 + +#define S_ICSPI_RXVALID 28 +#define M_ICSPI_RXVALID 0xfU +#define V_ICSPI_RXVALID(x) ((x) << S_ICSPI_RXVALID) +#define G_ICSPI_RXVALID(x) (((x) >> S_ICSPI_RXVALID) & M_ICSPI_RXVALID) + +#define S_ICSPI_RXFULL 24 +#define M_ICSPI_RXFULL 0xfU +#define V_ICSPI_RXFULL(x) ((x) << S_ICSPI_RXFULL) +#define G_ICSPI_RXFULL(x) (((x) >> S_ICSPI_RXFULL) & M_ICSPI_RXFULL) + +#define S_OESPI_VALID 20 +#define M_OESPI_VALID 0xfU +#define V_OESPI_VALID(x) ((x) << S_OESPI_VALID) +#define G_OESPI_VALID(x) (((x) >> S_OESPI_VALID) & M_OESPI_VALID) + +#define S_OESPI_FULL 16 +#define M_OESPI_FULL 0xfU +#define V_OESPI_FULL(x) ((x) << S_OESPI_FULL) +#define G_OESPI_FULL(x) (((x) >> S_OESPI_FULL) & M_OESPI_FULL) + +#define S_C_RXVALID 12 +#define M_C_RXVALID 0xfU +#define V_C_RXVALID(x) ((x) << S_C_RXVALID) +#define G_C_RXVALID(x) (((x) >> S_C_RXVALID) & M_C_RXVALID) + +#define S_C_RXAFULL 8 +#define M_C_RXAFULL 0xfU +#define V_C_RXAFULL(x) ((x) << S_C_RXAFULL) +#define G_C_RXAFULL(x) (((x) >> S_C_RXAFULL) & M_C_RXAFULL) + +#define S_E_TXVALID3 7 +#define V_E_TXVALID3(x) ((x) << S_E_TXVALID3) +#define F_E_TXVALID3 V_E_TXVALID3(1U) + +#define S_E_TXVALID2 6 +#define V_E_TXVALID2(x) ((x) << S_E_TXVALID2) +#define F_E_TXVALID2 V_E_TXVALID2(1U) + +#define S_E_TXVALID1 5 +#define V_E_TXVALID1(x) ((x) << S_E_TXVALID1) +#define F_E_TXVALID1 V_E_TXVALID1(1U) + +#define S_E_TXVALID0 4 +#define V_E_TXVALID0(x) ((x) << S_E_TXVALID0) +#define F_E_TXVALID0 V_E_TXVALID0(1U) + +#define S_E_TXFULL3 3 +#define V_E_TXFULL3(x) ((x) << S_E_TXFULL3) +#define F_E_TXFULL3 V_E_TXFULL3(1U) + +#define S_E_TXFULL2 2 +#define V_E_TXFULL2(x) ((x) << S_E_TXFULL2) +#define F_E_TXFULL2 V_E_TXFULL2(1U) + +#define S_E_TXFULL1 1 +#define V_E_TXFULL1(x) ((x) << S_E_TXFULL1) +#define F_E_TXFULL1 V_E_TXFULL1(1U) + +#define S_E_TXFULL0 0 +#define V_E_TXFULL0(x) ((x) << S_E_TXFULL0) +#define F_E_TXFULL0 V_E_TXFULL0(1U) + +#define A_PM_TX_DBG_STAT8 0x10034 + +#define S_MC_RSP_FIFO_CNT 24 +#define M_MC_RSP_FIFO_CNT 0x3U +#define V_MC_RSP_FIFO_CNT(x) ((x) << S_MC_RSP_FIFO_CNT) +#define G_MC_RSP_FIFO_CNT(x) (((x) >> S_MC_RSP_FIFO_CNT) & M_MC_RSP_FIFO_CNT) + +#define S_PCMD_FREE_CNT0 14 +#define M_PCMD_FREE_CNT0 0x3ffU +#define V_PCMD_FREE_CNT0(x) ((x) << S_PCMD_FREE_CNT0) +#define G_PCMD_FREE_CNT0(x) (((x) >> S_PCMD_FREE_CNT0) & M_PCMD_FREE_CNT0) + +#define S_PCMD_FREE_CNT1 4 +#define M_PCMD_FREE_CNT1 0x3ffU +#define V_PCMD_FREE_CNT1(x) ((x) << S_PCMD_FREE_CNT1) +#define G_PCMD_FREE_CNT1(x) (((x) >> S_PCMD_FREE_CNT1) & M_PCMD_FREE_CNT1) + +#define S_M_REQADDRRDY 3 +#define V_M_REQADDRRDY(x) ((x) << S_M_REQADDRRDY) +#define F_M_REQADDRRDY V_M_REQADDRRDY(1U) + +#define S_M_REQWRITE 2 +#define V_M_REQWRITE(x) ((x) << S_M_REQWRITE) +#define F_M_REQWRITE V_M_REQWRITE(1U) + +#define S_M_REQDATAVLD 1 +#define V_M_REQDATAVLD(x) ((x) << S_M_REQDATAVLD) +#define F_M_REQDATAVLD V_M_REQDATAVLD(1U) + +#define S_M_REQDATARDY 0 +#define V_M_REQDATARDY(x) ((x) << S_M_REQDATARDY) +#define F_M_REQDATARDY V_M_REQDATARDY(1U) + +#define A_PM_TX_DBG_STAT9 0x10035 + +#define S_PCMD_FREE_CNT2 10 +#define M_PCMD_FREE_CNT2 0x3ffU +#define V_PCMD_FREE_CNT2(x) ((x) << S_PCMD_FREE_CNT2) +#define G_PCMD_FREE_CNT2(x) (((x) >> S_PCMD_FREE_CNT2) & M_PCMD_FREE_CNT2) + +#define S_PCMD_FREE_CNT3 0 +#define M_PCMD_FREE_CNT3 0x3ffU +#define V_PCMD_FREE_CNT3(x) ((x) << S_PCMD_FREE_CNT3) +#define G_PCMD_FREE_CNT3(x) (((x) >> S_PCMD_FREE_CNT3) & M_PCMD_FREE_CNT3) + +#define A_PM_TX_DBG_STAT10 0x10036 + +#define S_IN_EOP_CNT3 28 +#define M_IN_EOP_CNT3 0xfU +#define V_IN_EOP_CNT3(x) ((x) << S_IN_EOP_CNT3) +#define G_IN_EOP_CNT3(x) (((x) >> S_IN_EOP_CNT3) & M_IN_EOP_CNT3) + +#define S_IN_EOP_CNT2 24 +#define M_IN_EOP_CNT2 0xfU +#define V_IN_EOP_CNT2(x) ((x) << S_IN_EOP_CNT2) +#define G_IN_EOP_CNT2(x) (((x) >> S_IN_EOP_CNT2) & M_IN_EOP_CNT2) + +#define S_IN_EOP_CNT1 20 +#define M_IN_EOP_CNT1 0xfU +#define V_IN_EOP_CNT1(x) ((x) << S_IN_EOP_CNT1) +#define G_IN_EOP_CNT1(x) (((x) >> S_IN_EOP_CNT1) & M_IN_EOP_CNT1) + +#define S_IN_EOP_CNT0 16 +#define M_IN_EOP_CNT0 0xfU +#define V_IN_EOP_CNT0(x) ((x) << S_IN_EOP_CNT0) +#define G_IN_EOP_CNT0(x) (((x) >> S_IN_EOP_CNT0) & M_IN_EOP_CNT0) + +#define S_IN_SOP_CNT3 12 +#define M_IN_SOP_CNT3 0xfU +#define V_IN_SOP_CNT3(x) ((x) << S_IN_SOP_CNT3) +#define G_IN_SOP_CNT3(x) (((x) >> S_IN_SOP_CNT3) & M_IN_SOP_CNT3) + +#define S_IN_SOP_CNT2 8 +#define M_IN_SOP_CNT2 0xfU +#define V_IN_SOP_CNT2(x) ((x) << S_IN_SOP_CNT2) +#define G_IN_SOP_CNT2(x) (((x) >> S_IN_SOP_CNT2) & M_IN_SOP_CNT2) + +#define S_IN_SOP_CNT1 4 +#define M_IN_SOP_CNT1 0xfU +#define V_IN_SOP_CNT1(x) ((x) << S_IN_SOP_CNT1) +#define G_IN_SOP_CNT1(x) (((x) >> S_IN_SOP_CNT1) & M_IN_SOP_CNT1) + +#define S_IN_SOP_CNT0 0 +#define M_IN_SOP_CNT0 0xfU +#define V_IN_SOP_CNT0(x) ((x) << S_IN_SOP_CNT0) +#define G_IN_SOP_CNT0(x) (((x) >> S_IN_SOP_CNT0) & M_IN_SOP_CNT0) + +#define A_PM_TX_DBG_STAT11 0x10037 + +#define S_OUT_EOP_CNT3 28 +#define M_OUT_EOP_CNT3 0xfU +#define V_OUT_EOP_CNT3(x) ((x) << S_OUT_EOP_CNT3) +#define G_OUT_EOP_CNT3(x) (((x) >> S_OUT_EOP_CNT3) & M_OUT_EOP_CNT3) + +#define S_OUT_EOP_CNT2 24 +#define M_OUT_EOP_CNT2 0xfU +#define V_OUT_EOP_CNT2(x) ((x) << S_OUT_EOP_CNT2) +#define G_OUT_EOP_CNT2(x) (((x) >> S_OUT_EOP_CNT2) & M_OUT_EOP_CNT2) + +#define S_OUT_EOP_CNT1 20 +#define M_OUT_EOP_CNT1 0xfU +#define V_OUT_EOP_CNT1(x) ((x) << S_OUT_EOP_CNT1) +#define G_OUT_EOP_CNT1(x) (((x) >> S_OUT_EOP_CNT1) & M_OUT_EOP_CNT1) + +#define S_OUT_EOP_CNT0 16 +#define M_OUT_EOP_CNT0 0xfU +#define V_OUT_EOP_CNT0(x) ((x) << S_OUT_EOP_CNT0) +#define G_OUT_EOP_CNT0(x) (((x) >> S_OUT_EOP_CNT0) & M_OUT_EOP_CNT0) + +#define S_OUT_SOP_CNT3 12 +#define M_OUT_SOP_CNT3 0xfU +#define V_OUT_SOP_CNT3(x) ((x) << S_OUT_SOP_CNT3) +#define G_OUT_SOP_CNT3(x) (((x) >> S_OUT_SOP_CNT3) & M_OUT_SOP_CNT3) + +#define S_OUT_SOP_CNT2 8 +#define M_OUT_SOP_CNT2 0xfU +#define V_OUT_SOP_CNT2(x) ((x) << S_OUT_SOP_CNT2) +#define G_OUT_SOP_CNT2(x) (((x) >> S_OUT_SOP_CNT2) & M_OUT_SOP_CNT2) + +#define S_OUT_SOP_CNT1 4 +#define M_OUT_SOP_CNT1 0xfU +#define V_OUT_SOP_CNT1(x) ((x) << S_OUT_SOP_CNT1) +#define G_OUT_SOP_CNT1(x) (((x) >> S_OUT_SOP_CNT1) & M_OUT_SOP_CNT1) + +#define S_OUT_SOP_CNT0 0 +#define M_OUT_SOP_CNT0 0xfU +#define V_OUT_SOP_CNT0(x) ((x) << S_OUT_SOP_CNT0) +#define G_OUT_SOP_CNT0(x) (((x) >> S_OUT_SOP_CNT0) & M_OUT_SOP_CNT0) + +#define A_PM_TX_DBG_STAT12 0x10038 +#define A_PM_TX_DBG_STAT13 0x10039 + +#define S_CH_DEFICIT_BLOWED 31 +#define V_CH_DEFICIT_BLOWED(x) ((x) << S_CH_DEFICIT_BLOWED) +#define F_CH_DEFICIT_BLOWED V_CH_DEFICIT_BLOWED(1U) + +#define S_CH1_DEFICIT 16 +#define M_CH1_DEFICIT 0xfffU +#define V_CH1_DEFICIT(x) ((x) << S_CH1_DEFICIT) +#define G_CH1_DEFICIT(x) (((x) >> S_CH1_DEFICIT) & M_CH1_DEFICIT) + +#define S_CH0_DEFICIT 0 +#define M_CH0_DEFICIT 0xfffU +#define V_CH0_DEFICIT(x) ((x) << S_CH0_DEFICIT) +#define G_CH0_DEFICIT(x) (((x) >> S_CH0_DEFICIT) & M_CH0_DEFICIT) + +#define A_PM_TX_DBG_STAT14 0x1003a + +#define S_CH3_DEFICIT 16 +#define M_CH3_DEFICIT 0xfffU +#define V_CH3_DEFICIT(x) ((x) << S_CH3_DEFICIT) +#define G_CH3_DEFICIT(x) (((x) >> S_CH3_DEFICIT) & M_CH3_DEFICIT) + +#define S_CH2_DEFICIT 0 +#define M_CH2_DEFICIT 0xfffU +#define V_CH2_DEFICIT(x) ((x) << S_CH2_DEFICIT) +#define G_CH2_DEFICIT(x) (((x) >> S_CH2_DEFICIT) & M_CH2_DEFICIT) + +#define A_PM_TX_DBG_STAT15 0x1003b + +#define S_BUNDLE_LEN_SRDY 28 +#define M_BUNDLE_LEN_SRDY 0xfU +#define V_BUNDLE_LEN_SRDY(x) ((x) << S_BUNDLE_LEN_SRDY) +#define G_BUNDLE_LEN_SRDY(x) (((x) >> S_BUNDLE_LEN_SRDY) & M_BUNDLE_LEN_SRDY) + +#define S_BUNDLE_LEN1 16 +#define M_BUNDLE_LEN1 0xfffU +#define V_BUNDLE_LEN1(x) ((x) << S_BUNDLE_LEN1) +#define G_BUNDLE_LEN1(x) (((x) >> S_BUNDLE_LEN1) & M_BUNDLE_LEN1) + +#define S_BUNDLE_LEN0 0 +#define M_BUNDLE_LEN0 0xfffU +#define V_BUNDLE_LEN0(x) ((x) << S_BUNDLE_LEN0) +#define G_BUNDLE_LEN0(x) (((x) >> S_BUNDLE_LEN0) & M_BUNDLE_LEN0) + +#define A_PM_TX_DBG_STAT16 0x1003c + +#define S_BUNDLE_LEN3 16 +#define M_BUNDLE_LEN3 0xfffU +#define V_BUNDLE_LEN3(x) ((x) << S_BUNDLE_LEN3) +#define G_BUNDLE_LEN3(x) (((x) >> S_BUNDLE_LEN3) & M_BUNDLE_LEN3) + +#define S_BUNDLE_LEN2 0 +#define M_BUNDLE_LEN2 0xfffU +#define V_BUNDLE_LEN2(x) ((x) << S_BUNDLE_LEN2) +#define G_BUNDLE_LEN2(x) (((x) >> S_BUNDLE_LEN2) & M_BUNDLE_LEN2) + +/* registers for module MPS */ +#define MPS_BASE_ADDR 0x9000 + +#define A_MPS_PORT_CTL 0x0 + +#define S_LPBKEN 31 +#define V_LPBKEN(x) ((x) << S_LPBKEN) +#define F_LPBKEN V_LPBKEN(1U) + +#define S_PORTTXEN 30 +#define V_PORTTXEN(x) ((x) << S_PORTTXEN) +#define F_PORTTXEN V_PORTTXEN(1U) + +#define S_PORTRXEN 29 +#define V_PORTRXEN(x) ((x) << S_PORTRXEN) +#define F_PORTRXEN V_PORTRXEN(1U) + +#define S_PPPEN 28 +#define V_PPPEN(x) ((x) << S_PPPEN) +#define F_PPPEN V_PPPEN(1U) + +#define S_FCSSTRIPEN 27 +#define V_FCSSTRIPEN(x) ((x) << S_FCSSTRIPEN) +#define F_FCSSTRIPEN V_FCSSTRIPEN(1U) + +#define S_PPPANDPAUSE 26 +#define V_PPPANDPAUSE(x) ((x) << S_PPPANDPAUSE) +#define F_PPPANDPAUSE V_PPPANDPAUSE(1U) + +#define S_PRIOPPPENMAP 16 +#define M_PRIOPPPENMAP 0xffU +#define V_PRIOPPPENMAP(x) ((x) << S_PRIOPPPENMAP) +#define G_PRIOPPPENMAP(x) (((x) >> S_PRIOPPPENMAP) & M_PRIOPPPENMAP) + +#define A_MPS_VF_CTL 0x0 +#define A_MPS_PORT_PAUSE_CTL 0x4 + +#define S_TIMEUNIT 0 +#define M_TIMEUNIT 0xffffU +#define V_TIMEUNIT(x) ((x) << S_TIMEUNIT) +#define G_TIMEUNIT(x) (((x) >> S_TIMEUNIT) & M_TIMEUNIT) + +#define A_MPS_PORT_TX_PAUSE_CTL 0x8 + +#define S_REGSENDOFF 24 +#define M_REGSENDOFF 0xffU +#define V_REGSENDOFF(x) ((x) << S_REGSENDOFF) +#define G_REGSENDOFF(x) (((x) >> S_REGSENDOFF) & M_REGSENDOFF) + +#define S_REGSENDON 16 +#define M_REGSENDON 0xffU +#define V_REGSENDON(x) ((x) << S_REGSENDON) +#define G_REGSENDON(x) (((x) >> S_REGSENDON) & M_REGSENDON) + +#define S_SGESENDEN 8 +#define M_SGESENDEN 0xffU +#define V_SGESENDEN(x) ((x) << S_SGESENDEN) +#define G_SGESENDEN(x) (((x) >> S_SGESENDEN) & M_SGESENDEN) + +#define S_RXSENDEN 0 +#define M_RXSENDEN 0xffU +#define V_RXSENDEN(x) ((x) << S_RXSENDEN) +#define G_RXSENDEN(x) (((x) >> S_RXSENDEN) & M_RXSENDEN) + +#define A_MPS_PORT_TX_PAUSE_CTL2 0xc + +#define S_XOFFDISABLE 0 +#define V_XOFFDISABLE(x) ((x) << S_XOFFDISABLE) +#define F_XOFFDISABLE V_XOFFDISABLE(1U) + +#define A_MPS_PORT_RX_PAUSE_CTL 0x10 + +#define S_REGHALTON 8 +#define M_REGHALTON 0xffU +#define V_REGHALTON(x) ((x) << S_REGHALTON) +#define G_REGHALTON(x) (((x) >> S_REGHALTON) & M_REGHALTON) + +#define S_RXHALTEN 0 +#define M_RXHALTEN 0xffU +#define V_RXHALTEN(x) ((x) << S_RXHALTEN) +#define G_RXHALTEN(x) (((x) >> S_RXHALTEN) & M_RXHALTEN) + +#define A_MPS_PORT_TX_PAUSE_STATUS 0x14 + +#define S_REGSENDING 16 +#define M_REGSENDING 0xffU +#define V_REGSENDING(x) ((x) << S_REGSENDING) +#define G_REGSENDING(x) (((x) >> S_REGSENDING) & M_REGSENDING) + +#define S_SGESENDING 8 +#define M_SGESENDING 0xffU +#define V_SGESENDING(x) ((x) << S_SGESENDING) +#define G_SGESENDING(x) (((x) >> S_SGESENDING) & M_SGESENDING) + +#define S_RXSENDING 0 +#define M_RXSENDING 0xffU +#define V_RXSENDING(x) ((x) << S_RXSENDING) +#define G_RXSENDING(x) (((x) >> S_RXSENDING) & M_RXSENDING) + +#define A_MPS_PORT_RX_PAUSE_STATUS 0x18 + +#define S_REGHALTED 8 +#define M_REGHALTED 0xffU +#define V_REGHALTED(x) ((x) << S_REGHALTED) +#define G_REGHALTED(x) (((x) >> S_REGHALTED) & M_REGHALTED) + +#define S_RXHALTED 0 +#define M_RXHALTED 0xffU +#define V_RXHALTED(x) ((x) << S_RXHALTED) +#define G_RXHALTED(x) (((x) >> S_RXHALTED) & M_RXHALTED) + +#define A_MPS_PORT_TX_PAUSE_DEST_L 0x1c +#define A_MPS_PORT_TX_PAUSE_DEST_H 0x20 + +#define S_ADDR 0 +#define M_ADDR 0xffffU +#define V_ADDR(x) ((x) << S_ADDR) +#define G_ADDR(x) (((x) >> S_ADDR) & M_ADDR) + +#define A_MPS_PORT_TX_PAUSE_SOURCE_L 0x24 +#define A_MPS_PORT_TX_PAUSE_SOURCE_H 0x28 +#define A_MPS_PORT_PRTY_BUFFER_GROUP_MAP 0x2c + +#define S_PRTY7 14 +#define M_PRTY7 0x3U +#define V_PRTY7(x) ((x) << S_PRTY7) +#define G_PRTY7(x) (((x) >> S_PRTY7) & M_PRTY7) + +#define S_PRTY6 12 +#define M_PRTY6 0x3U +#define V_PRTY6(x) ((x) << S_PRTY6) +#define G_PRTY6(x) (((x) >> S_PRTY6) & M_PRTY6) + +#define S_PRTY5 10 +#define M_PRTY5 0x3U +#define V_PRTY5(x) ((x) << S_PRTY5) +#define G_PRTY5(x) (((x) >> S_PRTY5) & M_PRTY5) + +#define S_PRTY4 8 +#define M_PRTY4 0x3U +#define V_PRTY4(x) ((x) << S_PRTY4) +#define G_PRTY4(x) (((x) >> S_PRTY4) & M_PRTY4) + +#define S_PRTY3 6 +#define M_PRTY3 0x3U +#define V_PRTY3(x) ((x) << S_PRTY3) +#define G_PRTY3(x) (((x) >> S_PRTY3) & M_PRTY3) + +#define S_PRTY2 4 +#define M_PRTY2 0x3U +#define V_PRTY2(x) ((x) << S_PRTY2) +#define G_PRTY2(x) (((x) >> S_PRTY2) & M_PRTY2) + +#define S_PRTY1 2 +#define M_PRTY1 0x3U +#define V_PRTY1(x) ((x) << S_PRTY1) +#define G_PRTY1(x) (((x) >> S_PRTY1) & M_PRTY1) + +#define S_PRTY0 0 +#define M_PRTY0 0x3U +#define V_PRTY0(x) ((x) << S_PRTY0) +#define G_PRTY0(x) (((x) >> S_PRTY0) & M_PRTY0) + +#define A_MPS_PORT_PRTY_BUFFER_GROUP_TH_MAP 0x30 + +#define S_TXPRTY7 28 +#define M_TXPRTY7 0xfU +#define V_TXPRTY7(x) ((x) << S_TXPRTY7) +#define G_TXPRTY7(x) (((x) >> S_TXPRTY7) & M_TXPRTY7) + +#define S_TXPRTY6 24 +#define M_TXPRTY6 0xfU +#define V_TXPRTY6(x) ((x) << S_TXPRTY6) +#define G_TXPRTY6(x) (((x) >> S_TXPRTY6) & M_TXPRTY6) + +#define S_TXPRTY5 20 +#define M_TXPRTY5 0xfU +#define V_TXPRTY5(x) ((x) << S_TXPRTY5) +#define G_TXPRTY5(x) (((x) >> S_TXPRTY5) & M_TXPRTY5) + +#define S_TXPRTY4 16 +#define M_TXPRTY4 0xfU +#define V_TXPRTY4(x) ((x) << S_TXPRTY4) +#define G_TXPRTY4(x) (((x) >> S_TXPRTY4) & M_TXPRTY4) + +#define S_TXPRTY3 12 +#define M_TXPRTY3 0xfU +#define V_TXPRTY3(x) ((x) << S_TXPRTY3) +#define G_TXPRTY3(x) (((x) >> S_TXPRTY3) & M_TXPRTY3) + +#define S_TXPRTY2 8 +#define M_TXPRTY2 0xfU +#define V_TXPRTY2(x) ((x) << S_TXPRTY2) +#define G_TXPRTY2(x) (((x) >> S_TXPRTY2) & M_TXPRTY2) + +#define S_TXPRTY1 4 +#define M_TXPRTY1 0xfU +#define V_TXPRTY1(x) ((x) << S_TXPRTY1) +#define G_TXPRTY1(x) (((x) >> S_TXPRTY1) & M_TXPRTY1) + +#define S_TXPRTY0 0 +#define M_TXPRTY0 0xfU +#define V_TXPRTY0(x) ((x) << S_TXPRTY0) +#define G_TXPRTY0(x) (((x) >> S_TXPRTY0) & M_TXPRTY0) + +#define A_MPS_VF_STAT_TX_VF_BCAST_BYTES_L 0x80 +#define A_MPS_VF_STAT_TX_VF_BCAST_BYTES_H 0x84 +#define A_MPS_VF_STAT_TX_VF_BCAST_FRAMES_L 0x88 +#define A_MPS_VF_STAT_TX_VF_BCAST_FRAMES_H 0x8c +#define A_MPS_VF_STAT_TX_VF_MCAST_BYTES_L 0x90 +#define A_MPS_VF_STAT_TX_VF_MCAST_BYTES_H 0x94 +#define A_MPS_VF_STAT_TX_VF_MCAST_FRAMES_L 0x98 +#define A_MPS_VF_STAT_TX_VF_MCAST_FRAMES_H 0x9c +#define A_MPS_VF_STAT_TX_VF_UCAST_BYTES_L 0xa0 +#define A_MPS_VF_STAT_TX_VF_UCAST_BYTES_H 0xa4 +#define A_MPS_VF_STAT_TX_VF_UCAST_FRAMES_L 0xa8 +#define A_MPS_VF_STAT_TX_VF_UCAST_FRAMES_H 0xac +#define A_MPS_VF_STAT_TX_VF_DROP_FRAMES_L 0xb0 +#define A_MPS_VF_STAT_TX_VF_DROP_FRAMES_H 0xb4 +#define A_MPS_VF_STAT_TX_VF_OFFLOAD_BYTES_L 0xb8 +#define A_MPS_VF_STAT_TX_VF_OFFLOAD_BYTES_H 0xbc +#define A_MPS_VF_STAT_TX_VF_OFFLOAD_FRAMES_L 0xc0 +#define A_MPS_VF_STAT_TX_VF_OFFLOAD_FRAMES_H 0xc4 +#define A_MPS_VF_STAT_RX_VF_BCAST_BYTES_L 0xc8 +#define A_MPS_VF_STAT_RX_VF_BCAST_BYTES_H 0xcc +#define A_MPS_VF_STAT_RX_VF_BCAST_FRAMES_L 0xd0 +#define A_MPS_VF_STAT_RX_VF_BCAST_FRAMES_H 0xd4 +#define A_MPS_VF_STAT_RX_VF_MCAST_BYTES_L 0xd8 +#define A_MPS_VF_STAT_RX_VF_MCAST_BYTES_H 0xdc +#define A_MPS_VF_STAT_RX_VF_MCAST_FRAMES_L 0xe0 +#define A_MPS_VF_STAT_RX_VF_MCAST_FRAMES_H 0xe4 +#define A_MPS_VF_STAT_RX_VF_UCAST_BYTES_L 0xe8 +#define A_MPS_VF_STAT_RX_VF_UCAST_BYTES_H 0xec +#define A_MPS_VF_STAT_RX_VF_UCAST_FRAMES_L 0xf0 +#define A_MPS_VF_STAT_RX_VF_UCAST_FRAMES_H 0xf4 +#define A_MPS_VF_STAT_RX_VF_ERR_FRAMES_L 0xf8 +#define A_MPS_VF_STAT_RX_VF_ERR_FRAMES_H 0xfc +#define A_MPS_PORT_RX_CTL 0x100 + +#define S_NO_RPLCT_M 20 +#define V_NO_RPLCT_M(x) ((x) << S_NO_RPLCT_M) +#define F_NO_RPLCT_M V_NO_RPLCT_M(1U) + +#define S_RPLCT_SEL_L 18 +#define M_RPLCT_SEL_L 0x3U +#define V_RPLCT_SEL_L(x) ((x) << S_RPLCT_SEL_L) +#define G_RPLCT_SEL_L(x) (((x) >> S_RPLCT_SEL_L) & M_RPLCT_SEL_L) + +#define S_FLTR_VLAN_SEL 17 +#define V_FLTR_VLAN_SEL(x) ((x) << S_FLTR_VLAN_SEL) +#define F_FLTR_VLAN_SEL V_FLTR_VLAN_SEL(1U) + +#define S_PRIO_VLAN_SEL 16 +#define V_PRIO_VLAN_SEL(x) ((x) << S_PRIO_VLAN_SEL) +#define F_PRIO_VLAN_SEL V_PRIO_VLAN_SEL(1U) + +#define S_CHK_8023_LEN_M 15 +#define V_CHK_8023_LEN_M(x) ((x) << S_CHK_8023_LEN_M) +#define F_CHK_8023_LEN_M V_CHK_8023_LEN_M(1U) + +#define S_CHK_8023_LEN_L 14 +#define V_CHK_8023_LEN_L(x) ((x) << S_CHK_8023_LEN_L) +#define F_CHK_8023_LEN_L V_CHK_8023_LEN_L(1U) + +#define S_NIV_DROP 13 +#define V_NIV_DROP(x) ((x) << S_NIV_DROP) +#define F_NIV_DROP V_NIV_DROP(1U) + +#define S_NOV_DROP 12 +#define V_NOV_DROP(x) ((x) << S_NOV_DROP) +#define F_NOV_DROP V_NOV_DROP(1U) + +#define S_CLS_PRT 11 +#define V_CLS_PRT(x) ((x) << S_CLS_PRT) +#define F_CLS_PRT V_CLS_PRT(1U) + +#define S_RX_QFC_EN 10 +#define V_RX_QFC_EN(x) ((x) << S_RX_QFC_EN) +#define F_RX_QFC_EN V_RX_QFC_EN(1U) + +#define S_QFC_FWD_UP 9 +#define V_QFC_FWD_UP(x) ((x) << S_QFC_FWD_UP) +#define F_QFC_FWD_UP V_QFC_FWD_UP(1U) + +#define S_PPP_FWD_UP 8 +#define V_PPP_FWD_UP(x) ((x) << S_PPP_FWD_UP) +#define F_PPP_FWD_UP V_PPP_FWD_UP(1U) + +#define S_PAUSE_FWD_UP 7 +#define V_PAUSE_FWD_UP(x) ((x) << S_PAUSE_FWD_UP) +#define F_PAUSE_FWD_UP V_PAUSE_FWD_UP(1U) + +#define S_LPBK_BP 6 +#define V_LPBK_BP(x) ((x) << S_LPBK_BP) +#define F_LPBK_BP V_LPBK_BP(1U) + +#define S_PASS_NO_MATCH 5 +#define V_PASS_NO_MATCH(x) ((x) << S_PASS_NO_MATCH) +#define F_PASS_NO_MATCH V_PASS_NO_MATCH(1U) + +#define S_IVLAN_EN 4 +#define V_IVLAN_EN(x) ((x) << S_IVLAN_EN) +#define F_IVLAN_EN V_IVLAN_EN(1U) + +#define S_OVLAN_EN3 3 +#define V_OVLAN_EN3(x) ((x) << S_OVLAN_EN3) +#define F_OVLAN_EN3 V_OVLAN_EN3(1U) + +#define S_OVLAN_EN2 2 +#define V_OVLAN_EN2(x) ((x) << S_OVLAN_EN2) +#define F_OVLAN_EN2 V_OVLAN_EN2(1U) + +#define S_OVLAN_EN1 1 +#define V_OVLAN_EN1(x) ((x) << S_OVLAN_EN1) +#define F_OVLAN_EN1 V_OVLAN_EN1(1U) + +#define S_OVLAN_EN0 0 +#define V_OVLAN_EN0(x) ((x) << S_OVLAN_EN0) +#define F_OVLAN_EN0 V_OVLAN_EN0(1U) + +#define S_PTP_FWD_UP 21 +#define V_PTP_FWD_UP(x) ((x) << S_PTP_FWD_UP) +#define F_PTP_FWD_UP V_PTP_FWD_UP(1U) + +#define A_MPS_PORT_RX_MTU 0x104 +#define A_MPS_PORT_RX_PF_MAP 0x108 +#define A_MPS_PORT_RX_VF_MAP0 0x10c +#define A_MPS_PORT_RX_VF_MAP1 0x110 +#define A_MPS_PORT_RX_VF_MAP2 0x114 +#define A_MPS_PORT_RX_VF_MAP3 0x118 +#define A_MPS_PORT_RX_IVLAN 0x11c + +#define S_IVLAN_ETYPE 0 +#define M_IVLAN_ETYPE 0xffffU +#define V_IVLAN_ETYPE(x) ((x) << S_IVLAN_ETYPE) +#define G_IVLAN_ETYPE(x) (((x) >> S_IVLAN_ETYPE) & M_IVLAN_ETYPE) + +#define A_MPS_PORT_RX_OVLAN0 0x120 + +#define S_OVLAN_MASK 16 +#define M_OVLAN_MASK 0xffffU +#define V_OVLAN_MASK(x) ((x) << S_OVLAN_MASK) +#define G_OVLAN_MASK(x) (((x) >> S_OVLAN_MASK) & M_OVLAN_MASK) + +#define S_OVLAN_ETYPE 0 +#define M_OVLAN_ETYPE 0xffffU +#define V_OVLAN_ETYPE(x) ((x) << S_OVLAN_ETYPE) +#define G_OVLAN_ETYPE(x) (((x) >> S_OVLAN_ETYPE) & M_OVLAN_ETYPE) + +#define A_MPS_PORT_RX_OVLAN1 0x124 +#define A_MPS_PORT_RX_OVLAN2 0x128 +#define A_MPS_PORT_RX_OVLAN3 0x12c +#define A_MPS_PORT_RX_RSS_HASH 0x130 +#define A_MPS_PORT_RX_RSS_CONTROL 0x134 + +#define S_RSS_CTRL 16 +#define M_RSS_CTRL 0xffU +#define V_RSS_CTRL(x) ((x) << S_RSS_CTRL) +#define G_RSS_CTRL(x) (((x) >> S_RSS_CTRL) & M_RSS_CTRL) + +#define S_QUE_NUM 0 +#define M_QUE_NUM 0xffffU +#define V_QUE_NUM(x) ((x) << S_QUE_NUM) +#define G_QUE_NUM(x) (((x) >> S_QUE_NUM) & M_QUE_NUM) + +#define A_MPS_PORT_RX_CTL1 0x138 + +#define S_FIXED_PFVF_MAC 13 +#define V_FIXED_PFVF_MAC(x) ((x) << S_FIXED_PFVF_MAC) +#define F_FIXED_PFVF_MAC V_FIXED_PFVF_MAC(1U) + +#define S_FIXED_PFVF_LPBK 12 +#define V_FIXED_PFVF_LPBK(x) ((x) << S_FIXED_PFVF_LPBK) +#define F_FIXED_PFVF_LPBK V_FIXED_PFVF_LPBK(1U) + +#define S_FIXED_PFVF_LPBK_OV 11 +#define V_FIXED_PFVF_LPBK_OV(x) ((x) << S_FIXED_PFVF_LPBK_OV) +#define F_FIXED_PFVF_LPBK_OV V_FIXED_PFVF_LPBK_OV(1U) + +#define S_FIXED_PF 8 +#define M_FIXED_PF 0x7U +#define V_FIXED_PF(x) ((x) << S_FIXED_PF) +#define G_FIXED_PF(x) (((x) >> S_FIXED_PF) & M_FIXED_PF) + +#define S_FIXED_VF_VLD 7 +#define V_FIXED_VF_VLD(x) ((x) << S_FIXED_VF_VLD) +#define F_FIXED_VF_VLD V_FIXED_VF_VLD(1U) + +#define S_FIXED_VF 0 +#define M_FIXED_VF 0x7fU +#define V_FIXED_VF(x) ((x) << S_FIXED_VF) +#define G_FIXED_VF(x) (((x) >> S_FIXED_VF) & M_FIXED_VF) + +#define A_MPS_PORT_RX_SPARE 0x13c +#define A_MPS_PORT_RX_PTP_RSS_HASH 0x140 +#define A_MPS_PORT_RX_PTP_RSS_CONTROL 0x144 +#define A_MPS_PORT_TX_MAC_RELOAD_CH0 0x190 + +#define S_CREDIT 0 +#define M_CREDIT 0xffffU +#define V_CREDIT(x) ((x) << S_CREDIT) +#define G_CREDIT(x) (((x) >> S_CREDIT) & M_CREDIT) + +#define A_MPS_PORT_TX_MAC_RELOAD_CH1 0x194 +#define A_MPS_PORT_TX_MAC_RELOAD_CH2 0x198 +#define A_MPS_PORT_TX_MAC_RELOAD_CH3 0x19c +#define A_MPS_PORT_TX_MAC_RELOAD_CH4 0x1a0 +#define A_MPS_PORT_TX_LPBK_RELOAD_CH0 0x1a8 +#define A_MPS_PORT_TX_LPBK_RELOAD_CH1 0x1ac +#define A_MPS_PORT_TX_LPBK_RELOAD_CH2 0x1b0 +#define A_MPS_PORT_TX_LPBK_RELOAD_CH3 0x1b4 +#define A_MPS_PORT_TX_LPBK_RELOAD_CH4 0x1b8 +#define A_MPS_PORT_TX_FIFO_CTL 0x1c4 + +#define S_FIFOTH 5 +#define M_FIFOTH 0x1ffU +#define V_FIFOTH(x) ((x) << S_FIFOTH) +#define G_FIFOTH(x) (((x) >> S_FIFOTH) & M_FIFOTH) + +#define S_FIFOEN 4 +#define V_FIFOEN(x) ((x) << S_FIFOEN) +#define F_FIFOEN V_FIFOEN(1U) + +#define S_MAXPKTCNT 0 +#define M_MAXPKTCNT 0xfU +#define V_MAXPKTCNT(x) ((x) << S_MAXPKTCNT) +#define G_MAXPKTCNT(x) (((x) >> S_MAXPKTCNT) & M_MAXPKTCNT) + +#define A_MPS_PORT_FPGA_PAUSE_CTL 0x1c8 + +#define S_FPGAPAUSEEN 0 +#define V_FPGAPAUSEEN(x) ((x) << S_FPGAPAUSEEN) +#define F_FPGAPAUSEEN V_FPGAPAUSEEN(1U) + +#define A_MPS_PORT_TX_PAUSE_PENDING_STATUS 0x1d0 + +#define S_OFF_PENDING 8 +#define M_OFF_PENDING 0xffU +#define V_OFF_PENDING(x) ((x) << S_OFF_PENDING) +#define G_OFF_PENDING(x) (((x) >> S_OFF_PENDING) & M_OFF_PENDING) + +#define S_ON_PENDING 0 +#define M_ON_PENDING 0xffU +#define V_ON_PENDING(x) ((x) << S_ON_PENDING) +#define G_ON_PENDING(x) (((x) >> S_ON_PENDING) & M_ON_PENDING) + +#define A_MPS_PORT_CLS_HASH_SRAM 0x200 + +#define S_VALID 20 +#define V_VALID(x) ((x) << S_VALID) +#define F_VALID V_VALID(1U) + +#define S_HASHPORTMAP 16 +#define M_HASHPORTMAP 0xfU +#define V_HASHPORTMAP(x) ((x) << S_HASHPORTMAP) +#define G_HASHPORTMAP(x) (((x) >> S_HASHPORTMAP) & M_HASHPORTMAP) + +#define S_MULTILISTEN 15 +#define V_MULTILISTEN(x) ((x) << S_MULTILISTEN) +#define F_MULTILISTEN V_MULTILISTEN(1U) + +#define S_PRIORITY 12 +#define M_PRIORITY 0x7U +#define V_PRIORITY(x) ((x) << S_PRIORITY) +#define G_PRIORITY(x) (((x) >> S_PRIORITY) & M_PRIORITY) + +#define S_REPLICATE 11 +#define V_REPLICATE(x) ((x) << S_REPLICATE) +#define F_REPLICATE V_REPLICATE(1U) + +#define S_PF 8 +#define M_PF 0x7U +#define V_PF(x) ((x) << S_PF) +#define G_PF(x) (((x) >> S_PF) & M_PF) + +#define S_VF_VALID 7 +#define V_VF_VALID(x) ((x) << S_VF_VALID) +#define F_VF_VALID V_VF_VALID(1U) + +#define S_VF 0 +#define M_VF 0x7fU +#define V_VF(x) ((x) << S_VF) +#define G_VF(x) (((x) >> S_VF) & M_VF) + +#define A_MPS_PF_CTL 0x2c0 + +#define S_TXEN 1 +#define V_TXEN(x) ((x) << S_TXEN) +#define F_TXEN V_TXEN(1U) + +#define S_RXEN 0 +#define V_RXEN(x) ((x) << S_RXEN) +#define F_RXEN V_RXEN(1U) + +#define A_MPS_PF_TX_QINQ_VLAN 0x2e0 + +#define S_PROTOCOLID 16 +#define M_PROTOCOLID 0xffffU +#define V_PROTOCOLID(x) ((x) << S_PROTOCOLID) +#define G_PROTOCOLID(x) (((x) >> S_PROTOCOLID) & M_PROTOCOLID) + +#define S_VLAN_PRIO 13 +#define M_VLAN_PRIO 0x7U +#define V_VLAN_PRIO(x) ((x) << S_VLAN_PRIO) +#define G_VLAN_PRIO(x) (((x) >> S_VLAN_PRIO) & M_VLAN_PRIO) + +#define S_CFI 12 +#define V_CFI(x) ((x) << S_CFI) +#define F_CFI V_CFI(1U) + +#define S_TAG 0 +#define M_TAG 0xfffU +#define V_TAG(x) ((x) << S_TAG) +#define G_TAG(x) (((x) >> S_TAG) & M_TAG) + +#define A_MPS_PF_STAT_TX_PF_BCAST_BYTES_L 0x300 +#define A_MPS_PF_STAT_TX_PF_BCAST_BYTES_H 0x304 +#define A_MPS_PORT_CLS_HASH_CTL 0x304 + +#define S_UNICASTENABLE 31 +#define V_UNICASTENABLE(x) ((x) << S_UNICASTENABLE) +#define F_UNICASTENABLE V_UNICASTENABLE(1U) + +#define A_MPS_PF_STAT_TX_PF_BCAST_FRAMES_L 0x308 +#define A_MPS_PORT_CLS_PROMISCUOUS_CTL 0x308 + +#define S_PROMISCEN 31 +#define V_PROMISCEN(x) ((x) << S_PROMISCEN) +#define F_PROMISCEN V_PROMISCEN(1U) + +#define A_MPS_PF_STAT_TX_PF_BCAST_FRAMES_H 0x30c +#define A_MPS_PORT_CLS_BMC_MAC_ADDR_L 0x30c +#define A_MPS_PF_STAT_TX_PF_MCAST_BYTES_L 0x310 +#define A_MPS_PORT_CLS_BMC_MAC_ADDR_H 0x310 + +#define S_MATCHBOTH 17 +#define V_MATCHBOTH(x) ((x) << S_MATCHBOTH) +#define F_MATCHBOTH V_MATCHBOTH(1U) + +#define S_BMC_VLD 16 +#define V_BMC_VLD(x) ((x) << S_BMC_VLD) +#define F_BMC_VLD V_BMC_VLD(1U) + +#define A_MPS_PF_STAT_TX_PF_MCAST_BYTES_H 0x314 +#define A_MPS_PORT_CLS_BMC_VLAN 0x314 + +#define S_BMC_VLAN_SEL 13 +#define V_BMC_VLAN_SEL(x) ((x) << S_BMC_VLAN_SEL) +#define F_BMC_VLAN_SEL V_BMC_VLAN_SEL(1U) + +#define S_VLAN_VLD 12 +#define V_VLAN_VLD(x) ((x) << S_VLAN_VLD) +#define F_VLAN_VLD V_VLAN_VLD(1U) + +#define A_MPS_PF_STAT_TX_PF_MCAST_FRAMES_L 0x318 +#define A_MPS_PORT_CLS_CTL 0x318 + +#define S_PF_VLAN_SEL 0 +#define V_PF_VLAN_SEL(x) ((x) << S_PF_VLAN_SEL) +#define F_PF_VLAN_SEL V_PF_VLAN_SEL(1U) + +#define S_LPBK_TCAM1_HIT_PRIORITY 14 +#define V_LPBK_TCAM1_HIT_PRIORITY(x) ((x) << S_LPBK_TCAM1_HIT_PRIORITY) +#define F_LPBK_TCAM1_HIT_PRIORITY V_LPBK_TCAM1_HIT_PRIORITY(1U) + +#define S_LPBK_TCAM0_HIT_PRIORITY 13 +#define V_LPBK_TCAM0_HIT_PRIORITY(x) ((x) << S_LPBK_TCAM0_HIT_PRIORITY) +#define F_LPBK_TCAM0_HIT_PRIORITY V_LPBK_TCAM0_HIT_PRIORITY(1U) + +#define S_LPBK_TCAM_PRIORITY 12 +#define V_LPBK_TCAM_PRIORITY(x) ((x) << S_LPBK_TCAM_PRIORITY) +#define F_LPBK_TCAM_PRIORITY V_LPBK_TCAM_PRIORITY(1U) + +#define S_LPBK_SMAC_TCAM_SEL 10 +#define M_LPBK_SMAC_TCAM_SEL 0x3U +#define V_LPBK_SMAC_TCAM_SEL(x) ((x) << S_LPBK_SMAC_TCAM_SEL) +#define G_LPBK_SMAC_TCAM_SEL(x) (((x) >> S_LPBK_SMAC_TCAM_SEL) & M_LPBK_SMAC_TCAM_SEL) + +#define S_LPBK_DMAC_TCAM_SEL 8 +#define M_LPBK_DMAC_TCAM_SEL 0x3U +#define V_LPBK_DMAC_TCAM_SEL(x) ((x) << S_LPBK_DMAC_TCAM_SEL) +#define G_LPBK_DMAC_TCAM_SEL(x) (((x) >> S_LPBK_DMAC_TCAM_SEL) & M_LPBK_DMAC_TCAM_SEL) + +#define S_TCAM1_HIT_PRIORITY 7 +#define V_TCAM1_HIT_PRIORITY(x) ((x) << S_TCAM1_HIT_PRIORITY) +#define F_TCAM1_HIT_PRIORITY V_TCAM1_HIT_PRIORITY(1U) + +#define S_TCAM0_HIT_PRIORITY 6 +#define V_TCAM0_HIT_PRIORITY(x) ((x) << S_TCAM0_HIT_PRIORITY) +#define F_TCAM0_HIT_PRIORITY V_TCAM0_HIT_PRIORITY(1U) + +#define S_TCAM_PRIORITY 5 +#define V_TCAM_PRIORITY(x) ((x) << S_TCAM_PRIORITY) +#define F_TCAM_PRIORITY V_TCAM_PRIORITY(1U) + +#define S_SMAC_TCAM_SEL 3 +#define M_SMAC_TCAM_SEL 0x3U +#define V_SMAC_TCAM_SEL(x) ((x) << S_SMAC_TCAM_SEL) +#define G_SMAC_TCAM_SEL(x) (((x) >> S_SMAC_TCAM_SEL) & M_SMAC_TCAM_SEL) + +#define S_DMAC_TCAM_SEL 1 +#define M_DMAC_TCAM_SEL 0x3U +#define V_DMAC_TCAM_SEL(x) ((x) << S_DMAC_TCAM_SEL) +#define G_DMAC_TCAM_SEL(x) (((x) >> S_DMAC_TCAM_SEL) & M_DMAC_TCAM_SEL) + +#define A_MPS_PF_STAT_TX_PF_MCAST_FRAMES_H 0x31c +#define A_MPS_PF_STAT_TX_PF_UCAST_BYTES_L 0x320 +#define A_MPS_PF_STAT_TX_PF_UCAST_BYTES_H 0x324 +#define A_MPS_PF_STAT_TX_PF_UCAST_FRAMES_L 0x328 +#define A_MPS_PF_STAT_TX_PF_UCAST_FRAMES_H 0x32c +#define A_MPS_PF_STAT_TX_PF_OFFLOAD_BYTES_L 0x330 +#define A_MPS_PF_STAT_TX_PF_OFFLOAD_BYTES_H 0x334 +#define A_MPS_PF_STAT_TX_PF_OFFLOAD_FRAMES_L 0x338 +#define A_MPS_PF_STAT_TX_PF_OFFLOAD_FRAMES_H 0x33c +#define A_MPS_PF_STAT_RX_PF_BYTES_L 0x340 +#define A_MPS_PF_STAT_RX_PF_BYTES_H 0x344 +#define A_MPS_PF_STAT_RX_PF_FRAMES_L 0x348 +#define A_MPS_PF_STAT_RX_PF_FRAMES_H 0x34c +#define A_MPS_PF_STAT_RX_PF_BCAST_BYTES_L 0x350 +#define A_MPS_PF_STAT_RX_PF_BCAST_BYTES_H 0x354 +#define A_MPS_PF_STAT_RX_PF_BCAST_FRAMES_L 0x358 +#define A_MPS_PF_STAT_RX_PF_BCAST_FRAMES_H 0x35c +#define A_MPS_PF_STAT_RX_PF_MCAST_BYTES_L 0x360 +#define A_MPS_PF_STAT_RX_PF_MCAST_BYTES_H 0x364 +#define A_MPS_PF_STAT_RX_PF_MCAST_FRAMES_L 0x368 +#define A_MPS_PF_STAT_RX_PF_MCAST_FRAMES_H 0x36c +#define A_MPS_PF_STAT_RX_PF_UCAST_BYTES_L 0x370 +#define A_MPS_PF_STAT_RX_PF_UCAST_BYTES_H 0x374 +#define A_MPS_PF_STAT_RX_PF_UCAST_FRAMES_L 0x378 +#define A_MPS_PF_STAT_RX_PF_UCAST_FRAMES_H 0x37c +#define A_MPS_PF_STAT_RX_PF_ERR_FRAMES_L 0x380 +#define A_MPS_PF_STAT_RX_PF_ERR_FRAMES_H 0x384 +#define A_MPS_PORT_STAT_TX_PORT_BYTES_L 0x400 +#define A_MPS_PORT_STAT_TX_PORT_BYTES_H 0x404 +#define A_MPS_PORT_STAT_TX_PORT_FRAMES_L 0x408 +#define A_MPS_PORT_STAT_TX_PORT_FRAMES_H 0x40c +#define A_MPS_PORT_STAT_TX_PORT_BCAST_L 0x410 +#define A_MPS_PORT_STAT_TX_PORT_BCAST_H 0x414 +#define A_MPS_PORT_STAT_TX_PORT_MCAST_L 0x418 +#define A_MPS_PORT_STAT_TX_PORT_MCAST_H 0x41c +#define A_MPS_PORT_STAT_TX_PORT_UCAST_L 0x420 +#define A_MPS_PORT_STAT_TX_PORT_UCAST_H 0x424 +#define A_MPS_PORT_STAT_TX_PORT_ERROR_L 0x428 +#define A_MPS_PORT_STAT_TX_PORT_ERROR_H 0x42c +#define A_MPS_PORT_STAT_TX_PORT_64B_L 0x430 +#define A_MPS_PORT_STAT_TX_PORT_64B_H 0x434 +#define A_MPS_PORT_STAT_TX_PORT_65B_127B_L 0x438 +#define A_MPS_PORT_STAT_TX_PORT_65B_127B_H 0x43c +#define A_MPS_PORT_STAT_TX_PORT_128B_255B_L 0x440 +#define A_MPS_PORT_STAT_TX_PORT_128B_255B_H 0x444 +#define A_MPS_PORT_STAT_TX_PORT_256B_511B_L 0x448 +#define A_MPS_PORT_STAT_TX_PORT_256B_511B_H 0x44c +#define A_MPS_PORT_STAT_TX_PORT_512B_1023B_L 0x450 +#define A_MPS_PORT_STAT_TX_PORT_512B_1023B_H 0x454 +#define A_MPS_PORT_STAT_TX_PORT_1024B_1518B_L 0x458 +#define A_MPS_PORT_STAT_TX_PORT_1024B_1518B_H 0x45c +#define A_MPS_PORT_STAT_TX_PORT_1519B_MAX_L 0x460 +#define A_MPS_PORT_STAT_TX_PORT_1519B_MAX_H 0x464 +#define A_MPS_PORT_STAT_TX_PORT_DROP_L 0x468 +#define A_MPS_PORT_STAT_TX_PORT_DROP_H 0x46c +#define A_MPS_PORT_STAT_TX_PORT_PAUSE_L 0x470 +#define A_MPS_PORT_STAT_TX_PORT_PAUSE_H 0x474 +#define A_MPS_PORT_STAT_TX_PORT_PPP0_L 0x478 +#define A_MPS_PORT_STAT_TX_PORT_PPP0_H 0x47c +#define A_MPS_PORT_STAT_TX_PORT_PPP1_L 0x480 +#define A_MPS_PORT_STAT_TX_PORT_PPP1_H 0x484 +#define A_MPS_PORT_STAT_TX_PORT_PPP2_L 0x488 +#define A_MPS_PORT_STAT_TX_PORT_PPP2_H 0x48c +#define A_MPS_PORT_STAT_TX_PORT_PPP3_L 0x490 +#define A_MPS_PORT_STAT_TX_PORT_PPP3_H 0x494 +#define A_MPS_PORT_STAT_TX_PORT_PPP4_L 0x498 +#define A_MPS_PORT_STAT_TX_PORT_PPP4_H 0x49c +#define A_MPS_PORT_STAT_TX_PORT_PPP5_L 0x4a0 +#define A_MPS_PORT_STAT_TX_PORT_PPP5_H 0x4a4 +#define A_MPS_PORT_STAT_TX_PORT_PPP6_L 0x4a8 +#define A_MPS_PORT_STAT_TX_PORT_PPP6_H 0x4ac +#define A_MPS_PORT_STAT_TX_PORT_PPP7_L 0x4b0 +#define A_MPS_PORT_STAT_TX_PORT_PPP7_H 0x4b4 +#define A_MPS_PORT_STAT_LB_PORT_BYTES_L 0x4c0 +#define A_MPS_PORT_STAT_LB_PORT_BYTES_H 0x4c4 +#define A_MPS_PORT_STAT_LB_PORT_FRAMES_L 0x4c8 +#define A_MPS_PORT_STAT_LB_PORT_FRAMES_H 0x4cc +#define A_MPS_PORT_STAT_LB_PORT_BCAST_L 0x4d0 +#define A_MPS_PORT_STAT_LB_PORT_BCAST_H 0x4d4 +#define A_MPS_PORT_STAT_LB_PORT_MCAST_L 0x4d8 +#define A_MPS_PORT_STAT_LB_PORT_MCAST_H 0x4dc +#define A_MPS_PORT_STAT_LB_PORT_UCAST_L 0x4e0 +#define A_MPS_PORT_STAT_LB_PORT_UCAST_H 0x4e4 +#define A_MPS_PORT_STAT_LB_PORT_ERROR_L 0x4e8 +#define A_MPS_PORT_STAT_LB_PORT_ERROR_H 0x4ec +#define A_MPS_PORT_STAT_LB_PORT_64B_L 0x4f0 +#define A_MPS_PORT_STAT_LB_PORT_64B_H 0x4f4 +#define A_MPS_PORT_STAT_LB_PORT_65B_127B_L 0x4f8 +#define A_MPS_PORT_STAT_LB_PORT_65B_127B_H 0x4fc +#define A_MPS_PORT_STAT_LB_PORT_128B_255B_L 0x500 +#define A_MPS_PORT_STAT_LB_PORT_128B_255B_H 0x504 +#define A_MPS_PORT_STAT_LB_PORT_256B_511B_L 0x508 +#define A_MPS_PORT_STAT_LB_PORT_256B_511B_H 0x50c +#define A_MPS_PORT_STAT_LB_PORT_512B_1023B_L 0x510 +#define A_MPS_PORT_STAT_LB_PORT_512B_1023B_H 0x514 +#define A_MPS_PORT_STAT_LB_PORT_1024B_1518B_L 0x518 +#define A_MPS_PORT_STAT_LB_PORT_1024B_1518B_H 0x51c +#define A_MPS_PORT_STAT_LB_PORT_1519B_MAX_L 0x520 +#define A_MPS_PORT_STAT_LB_PORT_1519B_MAX_H 0x524 +#define A_MPS_PORT_STAT_LB_PORT_DROP_FRAMES 0x528 +#define A_MPS_PORT_STAT_LB_PORT_DROP_FRAMES_L 0x528 +#define A_MPS_PORT_STAT_LB_PORT_DROP_FRAMES_H 0x52c +#define A_MPS_PORT_STAT_RX_PORT_BYTES_L 0x540 +#define A_MPS_PORT_STAT_RX_PORT_BYTES_H 0x544 +#define A_MPS_PORT_STAT_RX_PORT_FRAMES_L 0x548 +#define A_MPS_PORT_STAT_RX_PORT_FRAMES_H 0x54c +#define A_MPS_PORT_STAT_RX_PORT_BCAST_L 0x550 +#define A_MPS_PORT_STAT_RX_PORT_BCAST_H 0x554 +#define A_MPS_PORT_STAT_RX_PORT_MCAST_L 0x558 +#define A_MPS_PORT_STAT_RX_PORT_MCAST_H 0x55c +#define A_MPS_PORT_STAT_RX_PORT_UCAST_L 0x560 +#define A_MPS_PORT_STAT_RX_PORT_UCAST_H 0x564 +#define A_MPS_PORT_STAT_RX_PORT_MTU_ERROR_L 0x568 +#define A_MPS_PORT_STAT_RX_PORT_MTU_ERROR_H 0x56c +#define A_MPS_PORT_STAT_RX_PORT_MTU_CRC_ERROR_L 0x570 +#define A_MPS_PORT_STAT_RX_PORT_MTU_CRC_ERROR_H 0x574 +#define A_MPS_PORT_STAT_RX_PORT_CRC_ERROR_L 0x578 +#define A_MPS_PORT_STAT_RX_PORT_CRC_ERROR_H 0x57c +#define A_MPS_PORT_STAT_RX_PORT_LEN_ERROR_L 0x580 +#define A_MPS_PORT_STAT_RX_PORT_LEN_ERROR_H 0x584 +#define A_MPS_PORT_STAT_RX_PORT_SYM_ERROR_L 0x588 +#define A_MPS_PORT_STAT_RX_PORT_SYM_ERROR_H 0x58c +#define A_MPS_PORT_STAT_RX_PORT_64B_L 0x590 +#define A_MPS_PORT_STAT_RX_PORT_64B_H 0x594 +#define A_MPS_PORT_STAT_RX_PORT_65B_127B_L 0x598 +#define A_MPS_PORT_STAT_RX_PORT_65B_127B_H 0x59c +#define A_MPS_PORT_STAT_RX_PORT_128B_255B_L 0x5a0 +#define A_MPS_PORT_STAT_RX_PORT_128B_255B_H 0x5a4 +#define A_MPS_PORT_STAT_RX_PORT_256B_511B_L 0x5a8 +#define A_MPS_PORT_STAT_RX_PORT_256B_511B_H 0x5ac +#define A_MPS_PORT_STAT_RX_PORT_512B_1023B_L 0x5b0 +#define A_MPS_PORT_STAT_RX_PORT_512B_1023B_H 0x5b4 +#define A_MPS_PORT_STAT_RX_PORT_1024B_1518B_L 0x5b8 +#define A_MPS_PORT_STAT_RX_PORT_1024B_1518B_H 0x5bc +#define A_MPS_PORT_STAT_RX_PORT_1519B_MAX_L 0x5c0 +#define A_MPS_PORT_STAT_RX_PORT_1519B_MAX_H 0x5c4 +#define A_MPS_PORT_STAT_RX_PORT_PAUSE_L 0x5c8 +#define A_MPS_PORT_STAT_RX_PORT_PAUSE_H 0x5cc +#define A_MPS_PORT_STAT_RX_PORT_PPP0_L 0x5d0 +#define A_MPS_PORT_STAT_RX_PORT_PPP0_H 0x5d4 +#define A_MPS_PORT_STAT_RX_PORT_PPP1_L 0x5d8 +#define A_MPS_PORT_STAT_RX_PORT_PPP1_H 0x5dc +#define A_MPS_PORT_STAT_RX_PORT_PPP2_L 0x5e0 +#define A_MPS_PORT_STAT_RX_PORT_PPP2_H 0x5e4 +#define A_MPS_PORT_STAT_RX_PORT_PPP3_L 0x5e8 +#define A_MPS_PORT_STAT_RX_PORT_PPP3_H 0x5ec +#define A_MPS_PORT_STAT_RX_PORT_PPP4_L 0x5f0 +#define A_MPS_PORT_STAT_RX_PORT_PPP4_H 0x5f4 +#define A_MPS_PORT_STAT_RX_PORT_PPP5_L 0x5f8 +#define A_MPS_PORT_STAT_RX_PORT_PPP5_H 0x5fc +#define A_MPS_PORT_STAT_RX_PORT_PPP6_L 0x600 +#define A_MPS_PORT_STAT_RX_PORT_PPP6_H 0x604 +#define A_MPS_PORT_STAT_RX_PORT_PPP7_L 0x608 +#define A_MPS_PORT_STAT_RX_PORT_PPP7_H 0x60c +#define A_MPS_PORT_STAT_RX_PORT_LESS_64B_L 0x610 +#define A_MPS_PORT_STAT_RX_PORT_LESS_64B_H 0x614 +#define A_MPS_PORT_STAT_RX_PORT_MAC_ERROR_L 0x618 +#define A_MPS_PORT_STAT_RX_PORT_MAC_ERROR_H 0x61c +#define A_MPS_CMN_CTL 0x9000 + +#define S_DETECT8023 3 +#define V_DETECT8023(x) ((x) << S_DETECT8023) +#define F_DETECT8023 V_DETECT8023(1U) + +#define S_VFDIRECTACCESS 2 +#define V_VFDIRECTACCESS(x) ((x) << S_VFDIRECTACCESS) +#define F_VFDIRECTACCESS V_VFDIRECTACCESS(1U) + +#define S_NUMPORTS 0 +#define M_NUMPORTS 0x3U +#define V_NUMPORTS(x) ((x) << S_NUMPORTS) +#define G_NUMPORTS(x) (((x) >> S_NUMPORTS) & M_NUMPORTS) + +#define S_LPBKCRDTCTRL 4 +#define V_LPBKCRDTCTRL(x) ((x) << S_LPBKCRDTCTRL) +#define F_LPBKCRDTCTRL V_LPBKCRDTCTRL(1U) + +#define A_MPS_INT_ENABLE 0x9004 + +#define S_STATINTENB 5 +#define V_STATINTENB(x) ((x) << S_STATINTENB) +#define F_STATINTENB V_STATINTENB(1U) + +#define S_TXINTENB 4 +#define V_TXINTENB(x) ((x) << S_TXINTENB) +#define F_TXINTENB V_TXINTENB(1U) + +#define S_RXINTENB 3 +#define V_RXINTENB(x) ((x) << S_RXINTENB) +#define F_RXINTENB V_RXINTENB(1U) + +#define S_TRCINTENB 2 +#define V_TRCINTENB(x) ((x) << S_TRCINTENB) +#define F_TRCINTENB V_TRCINTENB(1U) + +#define S_CLSINTENB 1 +#define V_CLSINTENB(x) ((x) << S_CLSINTENB) +#define F_CLSINTENB V_CLSINTENB(1U) + +#define S_PLINTENB 0 +#define V_PLINTENB(x) ((x) << S_PLINTENB) +#define F_PLINTENB V_PLINTENB(1U) + +#define A_MPS_INT_CAUSE 0x9008 + +#define S_STATINT 5 +#define V_STATINT(x) ((x) << S_STATINT) +#define F_STATINT V_STATINT(1U) + +#define S_TXINT 4 +#define V_TXINT(x) ((x) << S_TXINT) +#define F_TXINT V_TXINT(1U) + +#define S_RXINT 3 +#define V_RXINT(x) ((x) << S_RXINT) +#define F_RXINT V_RXINT(1U) + +#define S_TRCINT 2 +#define V_TRCINT(x) ((x) << S_TRCINT) +#define F_TRCINT V_TRCINT(1U) + +#define S_CLSINT 1 +#define V_CLSINT(x) ((x) << S_CLSINT) +#define F_CLSINT V_CLSINT(1U) + +#define S_PLINT 0 +#define V_PLINT(x) ((x) << S_PLINT) +#define F_PLINT V_PLINT(1U) + +#define A_MPS_CGEN_GLOBAL 0x900c + +#define S_MPS_GLOBAL_CGEN 0 +#define V_MPS_GLOBAL_CGEN(x) ((x) << S_MPS_GLOBAL_CGEN) +#define F_MPS_GLOBAL_CGEN V_MPS_GLOBAL_CGEN(1U) + +#define A_MPS_VF_TX_CTL_31_0 0x9010 +#define A_MPS_VF_TX_CTL_63_32 0x9014 +#define A_MPS_VF_TX_CTL_95_64 0x9018 +#define A_MPS_VF_TX_CTL_127_96 0x901c +#define A_MPS_VF_RX_CTL_31_0 0x9020 +#define A_MPS_VF_RX_CTL_63_32 0x9024 +#define A_MPS_VF_RX_CTL_95_64 0x9028 +#define A_MPS_VF_RX_CTL_127_96 0x902c +#define A_MPS_TX_PAUSE_DURATION_BUF_GRP0 0x9030 + +#define S_VALUE 0 +#define M_VALUE 0xffffU +#define V_VALUE(x) ((x) << S_VALUE) +#define G_VALUE(x) (((x) >> S_VALUE) & M_VALUE) + +#define A_MPS_TX_PAUSE_DURATION_BUF_GRP1 0x9034 +#define A_MPS_TX_PAUSE_DURATION_BUF_GRP2 0x9038 +#define A_MPS_TX_PAUSE_DURATION_BUF_GRP3 0x903c +#define A_MPS_TX_PAUSE_RETRANS_BUF_GRP0 0x9040 +#define A_MPS_TX_PAUSE_RETRANS_BUF_GRP1 0x9044 +#define A_MPS_TX_PAUSE_RETRANS_BUF_GRP2 0x9048 +#define A_MPS_TX_PAUSE_RETRANS_BUF_GRP3 0x904c +#define A_MPS_TP_CSIDE_MUX_CTL_P0 0x9050 + +#define S_WEIGHT 0 +#define M_WEIGHT 0xfffU +#define V_WEIGHT(x) ((x) << S_WEIGHT) +#define G_WEIGHT(x) (((x) >> S_WEIGHT) & M_WEIGHT) + +#define A_MPS_TP_CSIDE_MUX_CTL_P1 0x9054 +#define A_MPS_WOL_CTL_MODE 0x9058 + +#define S_WOL_MODE 0 +#define V_WOL_MODE(x) ((x) << S_WOL_MODE) +#define F_WOL_MODE V_WOL_MODE(1U) + +#define A_MPS_FPGA_DEBUG 0x9060 + +#define S_LPBK_EN 8 +#define V_LPBK_EN(x) ((x) << S_LPBK_EN) +#define F_LPBK_EN V_LPBK_EN(1U) + +#define S_CH_MAP3 6 +#define M_CH_MAP3 0x3U +#define V_CH_MAP3(x) ((x) << S_CH_MAP3) +#define G_CH_MAP3(x) (((x) >> S_CH_MAP3) & M_CH_MAP3) + +#define S_CH_MAP2 4 +#define M_CH_MAP2 0x3U +#define V_CH_MAP2(x) ((x) << S_CH_MAP2) +#define G_CH_MAP2(x) (((x) >> S_CH_MAP2) & M_CH_MAP2) + +#define S_CH_MAP1 2 +#define M_CH_MAP1 0x3U +#define V_CH_MAP1(x) ((x) << S_CH_MAP1) +#define G_CH_MAP1(x) (((x) >> S_CH_MAP1) & M_CH_MAP1) + +#define S_CH_MAP0 0 +#define M_CH_MAP0 0x3U +#define V_CH_MAP0(x) ((x) << S_CH_MAP0) +#define G_CH_MAP0(x) (((x) >> S_CH_MAP0) & M_CH_MAP0) + +#define S_FPGA_PTP_PORT 9 +#define M_FPGA_PTP_PORT 0x3U +#define V_FPGA_PTP_PORT(x) ((x) << S_FPGA_PTP_PORT) +#define G_FPGA_PTP_PORT(x) (((x) >> S_FPGA_PTP_PORT) & M_FPGA_PTP_PORT) + +#define A_MPS_DEBUG_CTL 0x9068 + +#define S_DBGMODECTL_H 11 +#define V_DBGMODECTL_H(x) ((x) << S_DBGMODECTL_H) +#define F_DBGMODECTL_H V_DBGMODECTL_H(1U) + +#define S_DBGSEL_H 6 +#define M_DBGSEL_H 0x1fU +#define V_DBGSEL_H(x) ((x) << S_DBGSEL_H) +#define G_DBGSEL_H(x) (((x) >> S_DBGSEL_H) & M_DBGSEL_H) + +#define S_DBGMODECTL_L 5 +#define V_DBGMODECTL_L(x) ((x) << S_DBGMODECTL_L) +#define F_DBGMODECTL_L V_DBGMODECTL_L(1U) + +#define S_DBGSEL_L 0 +#define M_DBGSEL_L 0x1fU +#define V_DBGSEL_L(x) ((x) << S_DBGSEL_L) +#define G_DBGSEL_L(x) (((x) >> S_DBGSEL_L) & M_DBGSEL_L) + +#define A_MPS_DEBUG_DATA_REG_L 0x906c +#define A_MPS_DEBUG_DATA_REG_H 0x9070 +#define A_MPS_TOP_SPARE 0x9074 + +#define S_TOPSPARE 8 +#define M_TOPSPARE 0xffffffU +#define V_TOPSPARE(x) ((x) << S_TOPSPARE) +#define G_TOPSPARE(x) (((x) >> S_TOPSPARE) & M_TOPSPARE) + +#define S_OVLANSELLPBK3 7 +#define V_OVLANSELLPBK3(x) ((x) << S_OVLANSELLPBK3) +#define F_OVLANSELLPBK3 V_OVLANSELLPBK3(1U) + +#define S_OVLANSELLPBK2 6 +#define V_OVLANSELLPBK2(x) ((x) << S_OVLANSELLPBK2) +#define F_OVLANSELLPBK2 V_OVLANSELLPBK2(1U) + +#define S_OVLANSELLPBK1 5 +#define V_OVLANSELLPBK1(x) ((x) << S_OVLANSELLPBK1) +#define F_OVLANSELLPBK1 V_OVLANSELLPBK1(1U) + +#define S_OVLANSELLPBK0 4 +#define V_OVLANSELLPBK0(x) ((x) << S_OVLANSELLPBK0) +#define F_OVLANSELLPBK0 V_OVLANSELLPBK0(1U) + +#define S_OVLANSELMAC3 3 +#define V_OVLANSELMAC3(x) ((x) << S_OVLANSELMAC3) +#define F_OVLANSELMAC3 V_OVLANSELMAC3(1U) + +#define S_OVLANSELMAC2 2 +#define V_OVLANSELMAC2(x) ((x) << S_OVLANSELMAC2) +#define F_OVLANSELMAC2 V_OVLANSELMAC2(1U) + +#define S_OVLANSELMAC1 1 +#define V_OVLANSELMAC1(x) ((x) << S_OVLANSELMAC1) +#define F_OVLANSELMAC1 V_OVLANSELMAC1(1U) + +#define S_OVLANSELMAC0 0 +#define V_OVLANSELMAC0(x) ((x) << S_OVLANSELMAC0) +#define F_OVLANSELMAC0 V_OVLANSELMAC0(1U) + +#define S_T5_TOPSPARE 8 +#define M_T5_TOPSPARE 0xffffffU +#define V_T5_TOPSPARE(x) ((x) << S_T5_TOPSPARE) +#define G_T5_TOPSPARE(x) (((x) >> S_T5_TOPSPARE) & M_T5_TOPSPARE) + +#define A_MPS_T5_BUILD_REVISION 0x9078 +#define A_MPS_TX_PAUSE_DURATION_BUF_GRP_TH0 0x907c +#define A_MPS_TX_PAUSE_DURATION_BUF_GRP_TH1 0x9080 +#define A_MPS_TX_PAUSE_DURATION_BUF_GRP_TH2 0x9084 +#define A_MPS_TX_PAUSE_DURATION_BUF_GRP_TH3 0x9088 +#define A_MPS_TX_PAUSE_DURATION_BUF_GRP_TH4 0x908c +#define A_MPS_TX_PAUSE_DURATION_BUF_GRP_TH5 0x9090 +#define A_MPS_TX_PAUSE_DURATION_BUF_GRP_TH6 0x9094 +#define A_MPS_TX_PAUSE_DURATION_BUF_GRP_TH7 0x9098 +#define A_MPS_TX_PAUSE_DURATION_BUF_GRP_TH8 0x909c +#define A_MPS_TX_PAUSE_DURATION_BUF_GRP_TH9 0x90a0 +#define A_MPS_TX_PAUSE_DURATION_BUF_GRP_TH10 0x90a4 +#define A_MPS_TX_PAUSE_DURATION_BUF_GRP_TH11 0x90a8 +#define A_MPS_TX_PAUSE_DURATION_BUF_GRP_TH12 0x90ac +#define A_MPS_TX_PAUSE_DURATION_BUF_GRP_TH13 0x90b0 +#define A_MPS_TX_PAUSE_DURATION_BUF_GRP_TH14 0x90b4 +#define A_MPS_TX_PAUSE_DURATION_BUF_GRP_TH15 0x90b8 +#define A_MPS_TX_PAUSE_RETRANS_BUF_GRP_TH0 0x90bc +#define A_MPS_TX_PAUSE_RETRANS_BUF_GRP_TH1 0x90c0 +#define A_MPS_TX_PAUSE_RETRANS_BUF_GRP_TH2 0x90c4 +#define A_MPS_TX_PAUSE_RETRANS_BUF_GRP_TH3 0x90c8 +#define A_MPS_TX_PAUSE_RETRANS_BUF_GRP_TH4 0x90cc +#define A_MPS_TX_PAUSE_RETRANS_BUF_GRP_TH5 0x90d0 +#define A_MPS_TX_PAUSE_RETRANS_BUF_GRP_TH6 0x90d4 +#define A_MPS_TX_PAUSE_RETRANS_BUF_GRP_TH7 0x90d8 +#define A_MPS_TX_PAUSE_RETRANS_BUF_GRP_TH8 0x90dc +#define A_MPS_TX_PAUSE_RETRANS_BUF_GRP_TH9 0x90e0 +#define A_MPS_TX_PAUSE_RETRANS_BUF_GRP_TH10 0x90e4 +#define A_MPS_TX_PAUSE_RETRANS_BUF_GRP_TH11 0x90e8 +#define A_MPS_TX_PAUSE_RETRANS_BUF_GRP_TH12 0x90ec +#define A_MPS_TX_PAUSE_RETRANS_BUF_GRP_TH13 0x90f0 +#define A_MPS_TX_PAUSE_RETRANS_BUF_GRP_TH14 0x90f4 +#define A_MPS_TX_PAUSE_RETRANS_BUF_GRP_TH15 0x90f8 +#define A_MPS_BUILD_REVISION 0x90fc +#define A_MPS_TX_PRTY_SEL 0x9400 + +#define S_CH4_PRTY 20 +#define M_CH4_PRTY 0x7U +#define V_CH4_PRTY(x) ((x) << S_CH4_PRTY) +#define G_CH4_PRTY(x) (((x) >> S_CH4_PRTY) & M_CH4_PRTY) + +#define S_CH3_PRTY 16 +#define M_CH3_PRTY 0x7U +#define V_CH3_PRTY(x) ((x) << S_CH3_PRTY) +#define G_CH3_PRTY(x) (((x) >> S_CH3_PRTY) & M_CH3_PRTY) + +#define S_CH2_PRTY 12 +#define M_CH2_PRTY 0x7U +#define V_CH2_PRTY(x) ((x) << S_CH2_PRTY) +#define G_CH2_PRTY(x) (((x) >> S_CH2_PRTY) & M_CH2_PRTY) + +#define S_CH1_PRTY 8 +#define M_CH1_PRTY 0x7U +#define V_CH1_PRTY(x) ((x) << S_CH1_PRTY) +#define G_CH1_PRTY(x) (((x) >> S_CH1_PRTY) & M_CH1_PRTY) + +#define S_CH0_PRTY 4 +#define M_CH0_PRTY 0x7U +#define V_CH0_PRTY(x) ((x) << S_CH0_PRTY) +#define G_CH0_PRTY(x) (((x) >> S_CH0_PRTY) & M_CH0_PRTY) + +#define S_TP_SOURCE 2 +#define M_TP_SOURCE 0x3U +#define V_TP_SOURCE(x) ((x) << S_TP_SOURCE) +#define G_TP_SOURCE(x) (((x) >> S_TP_SOURCE) & M_TP_SOURCE) + +#define S_NCSI_SOURCE 0 +#define M_NCSI_SOURCE 0x3U +#define V_NCSI_SOURCE(x) ((x) << S_NCSI_SOURCE) +#define G_NCSI_SOURCE(x) (((x) >> S_NCSI_SOURCE) & M_NCSI_SOURCE) + +#define A_MPS_TX_INT_ENABLE 0x9404 + +#define S_PORTERR 16 +#define V_PORTERR(x) ((x) << S_PORTERR) +#define F_PORTERR V_PORTERR(1U) + +#define S_FRMERR 15 +#define V_FRMERR(x) ((x) << S_FRMERR) +#define F_FRMERR V_FRMERR(1U) + +#define S_SECNTERR 14 +#define V_SECNTERR(x) ((x) << S_SECNTERR) +#define F_SECNTERR V_SECNTERR(1U) + +#define S_BUBBLE 13 +#define V_BUBBLE(x) ((x) << S_BUBBLE) +#define F_BUBBLE V_BUBBLE(1U) + +#define S_TXDESCFIFO 9 +#define M_TXDESCFIFO 0xfU +#define V_TXDESCFIFO(x) ((x) << S_TXDESCFIFO) +#define G_TXDESCFIFO(x) (((x) >> S_TXDESCFIFO) & M_TXDESCFIFO) + +#define S_TXDATAFIFO 5 +#define M_TXDATAFIFO 0xfU +#define V_TXDATAFIFO(x) ((x) << S_TXDATAFIFO) +#define G_TXDATAFIFO(x) (((x) >> S_TXDATAFIFO) & M_TXDATAFIFO) + +#define S_NCSIFIFO 4 +#define V_NCSIFIFO(x) ((x) << S_NCSIFIFO) +#define F_NCSIFIFO V_NCSIFIFO(1U) + +#define S_TPFIFO 0 +#define M_TPFIFO 0xfU +#define V_TPFIFO(x) ((x) << S_TPFIFO) +#define G_TPFIFO(x) (((x) >> S_TPFIFO) & M_TPFIFO) + +#define A_MPS_TX_INT_CAUSE 0x9408 +#define A_MPS_TX_PERR_ENABLE 0x9410 +#define A_MPS_TX_PERR_INJECT 0x9414 + +#define S_MPSTXMEMSEL 1 +#define M_MPSTXMEMSEL 0x1fU +#define V_MPSTXMEMSEL(x) ((x) << S_MPSTXMEMSEL) +#define G_MPSTXMEMSEL(x) (((x) >> S_MPSTXMEMSEL) & M_MPSTXMEMSEL) + +#define A_MPS_TX_SE_CNT_TP01 0x9418 +#define A_MPS_TX_SE_CNT_TP23 0x941c +#define A_MPS_TX_SE_CNT_MAC01 0x9420 +#define A_MPS_TX_SE_CNT_MAC23 0x9424 +#define A_MPS_TX_SECNT_SPI_BUBBLE_ERR 0x9428 + +#define S_BUBBLEERR 16 +#define M_BUBBLEERR 0xffU +#define V_BUBBLEERR(x) ((x) << S_BUBBLEERR) +#define G_BUBBLEERR(x) (((x) >> S_BUBBLEERR) & M_BUBBLEERR) + +#define S_SPI 8 +#define M_SPI 0xffU +#define V_SPI(x) ((x) << S_SPI) +#define G_SPI(x) (((x) >> S_SPI) & M_SPI) + +#define S_SECNT 0 +#define M_SECNT 0xffU +#define V_SECNT(x) ((x) << S_SECNT) +#define G_SECNT(x) (((x) >> S_SECNT) & M_SECNT) + +#define A_MPS_TX_SECNT_BUBBLE_CLR 0x942c + +#define S_BUBBLECLR 8 +#define M_BUBBLECLR 0xffU +#define V_BUBBLECLR(x) ((x) << S_BUBBLECLR) +#define G_BUBBLECLR(x) (((x) >> S_BUBBLECLR) & M_BUBBLECLR) + +#define S_NCSISECNT 20 +#define V_NCSISECNT(x) ((x) << S_NCSISECNT) +#define F_NCSISECNT V_NCSISECNT(1U) + +#define S_LPBKSECNT 16 +#define M_LPBKSECNT 0xfU +#define V_LPBKSECNT(x) ((x) << S_LPBKSECNT) +#define G_LPBKSECNT(x) (((x) >> S_LPBKSECNT) & M_LPBKSECNT) + +#define A_MPS_TX_PORT_ERR 0x9430 + +#define S_LPBKPT3 7 +#define V_LPBKPT3(x) ((x) << S_LPBKPT3) +#define F_LPBKPT3 V_LPBKPT3(1U) + +#define S_LPBKPT2 6 +#define V_LPBKPT2(x) ((x) << S_LPBKPT2) +#define F_LPBKPT2 V_LPBKPT2(1U) + +#define S_LPBKPT1 5 +#define V_LPBKPT1(x) ((x) << S_LPBKPT1) +#define F_LPBKPT1 V_LPBKPT1(1U) + +#define S_LPBKPT0 4 +#define V_LPBKPT0(x) ((x) << S_LPBKPT0) +#define F_LPBKPT0 V_LPBKPT0(1U) + +#define S_PT3 3 +#define V_PT3(x) ((x) << S_PT3) +#define F_PT3 V_PT3(1U) + +#define S_PT2 2 +#define V_PT2(x) ((x) << S_PT2) +#define F_PT2 V_PT2(1U) + +#define S_PT1 1 +#define V_PT1(x) ((x) << S_PT1) +#define F_PT1 V_PT1(1U) + +#define S_PT0 0 +#define V_PT0(x) ((x) << S_PT0) +#define F_PT0 V_PT0(1U) + +#define A_MPS_TX_LPBK_DROP_BP_CTL_CH0 0x9434 + +#define S_BPEN 1 +#define V_BPEN(x) ((x) << S_BPEN) +#define F_BPEN V_BPEN(1U) + +#define S_DROPEN 0 +#define V_DROPEN(x) ((x) << S_DROPEN) +#define F_DROPEN V_DROPEN(1U) + +#define A_MPS_TX_LPBK_DROP_BP_CTL_CH1 0x9438 +#define A_MPS_TX_LPBK_DROP_BP_CTL_CH2 0x943c +#define A_MPS_TX_LPBK_DROP_BP_CTL_CH3 0x9440 +#define A_MPS_TX_DEBUG_REG_TP2TX_10 0x9444 + +#define S_SOPCH1 31 +#define V_SOPCH1(x) ((x) << S_SOPCH1) +#define F_SOPCH1 V_SOPCH1(1U) + +#define S_EOPCH1 30 +#define V_EOPCH1(x) ((x) << S_EOPCH1) +#define F_EOPCH1 V_EOPCH1(1U) + +#define S_SIZECH1 27 +#define M_SIZECH1 0x7U +#define V_SIZECH1(x) ((x) << S_SIZECH1) +#define G_SIZECH1(x) (((x) >> S_SIZECH1) & M_SIZECH1) + +#define S_ERRCH1 26 +#define V_ERRCH1(x) ((x) << S_ERRCH1) +#define F_ERRCH1 V_ERRCH1(1U) + +#define S_FULLCH1 25 +#define V_FULLCH1(x) ((x) << S_FULLCH1) +#define F_FULLCH1 V_FULLCH1(1U) + +#define S_VALIDCH1 24 +#define V_VALIDCH1(x) ((x) << S_VALIDCH1) +#define F_VALIDCH1 V_VALIDCH1(1U) + +#define S_DATACH1 16 +#define M_DATACH1 0xffU +#define V_DATACH1(x) ((x) << S_DATACH1) +#define G_DATACH1(x) (((x) >> S_DATACH1) & M_DATACH1) + +#define S_SOPCH0 15 +#define V_SOPCH0(x) ((x) << S_SOPCH0) +#define F_SOPCH0 V_SOPCH0(1U) + +#define S_EOPCH0 14 +#define V_EOPCH0(x) ((x) << S_EOPCH0) +#define F_EOPCH0 V_EOPCH0(1U) + +#define S_SIZECH0 11 +#define M_SIZECH0 0x7U +#define V_SIZECH0(x) ((x) << S_SIZECH0) +#define G_SIZECH0(x) (((x) >> S_SIZECH0) & M_SIZECH0) + +#define S_ERRCH0 10 +#define V_ERRCH0(x) ((x) << S_ERRCH0) +#define F_ERRCH0 V_ERRCH0(1U) + +#define S_FULLCH0 9 +#define V_FULLCH0(x) ((x) << S_FULLCH0) +#define F_FULLCH0 V_FULLCH0(1U) + +#define S_VALIDCH0 8 +#define V_VALIDCH0(x) ((x) << S_VALIDCH0) +#define F_VALIDCH0 V_VALIDCH0(1U) + +#define S_DATACH0 0 +#define M_DATACH0 0xffU +#define V_DATACH0(x) ((x) << S_DATACH0) +#define G_DATACH0(x) (((x) >> S_DATACH0) & M_DATACH0) + +#define A_MPS_TX_DEBUG_REG_TP2TX_32 0x9448 + +#define S_SOPCH3 31 +#define V_SOPCH3(x) ((x) << S_SOPCH3) +#define F_SOPCH3 V_SOPCH3(1U) + +#define S_EOPCH3 30 +#define V_EOPCH3(x) ((x) << S_EOPCH3) +#define F_EOPCH3 V_EOPCH3(1U) + +#define S_SIZECH3 27 +#define M_SIZECH3 0x7U +#define V_SIZECH3(x) ((x) << S_SIZECH3) +#define G_SIZECH3(x) (((x) >> S_SIZECH3) & M_SIZECH3) + +#define S_ERRCH3 26 +#define V_ERRCH3(x) ((x) << S_ERRCH3) +#define F_ERRCH3 V_ERRCH3(1U) + +#define S_FULLCH3 25 +#define V_FULLCH3(x) ((x) << S_FULLCH3) +#define F_FULLCH3 V_FULLCH3(1U) + +#define S_VALIDCH3 24 +#define V_VALIDCH3(x) ((x) << S_VALIDCH3) +#define F_VALIDCH3 V_VALIDCH3(1U) + +#define S_DATACH3 16 +#define M_DATACH3 0xffU +#define V_DATACH3(x) ((x) << S_DATACH3) +#define G_DATACH3(x) (((x) >> S_DATACH3) & M_DATACH3) + +#define S_SOPCH2 15 +#define V_SOPCH2(x) ((x) << S_SOPCH2) +#define F_SOPCH2 V_SOPCH2(1U) + +#define S_EOPCH2 14 +#define V_EOPCH2(x) ((x) << S_EOPCH2) +#define F_EOPCH2 V_EOPCH2(1U) + +#define S_SIZECH2 11 +#define M_SIZECH2 0x7U +#define V_SIZECH2(x) ((x) << S_SIZECH2) +#define G_SIZECH2(x) (((x) >> S_SIZECH2) & M_SIZECH2) + +#define S_ERRCH2 10 +#define V_ERRCH2(x) ((x) << S_ERRCH2) +#define F_ERRCH2 V_ERRCH2(1U) + +#define S_FULLCH2 9 +#define V_FULLCH2(x) ((x) << S_FULLCH2) +#define F_FULLCH2 V_FULLCH2(1U) + +#define S_VALIDCH2 8 +#define V_VALIDCH2(x) ((x) << S_VALIDCH2) +#define F_VALIDCH2 V_VALIDCH2(1U) + +#define S_DATACH2 0 +#define M_DATACH2 0xffU +#define V_DATACH2(x) ((x) << S_DATACH2) +#define G_DATACH2(x) (((x) >> S_DATACH2) & M_DATACH2) + +#define A_MPS_TX_DEBUG_REG_TX2MAC_10 0x944c + +#define S_SOPPT1 31 +#define V_SOPPT1(x) ((x) << S_SOPPT1) +#define F_SOPPT1 V_SOPPT1(1U) + +#define S_EOPPT1 30 +#define V_EOPPT1(x) ((x) << S_EOPPT1) +#define F_EOPPT1 V_EOPPT1(1U) + +#define S_SIZEPT1 27 +#define M_SIZEPT1 0x7U +#define V_SIZEPT1(x) ((x) << S_SIZEPT1) +#define G_SIZEPT1(x) (((x) >> S_SIZEPT1) & M_SIZEPT1) + +#define S_ERRPT1 26 +#define V_ERRPT1(x) ((x) << S_ERRPT1) +#define F_ERRPT1 V_ERRPT1(1U) + +#define S_FULLPT1 25 +#define V_FULLPT1(x) ((x) << S_FULLPT1) +#define F_FULLPT1 V_FULLPT1(1U) + +#define S_VALIDPT1 24 +#define V_VALIDPT1(x) ((x) << S_VALIDPT1) +#define F_VALIDPT1 V_VALIDPT1(1U) + +#define S_DATAPT1 16 +#define M_DATAPT1 0xffU +#define V_DATAPT1(x) ((x) << S_DATAPT1) +#define G_DATAPT1(x) (((x) >> S_DATAPT1) & M_DATAPT1) + +#define S_SOPPT0 15 +#define V_SOPPT0(x) ((x) << S_SOPPT0) +#define F_SOPPT0 V_SOPPT0(1U) + +#define S_EOPPT0 14 +#define V_EOPPT0(x) ((x) << S_EOPPT0) +#define F_EOPPT0 V_EOPPT0(1U) + +#define S_SIZEPT0 11 +#define M_SIZEPT0 0x7U +#define V_SIZEPT0(x) ((x) << S_SIZEPT0) +#define G_SIZEPT0(x) (((x) >> S_SIZEPT0) & M_SIZEPT0) + +#define S_ERRPT0 10 +#define V_ERRPT0(x) ((x) << S_ERRPT0) +#define F_ERRPT0 V_ERRPT0(1U) + +#define S_FULLPT0 9 +#define V_FULLPT0(x) ((x) << S_FULLPT0) +#define F_FULLPT0 V_FULLPT0(1U) + +#define S_VALIDPT0 8 +#define V_VALIDPT0(x) ((x) << S_VALIDPT0) +#define F_VALIDPT0 V_VALIDPT0(1U) + +#define S_DATAPT0 0 +#define M_DATAPT0 0xffU +#define V_DATAPT0(x) ((x) << S_DATAPT0) +#define G_DATAPT0(x) (((x) >> S_DATAPT0) & M_DATAPT0) + +#define A_MPS_TX_DEBUG_REG_TX2MAC_32 0x9450 + +#define S_SOPPT3 31 +#define V_SOPPT3(x) ((x) << S_SOPPT3) +#define F_SOPPT3 V_SOPPT3(1U) + +#define S_EOPPT3 30 +#define V_EOPPT3(x) ((x) << S_EOPPT3) +#define F_EOPPT3 V_EOPPT3(1U) + +#define S_SIZEPT3 27 +#define M_SIZEPT3 0x7U +#define V_SIZEPT3(x) ((x) << S_SIZEPT3) +#define G_SIZEPT3(x) (((x) >> S_SIZEPT3) & M_SIZEPT3) + +#define S_ERRPT3 26 +#define V_ERRPT3(x) ((x) << S_ERRPT3) +#define F_ERRPT3 V_ERRPT3(1U) + +#define S_FULLPT3 25 +#define V_FULLPT3(x) ((x) << S_FULLPT3) +#define F_FULLPT3 V_FULLPT3(1U) + +#define S_VALIDPT3 24 +#define V_VALIDPT3(x) ((x) << S_VALIDPT3) +#define F_VALIDPT3 V_VALIDPT3(1U) + +#define S_DATAPT3 16 +#define M_DATAPT3 0xffU +#define V_DATAPT3(x) ((x) << S_DATAPT3) +#define G_DATAPT3(x) (((x) >> S_DATAPT3) & M_DATAPT3) + +#define S_SOPPT2 15 +#define V_SOPPT2(x) ((x) << S_SOPPT2) +#define F_SOPPT2 V_SOPPT2(1U) + +#define S_EOPPT2 14 +#define V_EOPPT2(x) ((x) << S_EOPPT2) +#define F_EOPPT2 V_EOPPT2(1U) + +#define S_SIZEPT2 11 +#define M_SIZEPT2 0x7U +#define V_SIZEPT2(x) ((x) << S_SIZEPT2) +#define G_SIZEPT2(x) (((x) >> S_SIZEPT2) & M_SIZEPT2) + +#define S_ERRPT2 10 +#define V_ERRPT2(x) ((x) << S_ERRPT2) +#define F_ERRPT2 V_ERRPT2(1U) + +#define S_FULLPT2 9 +#define V_FULLPT2(x) ((x) << S_FULLPT2) +#define F_FULLPT2 V_FULLPT2(1U) + +#define S_VALIDPT2 8 +#define V_VALIDPT2(x) ((x) << S_VALIDPT2) +#define F_VALIDPT2 V_VALIDPT2(1U) + +#define S_DATAPT2 0 +#define M_DATAPT2 0xffU +#define V_DATAPT2(x) ((x) << S_DATAPT2) +#define G_DATAPT2(x) (((x) >> S_DATAPT2) & M_DATAPT2) + +#define A_MPS_TX_SGE_CH_PAUSE_IGNR 0x9454 + +#define S_SGEPAUSEIGNR 0 +#define M_SGEPAUSEIGNR 0xfU +#define V_SGEPAUSEIGNR(x) ((x) << S_SGEPAUSEIGNR) +#define G_SGEPAUSEIGNR(x) (((x) >> S_SGEPAUSEIGNR) & M_SGEPAUSEIGNR) + +#define A_MPS_T5_TX_SGE_CH_PAUSE_IGNR 0x9454 + +#define S_T5SGEPAUSEIGNR 0 +#define M_T5SGEPAUSEIGNR 0xffffU +#define V_T5SGEPAUSEIGNR(x) ((x) << S_T5SGEPAUSEIGNR) +#define G_T5SGEPAUSEIGNR(x) (((x) >> S_T5SGEPAUSEIGNR) & M_T5SGEPAUSEIGNR) + +#define A_MPS_TX_DEBUG_SUBPART_SEL 0x9458 + +#define S_SUBPRTH 11 +#define M_SUBPRTH 0x1fU +#define V_SUBPRTH(x) ((x) << S_SUBPRTH) +#define G_SUBPRTH(x) (((x) >> S_SUBPRTH) & M_SUBPRTH) + +#define S_PORTH 8 +#define M_PORTH 0x7U +#define V_PORTH(x) ((x) << S_PORTH) +#define G_PORTH(x) (((x) >> S_PORTH) & M_PORTH) + +#define S_SUBPRTL 3 +#define M_SUBPRTL 0x1fU +#define V_SUBPRTL(x) ((x) << S_SUBPRTL) +#define G_SUBPRTL(x) (((x) >> S_SUBPRTL) & M_SUBPRTL) + +#define S_PORTL 0 +#define M_PORTL 0x7U +#define V_PORTL(x) ((x) << S_PORTL) +#define G_PORTL(x) (((x) >> S_PORTL) & M_PORTL) + +#define A_MPS_TX_PAD_CTL 0x945c + +#define S_LPBKPADENPT3 7 +#define V_LPBKPADENPT3(x) ((x) << S_LPBKPADENPT3) +#define F_LPBKPADENPT3 V_LPBKPADENPT3(1U) + +#define S_LPBKPADENPT2 6 +#define V_LPBKPADENPT2(x) ((x) << S_LPBKPADENPT2) +#define F_LPBKPADENPT2 V_LPBKPADENPT2(1U) + +#define S_LPBKPADENPT1 5 +#define V_LPBKPADENPT1(x) ((x) << S_LPBKPADENPT1) +#define F_LPBKPADENPT1 V_LPBKPADENPT1(1U) + +#define S_LPBKPADENPT0 4 +#define V_LPBKPADENPT0(x) ((x) << S_LPBKPADENPT0) +#define F_LPBKPADENPT0 V_LPBKPADENPT0(1U) + +#define S_MACPADENPT3 3 +#define V_MACPADENPT3(x) ((x) << S_MACPADENPT3) +#define F_MACPADENPT3 V_MACPADENPT3(1U) + +#define S_MACPADENPT2 2 +#define V_MACPADENPT2(x) ((x) << S_MACPADENPT2) +#define F_MACPADENPT2 V_MACPADENPT2(1U) + +#define S_MACPADENPT1 1 +#define V_MACPADENPT1(x) ((x) << S_MACPADENPT1) +#define F_MACPADENPT1 V_MACPADENPT1(1U) + +#define S_MACPADENPT0 0 +#define V_MACPADENPT0(x) ((x) << S_MACPADENPT0) +#define F_MACPADENPT0 V_MACPADENPT0(1U) + +#define A_MPS_TX_PFVF_PORT_DROP_TP 0x9460 + +#define S_TP2MPS_CH3 24 +#define M_TP2MPS_CH3 0xffU +#define V_TP2MPS_CH3(x) ((x) << S_TP2MPS_CH3) +#define G_TP2MPS_CH3(x) (((x) >> S_TP2MPS_CH3) & M_TP2MPS_CH3) + +#define S_TP2MPS_CH2 16 +#define M_TP2MPS_CH2 0xffU +#define V_TP2MPS_CH2(x) ((x) << S_TP2MPS_CH2) +#define G_TP2MPS_CH2(x) (((x) >> S_TP2MPS_CH2) & M_TP2MPS_CH2) + +#define S_TP2MPS_CH1 8 +#define M_TP2MPS_CH1 0xffU +#define V_TP2MPS_CH1(x) ((x) << S_TP2MPS_CH1) +#define G_TP2MPS_CH1(x) (((x) >> S_TP2MPS_CH1) & M_TP2MPS_CH1) + +#define S_TP2MPS_CH0 0 +#define M_TP2MPS_CH0 0xffU +#define V_TP2MPS_CH0(x) ((x) << S_TP2MPS_CH0) +#define G_TP2MPS_CH0(x) (((x) >> S_TP2MPS_CH0) & M_TP2MPS_CH0) + +#define A_MPS_TX_PFVF_PORT_DROP_NCSI 0x9464 + +#define S_NCSI_CH4 0 +#define M_NCSI_CH4 0xffU +#define V_NCSI_CH4(x) ((x) << S_NCSI_CH4) +#define G_NCSI_CH4(x) (((x) >> S_NCSI_CH4) & M_NCSI_CH4) + +#define A_MPS_TX_PFVF_PORT_DROP_CTL 0x9468 + +#define S_PFNOVFDROP 5 +#define V_PFNOVFDROP(x) ((x) << S_PFNOVFDROP) +#define F_PFNOVFDROP V_PFNOVFDROP(1U) + +#define S_NCSI_CH4_CLR 4 +#define V_NCSI_CH4_CLR(x) ((x) << S_NCSI_CH4_CLR) +#define F_NCSI_CH4_CLR V_NCSI_CH4_CLR(1U) + +#define S_TP2MPS_CH3_CLR 3 +#define V_TP2MPS_CH3_CLR(x) ((x) << S_TP2MPS_CH3_CLR) +#define F_TP2MPS_CH3_CLR V_TP2MPS_CH3_CLR(1U) + +#define S_TP2MPS_CH2_CLR 2 +#define V_TP2MPS_CH2_CLR(x) ((x) << S_TP2MPS_CH2_CLR) +#define F_TP2MPS_CH2_CLR V_TP2MPS_CH2_CLR(1U) + +#define S_TP2MPS_CH1_CLR 1 +#define V_TP2MPS_CH1_CLR(x) ((x) << S_TP2MPS_CH1_CLR) +#define F_TP2MPS_CH1_CLR V_TP2MPS_CH1_CLR(1U) + +#define S_TP2MPS_CH0_CLR 0 +#define V_TP2MPS_CH0_CLR(x) ((x) << S_TP2MPS_CH0_CLR) +#define F_TP2MPS_CH0_CLR V_TP2MPS_CH0_CLR(1U) + +#define A_MPS_TX_CGEN 0x946c + +#define S_TXOUTLPBK3_CGEN 31 +#define V_TXOUTLPBK3_CGEN(x) ((x) << S_TXOUTLPBK3_CGEN) +#define F_TXOUTLPBK3_CGEN V_TXOUTLPBK3_CGEN(1U) + +#define S_TXOUTLPBK2_CGEN 30 +#define V_TXOUTLPBK2_CGEN(x) ((x) << S_TXOUTLPBK2_CGEN) +#define F_TXOUTLPBK2_CGEN V_TXOUTLPBK2_CGEN(1U) + +#define S_TXOUTLPBK1_CGEN 29 +#define V_TXOUTLPBK1_CGEN(x) ((x) << S_TXOUTLPBK1_CGEN) +#define F_TXOUTLPBK1_CGEN V_TXOUTLPBK1_CGEN(1U) + +#define S_TXOUTLPBK0_CGEN 28 +#define V_TXOUTLPBK0_CGEN(x) ((x) << S_TXOUTLPBK0_CGEN) +#define F_TXOUTLPBK0_CGEN V_TXOUTLPBK0_CGEN(1U) + +#define S_TXOUTMAC3_CGEN 27 +#define V_TXOUTMAC3_CGEN(x) ((x) << S_TXOUTMAC3_CGEN) +#define F_TXOUTMAC3_CGEN V_TXOUTMAC3_CGEN(1U) + +#define S_TXOUTMAC2_CGEN 26 +#define V_TXOUTMAC2_CGEN(x) ((x) << S_TXOUTMAC2_CGEN) +#define F_TXOUTMAC2_CGEN V_TXOUTMAC2_CGEN(1U) + +#define S_TXOUTMAC1_CGEN 25 +#define V_TXOUTMAC1_CGEN(x) ((x) << S_TXOUTMAC1_CGEN) +#define F_TXOUTMAC1_CGEN V_TXOUTMAC1_CGEN(1U) + +#define S_TXOUTMAC0_CGEN 24 +#define V_TXOUTMAC0_CGEN(x) ((x) << S_TXOUTMAC0_CGEN) +#define F_TXOUTMAC0_CGEN V_TXOUTMAC0_CGEN(1U) + +#define S_TXSCHLPBK3_CGEN 23 +#define V_TXSCHLPBK3_CGEN(x) ((x) << S_TXSCHLPBK3_CGEN) +#define F_TXSCHLPBK3_CGEN V_TXSCHLPBK3_CGEN(1U) + +#define S_TXSCHLPBK2_CGEN 22 +#define V_TXSCHLPBK2_CGEN(x) ((x) << S_TXSCHLPBK2_CGEN) +#define F_TXSCHLPBK2_CGEN V_TXSCHLPBK2_CGEN(1U) + +#define S_TXSCHLPBK1_CGEN 21 +#define V_TXSCHLPBK1_CGEN(x) ((x) << S_TXSCHLPBK1_CGEN) +#define F_TXSCHLPBK1_CGEN V_TXSCHLPBK1_CGEN(1U) + +#define S_TXSCHLPBK0_CGEN 20 +#define V_TXSCHLPBK0_CGEN(x) ((x) << S_TXSCHLPBK0_CGEN) +#define F_TXSCHLPBK0_CGEN V_TXSCHLPBK0_CGEN(1U) + +#define S_TXSCHMAC3_CGEN 19 +#define V_TXSCHMAC3_CGEN(x) ((x) << S_TXSCHMAC3_CGEN) +#define F_TXSCHMAC3_CGEN V_TXSCHMAC3_CGEN(1U) + +#define S_TXSCHMAC2_CGEN 18 +#define V_TXSCHMAC2_CGEN(x) ((x) << S_TXSCHMAC2_CGEN) +#define F_TXSCHMAC2_CGEN V_TXSCHMAC2_CGEN(1U) + +#define S_TXSCHMAC1_CGEN 17 +#define V_TXSCHMAC1_CGEN(x) ((x) << S_TXSCHMAC1_CGEN) +#define F_TXSCHMAC1_CGEN V_TXSCHMAC1_CGEN(1U) + +#define S_TXSCHMAC0_CGEN 16 +#define V_TXSCHMAC0_CGEN(x) ((x) << S_TXSCHMAC0_CGEN) +#define F_TXSCHMAC0_CGEN V_TXSCHMAC0_CGEN(1U) + +#define S_TXINCH4_CGEN 15 +#define V_TXINCH4_CGEN(x) ((x) << S_TXINCH4_CGEN) +#define F_TXINCH4_CGEN V_TXINCH4_CGEN(1U) + +#define S_TXINCH3_CGEN 14 +#define V_TXINCH3_CGEN(x) ((x) << S_TXINCH3_CGEN) +#define F_TXINCH3_CGEN V_TXINCH3_CGEN(1U) + +#define S_TXINCH2_CGEN 13 +#define V_TXINCH2_CGEN(x) ((x) << S_TXINCH2_CGEN) +#define F_TXINCH2_CGEN V_TXINCH2_CGEN(1U) + +#define S_TXINCH1_CGEN 12 +#define V_TXINCH1_CGEN(x) ((x) << S_TXINCH1_CGEN) +#define F_TXINCH1_CGEN V_TXINCH1_CGEN(1U) + +#define S_TXINCH0_CGEN 11 +#define V_TXINCH0_CGEN(x) ((x) << S_TXINCH0_CGEN) +#define F_TXINCH0_CGEN V_TXINCH0_CGEN(1U) + +#define A_MPS_TX_CGEN_DYNAMIC 0x9470 +#define A_MPS_STAT_CTL 0x9600 + +#define S_COUNTVFINPF 1 +#define V_COUNTVFINPF(x) ((x) << S_COUNTVFINPF) +#define F_COUNTVFINPF V_COUNTVFINPF(1U) + +#define S_LPBKERRSTAT 0 +#define V_LPBKERRSTAT(x) ((x) << S_LPBKERRSTAT) +#define F_LPBKERRSTAT V_LPBKERRSTAT(1U) + +#define S_STATSTOPCTRL 10 +#define V_STATSTOPCTRL(x) ((x) << S_STATSTOPCTRL) +#define F_STATSTOPCTRL V_STATSTOPCTRL(1U) + +#define S_STOPSTAT 9 +#define V_STOPSTAT(x) ((x) << S_STOPSTAT) +#define F_STOPSTAT V_STOPSTAT(1U) + +#define S_STATWRITECTRL 8 +#define V_STATWRITECTRL(x) ((x) << S_STATWRITECTRL) +#define F_STATWRITECTRL V_STATWRITECTRL(1U) + +#define S_COUNTLBPF 7 +#define V_COUNTLBPF(x) ((x) << S_COUNTLBPF) +#define F_COUNTLBPF V_COUNTLBPF(1U) + +#define S_COUNTLBVF 6 +#define V_COUNTLBVF(x) ((x) << S_COUNTLBVF) +#define F_COUNTLBVF V_COUNTLBVF(1U) + +#define S_COUNTPAUSEMCRX 5 +#define V_COUNTPAUSEMCRX(x) ((x) << S_COUNTPAUSEMCRX) +#define F_COUNTPAUSEMCRX V_COUNTPAUSEMCRX(1U) + +#define S_COUNTPAUSESTATRX 4 +#define V_COUNTPAUSESTATRX(x) ((x) << S_COUNTPAUSESTATRX) +#define F_COUNTPAUSESTATRX V_COUNTPAUSESTATRX(1U) + +#define S_COUNTPAUSEMCTX 3 +#define V_COUNTPAUSEMCTX(x) ((x) << S_COUNTPAUSEMCTX) +#define F_COUNTPAUSEMCTX V_COUNTPAUSEMCTX(1U) + +#define S_COUNTPAUSESTATTX 2 +#define V_COUNTPAUSESTATTX(x) ((x) << S_COUNTPAUSESTATTX) +#define F_COUNTPAUSESTATTX V_COUNTPAUSESTATTX(1U) + +#define A_MPS_STAT_INT_ENABLE 0x9608 + +#define S_PLREADSYNCERR 0 +#define V_PLREADSYNCERR(x) ((x) << S_PLREADSYNCERR) +#define F_PLREADSYNCERR V_PLREADSYNCERR(1U) + +#define A_MPS_STAT_INT_CAUSE 0x960c +#define A_MPS_STAT_PERR_INT_ENABLE_SRAM 0x9610 + +#define S_RXBG 20 +#define V_RXBG(x) ((x) << S_RXBG) +#define F_RXBG V_RXBG(1U) + +#define S_RXVF 18 +#define M_RXVF 0x3U +#define V_RXVF(x) ((x) << S_RXVF) +#define G_RXVF(x) (((x) >> S_RXVF) & M_RXVF) + +#define S_TXVF 16 +#define M_TXVF 0x3U +#define V_TXVF(x) ((x) << S_TXVF) +#define G_TXVF(x) (((x) >> S_TXVF) & M_TXVF) + +#define S_RXPF 13 +#define M_RXPF 0x7U +#define V_RXPF(x) ((x) << S_RXPF) +#define G_RXPF(x) (((x) >> S_RXPF) & M_RXPF) + +#define S_TXPF 11 +#define M_TXPF 0x3U +#define V_TXPF(x) ((x) << S_TXPF) +#define G_TXPF(x) (((x) >> S_TXPF) & M_TXPF) + +#define S_RXPORT 7 +#define M_RXPORT 0xfU +#define V_RXPORT(x) ((x) << S_RXPORT) +#define G_RXPORT(x) (((x) >> S_RXPORT) & M_RXPORT) + +#define S_LBPORT 4 +#define M_LBPORT 0x7U +#define V_LBPORT(x) ((x) << S_LBPORT) +#define G_LBPORT(x) (((x) >> S_LBPORT) & M_LBPORT) + +#define S_TXPORT 0 +#define M_TXPORT 0xfU +#define V_TXPORT(x) ((x) << S_TXPORT) +#define G_TXPORT(x) (((x) >> S_TXPORT) & M_TXPORT) + +#define S_T5_RXBG 27 +#define M_T5_RXBG 0x3U +#define V_T5_RXBG(x) ((x) << S_T5_RXBG) +#define G_T5_RXBG(x) (((x) >> S_T5_RXBG) & M_T5_RXBG) + +#define S_T5_RXPF 22 +#define M_T5_RXPF 0x1fU +#define V_T5_RXPF(x) ((x) << S_T5_RXPF) +#define G_T5_RXPF(x) (((x) >> S_T5_RXPF) & M_T5_RXPF) + +#define S_T5_TXPF 18 +#define M_T5_TXPF 0xfU +#define V_T5_TXPF(x) ((x) << S_T5_TXPF) +#define G_T5_TXPF(x) (((x) >> S_T5_TXPF) & M_T5_TXPF) + +#define S_T5_RXPORT 11 +#define M_T5_RXPORT 0x7fU +#define V_T5_RXPORT(x) ((x) << S_T5_RXPORT) +#define G_T5_RXPORT(x) (((x) >> S_T5_RXPORT) & M_T5_RXPORT) + +#define S_T5_LBPORT 6 +#define M_T5_LBPORT 0x1fU +#define V_T5_LBPORT(x) ((x) << S_T5_LBPORT) +#define G_T5_LBPORT(x) (((x) >> S_T5_LBPORT) & M_T5_LBPORT) + +#define S_T5_TXPORT 0 +#define M_T5_TXPORT 0x3fU +#define V_T5_TXPORT(x) ((x) << S_T5_TXPORT) +#define G_T5_TXPORT(x) (((x) >> S_T5_TXPORT) & M_T5_TXPORT) + +#define A_MPS_STAT_PERR_INT_CAUSE_SRAM 0x9614 +#define A_MPS_STAT_PERR_ENABLE_SRAM 0x9618 +#define A_MPS_STAT_PERR_INT_ENABLE_TX_FIFO 0x961c + +#define S_TX 12 +#define M_TX 0xffU +#define V_TX(x) ((x) << S_TX) +#define G_TX(x) (((x) >> S_TX) & M_TX) + +#define S_TXPAUSEFIFO 8 +#define M_TXPAUSEFIFO 0xfU +#define V_TXPAUSEFIFO(x) ((x) << S_TXPAUSEFIFO) +#define G_TXPAUSEFIFO(x) (((x) >> S_TXPAUSEFIFO) & M_TXPAUSEFIFO) + +#define S_DROP 0 +#define M_DROP 0xffU +#define V_DROP(x) ((x) << S_DROP) +#define G_DROP(x) (((x) >> S_DROP) & M_DROP) + +#define S_TXCH 20 +#define M_TXCH 0xfU +#define V_TXCH(x) ((x) << S_TXCH) +#define G_TXCH(x) (((x) >> S_TXCH) & M_TXCH) + +#define A_MPS_STAT_PERR_INT_CAUSE_TX_FIFO 0x9620 +#define A_MPS_STAT_PERR_ENABLE_TX_FIFO 0x9624 +#define A_MPS_STAT_PERR_INT_ENABLE_RX_FIFO 0x9628 + +#define S_PAUSEFIFO 20 +#define M_PAUSEFIFO 0xfU +#define V_PAUSEFIFO(x) ((x) << S_PAUSEFIFO) +#define G_PAUSEFIFO(x) (((x) >> S_PAUSEFIFO) & M_PAUSEFIFO) + +#define S_LPBK 16 +#define M_LPBK 0xfU +#define V_LPBK(x) ((x) << S_LPBK) +#define G_LPBK(x) (((x) >> S_LPBK) & M_LPBK) + +#define S_NQ 8 +#define M_NQ 0xffU +#define V_NQ(x) ((x) << S_NQ) +#define G_NQ(x) (((x) >> S_NQ) & M_NQ) + +#define S_PV 4 +#define M_PV 0xfU +#define V_PV(x) ((x) << S_PV) +#define G_PV(x) (((x) >> S_PV) & M_PV) + +#define S_MAC 0 +#define M_MAC 0xfU +#define V_MAC(x) ((x) << S_MAC) +#define G_MAC(x) (((x) >> S_MAC) & M_MAC) + +#define A_MPS_STAT_PERR_INT_CAUSE_RX_FIFO 0x962c +#define A_MPS_STAT_PERR_ENABLE_RX_FIFO 0x9630 +#define A_MPS_STAT_PERR_INJECT 0x9634 + +#define S_STATMEMSEL 1 +#define M_STATMEMSEL 0x7fU +#define V_STATMEMSEL(x) ((x) << S_STATMEMSEL) +#define G_STATMEMSEL(x) (((x) >> S_STATMEMSEL) & M_STATMEMSEL) + +#define A_MPS_STAT_DEBUG_SUB_SEL 0x9638 + +#define S_STATSSUBPRTH 5 +#define M_STATSSUBPRTH 0x1fU +#define V_STATSSUBPRTH(x) ((x) << S_STATSSUBPRTH) +#define G_STATSSUBPRTH(x) (((x) >> S_STATSSUBPRTH) & M_STATSSUBPRTH) + +#define S_STATSSUBPRTL 0 +#define M_STATSSUBPRTL 0x1fU +#define V_STATSSUBPRTL(x) ((x) << S_STATSSUBPRTL) +#define G_STATSSUBPRTL(x) (((x) >> S_STATSSUBPRTL) & M_STATSSUBPRTL) + +#define S_STATSUBPRTH 5 +#define M_STATSUBPRTH 0x1fU +#define V_STATSUBPRTH(x) ((x) << S_STATSUBPRTH) +#define G_STATSUBPRTH(x) (((x) >> S_STATSUBPRTH) & M_STATSUBPRTH) + +#define A_MPS_STAT_RX_BG_0_MAC_DROP_FRAME_L 0x9640 +#define A_MPS_STAT_RX_BG_0_MAC_DROP_FRAME_H 0x9644 +#define A_MPS_STAT_RX_BG_1_MAC_DROP_FRAME_L 0x9648 +#define A_MPS_STAT_RX_BG_1_MAC_DROP_FRAME_H 0x964c +#define A_MPS_STAT_RX_BG_2_MAC_DROP_FRAME_L 0x9650 +#define A_MPS_STAT_RX_BG_2_MAC_DROP_FRAME_H 0x9654 +#define A_MPS_STAT_RX_BG_3_MAC_DROP_FRAME_L 0x9658 +#define A_MPS_STAT_RX_BG_3_MAC_DROP_FRAME_H 0x965c +#define A_MPS_STAT_RX_BG_0_LB_DROP_FRAME_L 0x9660 +#define A_MPS_STAT_RX_BG_0_LB_DROP_FRAME_H 0x9664 +#define A_MPS_STAT_RX_BG_1_LB_DROP_FRAME_L 0x9668 +#define A_MPS_STAT_RX_BG_1_LB_DROP_FRAME_H 0x966c +#define A_MPS_STAT_RX_BG_2_LB_DROP_FRAME_L 0x9670 +#define A_MPS_STAT_RX_BG_2_LB_DROP_FRAME_H 0x9674 +#define A_MPS_STAT_RX_BG_3_LB_DROP_FRAME_L 0x9678 +#define A_MPS_STAT_RX_BG_3_LB_DROP_FRAME_H 0x967c +#define A_MPS_STAT_RX_BG_0_MAC_TRUNC_FRAME_L 0x9680 +#define A_MPS_STAT_RX_BG_0_MAC_TRUNC_FRAME_H 0x9684 +#define A_MPS_STAT_RX_BG_1_MAC_TRUNC_FRAME_L 0x9688 +#define A_MPS_STAT_RX_BG_1_MAC_TRUNC_FRAME_H 0x968c +#define A_MPS_STAT_RX_BG_2_MAC_TRUNC_FRAME_L 0x9690 +#define A_MPS_STAT_RX_BG_2_MAC_TRUNC_FRAME_H 0x9694 +#define A_MPS_STAT_RX_BG_3_MAC_TRUNC_FRAME_L 0x9698 +#define A_MPS_STAT_RX_BG_3_MAC_TRUNC_FRAME_H 0x969c +#define A_MPS_STAT_RX_BG_0_LB_TRUNC_FRAME_L 0x96a0 +#define A_MPS_STAT_RX_BG_0_LB_TRUNC_FRAME_H 0x96a4 +#define A_MPS_STAT_RX_BG_1_LB_TRUNC_FRAME_L 0x96a8 +#define A_MPS_STAT_RX_BG_1_LB_TRUNC_FRAME_H 0x96ac +#define A_MPS_STAT_RX_BG_2_LB_TRUNC_FRAME_L 0x96b0 +#define A_MPS_STAT_RX_BG_2_LB_TRUNC_FRAME_H 0x96b4 +#define A_MPS_STAT_RX_BG_3_LB_TRUNC_FRAME_L 0x96b8 +#define A_MPS_STAT_RX_BG_3_LB_TRUNC_FRAME_H 0x96bc +#define A_MPS_STAT_PERR_INT_ENABLE_SRAM1 0x96c0 + +#define S_T5_RXVF 5 +#define M_T5_RXVF 0x7U +#define V_T5_RXVF(x) ((x) << S_T5_RXVF) +#define G_T5_RXVF(x) (((x) >> S_T5_RXVF) & M_T5_RXVF) + +#define S_T5_TXVF 0 +#define M_T5_TXVF 0x1fU +#define V_T5_TXVF(x) ((x) << S_T5_TXVF) +#define G_T5_TXVF(x) (((x) >> S_T5_TXVF) & M_T5_TXVF) + +#define A_MPS_STAT_PERR_INT_CAUSE_SRAM1 0x96c4 +#define A_MPS_STAT_PERR_ENABLE_SRAM1 0x96c8 +#define A_MPS_STAT_STOP_UPD_BG 0x96cc + +#define S_BGRX 0 +#define M_BGRX 0xfU +#define V_BGRX(x) ((x) << S_BGRX) +#define G_BGRX(x) (((x) >> S_BGRX) & M_BGRX) + +#define A_MPS_STAT_STOP_UPD_PORT 0x96d0 + +#define S_PTLPBK 8 +#define M_PTLPBK 0xfU +#define V_PTLPBK(x) ((x) << S_PTLPBK) +#define G_PTLPBK(x) (((x) >> S_PTLPBK) & M_PTLPBK) + +#define S_PTTX 4 +#define M_PTTX 0xfU +#define V_PTTX(x) ((x) << S_PTTX) +#define G_PTTX(x) (((x) >> S_PTTX) & M_PTTX) + +#define S_PTRX 0 +#define M_PTRX 0xfU +#define V_PTRX(x) ((x) << S_PTRX) +#define G_PTRX(x) (((x) >> S_PTRX) & M_PTRX) + +#define A_MPS_STAT_STOP_UPD_PF 0x96d4 + +#define S_PFTX 8 +#define M_PFTX 0xffU +#define V_PFTX(x) ((x) << S_PFTX) +#define G_PFTX(x) (((x) >> S_PFTX) & M_PFTX) + +#define S_PFRX 0 +#define M_PFRX 0xffU +#define V_PFRX(x) ((x) << S_PFRX) +#define G_PFRX(x) (((x) >> S_PFRX) & M_PFRX) + +#define A_MPS_STAT_STOP_UPD_TX_VF_0_31 0x96d8 +#define A_MPS_STAT_STOP_UPD_TX_VF_32_63 0x96dc +#define A_MPS_STAT_STOP_UPD_TX_VF_64_95 0x96e0 +#define A_MPS_STAT_STOP_UPD_TX_VF_96_127 0x96e4 +#define A_MPS_STAT_STOP_UPD_RX_VF_0_31 0x96e8 +#define A_MPS_STAT_STOP_UPD_RX_VF_32_63 0x96ec +#define A_MPS_STAT_STOP_UPD_RX_VF_64_95 0x96f0 +#define A_MPS_STAT_STOP_UPD_RX_VF_96_127 0x96f4 +#define A_MPS_TRC_CFG 0x9800 + +#define S_TRCFIFOEMPTY 4 +#define V_TRCFIFOEMPTY(x) ((x) << S_TRCFIFOEMPTY) +#define F_TRCFIFOEMPTY V_TRCFIFOEMPTY(1U) + +#define S_TRCIGNOREDROPINPUT 3 +#define V_TRCIGNOREDROPINPUT(x) ((x) << S_TRCIGNOREDROPINPUT) +#define F_TRCIGNOREDROPINPUT V_TRCIGNOREDROPINPUT(1U) + +#define S_TRCKEEPDUPLICATES 2 +#define V_TRCKEEPDUPLICATES(x) ((x) << S_TRCKEEPDUPLICATES) +#define F_TRCKEEPDUPLICATES V_TRCKEEPDUPLICATES(1U) + +#define S_TRCEN 1 +#define V_TRCEN(x) ((x) << S_TRCEN) +#define F_TRCEN V_TRCEN(1U) + +#define S_TRCMULTIFILTER 0 +#define V_TRCMULTIFILTER(x) ((x) << S_TRCMULTIFILTER) +#define F_TRCMULTIFILTER V_TRCMULTIFILTER(1U) + +#define S_TRCMULTIRSSFILTER 5 +#define V_TRCMULTIRSSFILTER(x) ((x) << S_TRCMULTIRSSFILTER) +#define F_TRCMULTIRSSFILTER V_TRCMULTIRSSFILTER(1U) + +#define A_MPS_TRC_RSS_HASH 0x9804 +#define A_MPS_TRC_FILTER0_RSS_HASH 0x9804 +#define A_MPS_TRC_RSS_CONTROL 0x9808 + +#define S_RSSCONTROL 16 +#define M_RSSCONTROL 0xffU +#define V_RSSCONTROL(x) ((x) << S_RSSCONTROL) +#define G_RSSCONTROL(x) (((x) >> S_RSSCONTROL) & M_RSSCONTROL) + +#define S_QUEUENUMBER 0 +#define M_QUEUENUMBER 0xffffU +#define V_QUEUENUMBER(x) ((x) << S_QUEUENUMBER) +#define G_QUEUENUMBER(x) (((x) >> S_QUEUENUMBER) & M_QUEUENUMBER) + +#define A_MPS_TRC_FILTER0_RSS_CONTROL 0x9808 +#define A_MPS_TRC_FILTER_MATCH_CTL_A 0x9810 + +#define S_TFINVERTMATCH 24 +#define V_TFINVERTMATCH(x) ((x) << S_TFINVERTMATCH) +#define F_TFINVERTMATCH V_TFINVERTMATCH(1U) + +#define S_TFPKTTOOLARGE 23 +#define V_TFPKTTOOLARGE(x) ((x) << S_TFPKTTOOLARGE) +#define F_TFPKTTOOLARGE V_TFPKTTOOLARGE(1U) + +#define S_TFEN 22 +#define V_TFEN(x) ((x) << S_TFEN) +#define F_TFEN V_TFEN(1U) + +#define S_TFPORT 18 +#define M_TFPORT 0xfU +#define V_TFPORT(x) ((x) << S_TFPORT) +#define G_TFPORT(x) (((x) >> S_TFPORT) & M_TFPORT) + +#define S_TFDROP 17 +#define V_TFDROP(x) ((x) << S_TFDROP) +#define F_TFDROP V_TFDROP(1U) + +#define S_TFSOPEOPERR 16 +#define V_TFSOPEOPERR(x) ((x) << S_TFSOPEOPERR) +#define F_TFSOPEOPERR V_TFSOPEOPERR(1U) + +#define S_TFLENGTH 8 +#define M_TFLENGTH 0x1fU +#define V_TFLENGTH(x) ((x) << S_TFLENGTH) +#define G_TFLENGTH(x) (((x) >> S_TFLENGTH) & M_TFLENGTH) + +#define S_TFOFFSET 0 +#define M_TFOFFSET 0x1fU +#define V_TFOFFSET(x) ((x) << S_TFOFFSET) +#define G_TFOFFSET(x) (((x) >> S_TFOFFSET) & M_TFOFFSET) + +#define S_TFINSERTACTLEN 27 +#define V_TFINSERTACTLEN(x) ((x) << S_TFINSERTACTLEN) +#define F_TFINSERTACTLEN V_TFINSERTACTLEN(1U) + +#define S_TFINSERTTIMER 26 +#define V_TFINSERTTIMER(x) ((x) << S_TFINSERTTIMER) +#define F_TFINSERTTIMER V_TFINSERTTIMER(1U) + +#define S_T5_TFINVERTMATCH 25 +#define V_T5_TFINVERTMATCH(x) ((x) << S_T5_TFINVERTMATCH) +#define F_T5_TFINVERTMATCH V_T5_TFINVERTMATCH(1U) + +#define S_T5_TFPKTTOOLARGE 24 +#define V_T5_TFPKTTOOLARGE(x) ((x) << S_T5_TFPKTTOOLARGE) +#define F_T5_TFPKTTOOLARGE V_T5_TFPKTTOOLARGE(1U) + +#define S_T5_TFEN 23 +#define V_T5_TFEN(x) ((x) << S_T5_TFEN) +#define F_T5_TFEN V_T5_TFEN(1U) + +#define S_T5_TFPORT 18 +#define M_T5_TFPORT 0x1fU +#define V_T5_TFPORT(x) ((x) << S_T5_TFPORT) +#define G_T5_TFPORT(x) (((x) >> S_T5_TFPORT) & M_T5_TFPORT) + +#define A_MPS_TRC_FILTER_MATCH_CTL_B 0x9820 + +#define S_TFMINPKTSIZE 16 +#define M_TFMINPKTSIZE 0x1ffU +#define V_TFMINPKTSIZE(x) ((x) << S_TFMINPKTSIZE) +#define G_TFMINPKTSIZE(x) (((x) >> S_TFMINPKTSIZE) & M_TFMINPKTSIZE) + +#define S_TFCAPTUREMAX 0 +#define M_TFCAPTUREMAX 0x3fffU +#define V_TFCAPTUREMAX(x) ((x) << S_TFCAPTUREMAX) +#define G_TFCAPTUREMAX(x) (((x) >> S_TFCAPTUREMAX) & M_TFCAPTUREMAX) + +#define A_MPS_TRC_FILTER_RUNT_CTL 0x9830 + +#define S_TFRUNTSIZE 0 +#define M_TFRUNTSIZE 0x3fU +#define V_TFRUNTSIZE(x) ((x) << S_TFRUNTSIZE) +#define G_TFRUNTSIZE(x) (((x) >> S_TFRUNTSIZE) & M_TFRUNTSIZE) + +#define A_MPS_TRC_FILTER_DROP 0x9840 + +#define S_TFDROPINPCOUNT 16 +#define M_TFDROPINPCOUNT 0xffffU +#define V_TFDROPINPCOUNT(x) ((x) << S_TFDROPINPCOUNT) +#define G_TFDROPINPCOUNT(x) (((x) >> S_TFDROPINPCOUNT) & M_TFDROPINPCOUNT) + +#define S_TFDROPBUFFERCOUNT 0 +#define M_TFDROPBUFFERCOUNT 0xffffU +#define V_TFDROPBUFFERCOUNT(x) ((x) << S_TFDROPBUFFERCOUNT) +#define G_TFDROPBUFFERCOUNT(x) (((x) >> S_TFDROPBUFFERCOUNT) & M_TFDROPBUFFERCOUNT) + +#define A_MPS_TRC_PERR_INJECT 0x9850 + +#define S_TRCMEMSEL 1 +#define M_TRCMEMSEL 0xfU +#define V_TRCMEMSEL(x) ((x) << S_TRCMEMSEL) +#define G_TRCMEMSEL(x) (((x) >> S_TRCMEMSEL) & M_TRCMEMSEL) + +#define A_MPS_TRC_PERR_ENABLE 0x9854 + +#define S_MISCPERR 8 +#define V_MISCPERR(x) ((x) << S_MISCPERR) +#define F_MISCPERR V_MISCPERR(1U) + +#define S_PKTFIFO 4 +#define M_PKTFIFO 0xfU +#define V_PKTFIFO(x) ((x) << S_PKTFIFO) +#define G_PKTFIFO(x) (((x) >> S_PKTFIFO) & M_PKTFIFO) + +#define S_FILTMEM 0 +#define M_FILTMEM 0xfU +#define V_FILTMEM(x) ((x) << S_FILTMEM) +#define G_FILTMEM(x) (((x) >> S_FILTMEM) & M_FILTMEM) + +#define A_MPS_TRC_INT_ENABLE 0x9858 + +#define S_TRCPLERRENB 9 +#define V_TRCPLERRENB(x) ((x) << S_TRCPLERRENB) +#define F_TRCPLERRENB V_TRCPLERRENB(1U) + +#define A_MPS_TRC_INT_CAUSE 0x985c +#define A_MPS_TRC_TIMESTAMP_L 0x9860 +#define A_MPS_TRC_TIMESTAMP_H 0x9864 +#define A_MPS_TRC_FILTER0_MATCH 0x9c00 +#define A_MPS_TRC_FILTER0_DONT_CARE 0x9c80 +#define A_MPS_TRC_FILTER1_MATCH 0x9d00 +#define A_MPS_TRC_FILTER1_DONT_CARE 0x9d80 +#define A_MPS_TRC_FILTER2_MATCH 0x9e00 +#define A_MPS_TRC_FILTER2_DONT_CARE 0x9e80 +#define A_MPS_TRC_FILTER3_MATCH 0x9f00 +#define A_MPS_TRC_FILTER3_DONT_CARE 0x9f80 +#define A_MPS_TRC_FILTER1_RSS_HASH 0x9ff0 +#define A_MPS_TRC_FILTER1_RSS_CONTROL 0x9ff4 +#define A_MPS_TRC_FILTER2_RSS_HASH 0x9ff8 +#define A_MPS_TRC_FILTER2_RSS_CONTROL 0x9ffc +#define A_MPS_TRC_FILTER3_RSS_HASH 0xa000 +#define A_MPS_TRC_FILTER3_RSS_CONTROL 0xa004 +#define A_MPS_T5_TRC_RSS_HASH 0xa008 +#define A_MPS_T5_TRC_RSS_CONTROL 0xa00c +#define A_MPS_TRC_VF_OFF_FILTER_0 0xa010 + +#define S_TRCMPS2TP_MACONLY 20 +#define V_TRCMPS2TP_MACONLY(x) ((x) << S_TRCMPS2TP_MACONLY) +#define F_TRCMPS2TP_MACONLY V_TRCMPS2TP_MACONLY(1U) + +#define S_TRCALLMPS2TP 19 +#define V_TRCALLMPS2TP(x) ((x) << S_TRCALLMPS2TP) +#define F_TRCALLMPS2TP V_TRCALLMPS2TP(1U) + +#define S_TRCALLTP2MPS 18 +#define V_TRCALLTP2MPS(x) ((x) << S_TRCALLTP2MPS) +#define F_TRCALLTP2MPS V_TRCALLTP2MPS(1U) + +#define S_TRCALLVF 17 +#define V_TRCALLVF(x) ((x) << S_TRCALLVF) +#define F_TRCALLVF V_TRCALLVF(1U) + +#define S_TRC_OFLD_EN 16 +#define V_TRC_OFLD_EN(x) ((x) << S_TRC_OFLD_EN) +#define F_TRC_OFLD_EN V_TRC_OFLD_EN(1U) + +#define S_VFFILTEN 15 +#define V_VFFILTEN(x) ((x) << S_VFFILTEN) +#define F_VFFILTEN V_VFFILTEN(1U) + +#define S_VFFILTMASK 8 +#define M_VFFILTMASK 0x7fU +#define V_VFFILTMASK(x) ((x) << S_VFFILTMASK) +#define G_VFFILTMASK(x) (((x) >> S_VFFILTMASK) & M_VFFILTMASK) + +#define S_VFFILTVALID 7 +#define V_VFFILTVALID(x) ((x) << S_VFFILTVALID) +#define F_VFFILTVALID V_VFFILTVALID(1U) + +#define S_VFFILTDATA 0 +#define M_VFFILTDATA 0x7fU +#define V_VFFILTDATA(x) ((x) << S_VFFILTDATA) +#define G_VFFILTDATA(x) (((x) >> S_VFFILTDATA) & M_VFFILTDATA) + +#define A_MPS_TRC_VF_OFF_FILTER_1 0xa014 +#define A_MPS_TRC_VF_OFF_FILTER_2 0xa018 +#define A_MPS_TRC_VF_OFF_FILTER_3 0xa01c +#define A_MPS_TRC_CGEN 0xa020 + +#define S_MPSTRCCGEN 0 +#define M_MPSTRCCGEN 0xfU +#define V_MPSTRCCGEN(x) ((x) << S_MPSTRCCGEN) +#define G_MPSTRCCGEN(x) (((x) >> S_MPSTRCCGEN) & M_MPSTRCCGEN) + +#define A_MPS_CLS_CTL 0xd000 + +#define S_MEMWRITEFAULT 4 +#define V_MEMWRITEFAULT(x) ((x) << S_MEMWRITEFAULT) +#define F_MEMWRITEFAULT V_MEMWRITEFAULT(1U) + +#define S_MEMWRITEWAITING 3 +#define V_MEMWRITEWAITING(x) ((x) << S_MEMWRITEWAITING) +#define F_MEMWRITEWAITING V_MEMWRITEWAITING(1U) + +#define S_CIMNOPROMISCUOUS 2 +#define V_CIMNOPROMISCUOUS(x) ((x) << S_CIMNOPROMISCUOUS) +#define F_CIMNOPROMISCUOUS V_CIMNOPROMISCUOUS(1U) + +#define S_HYPERVISORONLY 1 +#define V_HYPERVISORONLY(x) ((x) << S_HYPERVISORONLY) +#define F_HYPERVISORONLY V_HYPERVISORONLY(1U) + +#define S_VLANCLSEN 0 +#define V_VLANCLSEN(x) ((x) << S_VLANCLSEN) +#define F_VLANCLSEN V_VLANCLSEN(1U) + +#define A_MPS_CLS_ARB_WEIGHT 0xd004 + +#define S_PLWEIGHT 16 +#define M_PLWEIGHT 0x1fU +#define V_PLWEIGHT(x) ((x) << S_PLWEIGHT) +#define G_PLWEIGHT(x) (((x) >> S_PLWEIGHT) & M_PLWEIGHT) + +#define S_CIMWEIGHT 8 +#define M_CIMWEIGHT 0x1fU +#define V_CIMWEIGHT(x) ((x) << S_CIMWEIGHT) +#define G_CIMWEIGHT(x) (((x) >> S_CIMWEIGHT) & M_CIMWEIGHT) + +#define S_LPBKWEIGHT 0 +#define M_LPBKWEIGHT 0x1fU +#define V_LPBKWEIGHT(x) ((x) << S_LPBKWEIGHT) +#define G_LPBKWEIGHT(x) (((x) >> S_LPBKWEIGHT) & M_LPBKWEIGHT) + +#define A_MPS_CLS_BMC_MAC_ADDR_L 0xd010 +#define A_MPS_CLS_BMC_MAC_ADDR_H 0xd014 +#define A_MPS_CLS_BMC_VLAN 0xd018 +#define A_MPS_CLS_PERR_INJECT 0xd01c + +#define S_CLS_MEMSEL 1 +#define M_CLS_MEMSEL 0x3U +#define V_CLS_MEMSEL(x) ((x) << S_CLS_MEMSEL) +#define G_CLS_MEMSEL(x) (((x) >> S_CLS_MEMSEL) & M_CLS_MEMSEL) + +#define A_MPS_CLS_PERR_ENABLE 0xd020 + +#define S_HASHSRAM 2 +#define V_HASHSRAM(x) ((x) << S_HASHSRAM) +#define F_HASHSRAM V_HASHSRAM(1U) + +#define S_MATCHTCAM 1 +#define V_MATCHTCAM(x) ((x) << S_MATCHTCAM) +#define F_MATCHTCAM V_MATCHTCAM(1U) + +#define S_MATCHSRAM 0 +#define V_MATCHSRAM(x) ((x) << S_MATCHSRAM) +#define F_MATCHSRAM V_MATCHSRAM(1U) + +#define A_MPS_CLS_INT_ENABLE 0xd024 + +#define S_PLERRENB 3 +#define V_PLERRENB(x) ((x) << S_PLERRENB) +#define F_PLERRENB V_PLERRENB(1U) + +#define A_MPS_CLS_INT_CAUSE 0xd028 +#define A_MPS_CLS_PL_TEST_DATA_L 0xd02c +#define A_MPS_CLS_PL_TEST_DATA_H 0xd030 +#define A_MPS_CLS_PL_TEST_RES_DATA 0xd034 + +#define S_CLS_PRIORITY 24 +#define M_CLS_PRIORITY 0x7U +#define V_CLS_PRIORITY(x) ((x) << S_CLS_PRIORITY) +#define G_CLS_PRIORITY(x) (((x) >> S_CLS_PRIORITY) & M_CLS_PRIORITY) + +#define S_CLS_REPLICATE 23 +#define V_CLS_REPLICATE(x) ((x) << S_CLS_REPLICATE) +#define F_CLS_REPLICATE V_CLS_REPLICATE(1U) + +#define S_CLS_INDEX 14 +#define M_CLS_INDEX 0x1ffU +#define V_CLS_INDEX(x) ((x) << S_CLS_INDEX) +#define G_CLS_INDEX(x) (((x) >> S_CLS_INDEX) & M_CLS_INDEX) + +#define S_CLS_VF 7 +#define M_CLS_VF 0x7fU +#define V_CLS_VF(x) ((x) << S_CLS_VF) +#define G_CLS_VF(x) (((x) >> S_CLS_VF) & M_CLS_VF) + +#define S_CLS_VF_VLD 6 +#define V_CLS_VF_VLD(x) ((x) << S_CLS_VF_VLD) +#define F_CLS_VF_VLD V_CLS_VF_VLD(1U) + +#define S_CLS_PF 3 +#define M_CLS_PF 0x7U +#define V_CLS_PF(x) ((x) << S_CLS_PF) +#define G_CLS_PF(x) (((x) >> S_CLS_PF) & M_CLS_PF) + +#define S_CLS_MATCH 0 +#define M_CLS_MATCH 0x7U +#define V_CLS_MATCH(x) ((x) << S_CLS_MATCH) +#define G_CLS_MATCH(x) (((x) >> S_CLS_MATCH) & M_CLS_MATCH) + +#define A_MPS_CLS_PL_TEST_CTL 0xd038 + +#define S_PLTESTCTL 0 +#define V_PLTESTCTL(x) ((x) << S_PLTESTCTL) +#define F_PLTESTCTL V_PLTESTCTL(1U) + +#define A_MPS_CLS_PORT_BMC_CTL 0xd03c + +#define S_PRTBMCCTL 0 +#define V_PRTBMCCTL(x) ((x) << S_PRTBMCCTL) +#define F_PRTBMCCTL V_PRTBMCCTL(1U) + +#define A_MPS_CLS_VLAN_TABLE 0xdfc0 + +#define S_VLAN_MASK 16 +#define M_VLAN_MASK 0xfffU +#define V_VLAN_MASK(x) ((x) << S_VLAN_MASK) +#define G_VLAN_MASK(x) (((x) >> S_VLAN_MASK) & M_VLAN_MASK) + +#define S_VLANPF 13 +#define M_VLANPF 0x7U +#define V_VLANPF(x) ((x) << S_VLANPF) +#define G_VLANPF(x) (((x) >> S_VLANPF) & M_VLANPF) + +#define S_VLAN_VALID 12 +#define V_VLAN_VALID(x) ((x) << S_VLAN_VALID) +#define F_VLAN_VALID V_VLAN_VALID(1U) + +#define A_MPS_CLS_SRAM_L 0xe000 + +#define S_MULTILISTEN3 28 +#define V_MULTILISTEN3(x) ((x) << S_MULTILISTEN3) +#define F_MULTILISTEN3 V_MULTILISTEN3(1U) + +#define S_MULTILISTEN2 27 +#define V_MULTILISTEN2(x) ((x) << S_MULTILISTEN2) +#define F_MULTILISTEN2 V_MULTILISTEN2(1U) + +#define S_MULTILISTEN1 26 +#define V_MULTILISTEN1(x) ((x) << S_MULTILISTEN1) +#define F_MULTILISTEN1 V_MULTILISTEN1(1U) + +#define S_MULTILISTEN0 25 +#define V_MULTILISTEN0(x) ((x) << S_MULTILISTEN0) +#define F_MULTILISTEN0 V_MULTILISTEN0(1U) + +#define S_SRAM_PRIO3 22 +#define M_SRAM_PRIO3 0x7U +#define V_SRAM_PRIO3(x) ((x) << S_SRAM_PRIO3) +#define G_SRAM_PRIO3(x) (((x) >> S_SRAM_PRIO3) & M_SRAM_PRIO3) + +#define S_SRAM_PRIO2 19 +#define M_SRAM_PRIO2 0x7U +#define V_SRAM_PRIO2(x) ((x) << S_SRAM_PRIO2) +#define G_SRAM_PRIO2(x) (((x) >> S_SRAM_PRIO2) & M_SRAM_PRIO2) + +#define S_SRAM_PRIO1 16 +#define M_SRAM_PRIO1 0x7U +#define V_SRAM_PRIO1(x) ((x) << S_SRAM_PRIO1) +#define G_SRAM_PRIO1(x) (((x) >> S_SRAM_PRIO1) & M_SRAM_PRIO1) + +#define S_SRAM_PRIO0 13 +#define M_SRAM_PRIO0 0x7U +#define V_SRAM_PRIO0(x) ((x) << S_SRAM_PRIO0) +#define G_SRAM_PRIO0(x) (((x) >> S_SRAM_PRIO0) & M_SRAM_PRIO0) + +#define S_SRAM_VLD 12 +#define V_SRAM_VLD(x) ((x) << S_SRAM_VLD) +#define F_SRAM_VLD V_SRAM_VLD(1U) + +#define A_MPS_T5_CLS_SRAM_L 0xe000 +#define A_MPS_CLS_SRAM_H 0xe004 + +#define S_MACPARITY1 9 +#define V_MACPARITY1(x) ((x) << S_MACPARITY1) +#define F_MACPARITY1 V_MACPARITY1(1U) + +#define S_MACPARITY0 8 +#define V_MACPARITY0(x) ((x) << S_MACPARITY0) +#define F_MACPARITY0 V_MACPARITY0(1U) + +#define S_MACPARITYMASKSIZE 4 +#define M_MACPARITYMASKSIZE 0xfU +#define V_MACPARITYMASKSIZE(x) ((x) << S_MACPARITYMASKSIZE) +#define G_MACPARITYMASKSIZE(x) (((x) >> S_MACPARITYMASKSIZE) & M_MACPARITYMASKSIZE) + +#define S_PORTMAP 0 +#define M_PORTMAP 0xfU +#define V_PORTMAP(x) ((x) << S_PORTMAP) +#define G_PORTMAP(x) (((x) >> S_PORTMAP) & M_PORTMAP) + +#define A_MPS_T5_CLS_SRAM_H 0xe004 +#define A_MPS_CLS_TCAM_Y_L 0xf000 +#define A_MPS_CLS_TCAM_Y_H 0xf004 + +#define S_TCAMYH 0 +#define M_TCAMYH 0xffffU +#define V_TCAMYH(x) ((x) << S_TCAMYH) +#define G_TCAMYH(x) (((x) >> S_TCAMYH) & M_TCAMYH) + +#define A_MPS_CLS_TCAM_X_L 0xf008 +#define A_MPS_CLS_TCAM_X_H 0xf00c + +#define S_TCAMXH 0 +#define M_TCAMXH 0xffffU +#define V_TCAMXH(x) ((x) << S_TCAMXH) +#define G_TCAMXH(x) (((x) >> S_TCAMXH) & M_TCAMXH) + +#define A_MPS_RX_CTL 0x11000 + +#define S_FILT_VLAN_SEL 17 +#define V_FILT_VLAN_SEL(x) ((x) << S_FILT_VLAN_SEL) +#define F_FILT_VLAN_SEL V_FILT_VLAN_SEL(1U) + +#define S_CBA_EN 16 +#define V_CBA_EN(x) ((x) << S_CBA_EN) +#define F_CBA_EN V_CBA_EN(1U) + +#define S_BLK_SNDR 12 +#define M_BLK_SNDR 0xfU +#define V_BLK_SNDR(x) ((x) << S_BLK_SNDR) +#define G_BLK_SNDR(x) (((x) >> S_BLK_SNDR) & M_BLK_SNDR) + +#define S_CMPRS 8 +#define M_CMPRS 0xfU +#define V_CMPRS(x) ((x) << S_CMPRS) +#define G_CMPRS(x) (((x) >> S_CMPRS) & M_CMPRS) + +#define S_SNF 0 +#define M_SNF 0xffU +#define V_SNF(x) ((x) << S_SNF) +#define G_SNF(x) (((x) >> S_SNF) & M_SNF) + +#define A_MPS_RX_PORT_MUX_CTL 0x11004 + +#define S_CTL_P3 12 +#define M_CTL_P3 0xfU +#define V_CTL_P3(x) ((x) << S_CTL_P3) +#define G_CTL_P3(x) (((x) >> S_CTL_P3) & M_CTL_P3) + +#define S_CTL_P2 8 +#define M_CTL_P2 0xfU +#define V_CTL_P2(x) ((x) << S_CTL_P2) +#define G_CTL_P2(x) (((x) >> S_CTL_P2) & M_CTL_P2) + +#define S_CTL_P1 4 +#define M_CTL_P1 0xfU +#define V_CTL_P1(x) ((x) << S_CTL_P1) +#define G_CTL_P1(x) (((x) >> S_CTL_P1) & M_CTL_P1) + +#define S_CTL_P0 0 +#define M_CTL_P0 0xfU +#define V_CTL_P0(x) ((x) << S_CTL_P0) +#define G_CTL_P0(x) (((x) >> S_CTL_P0) & M_CTL_P0) + +#define A_MPS_RX_PG_FL 0x11008 + +#define S_RST 16 +#define V_RST(x) ((x) << S_RST) +#define F_RST V_RST(1U) + +#define S_CNT 0 +#define M_CNT 0xffffU +#define V_CNT(x) ((x) << S_CNT) +#define G_CNT(x) (((x) >> S_CNT) & M_CNT) + +#define A_MPS_RX_PKT_FL 0x1100c +#define A_MPS_RX_PG_RSV0 0x11010 + +#define S_CLR_INTR 31 +#define V_CLR_INTR(x) ((x) << S_CLR_INTR) +#define F_CLR_INTR V_CLR_INTR(1U) + +#define S_SET_INTR 30 +#define V_SET_INTR(x) ((x) << S_SET_INTR) +#define F_SET_INTR V_SET_INTR(1U) + +#define S_USED 16 +#define M_USED 0x7ffU +#define V_USED(x) ((x) << S_USED) +#define G_USED(x) (((x) >> S_USED) & M_USED) + +#define S_ALLOC 0 +#define M_ALLOC 0x7ffU +#define V_ALLOC(x) ((x) << S_ALLOC) +#define G_ALLOC(x) (((x) >> S_ALLOC) & M_ALLOC) + +#define S_T5_USED 16 +#define M_T5_USED 0xfffU +#define V_T5_USED(x) ((x) << S_T5_USED) +#define G_T5_USED(x) (((x) >> S_T5_USED) & M_T5_USED) + +#define S_T5_ALLOC 0 +#define M_T5_ALLOC 0xfffU +#define V_T5_ALLOC(x) ((x) << S_T5_ALLOC) +#define G_T5_ALLOC(x) (((x) >> S_T5_ALLOC) & M_T5_ALLOC) + +#define A_MPS_RX_PG_RSV1 0x11014 +#define A_MPS_RX_PG_RSV2 0x11018 +#define A_MPS_RX_PG_RSV3 0x1101c +#define A_MPS_RX_PG_RSV4 0x11020 +#define A_MPS_RX_PG_RSV5 0x11024 +#define A_MPS_RX_PG_RSV6 0x11028 +#define A_MPS_RX_PG_RSV7 0x1102c +#define A_MPS_RX_PG_SHR_BG0 0x11030 + +#define S_EN 31 +#define V_EN(x) ((x) << S_EN) +#define F_EN V_EN(1U) + +#define S_SEL 30 +#define V_SEL(x) ((x) << S_SEL) +#define F_SEL V_SEL(1U) + +#define S_MAX 16 +#define M_MAX 0x7ffU +#define V_MAX(x) ((x) << S_MAX) +#define G_MAX(x) (((x) >> S_MAX) & M_MAX) + +#define S_BORW 0 +#define M_BORW 0x7ffU +#define V_BORW(x) ((x) << S_BORW) +#define G_BORW(x) (((x) >> S_BORW) & M_BORW) + +#define S_T5_MAX 16 +#define M_T5_MAX 0xfffU +#define V_T5_MAX(x) ((x) << S_T5_MAX) +#define G_T5_MAX(x) (((x) >> S_T5_MAX) & M_T5_MAX) + +#define S_T5_BORW 0 +#define M_T5_BORW 0xfffU +#define V_T5_BORW(x) ((x) << S_T5_BORW) +#define G_T5_BORW(x) (((x) >> S_T5_BORW) & M_T5_BORW) + +#define A_MPS_RX_PG_SHR_BG1 0x11034 +#define A_MPS_RX_PG_SHR_BG2 0x11038 +#define A_MPS_RX_PG_SHR_BG3 0x1103c +#define A_MPS_RX_PG_SHR0 0x11040 + +#define S_QUOTA 16 +#define M_QUOTA 0x7ffU +#define V_QUOTA(x) ((x) << S_QUOTA) +#define G_QUOTA(x) (((x) >> S_QUOTA) & M_QUOTA) + +#define S_SHR_USED 0 +#define M_SHR_USED 0x7ffU +#define V_SHR_USED(x) ((x) << S_SHR_USED) +#define G_SHR_USED(x) (((x) >> S_SHR_USED) & M_SHR_USED) + +#define S_T5_QUOTA 16 +#define M_T5_QUOTA 0xfffU +#define V_T5_QUOTA(x) ((x) << S_T5_QUOTA) +#define G_T5_QUOTA(x) (((x) >> S_T5_QUOTA) & M_T5_QUOTA) + +#define S_T5_SHR_USED 0 +#define M_T5_SHR_USED 0xfffU +#define V_T5_SHR_USED(x) ((x) << S_T5_SHR_USED) +#define G_T5_SHR_USED(x) (((x) >> S_T5_SHR_USED) & M_T5_SHR_USED) + +#define A_MPS_RX_PG_SHR1 0x11044 +#define A_MPS_RX_PG_HYST_BG0 0x11048 + +#define S_TH 0 +#define M_TH 0x7ffU +#define V_TH(x) ((x) << S_TH) +#define G_TH(x) (((x) >> S_TH) & M_TH) + +#define S_T5_TH 0 +#define M_T5_TH 0xfffU +#define V_T5_TH(x) ((x) << S_T5_TH) +#define G_T5_TH(x) (((x) >> S_T5_TH) & M_T5_TH) + +#define A_MPS_RX_PG_HYST_BG1 0x1104c +#define A_MPS_RX_PG_HYST_BG2 0x11050 +#define A_MPS_RX_PG_HYST_BG3 0x11054 +#define A_MPS_RX_OCH_CTL 0x11058 + +#define S_DROP_WT 27 +#define M_DROP_WT 0x1fU +#define V_DROP_WT(x) ((x) << S_DROP_WT) +#define G_DROP_WT(x) (((x) >> S_DROP_WT) & M_DROP_WT) + +#define S_TRUNC_WT 22 +#define M_TRUNC_WT 0x1fU +#define V_TRUNC_WT(x) ((x) << S_TRUNC_WT) +#define G_TRUNC_WT(x) (((x) >> S_TRUNC_WT) & M_TRUNC_WT) + +#define S_OCH_DRAIN 13 +#define M_OCH_DRAIN 0x1fU +#define V_OCH_DRAIN(x) ((x) << S_OCH_DRAIN) +#define G_OCH_DRAIN(x) (((x) >> S_OCH_DRAIN) & M_OCH_DRAIN) + +#define S_OCH_DROP 8 +#define M_OCH_DROP 0x1fU +#define V_OCH_DROP(x) ((x) << S_OCH_DROP) +#define G_OCH_DROP(x) (((x) >> S_OCH_DROP) & M_OCH_DROP) + +#define S_STOP 0 +#define M_STOP 0x1fU +#define V_STOP(x) ((x) << S_STOP) +#define G_STOP(x) (((x) >> S_STOP) & M_STOP) + +#define A_MPS_RX_LPBK_BP0 0x1105c + +#define S_THRESH 0 +#define M_THRESH 0x7ffU +#define V_THRESH(x) ((x) << S_THRESH) +#define G_THRESH(x) (((x) >> S_THRESH) & M_THRESH) + +#define A_MPS_RX_LPBK_BP1 0x11060 +#define A_MPS_RX_LPBK_BP2 0x11064 +#define A_MPS_RX_LPBK_BP3 0x11068 +#define A_MPS_RX_PORT_GAP 0x1106c + +#define S_GAP 0 +#define M_GAP 0xfffffU +#define V_GAP(x) ((x) << S_GAP) +#define G_GAP(x) (((x) >> S_GAP) & M_GAP) + +#define A_MPS_RX_CHMN_CNT 0x11070 +#define A_MPS_RX_PERR_INT_CAUSE 0x11074 + +#define S_FF 23 +#define V_FF(x) ((x) << S_FF) +#define F_FF V_FF(1U) + +#define S_PGMO 22 +#define V_PGMO(x) ((x) << S_PGMO) +#define F_PGMO V_PGMO(1U) + +#define S_PGME 21 +#define V_PGME(x) ((x) << S_PGME) +#define F_PGME V_PGME(1U) + +#define S_CHMN 20 +#define V_CHMN(x) ((x) << S_CHMN) +#define F_CHMN V_CHMN(1U) + +#define S_RPLC 19 +#define V_RPLC(x) ((x) << S_RPLC) +#define F_RPLC V_RPLC(1U) + +#define S_ATRB 18 +#define V_ATRB(x) ((x) << S_ATRB) +#define F_ATRB V_ATRB(1U) + +#define S_PSMX 17 +#define V_PSMX(x) ((x) << S_PSMX) +#define F_PSMX V_PSMX(1U) + +#define S_PGLL 16 +#define V_PGLL(x) ((x) << S_PGLL) +#define F_PGLL V_PGLL(1U) + +#define S_PGFL 15 +#define V_PGFL(x) ((x) << S_PGFL) +#define F_PGFL V_PGFL(1U) + +#define S_PKTQ 14 +#define V_PKTQ(x) ((x) << S_PKTQ) +#define F_PKTQ V_PKTQ(1U) + +#define S_PKFL 13 +#define V_PKFL(x) ((x) << S_PKFL) +#define F_PKFL V_PKFL(1U) + +#define S_PPM3 12 +#define V_PPM3(x) ((x) << S_PPM3) +#define F_PPM3 V_PPM3(1U) + +#define S_PPM2 11 +#define V_PPM2(x) ((x) << S_PPM2) +#define F_PPM2 V_PPM2(1U) + +#define S_PPM1 10 +#define V_PPM1(x) ((x) << S_PPM1) +#define F_PPM1 V_PPM1(1U) + +#define S_PPM0 9 +#define V_PPM0(x) ((x) << S_PPM0) +#define F_PPM0 V_PPM0(1U) + +#define S_SPMX 8 +#define V_SPMX(x) ((x) << S_SPMX) +#define F_SPMX V_SPMX(1U) + +#define S_CDL3 7 +#define V_CDL3(x) ((x) << S_CDL3) +#define F_CDL3 V_CDL3(1U) + +#define S_CDL2 6 +#define V_CDL2(x) ((x) << S_CDL2) +#define F_CDL2 V_CDL2(1U) + +#define S_CDL1 5 +#define V_CDL1(x) ((x) << S_CDL1) +#define F_CDL1 V_CDL1(1U) + +#define S_CDL0 4 +#define V_CDL0(x) ((x) << S_CDL0) +#define F_CDL0 V_CDL0(1U) + +#define S_CDM3 3 +#define V_CDM3(x) ((x) << S_CDM3) +#define F_CDM3 V_CDM3(1U) + +#define S_CDM2 2 +#define V_CDM2(x) ((x) << S_CDM2) +#define F_CDM2 V_CDM2(1U) + +#define S_CDM1 1 +#define V_CDM1(x) ((x) << S_CDM1) +#define F_CDM1 V_CDM1(1U) + +#define S_CDM0 0 +#define V_CDM0(x) ((x) << S_CDM0) +#define F_CDM0 V_CDM0(1U) + +#define A_MPS_RX_PERR_INT_ENABLE 0x11078 +#define A_MPS_RX_PERR_ENABLE 0x1107c +#define A_MPS_RX_PERR_INJECT 0x11080 +#define A_MPS_RX_FUNC_INT_CAUSE 0x11084 + +#define S_INT_ERR_INT 8 +#define M_INT_ERR_INT 0x1fU +#define V_INT_ERR_INT(x) ((x) << S_INT_ERR_INT) +#define G_INT_ERR_INT(x) (((x) >> S_INT_ERR_INT) & M_INT_ERR_INT) + +#define S_PG_TH_INT7 7 +#define V_PG_TH_INT7(x) ((x) << S_PG_TH_INT7) +#define F_PG_TH_INT7 V_PG_TH_INT7(1U) + +#define S_PG_TH_INT6 6 +#define V_PG_TH_INT6(x) ((x) << S_PG_TH_INT6) +#define F_PG_TH_INT6 V_PG_TH_INT6(1U) + +#define S_PG_TH_INT5 5 +#define V_PG_TH_INT5(x) ((x) << S_PG_TH_INT5) +#define F_PG_TH_INT5 V_PG_TH_INT5(1U) + +#define S_PG_TH_INT4 4 +#define V_PG_TH_INT4(x) ((x) << S_PG_TH_INT4) +#define F_PG_TH_INT4 V_PG_TH_INT4(1U) + +#define S_PG_TH_INT3 3 +#define V_PG_TH_INT3(x) ((x) << S_PG_TH_INT3) +#define F_PG_TH_INT3 V_PG_TH_INT3(1U) + +#define S_PG_TH_INT2 2 +#define V_PG_TH_INT2(x) ((x) << S_PG_TH_INT2) +#define F_PG_TH_INT2 V_PG_TH_INT2(1U) + +#define S_PG_TH_INT1 1 +#define V_PG_TH_INT1(x) ((x) << S_PG_TH_INT1) +#define F_PG_TH_INT1 V_PG_TH_INT1(1U) + +#define S_PG_TH_INT0 0 +#define V_PG_TH_INT0(x) ((x) << S_PG_TH_INT0) +#define F_PG_TH_INT0 V_PG_TH_INT0(1U) + +#define S_MTU_ERR_INT3 19 +#define V_MTU_ERR_INT3(x) ((x) << S_MTU_ERR_INT3) +#define F_MTU_ERR_INT3 V_MTU_ERR_INT3(1U) + +#define S_MTU_ERR_INT2 18 +#define V_MTU_ERR_INT2(x) ((x) << S_MTU_ERR_INT2) +#define F_MTU_ERR_INT2 V_MTU_ERR_INT2(1U) + +#define S_MTU_ERR_INT1 17 +#define V_MTU_ERR_INT1(x) ((x) << S_MTU_ERR_INT1) +#define F_MTU_ERR_INT1 V_MTU_ERR_INT1(1U) + +#define S_MTU_ERR_INT0 16 +#define V_MTU_ERR_INT0(x) ((x) << S_MTU_ERR_INT0) +#define F_MTU_ERR_INT0 V_MTU_ERR_INT0(1U) + +#define S_SE_CNT_ERR_INT 15 +#define V_SE_CNT_ERR_INT(x) ((x) << S_SE_CNT_ERR_INT) +#define F_SE_CNT_ERR_INT V_SE_CNT_ERR_INT(1U) + +#define S_FRM_ERR_INT 14 +#define V_FRM_ERR_INT(x) ((x) << S_FRM_ERR_INT) +#define F_FRM_ERR_INT V_FRM_ERR_INT(1U) + +#define S_LEN_ERR_INT 13 +#define V_LEN_ERR_INT(x) ((x) << S_LEN_ERR_INT) +#define F_LEN_ERR_INT V_LEN_ERR_INT(1U) + +#define A_MPS_RX_FUNC_INT_ENABLE 0x11088 +#define A_MPS_RX_PAUSE_GEN_TH_0 0x1108c + +#define S_TH_HIGH 16 +#define M_TH_HIGH 0xffffU +#define V_TH_HIGH(x) ((x) << S_TH_HIGH) +#define G_TH_HIGH(x) (((x) >> S_TH_HIGH) & M_TH_HIGH) + +#define S_TH_LOW 0 +#define M_TH_LOW 0xffffU +#define V_TH_LOW(x) ((x) << S_TH_LOW) +#define G_TH_LOW(x) (((x) >> S_TH_LOW) & M_TH_LOW) + +#define A_MPS_RX_PAUSE_GEN_TH_1 0x11090 +#define A_MPS_RX_PAUSE_GEN_TH_2 0x11094 +#define A_MPS_RX_PAUSE_GEN_TH_3 0x11098 +#define A_MPS_RX_PPP_ATRB 0x1109c + +#define S_ETYPE 16 +#define M_ETYPE 0xffffU +#define V_ETYPE(x) ((x) << S_ETYPE) +#define G_ETYPE(x) (((x) >> S_ETYPE) & M_ETYPE) + +#define S_OPCODE 0 +#define M_OPCODE 0xffffU +#define V_OPCODE(x) ((x) << S_OPCODE) +#define G_OPCODE(x) (((x) >> S_OPCODE) & M_OPCODE) + +#define A_MPS_RX_QFC0_ATRB 0x110a0 + +#define S_DA 0 +#define M_DA 0xffffU +#define V_DA(x) ((x) << S_DA) +#define G_DA(x) (((x) >> S_DA) & M_DA) + +#define A_MPS_RX_QFC1_ATRB 0x110a4 +#define A_MPS_RX_PT_ARB0 0x110a8 + +#define S_LPBK_WT 16 +#define M_LPBK_WT 0x3fffU +#define V_LPBK_WT(x) ((x) << S_LPBK_WT) +#define G_LPBK_WT(x) (((x) >> S_LPBK_WT) & M_LPBK_WT) + +#define S_MAC_WT 0 +#define M_MAC_WT 0x3fffU +#define V_MAC_WT(x) ((x) << S_MAC_WT) +#define G_MAC_WT(x) (((x) >> S_MAC_WT) & M_MAC_WT) + +#define A_MPS_RX_PT_ARB1 0x110ac +#define A_MPS_RX_PT_ARB2 0x110b0 +#define A_MPS_RX_PT_ARB3 0x110b4 +#define A_MPS_RX_PT_ARB4 0x110b8 +#define A_MPS_PF_OUT_EN 0x110bc + +#define S_OUTEN 0 +#define M_OUTEN 0xffU +#define V_OUTEN(x) ((x) << S_OUTEN) +#define G_OUTEN(x) (((x) >> S_OUTEN) & M_OUTEN) + +#define A_MPS_BMC_MTU 0x110c0 + +#define S_MTU 0 +#define M_MTU 0x3fffU +#define V_MTU(x) ((x) << S_MTU) +#define G_MTU(x) (((x) >> S_MTU) & M_MTU) + +#define A_MPS_BMC_PKT_CNT 0x110c4 +#define A_MPS_BMC_BYTE_CNT 0x110c8 +#define A_MPS_PFVF_ATRB_CTL 0x110cc + +#define S_RD_WRN 31 +#define V_RD_WRN(x) ((x) << S_RD_WRN) +#define F_RD_WRN V_RD_WRN(1U) + +#define S_PFVF 0 +#define M_PFVF 0xffU +#define V_PFVF(x) ((x) << S_PFVF) +#define G_PFVF(x) (((x) >> S_PFVF) & M_PFVF) + +#define A_MPS_PFVF_ATRB 0x110d0 + +#define S_ATTR_PF 28 +#define M_ATTR_PF 0x7U +#define V_ATTR_PF(x) ((x) << S_ATTR_PF) +#define G_ATTR_PF(x) (((x) >> S_ATTR_PF) & M_ATTR_PF) + +#define S_OFF 18 +#define V_OFF(x) ((x) << S_OFF) +#define F_OFF V_OFF(1U) + +#define S_NV_DROP 17 +#define V_NV_DROP(x) ((x) << S_NV_DROP) +#define F_NV_DROP V_NV_DROP(1U) + +#define S_ATTR_MODE 16 +#define V_ATTR_MODE(x) ((x) << S_ATTR_MODE) +#define F_ATTR_MODE V_ATTR_MODE(1U) + +#define A_MPS_PFVF_ATRB_FLTR0 0x110d4 + +#define S_VLAN_EN 16 +#define V_VLAN_EN(x) ((x) << S_VLAN_EN) +#define F_VLAN_EN V_VLAN_EN(1U) + +#define S_VLAN_ID 0 +#define M_VLAN_ID 0xfffU +#define V_VLAN_ID(x) ((x) << S_VLAN_ID) +#define G_VLAN_ID(x) (((x) >> S_VLAN_ID) & M_VLAN_ID) + +#define A_MPS_PFVF_ATRB_FLTR1 0x110d8 +#define A_MPS_PFVF_ATRB_FLTR2 0x110dc +#define A_MPS_PFVF_ATRB_FLTR3 0x110e0 +#define A_MPS_PFVF_ATRB_FLTR4 0x110e4 +#define A_MPS_PFVF_ATRB_FLTR5 0x110e8 +#define A_MPS_PFVF_ATRB_FLTR6 0x110ec +#define A_MPS_PFVF_ATRB_FLTR7 0x110f0 +#define A_MPS_PFVF_ATRB_FLTR8 0x110f4 +#define A_MPS_PFVF_ATRB_FLTR9 0x110f8 +#define A_MPS_PFVF_ATRB_FLTR10 0x110fc +#define A_MPS_PFVF_ATRB_FLTR11 0x11100 +#define A_MPS_PFVF_ATRB_FLTR12 0x11104 +#define A_MPS_PFVF_ATRB_FLTR13 0x11108 +#define A_MPS_PFVF_ATRB_FLTR14 0x1110c +#define A_MPS_PFVF_ATRB_FLTR15 0x11110 +#define A_MPS_RPLC_MAP_CTL 0x11114 + +#define S_RPLC_MAP_ADDR 0 +#define M_RPLC_MAP_ADDR 0x3ffU +#define V_RPLC_MAP_ADDR(x) ((x) << S_RPLC_MAP_ADDR) +#define G_RPLC_MAP_ADDR(x) (((x) >> S_RPLC_MAP_ADDR) & M_RPLC_MAP_ADDR) + +#define A_MPS_PF_RPLCT_MAP 0x11118 + +#define S_PF_EN 0 +#define M_PF_EN 0xffU +#define V_PF_EN(x) ((x) << S_PF_EN) +#define G_PF_EN(x) (((x) >> S_PF_EN) & M_PF_EN) + +#define A_MPS_VF_RPLCT_MAP0 0x1111c +#define A_MPS_VF_RPLCT_MAP1 0x11120 +#define A_MPS_VF_RPLCT_MAP2 0x11124 +#define A_MPS_VF_RPLCT_MAP3 0x11128 +#define A_MPS_MEM_DBG_CTL 0x1112c + +#define S_PKD 17 +#define V_PKD(x) ((x) << S_PKD) +#define F_PKD V_PKD(1U) + +#define S_PGD 16 +#define V_PGD(x) ((x) << S_PGD) +#define F_PGD V_PGD(1U) + +#define A_MPS_PKD_MEM_DATA0 0x11130 +#define A_MPS_PKD_MEM_DATA1 0x11134 +#define A_MPS_PKD_MEM_DATA2 0x11138 +#define A_MPS_PGD_MEM_DATA 0x1113c +#define A_MPS_RX_SE_CNT_ERR 0x11140 + +#define S_RX_SE_ERRMAP 0 +#define M_RX_SE_ERRMAP 0xfffffU +#define V_RX_SE_ERRMAP(x) ((x) << S_RX_SE_ERRMAP) +#define G_RX_SE_ERRMAP(x) (((x) >> S_RX_SE_ERRMAP) & M_RX_SE_ERRMAP) + +#define A_MPS_RX_SE_CNT_CLR 0x11144 +#define A_MPS_RX_SE_CNT_IN0 0x11148 + +#define S_SOP_CNT_PM 24 +#define M_SOP_CNT_PM 0xffU +#define V_SOP_CNT_PM(x) ((x) << S_SOP_CNT_PM) +#define G_SOP_CNT_PM(x) (((x) >> S_SOP_CNT_PM) & M_SOP_CNT_PM) + +#define S_EOP_CNT_PM 16 +#define M_EOP_CNT_PM 0xffU +#define V_EOP_CNT_PM(x) ((x) << S_EOP_CNT_PM) +#define G_EOP_CNT_PM(x) (((x) >> S_EOP_CNT_PM) & M_EOP_CNT_PM) + +#define S_SOP_CNT_IN 8 +#define M_SOP_CNT_IN 0xffU +#define V_SOP_CNT_IN(x) ((x) << S_SOP_CNT_IN) +#define G_SOP_CNT_IN(x) (((x) >> S_SOP_CNT_IN) & M_SOP_CNT_IN) + +#define S_EOP_CNT_IN 0 +#define M_EOP_CNT_IN 0xffU +#define V_EOP_CNT_IN(x) ((x) << S_EOP_CNT_IN) +#define G_EOP_CNT_IN(x) (((x) >> S_EOP_CNT_IN) & M_EOP_CNT_IN) + +#define A_MPS_RX_SE_CNT_IN1 0x1114c +#define A_MPS_RX_SE_CNT_IN2 0x11150 +#define A_MPS_RX_SE_CNT_IN3 0x11154 +#define A_MPS_RX_SE_CNT_IN4 0x11158 +#define A_MPS_RX_SE_CNT_IN5 0x1115c +#define A_MPS_RX_SE_CNT_IN6 0x11160 +#define A_MPS_RX_SE_CNT_IN7 0x11164 +#define A_MPS_RX_SE_CNT_OUT01 0x11168 + +#define S_SOP_CNT_1 24 +#define M_SOP_CNT_1 0xffU +#define V_SOP_CNT_1(x) ((x) << S_SOP_CNT_1) +#define G_SOP_CNT_1(x) (((x) >> S_SOP_CNT_1) & M_SOP_CNT_1) + +#define S_EOP_CNT_1 16 +#define M_EOP_CNT_1 0xffU +#define V_EOP_CNT_1(x) ((x) << S_EOP_CNT_1) +#define G_EOP_CNT_1(x) (((x) >> S_EOP_CNT_1) & M_EOP_CNT_1) + +#define S_SOP_CNT_0 8 +#define M_SOP_CNT_0 0xffU +#define V_SOP_CNT_0(x) ((x) << S_SOP_CNT_0) +#define G_SOP_CNT_0(x) (((x) >> S_SOP_CNT_0) & M_SOP_CNT_0) + +#define S_EOP_CNT_0 0 +#define M_EOP_CNT_0 0xffU +#define V_EOP_CNT_0(x) ((x) << S_EOP_CNT_0) +#define G_EOP_CNT_0(x) (((x) >> S_EOP_CNT_0) & M_EOP_CNT_0) + +#define A_MPS_RX_SE_CNT_OUT23 0x1116c + +#define S_SOP_CNT_3 24 +#define M_SOP_CNT_3 0xffU +#define V_SOP_CNT_3(x) ((x) << S_SOP_CNT_3) +#define G_SOP_CNT_3(x) (((x) >> S_SOP_CNT_3) & M_SOP_CNT_3) + +#define S_EOP_CNT_3 16 +#define M_EOP_CNT_3 0xffU +#define V_EOP_CNT_3(x) ((x) << S_EOP_CNT_3) +#define G_EOP_CNT_3(x) (((x) >> S_EOP_CNT_3) & M_EOP_CNT_3) + +#define S_SOP_CNT_2 8 +#define M_SOP_CNT_2 0xffU +#define V_SOP_CNT_2(x) ((x) << S_SOP_CNT_2) +#define G_SOP_CNT_2(x) (((x) >> S_SOP_CNT_2) & M_SOP_CNT_2) + +#define S_EOP_CNT_2 0 +#define M_EOP_CNT_2 0xffU +#define V_EOP_CNT_2(x) ((x) << S_EOP_CNT_2) +#define G_EOP_CNT_2(x) (((x) >> S_EOP_CNT_2) & M_EOP_CNT_2) + +#define A_MPS_RX_SPI_ERR 0x11170 + +#define S_LENERR 21 +#define M_LENERR 0xfU +#define V_LENERR(x) ((x) << S_LENERR) +#define G_LENERR(x) (((x) >> S_LENERR) & M_LENERR) + +#define S_SPIERR 0 +#define M_SPIERR 0x1fffffU +#define V_SPIERR(x) ((x) << S_SPIERR) +#define G_SPIERR(x) (((x) >> S_SPIERR) & M_SPIERR) + +#define A_MPS_RX_IN_BUS_STATE 0x11174 + +#define S_ST3 24 +#define M_ST3 0xffU +#define V_ST3(x) ((x) << S_ST3) +#define G_ST3(x) (((x) >> S_ST3) & M_ST3) + +#define S_ST2 16 +#define M_ST2 0xffU +#define V_ST2(x) ((x) << S_ST2) +#define G_ST2(x) (((x) >> S_ST2) & M_ST2) + +#define S_ST1 8 +#define M_ST1 0xffU +#define V_ST1(x) ((x) << S_ST1) +#define G_ST1(x) (((x) >> S_ST1) & M_ST1) + +#define S_ST0 0 +#define M_ST0 0xffU +#define V_ST0(x) ((x) << S_ST0) +#define G_ST0(x) (((x) >> S_ST0) & M_ST0) + +#define A_MPS_RX_OUT_BUS_STATE 0x11178 + +#define S_ST_NCSI 23 +#define M_ST_NCSI 0x1ffU +#define V_ST_NCSI(x) ((x) << S_ST_NCSI) +#define G_ST_NCSI(x) (((x) >> S_ST_NCSI) & M_ST_NCSI) + +#define S_ST_TP 0 +#define M_ST_TP 0x7fffffU +#define V_ST_TP(x) ((x) << S_ST_TP) +#define G_ST_TP(x) (((x) >> S_ST_TP) & M_ST_TP) + +#define A_MPS_RX_DBG_CTL 0x1117c + +#define S_OUT_DBG_CHNL 8 +#define M_OUT_DBG_CHNL 0x7U +#define V_OUT_DBG_CHNL(x) ((x) << S_OUT_DBG_CHNL) +#define G_OUT_DBG_CHNL(x) (((x) >> S_OUT_DBG_CHNL) & M_OUT_DBG_CHNL) + +#define S_DBG_PKD_QSEL 7 +#define V_DBG_PKD_QSEL(x) ((x) << S_DBG_PKD_QSEL) +#define F_DBG_PKD_QSEL V_DBG_PKD_QSEL(1U) + +#define S_DBG_CDS_INV 6 +#define V_DBG_CDS_INV(x) ((x) << S_DBG_CDS_INV) +#define F_DBG_CDS_INV V_DBG_CDS_INV(1U) + +#define S_IN_DBG_PORT 3 +#define M_IN_DBG_PORT 0x7U +#define V_IN_DBG_PORT(x) ((x) << S_IN_DBG_PORT) +#define G_IN_DBG_PORT(x) (((x) >> S_IN_DBG_PORT) & M_IN_DBG_PORT) + +#define S_IN_DBG_CHNL 0 +#define M_IN_DBG_CHNL 0x7U +#define V_IN_DBG_CHNL(x) ((x) << S_IN_DBG_CHNL) +#define G_IN_DBG_CHNL(x) (((x) >> S_IN_DBG_CHNL) & M_IN_DBG_CHNL) + +#define A_MPS_RX_CLS_DROP_CNT0 0x11180 + +#define S_LPBK_CNT0 16 +#define M_LPBK_CNT0 0xffffU +#define V_LPBK_CNT0(x) ((x) << S_LPBK_CNT0) +#define G_LPBK_CNT0(x) (((x) >> S_LPBK_CNT0) & M_LPBK_CNT0) + +#define S_MAC_CNT0 0 +#define M_MAC_CNT0 0xffffU +#define V_MAC_CNT0(x) ((x) << S_MAC_CNT0) +#define G_MAC_CNT0(x) (((x) >> S_MAC_CNT0) & M_MAC_CNT0) + +#define A_MPS_RX_CLS_DROP_CNT1 0x11184 + +#define S_LPBK_CNT1 16 +#define M_LPBK_CNT1 0xffffU +#define V_LPBK_CNT1(x) ((x) << S_LPBK_CNT1) +#define G_LPBK_CNT1(x) (((x) >> S_LPBK_CNT1) & M_LPBK_CNT1) + +#define S_MAC_CNT1 0 +#define M_MAC_CNT1 0xffffU +#define V_MAC_CNT1(x) ((x) << S_MAC_CNT1) +#define G_MAC_CNT1(x) (((x) >> S_MAC_CNT1) & M_MAC_CNT1) + +#define A_MPS_RX_CLS_DROP_CNT2 0x11188 + +#define S_LPBK_CNT2 16 +#define M_LPBK_CNT2 0xffffU +#define V_LPBK_CNT2(x) ((x) << S_LPBK_CNT2) +#define G_LPBK_CNT2(x) (((x) >> S_LPBK_CNT2) & M_LPBK_CNT2) + +#define S_MAC_CNT2 0 +#define M_MAC_CNT2 0xffffU +#define V_MAC_CNT2(x) ((x) << S_MAC_CNT2) +#define G_MAC_CNT2(x) (((x) >> S_MAC_CNT2) & M_MAC_CNT2) + +#define A_MPS_RX_CLS_DROP_CNT3 0x1118c + +#define S_LPBK_CNT3 16 +#define M_LPBK_CNT3 0xffffU +#define V_LPBK_CNT3(x) ((x) << S_LPBK_CNT3) +#define G_LPBK_CNT3(x) (((x) >> S_LPBK_CNT3) & M_LPBK_CNT3) + +#define S_MAC_CNT3 0 +#define M_MAC_CNT3 0xffffU +#define V_MAC_CNT3(x) ((x) << S_MAC_CNT3) +#define G_MAC_CNT3(x) (((x) >> S_MAC_CNT3) & M_MAC_CNT3) + +#define A_MPS_RX_SPARE 0x11190 +#define A_MPS_RX_PTP_ETYPE 0x11194 + +#define S_PETYPE2 16 +#define M_PETYPE2 0xffffU +#define V_PETYPE2(x) ((x) << S_PETYPE2) +#define G_PETYPE2(x) (((x) >> S_PETYPE2) & M_PETYPE2) + +#define S_PETYPE1 0 +#define M_PETYPE1 0xffffU +#define V_PETYPE1(x) ((x) << S_PETYPE1) +#define G_PETYPE1(x) (((x) >> S_PETYPE1) & M_PETYPE1) + +#define A_MPS_RX_PTP_TCP 0x11198 + +#define S_PTCPORT2 16 +#define M_PTCPORT2 0xffffU +#define V_PTCPORT2(x) ((x) << S_PTCPORT2) +#define G_PTCPORT2(x) (((x) >> S_PTCPORT2) & M_PTCPORT2) + +#define S_PTCPORT1 0 +#define M_PTCPORT1 0xffffU +#define V_PTCPORT1(x) ((x) << S_PTCPORT1) +#define G_PTCPORT1(x) (((x) >> S_PTCPORT1) & M_PTCPORT1) + +#define A_MPS_RX_PTP_UDP 0x1119c + +#define S_PUDPORT2 16 +#define M_PUDPORT2 0xffffU +#define V_PUDPORT2(x) ((x) << S_PUDPORT2) +#define G_PUDPORT2(x) (((x) >> S_PUDPORT2) & M_PUDPORT2) + +#define S_PUDPORT1 0 +#define M_PUDPORT1 0xffffU +#define V_PUDPORT1(x) ((x) << S_PUDPORT1) +#define G_PUDPORT1(x) (((x) >> S_PUDPORT1) & M_PUDPORT1) + +#define A_MPS_RX_PTP_CTL 0x111a0 + +#define S_MIN_PTP_SPACE 24 +#define M_MIN_PTP_SPACE 0x7fU +#define V_MIN_PTP_SPACE(x) ((x) << S_MIN_PTP_SPACE) +#define G_MIN_PTP_SPACE(x) (((x) >> S_MIN_PTP_SPACE) & M_MIN_PTP_SPACE) + +#define S_PUDP2EN 20 +#define M_PUDP2EN 0xfU +#define V_PUDP2EN(x) ((x) << S_PUDP2EN) +#define G_PUDP2EN(x) (((x) >> S_PUDP2EN) & M_PUDP2EN) + +#define S_PUDP1EN 16 +#define M_PUDP1EN 0xfU +#define V_PUDP1EN(x) ((x) << S_PUDP1EN) +#define G_PUDP1EN(x) (((x) >> S_PUDP1EN) & M_PUDP1EN) + +#define S_PTCP2EN 12 +#define M_PTCP2EN 0xfU +#define V_PTCP2EN(x) ((x) << S_PTCP2EN) +#define G_PTCP2EN(x) (((x) >> S_PTCP2EN) & M_PTCP2EN) + +#define S_PTCP1EN 8 +#define M_PTCP1EN 0xfU +#define V_PTCP1EN(x) ((x) << S_PTCP1EN) +#define G_PTCP1EN(x) (((x) >> S_PTCP1EN) & M_PTCP1EN) + +#define S_PETYPE2EN 4 +#define M_PETYPE2EN 0xfU +#define V_PETYPE2EN(x) ((x) << S_PETYPE2EN) +#define G_PETYPE2EN(x) (((x) >> S_PETYPE2EN) & M_PETYPE2EN) + +#define S_PETYPE1EN 0 +#define M_PETYPE1EN 0xfU +#define V_PETYPE1EN(x) ((x) << S_PETYPE1EN) +#define G_PETYPE1EN(x) (((x) >> S_PETYPE1EN) & M_PETYPE1EN) + +#define A_MPS_RX_PAUSE_GEN_TH_0_0 0x111a4 +#define A_MPS_RX_PAUSE_GEN_TH_0_1 0x111a8 +#define A_MPS_RX_PAUSE_GEN_TH_0_2 0x111ac +#define A_MPS_RX_PAUSE_GEN_TH_0_3 0x111b0 +#define A_MPS_RX_PAUSE_GEN_TH_1_0 0x111b4 +#define A_MPS_RX_PAUSE_GEN_TH_1_1 0x111b8 +#define A_MPS_RX_PAUSE_GEN_TH_1_2 0x111bc +#define A_MPS_RX_PAUSE_GEN_TH_1_3 0x111c0 +#define A_MPS_RX_PAUSE_GEN_TH_2_0 0x111c4 +#define A_MPS_RX_PAUSE_GEN_TH_2_1 0x111c8 +#define A_MPS_RX_PAUSE_GEN_TH_2_2 0x111cc +#define A_MPS_RX_PAUSE_GEN_TH_2_3 0x111d0 +#define A_MPS_RX_PAUSE_GEN_TH_3_0 0x111d4 +#define A_MPS_RX_PAUSE_GEN_TH_3_1 0x111d8 +#define A_MPS_RX_PAUSE_GEN_TH_3_2 0x111dc +#define A_MPS_RX_PAUSE_GEN_TH_3_3 0x111e0 +#define A_MPS_RX_MAC_CLS_DROP_CNT0 0x111e4 +#define A_MPS_RX_MAC_CLS_DROP_CNT1 0x111e8 +#define A_MPS_RX_MAC_CLS_DROP_CNT2 0x111ec +#define A_MPS_RX_MAC_CLS_DROP_CNT3 0x111f0 +#define A_MPS_RX_LPBK_CLS_DROP_CNT0 0x111f4 +#define A_MPS_RX_LPBK_CLS_DROP_CNT1 0x111f8 +#define A_MPS_RX_LPBK_CLS_DROP_CNT2 0x111fc +#define A_MPS_RX_LPBK_CLS_DROP_CNT3 0x11200 +#define A_MPS_RX_CGEN 0x11204 + +#define S_MPS_RX_CGEN_NCSI 12 +#define V_MPS_RX_CGEN_NCSI(x) ((x) << S_MPS_RX_CGEN_NCSI) +#define F_MPS_RX_CGEN_NCSI V_MPS_RX_CGEN_NCSI(1U) + +#define S_MPS_RX_CGEN_OUT 8 +#define M_MPS_RX_CGEN_OUT 0xfU +#define V_MPS_RX_CGEN_OUT(x) ((x) << S_MPS_RX_CGEN_OUT) +#define G_MPS_RX_CGEN_OUT(x) (((x) >> S_MPS_RX_CGEN_OUT) & M_MPS_RX_CGEN_OUT) + +#define S_MPS_RX_CGEN_LPBK_IN 4 +#define M_MPS_RX_CGEN_LPBK_IN 0xfU +#define V_MPS_RX_CGEN_LPBK_IN(x) ((x) << S_MPS_RX_CGEN_LPBK_IN) +#define G_MPS_RX_CGEN_LPBK_IN(x) (((x) >> S_MPS_RX_CGEN_LPBK_IN) & M_MPS_RX_CGEN_LPBK_IN) + +#define S_MPS_RX_CGEN_MAC_IN 0 +#define M_MPS_RX_CGEN_MAC_IN 0xfU +#define V_MPS_RX_CGEN_MAC_IN(x) ((x) << S_MPS_RX_CGEN_MAC_IN) +#define G_MPS_RX_CGEN_MAC_IN(x) (((x) >> S_MPS_RX_CGEN_MAC_IN) & M_MPS_RX_CGEN_MAC_IN) + +/* registers for module CPL_SWITCH */ +#define CPL_SWITCH_BASE_ADDR 0x19040 + +#define A_CPL_SWITCH_CNTRL 0x19040 + +#define S_CPL_PKT_TID 8 +#define M_CPL_PKT_TID 0xffffffU +#define V_CPL_PKT_TID(x) ((x) << S_CPL_PKT_TID) +#define G_CPL_PKT_TID(x) (((x) >> S_CPL_PKT_TID) & M_CPL_PKT_TID) + +#define S_CIM_TRUNCATE_ENABLE 5 +#define V_CIM_TRUNCATE_ENABLE(x) ((x) << S_CIM_TRUNCATE_ENABLE) +#define F_CIM_TRUNCATE_ENABLE V_CIM_TRUNCATE_ENABLE(1U) + +#define S_CIM_TO_UP_FULL_SIZE 4 +#define V_CIM_TO_UP_FULL_SIZE(x) ((x) << S_CIM_TO_UP_FULL_SIZE) +#define F_CIM_TO_UP_FULL_SIZE V_CIM_TO_UP_FULL_SIZE(1U) + +#define S_CPU_NO_ENABLE 3 +#define V_CPU_NO_ENABLE(x) ((x) << S_CPU_NO_ENABLE) +#define F_CPU_NO_ENABLE V_CPU_NO_ENABLE(1U) + +#define S_SWITCH_TABLE_ENABLE 2 +#define V_SWITCH_TABLE_ENABLE(x) ((x) << S_SWITCH_TABLE_ENABLE) +#define F_SWITCH_TABLE_ENABLE V_SWITCH_TABLE_ENABLE(1U) + +#define S_SGE_ENABLE 1 +#define V_SGE_ENABLE(x) ((x) << S_SGE_ENABLE) +#define F_SGE_ENABLE V_SGE_ENABLE(1U) + +#define S_CIM_ENABLE 0 +#define V_CIM_ENABLE(x) ((x) << S_CIM_ENABLE) +#define F_CIM_ENABLE V_CIM_ENABLE(1U) + +#define S_CIM_SPLIT_ENABLE 6 +#define V_CIM_SPLIT_ENABLE(x) ((x) << S_CIM_SPLIT_ENABLE) +#define F_CIM_SPLIT_ENABLE V_CIM_SPLIT_ENABLE(1U) + +#define A_CPL_SWITCH_TBL_IDX 0x19044 + +#define S_SWITCH_TBL_IDX 0 +#define M_SWITCH_TBL_IDX 0xfU +#define V_SWITCH_TBL_IDX(x) ((x) << S_SWITCH_TBL_IDX) +#define G_SWITCH_TBL_IDX(x) (((x) >> S_SWITCH_TBL_IDX) & M_SWITCH_TBL_IDX) + +#define A_CPL_SWITCH_TBL_DATA 0x19048 +#define A_CPL_SWITCH_ZERO_ERROR 0x1904c + +#define S_ZERO_CMD_CH1 8 +#define M_ZERO_CMD_CH1 0xffU +#define V_ZERO_CMD_CH1(x) ((x) << S_ZERO_CMD_CH1) +#define G_ZERO_CMD_CH1(x) (((x) >> S_ZERO_CMD_CH1) & M_ZERO_CMD_CH1) + +#define S_ZERO_CMD_CH0 0 +#define M_ZERO_CMD_CH0 0xffU +#define V_ZERO_CMD_CH0(x) ((x) << S_ZERO_CMD_CH0) +#define G_ZERO_CMD_CH0(x) (((x) >> S_ZERO_CMD_CH0) & M_ZERO_CMD_CH0) + +#define A_CPL_INTR_ENABLE 0x19050 + +#define S_CIM_OP_MAP_PERR 5 +#define V_CIM_OP_MAP_PERR(x) ((x) << S_CIM_OP_MAP_PERR) +#define F_CIM_OP_MAP_PERR V_CIM_OP_MAP_PERR(1U) + +#define S_CIM_OVFL_ERROR 4 +#define V_CIM_OVFL_ERROR(x) ((x) << S_CIM_OVFL_ERROR) +#define F_CIM_OVFL_ERROR V_CIM_OVFL_ERROR(1U) + +#define S_TP_FRAMING_ERROR 3 +#define V_TP_FRAMING_ERROR(x) ((x) << S_TP_FRAMING_ERROR) +#define F_TP_FRAMING_ERROR V_TP_FRAMING_ERROR(1U) + +#define S_SGE_FRAMING_ERROR 2 +#define V_SGE_FRAMING_ERROR(x) ((x) << S_SGE_FRAMING_ERROR) +#define F_SGE_FRAMING_ERROR V_SGE_FRAMING_ERROR(1U) + +#define S_CIM_FRAMING_ERROR 1 +#define V_CIM_FRAMING_ERROR(x) ((x) << S_CIM_FRAMING_ERROR) +#define F_CIM_FRAMING_ERROR V_CIM_FRAMING_ERROR(1U) + +#define S_ZERO_SWITCH_ERROR 0 +#define V_ZERO_SWITCH_ERROR(x) ((x) << S_ZERO_SWITCH_ERROR) +#define F_ZERO_SWITCH_ERROR V_ZERO_SWITCH_ERROR(1U) + +#define S_PERR_CPL_128TO128_1 7 +#define V_PERR_CPL_128TO128_1(x) ((x) << S_PERR_CPL_128TO128_1) +#define F_PERR_CPL_128TO128_1 V_PERR_CPL_128TO128_1(1U) + +#define S_PERR_CPL_128TO128_0 6 +#define V_PERR_CPL_128TO128_0(x) ((x) << S_PERR_CPL_128TO128_0) +#define F_PERR_CPL_128TO128_0 V_PERR_CPL_128TO128_0(1U) + +#define A_CPL_INTR_CAUSE 0x19054 +#define A_CPL_MAP_TBL_IDX 0x19058 + +#define S_MAP_TBL_IDX 0 +#define M_MAP_TBL_IDX 0xffU +#define V_MAP_TBL_IDX(x) ((x) << S_MAP_TBL_IDX) +#define G_MAP_TBL_IDX(x) (((x) >> S_MAP_TBL_IDX) & M_MAP_TBL_IDX) + +#define S_CIM_SPLIT_OPCODE_PROGRAM 8 +#define V_CIM_SPLIT_OPCODE_PROGRAM(x) ((x) << S_CIM_SPLIT_OPCODE_PROGRAM) +#define F_CIM_SPLIT_OPCODE_PROGRAM V_CIM_SPLIT_OPCODE_PROGRAM(1U) + +#define A_CPL_MAP_TBL_DATA 0x1905c + +#define S_MAP_TBL_DATA 0 +#define M_MAP_TBL_DATA 0xffU +#define V_MAP_TBL_DATA(x) ((x) << S_MAP_TBL_DATA) +#define G_MAP_TBL_DATA(x) (((x) >> S_MAP_TBL_DATA) & M_MAP_TBL_DATA) + +/* registers for module SMB */ +#define SMB_BASE_ADDR 0x19060 + +#define A_SMB_GLOBAL_TIME_CFG 0x19060 + +#define S_MACROCNTCFG 8 +#define M_MACROCNTCFG 0x1fU +#define V_MACROCNTCFG(x) ((x) << S_MACROCNTCFG) +#define G_MACROCNTCFG(x) (((x) >> S_MACROCNTCFG) & M_MACROCNTCFG) + +#define S_MICROCNTCFG 0 +#define M_MICROCNTCFG 0xffU +#define V_MICROCNTCFG(x) ((x) << S_MICROCNTCFG) +#define G_MICROCNTCFG(x) (((x) >> S_MICROCNTCFG) & M_MICROCNTCFG) + +#define A_SMB_MST_TIMEOUT_CFG 0x19064 + +#define S_MSTTIMEOUTCFG 0 +#define M_MSTTIMEOUTCFG 0xffffffU +#define V_MSTTIMEOUTCFG(x) ((x) << S_MSTTIMEOUTCFG) +#define G_MSTTIMEOUTCFG(x) (((x) >> S_MSTTIMEOUTCFG) & M_MSTTIMEOUTCFG) + +#define A_SMB_MST_CTL_CFG 0x19068 + +#define S_MSTFIFODBG 31 +#define V_MSTFIFODBG(x) ((x) << S_MSTFIFODBG) +#define F_MSTFIFODBG V_MSTFIFODBG(1U) + +#define S_MSTFIFODBGCLR 30 +#define V_MSTFIFODBGCLR(x) ((x) << S_MSTFIFODBGCLR) +#define F_MSTFIFODBGCLR V_MSTFIFODBGCLR(1U) + +#define S_MSTRXBYTECFG 12 +#define M_MSTRXBYTECFG 0x3fU +#define V_MSTRXBYTECFG(x) ((x) << S_MSTRXBYTECFG) +#define G_MSTRXBYTECFG(x) (((x) >> S_MSTRXBYTECFG) & M_MSTRXBYTECFG) + +#define S_MSTTXBYTECFG 6 +#define M_MSTTXBYTECFG 0x3fU +#define V_MSTTXBYTECFG(x) ((x) << S_MSTTXBYTECFG) +#define G_MSTTXBYTECFG(x) (((x) >> S_MSTTXBYTECFG) & M_MSTTXBYTECFG) + +#define S_MSTRESET 1 +#define V_MSTRESET(x) ((x) << S_MSTRESET) +#define F_MSTRESET V_MSTRESET(1U) + +#define S_MSTCTLEN 0 +#define V_MSTCTLEN(x) ((x) << S_MSTCTLEN) +#define F_MSTCTLEN V_MSTCTLEN(1U) + +#define A_SMB_MST_CTL_STS 0x1906c + +#define S_MSTRXBYTECNT 12 +#define M_MSTRXBYTECNT 0x3fU +#define V_MSTRXBYTECNT(x) ((x) << S_MSTRXBYTECNT) +#define G_MSTRXBYTECNT(x) (((x) >> S_MSTRXBYTECNT) & M_MSTRXBYTECNT) + +#define S_MSTTXBYTECNT 6 +#define M_MSTTXBYTECNT 0x3fU +#define V_MSTTXBYTECNT(x) ((x) << S_MSTTXBYTECNT) +#define G_MSTTXBYTECNT(x) (((x) >> S_MSTTXBYTECNT) & M_MSTTXBYTECNT) + +#define S_MSTBUSYSTS 0 +#define V_MSTBUSYSTS(x) ((x) << S_MSTBUSYSTS) +#define F_MSTBUSYSTS V_MSTBUSYSTS(1U) + +#define A_SMB_MST_TX_FIFO_RDWR 0x19070 +#define A_SMB_MST_RX_FIFO_RDWR 0x19074 +#define A_SMB_SLV_TIMEOUT_CFG 0x19078 + +#define S_SLVTIMEOUTCFG 0 +#define M_SLVTIMEOUTCFG 0xffffffU +#define V_SLVTIMEOUTCFG(x) ((x) << S_SLVTIMEOUTCFG) +#define G_SLVTIMEOUTCFG(x) (((x) >> S_SLVTIMEOUTCFG) & M_SLVTIMEOUTCFG) + +#define A_SMB_SLV_CTL_CFG 0x1907c + +#define S_SLVFIFODBG 31 +#define V_SLVFIFODBG(x) ((x) << S_SLVFIFODBG) +#define F_SLVFIFODBG V_SLVFIFODBG(1U) + +#define S_SLVFIFODBGCLR 30 +#define V_SLVFIFODBGCLR(x) ((x) << S_SLVFIFODBGCLR) +#define F_SLVFIFODBGCLR V_SLVFIFODBGCLR(1U) + +#define S_SLVCRCOUTBITINV 21 +#define V_SLVCRCOUTBITINV(x) ((x) << S_SLVCRCOUTBITINV) +#define F_SLVCRCOUTBITINV V_SLVCRCOUTBITINV(1U) + +#define S_SLVCRCOUTBITREV 20 +#define V_SLVCRCOUTBITREV(x) ((x) << S_SLVCRCOUTBITREV) +#define F_SLVCRCOUTBITREV V_SLVCRCOUTBITREV(1U) + +#define S_SLVCRCINBITREV 19 +#define V_SLVCRCINBITREV(x) ((x) << S_SLVCRCINBITREV) +#define F_SLVCRCINBITREV V_SLVCRCINBITREV(1U) + +#define S_SLVCRCPRESET 11 +#define M_SLVCRCPRESET 0xffU +#define V_SLVCRCPRESET(x) ((x) << S_SLVCRCPRESET) +#define G_SLVCRCPRESET(x) (((x) >> S_SLVCRCPRESET) & M_SLVCRCPRESET) + +#define S_SLVADDRCFG 4 +#define M_SLVADDRCFG 0x7fU +#define V_SLVADDRCFG(x) ((x) << S_SLVADDRCFG) +#define G_SLVADDRCFG(x) (((x) >> S_SLVADDRCFG) & M_SLVADDRCFG) + +#define S_SLVALRTSET 2 +#define V_SLVALRTSET(x) ((x) << S_SLVALRTSET) +#define F_SLVALRTSET V_SLVALRTSET(1U) + +#define S_SLVRESET 1 +#define V_SLVRESET(x) ((x) << S_SLVRESET) +#define F_SLVRESET V_SLVRESET(1U) + +#define S_SLVCTLEN 0 +#define V_SLVCTLEN(x) ((x) << S_SLVCTLEN) +#define F_SLVCTLEN V_SLVCTLEN(1U) + +#define A_SMB_SLV_CTL_STS 0x19080 + +#define S_SLVFIFOTXCNT 12 +#define M_SLVFIFOTXCNT 0x3fU +#define V_SLVFIFOTXCNT(x) ((x) << S_SLVFIFOTXCNT) +#define G_SLVFIFOTXCNT(x) (((x) >> S_SLVFIFOTXCNT) & M_SLVFIFOTXCNT) + +#define S_SLVFIFOCNT 6 +#define M_SLVFIFOCNT 0x3fU +#define V_SLVFIFOCNT(x) ((x) << S_SLVFIFOCNT) +#define G_SLVFIFOCNT(x) (((x) >> S_SLVFIFOCNT) & M_SLVFIFOCNT) + +#define S_SLVALRTSTS 2 +#define V_SLVALRTSTS(x) ((x) << S_SLVALRTSTS) +#define F_SLVALRTSTS V_SLVALRTSTS(1U) + +#define S_SLVBUSYSTS 0 +#define V_SLVBUSYSTS(x) ((x) << S_SLVBUSYSTS) +#define F_SLVBUSYSTS V_SLVBUSYSTS(1U) + +#define A_SMB_SLV_FIFO_RDWR 0x19084 +#define A_SMB_INT_ENABLE 0x1908c + +#define S_MSTTXFIFOPAREN 21 +#define V_MSTTXFIFOPAREN(x) ((x) << S_MSTTXFIFOPAREN) +#define F_MSTTXFIFOPAREN V_MSTTXFIFOPAREN(1U) + +#define S_MSTRXFIFOPAREN 20 +#define V_MSTRXFIFOPAREN(x) ((x) << S_MSTRXFIFOPAREN) +#define F_MSTRXFIFOPAREN V_MSTRXFIFOPAREN(1U) + +#define S_SLVFIFOPAREN 19 +#define V_SLVFIFOPAREN(x) ((x) << S_SLVFIFOPAREN) +#define F_SLVFIFOPAREN V_SLVFIFOPAREN(1U) + +#define S_SLVUNEXPBUSSTOPEN 18 +#define V_SLVUNEXPBUSSTOPEN(x) ((x) << S_SLVUNEXPBUSSTOPEN) +#define F_SLVUNEXPBUSSTOPEN V_SLVUNEXPBUSSTOPEN(1U) + +#define S_SLVUNEXPBUSSTARTEN 17 +#define V_SLVUNEXPBUSSTARTEN(x) ((x) << S_SLVUNEXPBUSSTARTEN) +#define F_SLVUNEXPBUSSTARTEN V_SLVUNEXPBUSSTARTEN(1U) + +#define S_SLVCOMMANDCODEINVEN 16 +#define V_SLVCOMMANDCODEINVEN(x) ((x) << S_SLVCOMMANDCODEINVEN) +#define F_SLVCOMMANDCODEINVEN V_SLVCOMMANDCODEINVEN(1U) + +#define S_SLVBYTECNTERREN 15 +#define V_SLVBYTECNTERREN(x) ((x) << S_SLVBYTECNTERREN) +#define F_SLVBYTECNTERREN V_SLVBYTECNTERREN(1U) + +#define S_SLVUNEXPACKMSTEN 14 +#define V_SLVUNEXPACKMSTEN(x) ((x) << S_SLVUNEXPACKMSTEN) +#define F_SLVUNEXPACKMSTEN V_SLVUNEXPACKMSTEN(1U) + +#define S_SLVUNEXPNACKMSTEN 13 +#define V_SLVUNEXPNACKMSTEN(x) ((x) << S_SLVUNEXPNACKMSTEN) +#define F_SLVUNEXPNACKMSTEN V_SLVUNEXPNACKMSTEN(1U) + +#define S_SLVNOBUSSTOPEN 12 +#define V_SLVNOBUSSTOPEN(x) ((x) << S_SLVNOBUSSTOPEN) +#define F_SLVNOBUSSTOPEN V_SLVNOBUSSTOPEN(1U) + +#define S_SLVNOREPSTARTEN 11 +#define V_SLVNOREPSTARTEN(x) ((x) << S_SLVNOREPSTARTEN) +#define F_SLVNOREPSTARTEN V_SLVNOREPSTARTEN(1U) + +#define S_SLVRXADDRINTEN 10 +#define V_SLVRXADDRINTEN(x) ((x) << S_SLVRXADDRINTEN) +#define F_SLVRXADDRINTEN V_SLVRXADDRINTEN(1U) + +#define S_SLVRXPECERRINTEN 9 +#define V_SLVRXPECERRINTEN(x) ((x) << S_SLVRXPECERRINTEN) +#define F_SLVRXPECERRINTEN V_SLVRXPECERRINTEN(1U) + +#define S_SLVPREPTOARPINTEN 8 +#define V_SLVPREPTOARPINTEN(x) ((x) << S_SLVPREPTOARPINTEN) +#define F_SLVPREPTOARPINTEN V_SLVPREPTOARPINTEN(1U) + +#define S_SLVTIMEOUTINTEN 7 +#define V_SLVTIMEOUTINTEN(x) ((x) << S_SLVTIMEOUTINTEN) +#define F_SLVTIMEOUTINTEN V_SLVTIMEOUTINTEN(1U) + +#define S_SLVERRINTEN 6 +#define V_SLVERRINTEN(x) ((x) << S_SLVERRINTEN) +#define F_SLVERRINTEN V_SLVERRINTEN(1U) + +#define S_SLVDONEINTEN 5 +#define V_SLVDONEINTEN(x) ((x) << S_SLVDONEINTEN) +#define F_SLVDONEINTEN V_SLVDONEINTEN(1U) + +#define S_SLVRXRDYINTEN 4 +#define V_SLVRXRDYINTEN(x) ((x) << S_SLVRXRDYINTEN) +#define F_SLVRXRDYINTEN V_SLVRXRDYINTEN(1U) + +#define S_MSTTIMEOUTINTEN 3 +#define V_MSTTIMEOUTINTEN(x) ((x) << S_MSTTIMEOUTINTEN) +#define F_MSTTIMEOUTINTEN V_MSTTIMEOUTINTEN(1U) + +#define S_MSTNACKINTEN 2 +#define V_MSTNACKINTEN(x) ((x) << S_MSTNACKINTEN) +#define F_MSTNACKINTEN V_MSTNACKINTEN(1U) + +#define S_MSTLOSTARBINTEN 1 +#define V_MSTLOSTARBINTEN(x) ((x) << S_MSTLOSTARBINTEN) +#define F_MSTLOSTARBINTEN V_MSTLOSTARBINTEN(1U) + +#define S_MSTDONEINTEN 0 +#define V_MSTDONEINTEN(x) ((x) << S_MSTDONEINTEN) +#define F_MSTDONEINTEN V_MSTDONEINTEN(1U) + +#define A_SMB_INT_CAUSE 0x19090 + +#define S_MSTTXFIFOPARINT 21 +#define V_MSTTXFIFOPARINT(x) ((x) << S_MSTTXFIFOPARINT) +#define F_MSTTXFIFOPARINT V_MSTTXFIFOPARINT(1U) + +#define S_MSTRXFIFOPARINT 20 +#define V_MSTRXFIFOPARINT(x) ((x) << S_MSTRXFIFOPARINT) +#define F_MSTRXFIFOPARINT V_MSTRXFIFOPARINT(1U) + +#define S_SLVFIFOPARINT 19 +#define V_SLVFIFOPARINT(x) ((x) << S_SLVFIFOPARINT) +#define F_SLVFIFOPARINT V_SLVFIFOPARINT(1U) + +#define S_SLVUNEXPBUSSTOPINT 18 +#define V_SLVUNEXPBUSSTOPINT(x) ((x) << S_SLVUNEXPBUSSTOPINT) +#define F_SLVUNEXPBUSSTOPINT V_SLVUNEXPBUSSTOPINT(1U) + +#define S_SLVUNEXPBUSSTARTINT 17 +#define V_SLVUNEXPBUSSTARTINT(x) ((x) << S_SLVUNEXPBUSSTARTINT) +#define F_SLVUNEXPBUSSTARTINT V_SLVUNEXPBUSSTARTINT(1U) + +#define S_SLVCOMMANDCODEINVINT 16 +#define V_SLVCOMMANDCODEINVINT(x) ((x) << S_SLVCOMMANDCODEINVINT) +#define F_SLVCOMMANDCODEINVINT V_SLVCOMMANDCODEINVINT(1U) + +#define S_SLVBYTECNTERRINT 15 +#define V_SLVBYTECNTERRINT(x) ((x) << S_SLVBYTECNTERRINT) +#define F_SLVBYTECNTERRINT V_SLVBYTECNTERRINT(1U) + +#define S_SLVUNEXPACKMSTINT 14 +#define V_SLVUNEXPACKMSTINT(x) ((x) << S_SLVUNEXPACKMSTINT) +#define F_SLVUNEXPACKMSTINT V_SLVUNEXPACKMSTINT(1U) + +#define S_SLVUNEXPNACKMSTINT 13 +#define V_SLVUNEXPNACKMSTINT(x) ((x) << S_SLVUNEXPNACKMSTINT) +#define F_SLVUNEXPNACKMSTINT V_SLVUNEXPNACKMSTINT(1U) + +#define S_SLVNOBUSSTOPINT 12 +#define V_SLVNOBUSSTOPINT(x) ((x) << S_SLVNOBUSSTOPINT) +#define F_SLVNOBUSSTOPINT V_SLVNOBUSSTOPINT(1U) + +#define S_SLVNOREPSTARTINT 11 +#define V_SLVNOREPSTARTINT(x) ((x) << S_SLVNOREPSTARTINT) +#define F_SLVNOREPSTARTINT V_SLVNOREPSTARTINT(1U) + +#define S_SLVRXADDRINT 10 +#define V_SLVRXADDRINT(x) ((x) << S_SLVRXADDRINT) +#define F_SLVRXADDRINT V_SLVRXADDRINT(1U) + +#define S_SLVRXPECERRINT 9 +#define V_SLVRXPECERRINT(x) ((x) << S_SLVRXPECERRINT) +#define F_SLVRXPECERRINT V_SLVRXPECERRINT(1U) + +#define S_SLVPREPTOARPINT 8 +#define V_SLVPREPTOARPINT(x) ((x) << S_SLVPREPTOARPINT) +#define F_SLVPREPTOARPINT V_SLVPREPTOARPINT(1U) + +#define S_SLVTIMEOUTINT 7 +#define V_SLVTIMEOUTINT(x) ((x) << S_SLVTIMEOUTINT) +#define F_SLVTIMEOUTINT V_SLVTIMEOUTINT(1U) + +#define S_SLVERRINT 6 +#define V_SLVERRINT(x) ((x) << S_SLVERRINT) +#define F_SLVERRINT V_SLVERRINT(1U) + +#define S_SLVDONEINT 5 +#define V_SLVDONEINT(x) ((x) << S_SLVDONEINT) +#define F_SLVDONEINT V_SLVDONEINT(1U) + +#define S_SLVRXRDYINT 4 +#define V_SLVRXRDYINT(x) ((x) << S_SLVRXRDYINT) +#define F_SLVRXRDYINT V_SLVRXRDYINT(1U) + +#define S_MSTTIMEOUTINT 3 +#define V_MSTTIMEOUTINT(x) ((x) << S_MSTTIMEOUTINT) +#define F_MSTTIMEOUTINT V_MSTTIMEOUTINT(1U) + +#define S_MSTNACKINT 2 +#define V_MSTNACKINT(x) ((x) << S_MSTNACKINT) +#define F_MSTNACKINT V_MSTNACKINT(1U) + +#define S_MSTLOSTARBINT 1 +#define V_MSTLOSTARBINT(x) ((x) << S_MSTLOSTARBINT) +#define F_MSTLOSTARBINT V_MSTLOSTARBINT(1U) + +#define S_MSTDONEINT 0 +#define V_MSTDONEINT(x) ((x) << S_MSTDONEINT) +#define F_MSTDONEINT V_MSTDONEINT(1U) + +#define A_SMB_DEBUG_DATA 0x19094 + +#define S_DEBUGDATAH 16 +#define M_DEBUGDATAH 0xffffU +#define V_DEBUGDATAH(x) ((x) << S_DEBUGDATAH) +#define G_DEBUGDATAH(x) (((x) >> S_DEBUGDATAH) & M_DEBUGDATAH) + +#define S_DEBUGDATAL 0 +#define M_DEBUGDATAL 0xffffU +#define V_DEBUGDATAL(x) ((x) << S_DEBUGDATAL) +#define G_DEBUGDATAL(x) (((x) >> S_DEBUGDATAL) & M_DEBUGDATAL) + +#define A_SMB_PERR_EN 0x19098 + +#define S_MSTTXFIFOPERREN 2 +#define V_MSTTXFIFOPERREN(x) ((x) << S_MSTTXFIFOPERREN) +#define F_MSTTXFIFOPERREN V_MSTTXFIFOPERREN(1U) + +#define S_MSTRXFIFOPERREN 1 +#define V_MSTRXFIFOPERREN(x) ((x) << S_MSTRXFIFOPERREN) +#define F_MSTRXFIFOPERREN V_MSTRXFIFOPERREN(1U) + +#define S_SLVFIFOPERREN 0 +#define V_SLVFIFOPERREN(x) ((x) << S_SLVFIFOPERREN) +#define F_SLVFIFOPERREN V_SLVFIFOPERREN(1U) + +#define S_MSTTXFIFO 21 +#define V_MSTTXFIFO(x) ((x) << S_MSTTXFIFO) +#define F_MSTTXFIFO V_MSTTXFIFO(1U) + +#define S_MSTRXFIFO 19 +#define V_MSTRXFIFO(x) ((x) << S_MSTRXFIFO) +#define F_MSTRXFIFO V_MSTRXFIFO(1U) + +#define S_SLVFIFO 18 +#define V_SLVFIFO(x) ((x) << S_SLVFIFO) +#define F_SLVFIFO V_SLVFIFO(1U) + +#define A_SMB_PERR_INJ 0x1909c + +#define S_MSTTXINJDATAERR 3 +#define V_MSTTXINJDATAERR(x) ((x) << S_MSTTXINJDATAERR) +#define F_MSTTXINJDATAERR V_MSTTXINJDATAERR(1U) + +#define S_MSTRXINJDATAERR 2 +#define V_MSTRXINJDATAERR(x) ((x) << S_MSTRXINJDATAERR) +#define F_MSTRXINJDATAERR V_MSTRXINJDATAERR(1U) + +#define S_SLVINJDATAERR 1 +#define V_SLVINJDATAERR(x) ((x) << S_SLVINJDATAERR) +#define F_SLVINJDATAERR V_SLVINJDATAERR(1U) + +#define S_FIFOINJDATAERREN 0 +#define V_FIFOINJDATAERREN(x) ((x) << S_FIFOINJDATAERREN) +#define F_FIFOINJDATAERREN V_FIFOINJDATAERREN(1U) + +#define A_SMB_SLV_ARP_CTL 0x190a0 + +#define S_ARPCOMMANDCODE 2 +#define M_ARPCOMMANDCODE 0xffU +#define V_ARPCOMMANDCODE(x) ((x) << S_ARPCOMMANDCODE) +#define G_ARPCOMMANDCODE(x) (((x) >> S_ARPCOMMANDCODE) & M_ARPCOMMANDCODE) + +#define S_ARPADDRRES 1 +#define V_ARPADDRRES(x) ((x) << S_ARPADDRRES) +#define F_ARPADDRRES V_ARPADDRRES(1U) + +#define S_ARPADDRVAL 0 +#define V_ARPADDRVAL(x) ((x) << S_ARPADDRVAL) +#define F_ARPADDRVAL V_ARPADDRVAL(1U) + +#define A_SMB_ARP_UDID0 0x190a4 +#define A_SMB_ARP_UDID1 0x190a8 + +#define S_SUBSYSTEMVENDORID 16 +#define M_SUBSYSTEMVENDORID 0xffffU +#define V_SUBSYSTEMVENDORID(x) ((x) << S_SUBSYSTEMVENDORID) +#define G_SUBSYSTEMVENDORID(x) (((x) >> S_SUBSYSTEMVENDORID) & M_SUBSYSTEMVENDORID) + +#define S_SUBSYSTEMDEVICEID 0 +#define M_SUBSYSTEMDEVICEID 0xffffU +#define V_SUBSYSTEMDEVICEID(x) ((x) << S_SUBSYSTEMDEVICEID) +#define G_SUBSYSTEMDEVICEID(x) (((x) >> S_SUBSYSTEMDEVICEID) & M_SUBSYSTEMDEVICEID) + +#define A_SMB_ARP_UDID2 0x190ac + +#define S_DEVICEID 16 +#define M_DEVICEID 0xffffU +#define V_DEVICEID(x) ((x) << S_DEVICEID) +#define G_DEVICEID(x) (((x) >> S_DEVICEID) & M_DEVICEID) + +#define S_INTERFACE 0 +#define M_INTERFACE 0xffffU +#define V_INTERFACE(x) ((x) << S_INTERFACE) +#define G_INTERFACE(x) (((x) >> S_INTERFACE) & M_INTERFACE) + +#define A_SMB_ARP_UDID3 0x190b0 + +#define S_DEVICECAP 24 +#define M_DEVICECAP 0xffU +#define V_DEVICECAP(x) ((x) << S_DEVICECAP) +#define G_DEVICECAP(x) (((x) >> S_DEVICECAP) & M_DEVICECAP) + +#define S_VERSIONID 16 +#define M_VERSIONID 0xffU +#define V_VERSIONID(x) ((x) << S_VERSIONID) +#define G_VERSIONID(x) (((x) >> S_VERSIONID) & M_VERSIONID) + +#define S_VENDORID 0 +#define M_VENDORID 0xffffU +#define V_VENDORID(x) ((x) << S_VENDORID) +#define G_VENDORID(x) (((x) >> S_VENDORID) & M_VENDORID) + +#define A_SMB_SLV_AUX_ADDR0 0x190b4 + +#define S_AUXADDR0VAL 6 +#define V_AUXADDR0VAL(x) ((x) << S_AUXADDR0VAL) +#define F_AUXADDR0VAL V_AUXADDR0VAL(1U) + +#define S_AUXADDR0 0 +#define M_AUXADDR0 0x3fU +#define V_AUXADDR0(x) ((x) << S_AUXADDR0) +#define G_AUXADDR0(x) (((x) >> S_AUXADDR0) & M_AUXADDR0) + +#define A_SMB_SLV_AUX_ADDR1 0x190b8 + +#define S_AUXADDR1VAL 6 +#define V_AUXADDR1VAL(x) ((x) << S_AUXADDR1VAL) +#define F_AUXADDR1VAL V_AUXADDR1VAL(1U) + +#define S_AUXADDR1 0 +#define M_AUXADDR1 0x3fU +#define V_AUXADDR1(x) ((x) << S_AUXADDR1) +#define G_AUXADDR1(x) (((x) >> S_AUXADDR1) & M_AUXADDR1) + +#define A_SMB_SLV_AUX_ADDR2 0x190bc + +#define S_AUXADDR2VAL 6 +#define V_AUXADDR2VAL(x) ((x) << S_AUXADDR2VAL) +#define F_AUXADDR2VAL V_AUXADDR2VAL(1U) + +#define S_AUXADDR2 0 +#define M_AUXADDR2 0x3fU +#define V_AUXADDR2(x) ((x) << S_AUXADDR2) +#define G_AUXADDR2(x) (((x) >> S_AUXADDR2) & M_AUXADDR2) + +#define A_SMB_SLV_AUX_ADDR3 0x190c0 + +#define S_AUXADDR3VAL 6 +#define V_AUXADDR3VAL(x) ((x) << S_AUXADDR3VAL) +#define F_AUXADDR3VAL V_AUXADDR3VAL(1U) + +#define S_AUXADDR3 0 +#define M_AUXADDR3 0x3fU +#define V_AUXADDR3(x) ((x) << S_AUXADDR3) +#define G_AUXADDR3(x) (((x) >> S_AUXADDR3) & M_AUXADDR3) + +#define A_SMB_COMMAND_CODE0 0x190c4 + +#define S_SMBUSCOMMANDCODE0 0 +#define M_SMBUSCOMMANDCODE0 0xffU +#define V_SMBUSCOMMANDCODE0(x) ((x) << S_SMBUSCOMMANDCODE0) +#define G_SMBUSCOMMANDCODE0(x) (((x) >> S_SMBUSCOMMANDCODE0) & M_SMBUSCOMMANDCODE0) + +#define A_SMB_COMMAND_CODE1 0x190c8 + +#define S_SMBUSCOMMANDCODE1 0 +#define M_SMBUSCOMMANDCODE1 0xffU +#define V_SMBUSCOMMANDCODE1(x) ((x) << S_SMBUSCOMMANDCODE1) +#define G_SMBUSCOMMANDCODE1(x) (((x) >> S_SMBUSCOMMANDCODE1) & M_SMBUSCOMMANDCODE1) + +#define A_SMB_COMMAND_CODE2 0x190cc + +#define S_SMBUSCOMMANDCODE2 0 +#define M_SMBUSCOMMANDCODE2 0xffU +#define V_SMBUSCOMMANDCODE2(x) ((x) << S_SMBUSCOMMANDCODE2) +#define G_SMBUSCOMMANDCODE2(x) (((x) >> S_SMBUSCOMMANDCODE2) & M_SMBUSCOMMANDCODE2) + +#define A_SMB_COMMAND_CODE3 0x190d0 + +#define S_SMBUSCOMMANDCODE3 0 +#define M_SMBUSCOMMANDCODE3 0xffU +#define V_SMBUSCOMMANDCODE3(x) ((x) << S_SMBUSCOMMANDCODE3) +#define G_SMBUSCOMMANDCODE3(x) (((x) >> S_SMBUSCOMMANDCODE3) & M_SMBUSCOMMANDCODE3) + +#define A_SMB_COMMAND_CODE4 0x190d4 + +#define S_SMBUSCOMMANDCODE4 0 +#define M_SMBUSCOMMANDCODE4 0xffU +#define V_SMBUSCOMMANDCODE4(x) ((x) << S_SMBUSCOMMANDCODE4) +#define G_SMBUSCOMMANDCODE4(x) (((x) >> S_SMBUSCOMMANDCODE4) & M_SMBUSCOMMANDCODE4) + +#define A_SMB_COMMAND_CODE5 0x190d8 + +#define S_SMBUSCOMMANDCODE5 0 +#define M_SMBUSCOMMANDCODE5 0xffU +#define V_SMBUSCOMMANDCODE5(x) ((x) << S_SMBUSCOMMANDCODE5) +#define G_SMBUSCOMMANDCODE5(x) (((x) >> S_SMBUSCOMMANDCODE5) & M_SMBUSCOMMANDCODE5) + +#define A_SMB_COMMAND_CODE6 0x190dc + +#define S_SMBUSCOMMANDCODE6 0 +#define M_SMBUSCOMMANDCODE6 0xffU +#define V_SMBUSCOMMANDCODE6(x) ((x) << S_SMBUSCOMMANDCODE6) +#define G_SMBUSCOMMANDCODE6(x) (((x) >> S_SMBUSCOMMANDCODE6) & M_SMBUSCOMMANDCODE6) + +#define A_SMB_COMMAND_CODE7 0x190e0 + +#define S_SMBUSCOMMANDCODE7 0 +#define M_SMBUSCOMMANDCODE7 0xffU +#define V_SMBUSCOMMANDCODE7(x) ((x) << S_SMBUSCOMMANDCODE7) +#define G_SMBUSCOMMANDCODE7(x) (((x) >> S_SMBUSCOMMANDCODE7) & M_SMBUSCOMMANDCODE7) + +#define A_SMB_MICRO_CNT_CLK_CFG 0x190e4 + +#define S_MACROCNTCLKCFG 8 +#define M_MACROCNTCLKCFG 0x1fU +#define V_MACROCNTCLKCFG(x) ((x) << S_MACROCNTCLKCFG) +#define G_MACROCNTCLKCFG(x) (((x) >> S_MACROCNTCLKCFG) & M_MACROCNTCLKCFG) + +#define S_MICROCNTCLKCFG 0 +#define M_MICROCNTCLKCFG 0xffU +#define V_MICROCNTCLKCFG(x) ((x) << S_MICROCNTCLKCFG) +#define G_MICROCNTCLKCFG(x) (((x) >> S_MICROCNTCLKCFG) & M_MICROCNTCLKCFG) + +#define A_SMB_CTL_STATUS 0x190e8 + +#define S_MSTBUSBUSY 2 +#define V_MSTBUSBUSY(x) ((x) << S_MSTBUSBUSY) +#define F_MSTBUSBUSY V_MSTBUSBUSY(1U) + +#define S_SLVBUSBUSY 1 +#define V_SLVBUSBUSY(x) ((x) << S_SLVBUSBUSY) +#define F_SLVBUSBUSY V_SLVBUSBUSY(1U) + +#define S_BUSBUSY 0 +#define V_BUSBUSY(x) ((x) << S_BUSBUSY) +#define F_BUSBUSY V_BUSBUSY(1U) + +/* registers for module I2CM */ +#define I2CM_BASE_ADDR 0x190f0 + +#define A_I2CM_CFG 0x190f0 + +#define S_I2C_CLKDIV 0 +#define M_I2C_CLKDIV 0xfffU +#define V_I2C_CLKDIV(x) ((x) << S_I2C_CLKDIV) +#define G_I2C_CLKDIV(x) (((x) >> S_I2C_CLKDIV) & M_I2C_CLKDIV) + +#define S_I2C_CLKDIV16B 0 +#define M_I2C_CLKDIV16B 0xffffU +#define V_I2C_CLKDIV16B(x) ((x) << S_I2C_CLKDIV16B) +#define G_I2C_CLKDIV16B(x) (((x) >> S_I2C_CLKDIV16B) & M_I2C_CLKDIV16B) + +#define A_I2CM_DATA 0x190f4 + +#define S_I2C_DATA 0 +#define M_I2C_DATA 0xffU +#define V_I2C_DATA(x) ((x) << S_I2C_DATA) +#define G_I2C_DATA(x) (((x) >> S_I2C_DATA) & M_I2C_DATA) + +#define A_I2CM_OP 0x190f8 + +#define S_I2C_ACK 30 +#define V_I2C_ACK(x) ((x) << S_I2C_ACK) +#define F_I2C_ACK V_I2C_ACK(1U) + +#define S_I2C_CONT 1 +#define V_I2C_CONT(x) ((x) << S_I2C_CONT) +#define F_I2C_CONT V_I2C_CONT(1U) + +#define S_OP 0 +#define V_OP(x) ((x) << S_OP) +#define F_OP V_OP(1U) + +/* registers for module MI */ +#define MI_BASE_ADDR 0x19100 + +#define A_MI_CFG 0x19100 + +#define S_T4_ST 14 +#define V_T4_ST(x) ((x) << S_T4_ST) +#define F_T4_ST V_T4_ST(1U) + +#define S_CLKDIV 5 +#define M_CLKDIV 0xffU +#define V_CLKDIV(x) ((x) << S_CLKDIV) +#define G_CLKDIV(x) (((x) >> S_CLKDIV) & M_CLKDIV) + +#define S_ST 3 +#define M_ST 0x3U +#define V_ST(x) ((x) << S_ST) +#define G_ST(x) (((x) >> S_ST) & M_ST) + +#define S_PREEN 2 +#define V_PREEN(x) ((x) << S_PREEN) +#define F_PREEN V_PREEN(1U) + +#define S_MDIINV 1 +#define V_MDIINV(x) ((x) << S_MDIINV) +#define F_MDIINV V_MDIINV(1U) + +#define S_MDIO_1P2V_SEL 0 +#define V_MDIO_1P2V_SEL(x) ((x) << S_MDIO_1P2V_SEL) +#define F_MDIO_1P2V_SEL V_MDIO_1P2V_SEL(1U) + +#define A_MI_ADDR 0x19104 + +#define S_PHYADDR 5 +#define M_PHYADDR 0x1fU +#define V_PHYADDR(x) ((x) << S_PHYADDR) +#define G_PHYADDR(x) (((x) >> S_PHYADDR) & M_PHYADDR) + +#define S_REGADDR 0 +#define M_REGADDR 0x1fU +#define V_REGADDR(x) ((x) << S_REGADDR) +#define G_REGADDR(x) (((x) >> S_REGADDR) & M_REGADDR) + +#define A_MI_DATA 0x19108 + +#define S_MDIDATA 0 +#define M_MDIDATA 0xffffU +#define V_MDIDATA(x) ((x) << S_MDIDATA) +#define G_MDIDATA(x) (((x) >> S_MDIDATA) & M_MDIDATA) + +#define A_MI_OP 0x1910c + +#define S_INC 2 +#define V_INC(x) ((x) << S_INC) +#define F_INC V_INC(1U) + +#define S_MDIOP 0 +#define M_MDIOP 0x3U +#define V_MDIOP(x) ((x) << S_MDIOP) +#define G_MDIOP(x) (((x) >> S_MDIOP) & M_MDIOP) + +/* registers for module UART */ +#define UART_BASE_ADDR 0x19110 + +#define A_UART_CONFIG 0x19110 + +#define S_STOPBITS 22 +#define M_STOPBITS 0x3U +#define V_STOPBITS(x) ((x) << S_STOPBITS) +#define G_STOPBITS(x) (((x) >> S_STOPBITS) & M_STOPBITS) + +#define S_PARITY 20 +#define M_PARITY 0x3U +#define V_PARITY(x) ((x) << S_PARITY) +#define G_PARITY(x) (((x) >> S_PARITY) & M_PARITY) + +#define S_DATABITS 16 +#define M_DATABITS 0xfU +#define V_DATABITS(x) ((x) << S_DATABITS) +#define G_DATABITS(x) (((x) >> S_DATABITS) & M_DATABITS) + +#define S_UART_CLKDIV 0 +#define M_UART_CLKDIV 0xfffU +#define V_UART_CLKDIV(x) ((x) << S_UART_CLKDIV) +#define G_UART_CLKDIV(x) (((x) >> S_UART_CLKDIV) & M_UART_CLKDIV) + +/* registers for module PMU */ +#define PMU_BASE_ADDR 0x19120 + +#define A_PMU_PART_CG_PWRMODE 0x19120 + +#define S_TPPARTCGEN 14 +#define V_TPPARTCGEN(x) ((x) << S_TPPARTCGEN) +#define F_TPPARTCGEN V_TPPARTCGEN(1U) + +#define S_PDPPARTCGEN 13 +#define V_PDPPARTCGEN(x) ((x) << S_PDPPARTCGEN) +#define F_PDPPARTCGEN V_PDPPARTCGEN(1U) + +#define S_PCIEPARTCGEN 12 +#define V_PCIEPARTCGEN(x) ((x) << S_PCIEPARTCGEN) +#define F_PCIEPARTCGEN V_PCIEPARTCGEN(1U) + +#define S_EDC1PARTCGEN 11 +#define V_EDC1PARTCGEN(x) ((x) << S_EDC1PARTCGEN) +#define F_EDC1PARTCGEN V_EDC1PARTCGEN(1U) + +#define S_MCPARTCGEN 10 +#define V_MCPARTCGEN(x) ((x) << S_MCPARTCGEN) +#define F_MCPARTCGEN V_MCPARTCGEN(1U) + +#define S_EDC0PARTCGEN 9 +#define V_EDC0PARTCGEN(x) ((x) << S_EDC0PARTCGEN) +#define F_EDC0PARTCGEN V_EDC0PARTCGEN(1U) + +#define S_LEPARTCGEN 8 +#define V_LEPARTCGEN(x) ((x) << S_LEPARTCGEN) +#define F_LEPARTCGEN V_LEPARTCGEN(1U) + +#define S_INITPOWERMODE 0 +#define M_INITPOWERMODE 0x3U +#define V_INITPOWERMODE(x) ((x) << S_INITPOWERMODE) +#define G_INITPOWERMODE(x) (((x) >> S_INITPOWERMODE) & M_INITPOWERMODE) + +#define S_SGE_PART_CGEN 19 +#define V_SGE_PART_CGEN(x) ((x) << S_SGE_PART_CGEN) +#define F_SGE_PART_CGEN V_SGE_PART_CGEN(1U) + +#define S_PDP_PART_CGEN 18 +#define V_PDP_PART_CGEN(x) ((x) << S_PDP_PART_CGEN) +#define F_PDP_PART_CGEN V_PDP_PART_CGEN(1U) + +#define S_TP_PART_CGEN 17 +#define V_TP_PART_CGEN(x) ((x) << S_TP_PART_CGEN) +#define F_TP_PART_CGEN V_TP_PART_CGEN(1U) + +#define S_EDC0_PART_CGEN 16 +#define V_EDC0_PART_CGEN(x) ((x) << S_EDC0_PART_CGEN) +#define F_EDC0_PART_CGEN V_EDC0_PART_CGEN(1U) + +#define S_EDC1_PART_CGEN 15 +#define V_EDC1_PART_CGEN(x) ((x) << S_EDC1_PART_CGEN) +#define F_EDC1_PART_CGEN V_EDC1_PART_CGEN(1U) + +#define S_LE_PART_CGEN 14 +#define V_LE_PART_CGEN(x) ((x) << S_LE_PART_CGEN) +#define F_LE_PART_CGEN V_LE_PART_CGEN(1U) + +#define S_MA_PART_CGEN 13 +#define V_MA_PART_CGEN(x) ((x) << S_MA_PART_CGEN) +#define F_MA_PART_CGEN V_MA_PART_CGEN(1U) + +#define S_MC0_PART_CGEN 12 +#define V_MC0_PART_CGEN(x) ((x) << S_MC0_PART_CGEN) +#define F_MC0_PART_CGEN V_MC0_PART_CGEN(1U) + +#define S_MC1_PART_CGEN 11 +#define V_MC1_PART_CGEN(x) ((x) << S_MC1_PART_CGEN) +#define F_MC1_PART_CGEN V_MC1_PART_CGEN(1U) + +#define S_PCIE_PART_CGEN 10 +#define V_PCIE_PART_CGEN(x) ((x) << S_PCIE_PART_CGEN) +#define F_PCIE_PART_CGEN V_PCIE_PART_CGEN(1U) + +#define A_PMU_SLEEPMODE_WAKEUP 0x19124 + +#define S_HWWAKEUPEN 5 +#define V_HWWAKEUPEN(x) ((x) << S_HWWAKEUPEN) +#define F_HWWAKEUPEN V_HWWAKEUPEN(1U) + +#define S_PORT3SLEEPMODE 4 +#define V_PORT3SLEEPMODE(x) ((x) << S_PORT3SLEEPMODE) +#define F_PORT3SLEEPMODE V_PORT3SLEEPMODE(1U) + +#define S_PORT2SLEEPMODE 3 +#define V_PORT2SLEEPMODE(x) ((x) << S_PORT2SLEEPMODE) +#define F_PORT2SLEEPMODE V_PORT2SLEEPMODE(1U) + +#define S_PORT1SLEEPMODE 2 +#define V_PORT1SLEEPMODE(x) ((x) << S_PORT1SLEEPMODE) +#define F_PORT1SLEEPMODE V_PORT1SLEEPMODE(1U) + +#define S_PORT0SLEEPMODE 1 +#define V_PORT0SLEEPMODE(x) ((x) << S_PORT0SLEEPMODE) +#define F_PORT0SLEEPMODE V_PORT0SLEEPMODE(1U) + +#define S_WAKEUP 0 +#define V_WAKEUP(x) ((x) << S_WAKEUP) +#define F_WAKEUP V_WAKEUP(1U) + +#define S_GLOBALDEEPSLEEPEN 6 +#define V_GLOBALDEEPSLEEPEN(x) ((x) << S_GLOBALDEEPSLEEPEN) +#define F_GLOBALDEEPSLEEPEN V_GLOBALDEEPSLEEPEN(1U) + +/* registers for module ULP_RX */ +#define ULP_RX_BASE_ADDR 0x19150 + +#define A_ULP_RX_CTL 0x19150 + +#define S_PCMD1THRESHOLD 24 +#define M_PCMD1THRESHOLD 0xffU +#define V_PCMD1THRESHOLD(x) ((x) << S_PCMD1THRESHOLD) +#define G_PCMD1THRESHOLD(x) (((x) >> S_PCMD1THRESHOLD) & M_PCMD1THRESHOLD) + +#define S_PCMD0THRESHOLD 16 +#define M_PCMD0THRESHOLD 0xffU +#define V_PCMD0THRESHOLD(x) ((x) << S_PCMD0THRESHOLD) +#define G_PCMD0THRESHOLD(x) (((x) >> S_PCMD0THRESHOLD) & M_PCMD0THRESHOLD) + +#define S_DISABLE_0B_STAG_ERR 14 +#define V_DISABLE_0B_STAG_ERR(x) ((x) << S_DISABLE_0B_STAG_ERR) +#define F_DISABLE_0B_STAG_ERR V_DISABLE_0B_STAG_ERR(1U) + +#define S_RDMA_0B_WR_OPCODE 10 +#define M_RDMA_0B_WR_OPCODE 0xfU +#define V_RDMA_0B_WR_OPCODE(x) ((x) << S_RDMA_0B_WR_OPCODE) +#define G_RDMA_0B_WR_OPCODE(x) (((x) >> S_RDMA_0B_WR_OPCODE) & M_RDMA_0B_WR_OPCODE) + +#define S_RDMA_0B_WR_PASS 9 +#define V_RDMA_0B_WR_PASS(x) ((x) << S_RDMA_0B_WR_PASS) +#define F_RDMA_0B_WR_PASS V_RDMA_0B_WR_PASS(1U) + +#define S_STAG_RQE 8 +#define V_STAG_RQE(x) ((x) << S_STAG_RQE) +#define F_STAG_RQE V_STAG_RQE(1U) + +#define S_RDMA_STATE_EN 7 +#define V_RDMA_STATE_EN(x) ((x) << S_RDMA_STATE_EN) +#define F_RDMA_STATE_EN V_RDMA_STATE_EN(1U) + +#define S_CRC1_EN 6 +#define V_CRC1_EN(x) ((x) << S_CRC1_EN) +#define F_CRC1_EN V_CRC1_EN(1U) + +#define S_RDMA_0B_WR_CQE 5 +#define V_RDMA_0B_WR_CQE(x) ((x) << S_RDMA_0B_WR_CQE) +#define F_RDMA_0B_WR_CQE V_RDMA_0B_WR_CQE(1U) + +#define S_PCIE_ATRB_EN 4 +#define V_PCIE_ATRB_EN(x) ((x) << S_PCIE_ATRB_EN) +#define F_PCIE_ATRB_EN V_PCIE_ATRB_EN(1U) + +#define S_RDMA_PERMISSIVE_MODE 3 +#define V_RDMA_PERMISSIVE_MODE(x) ((x) << S_RDMA_PERMISSIVE_MODE) +#define F_RDMA_PERMISSIVE_MODE V_RDMA_PERMISSIVE_MODE(1U) + +#define S_PAGEPODME 2 +#define V_PAGEPODME(x) ((x) << S_PAGEPODME) +#define F_PAGEPODME V_PAGEPODME(1U) + +#define S_ISCSITAGTCB 1 +#define V_ISCSITAGTCB(x) ((x) << S_ISCSITAGTCB) +#define F_ISCSITAGTCB V_ISCSITAGTCB(1U) + +#define S_TDDPTAGTCB 0 +#define V_TDDPTAGTCB(x) ((x) << S_TDDPTAGTCB) +#define F_TDDPTAGTCB V_TDDPTAGTCB(1U) + +#define A_ULP_RX_INT_ENABLE 0x19154 + +#define S_ENABLE_CTX_1 24 +#define V_ENABLE_CTX_1(x) ((x) << S_ENABLE_CTX_1) +#define F_ENABLE_CTX_1 V_ENABLE_CTX_1(1U) + +#define S_ENABLE_CTX_0 23 +#define V_ENABLE_CTX_0(x) ((x) << S_ENABLE_CTX_0) +#define F_ENABLE_CTX_0 V_ENABLE_CTX_0(1U) + +#define S_ENABLE_FF 22 +#define V_ENABLE_FF(x) ((x) << S_ENABLE_FF) +#define F_ENABLE_FF V_ENABLE_FF(1U) + +#define S_ENABLE_APF_1 21 +#define V_ENABLE_APF_1(x) ((x) << S_ENABLE_APF_1) +#define F_ENABLE_APF_1 V_ENABLE_APF_1(1U) + +#define S_ENABLE_APF_0 20 +#define V_ENABLE_APF_0(x) ((x) << S_ENABLE_APF_0) +#define F_ENABLE_APF_0 V_ENABLE_APF_0(1U) + +#define S_ENABLE_AF_1 19 +#define V_ENABLE_AF_1(x) ((x) << S_ENABLE_AF_1) +#define F_ENABLE_AF_1 V_ENABLE_AF_1(1U) + +#define S_ENABLE_AF_0 18 +#define V_ENABLE_AF_0(x) ((x) << S_ENABLE_AF_0) +#define F_ENABLE_AF_0 V_ENABLE_AF_0(1U) + +#define S_ENABLE_DDPDF_1 17 +#define V_ENABLE_DDPDF_1(x) ((x) << S_ENABLE_DDPDF_1) +#define F_ENABLE_DDPDF_1 V_ENABLE_DDPDF_1(1U) + +#define S_ENABLE_DDPMF_1 16 +#define V_ENABLE_DDPMF_1(x) ((x) << S_ENABLE_DDPMF_1) +#define F_ENABLE_DDPMF_1 V_ENABLE_DDPMF_1(1U) + +#define S_ENABLE_MEMRF_1 15 +#define V_ENABLE_MEMRF_1(x) ((x) << S_ENABLE_MEMRF_1) +#define F_ENABLE_MEMRF_1 V_ENABLE_MEMRF_1(1U) + +#define S_ENABLE_PRSDF_1 14 +#define V_ENABLE_PRSDF_1(x) ((x) << S_ENABLE_PRSDF_1) +#define F_ENABLE_PRSDF_1 V_ENABLE_PRSDF_1(1U) + +#define S_ENABLE_DDPDF_0 13 +#define V_ENABLE_DDPDF_0(x) ((x) << S_ENABLE_DDPDF_0) +#define F_ENABLE_DDPDF_0 V_ENABLE_DDPDF_0(1U) + +#define S_ENABLE_DDPMF_0 12 +#define V_ENABLE_DDPMF_0(x) ((x) << S_ENABLE_DDPMF_0) +#define F_ENABLE_DDPMF_0 V_ENABLE_DDPMF_0(1U) + +#define S_ENABLE_MEMRF_0 11 +#define V_ENABLE_MEMRF_0(x) ((x) << S_ENABLE_MEMRF_0) +#define F_ENABLE_MEMRF_0 V_ENABLE_MEMRF_0(1U) + +#define S_ENABLE_PRSDF_0 10 +#define V_ENABLE_PRSDF_0(x) ((x) << S_ENABLE_PRSDF_0) +#define F_ENABLE_PRSDF_0 V_ENABLE_PRSDF_0(1U) + +#define S_ENABLE_PCMDF_1 9 +#define V_ENABLE_PCMDF_1(x) ((x) << S_ENABLE_PCMDF_1) +#define F_ENABLE_PCMDF_1 V_ENABLE_PCMDF_1(1U) + +#define S_ENABLE_TPTCF_1 8 +#define V_ENABLE_TPTCF_1(x) ((x) << S_ENABLE_TPTCF_1) +#define F_ENABLE_TPTCF_1 V_ENABLE_TPTCF_1(1U) + +#define S_ENABLE_DDPCF_1 7 +#define V_ENABLE_DDPCF_1(x) ((x) << S_ENABLE_DDPCF_1) +#define F_ENABLE_DDPCF_1 V_ENABLE_DDPCF_1(1U) + +#define S_ENABLE_MPARF_1 6 +#define V_ENABLE_MPARF_1(x) ((x) << S_ENABLE_MPARF_1) +#define F_ENABLE_MPARF_1 V_ENABLE_MPARF_1(1U) + +#define S_ENABLE_MPARC_1 5 +#define V_ENABLE_MPARC_1(x) ((x) << S_ENABLE_MPARC_1) +#define F_ENABLE_MPARC_1 V_ENABLE_MPARC_1(1U) + +#define S_ENABLE_PCMDF_0 4 +#define V_ENABLE_PCMDF_0(x) ((x) << S_ENABLE_PCMDF_0) +#define F_ENABLE_PCMDF_0 V_ENABLE_PCMDF_0(1U) + +#define S_ENABLE_TPTCF_0 3 +#define V_ENABLE_TPTCF_0(x) ((x) << S_ENABLE_TPTCF_0) +#define F_ENABLE_TPTCF_0 V_ENABLE_TPTCF_0(1U) + +#define S_ENABLE_DDPCF_0 2 +#define V_ENABLE_DDPCF_0(x) ((x) << S_ENABLE_DDPCF_0) +#define F_ENABLE_DDPCF_0 V_ENABLE_DDPCF_0(1U) + +#define S_ENABLE_MPARF_0 1 +#define V_ENABLE_MPARF_0(x) ((x) << S_ENABLE_MPARF_0) +#define F_ENABLE_MPARF_0 V_ENABLE_MPARF_0(1U) + +#define S_ENABLE_MPARC_0 0 +#define V_ENABLE_MPARC_0(x) ((x) << S_ENABLE_MPARC_0) +#define F_ENABLE_MPARC_0 V_ENABLE_MPARC_0(1U) + +#define S_SE_CNT_MISMATCH_1 26 +#define V_SE_CNT_MISMATCH_1(x) ((x) << S_SE_CNT_MISMATCH_1) +#define F_SE_CNT_MISMATCH_1 V_SE_CNT_MISMATCH_1(1U) + +#define S_SE_CNT_MISMATCH_0 25 +#define V_SE_CNT_MISMATCH_0(x) ((x) << S_SE_CNT_MISMATCH_0) +#define F_SE_CNT_MISMATCH_0 V_SE_CNT_MISMATCH_0(1U) + +#define A_ULP_RX_INT_CAUSE 0x19158 + +#define S_CAUSE_CTX_1 24 +#define V_CAUSE_CTX_1(x) ((x) << S_CAUSE_CTX_1) +#define F_CAUSE_CTX_1 V_CAUSE_CTX_1(1U) + +#define S_CAUSE_CTX_0 23 +#define V_CAUSE_CTX_0(x) ((x) << S_CAUSE_CTX_0) +#define F_CAUSE_CTX_0 V_CAUSE_CTX_0(1U) + +#define S_CAUSE_FF 22 +#define V_CAUSE_FF(x) ((x) << S_CAUSE_FF) +#define F_CAUSE_FF V_CAUSE_FF(1U) + +#define S_CAUSE_APF_1 21 +#define V_CAUSE_APF_1(x) ((x) << S_CAUSE_APF_1) +#define F_CAUSE_APF_1 V_CAUSE_APF_1(1U) + +#define S_CAUSE_APF_0 20 +#define V_CAUSE_APF_0(x) ((x) << S_CAUSE_APF_0) +#define F_CAUSE_APF_0 V_CAUSE_APF_0(1U) + +#define S_CAUSE_AF_1 19 +#define V_CAUSE_AF_1(x) ((x) << S_CAUSE_AF_1) +#define F_CAUSE_AF_1 V_CAUSE_AF_1(1U) + +#define S_CAUSE_AF_0 18 +#define V_CAUSE_AF_0(x) ((x) << S_CAUSE_AF_0) +#define F_CAUSE_AF_0 V_CAUSE_AF_0(1U) + +#define S_CAUSE_DDPDF_1 17 +#define V_CAUSE_DDPDF_1(x) ((x) << S_CAUSE_DDPDF_1) +#define F_CAUSE_DDPDF_1 V_CAUSE_DDPDF_1(1U) + +#define S_CAUSE_DDPMF_1 16 +#define V_CAUSE_DDPMF_1(x) ((x) << S_CAUSE_DDPMF_1) +#define F_CAUSE_DDPMF_1 V_CAUSE_DDPMF_1(1U) + +#define S_CAUSE_MEMRF_1 15 +#define V_CAUSE_MEMRF_1(x) ((x) << S_CAUSE_MEMRF_1) +#define F_CAUSE_MEMRF_1 V_CAUSE_MEMRF_1(1U) + +#define S_CAUSE_PRSDF_1 14 +#define V_CAUSE_PRSDF_1(x) ((x) << S_CAUSE_PRSDF_1) +#define F_CAUSE_PRSDF_1 V_CAUSE_PRSDF_1(1U) + +#define S_CAUSE_DDPDF_0 13 +#define V_CAUSE_DDPDF_0(x) ((x) << S_CAUSE_DDPDF_0) +#define F_CAUSE_DDPDF_0 V_CAUSE_DDPDF_0(1U) + +#define S_CAUSE_DDPMF_0 12 +#define V_CAUSE_DDPMF_0(x) ((x) << S_CAUSE_DDPMF_0) +#define F_CAUSE_DDPMF_0 V_CAUSE_DDPMF_0(1U) + +#define S_CAUSE_MEMRF_0 11 +#define V_CAUSE_MEMRF_0(x) ((x) << S_CAUSE_MEMRF_0) +#define F_CAUSE_MEMRF_0 V_CAUSE_MEMRF_0(1U) + +#define S_CAUSE_PRSDF_0 10 +#define V_CAUSE_PRSDF_0(x) ((x) << S_CAUSE_PRSDF_0) +#define F_CAUSE_PRSDF_0 V_CAUSE_PRSDF_0(1U) + +#define S_CAUSE_PCMDF_1 9 +#define V_CAUSE_PCMDF_1(x) ((x) << S_CAUSE_PCMDF_1) +#define F_CAUSE_PCMDF_1 V_CAUSE_PCMDF_1(1U) + +#define S_CAUSE_TPTCF_1 8 +#define V_CAUSE_TPTCF_1(x) ((x) << S_CAUSE_TPTCF_1) +#define F_CAUSE_TPTCF_1 V_CAUSE_TPTCF_1(1U) + +#define S_CAUSE_DDPCF_1 7 +#define V_CAUSE_DDPCF_1(x) ((x) << S_CAUSE_DDPCF_1) +#define F_CAUSE_DDPCF_1 V_CAUSE_DDPCF_1(1U) + +#define S_CAUSE_MPARF_1 6 +#define V_CAUSE_MPARF_1(x) ((x) << S_CAUSE_MPARF_1) +#define F_CAUSE_MPARF_1 V_CAUSE_MPARF_1(1U) + +#define S_CAUSE_MPARC_1 5 +#define V_CAUSE_MPARC_1(x) ((x) << S_CAUSE_MPARC_1) +#define F_CAUSE_MPARC_1 V_CAUSE_MPARC_1(1U) + +#define S_CAUSE_PCMDF_0 4 +#define V_CAUSE_PCMDF_0(x) ((x) << S_CAUSE_PCMDF_0) +#define F_CAUSE_PCMDF_0 V_CAUSE_PCMDF_0(1U) + +#define S_CAUSE_TPTCF_0 3 +#define V_CAUSE_TPTCF_0(x) ((x) << S_CAUSE_TPTCF_0) +#define F_CAUSE_TPTCF_0 V_CAUSE_TPTCF_0(1U) + +#define S_CAUSE_DDPCF_0 2 +#define V_CAUSE_DDPCF_0(x) ((x) << S_CAUSE_DDPCF_0) +#define F_CAUSE_DDPCF_0 V_CAUSE_DDPCF_0(1U) + +#define S_CAUSE_MPARF_0 1 +#define V_CAUSE_MPARF_0(x) ((x) << S_CAUSE_MPARF_0) +#define F_CAUSE_MPARF_0 V_CAUSE_MPARF_0(1U) + +#define S_CAUSE_MPARC_0 0 +#define V_CAUSE_MPARC_0(x) ((x) << S_CAUSE_MPARC_0) +#define F_CAUSE_MPARC_0 V_CAUSE_MPARC_0(1U) + +#define A_ULP_RX_ISCSI_LLIMIT 0x1915c + +#define S_ISCSILLIMIT 6 +#define M_ISCSILLIMIT 0x3ffffffU +#define V_ISCSILLIMIT(x) ((x) << S_ISCSILLIMIT) +#define G_ISCSILLIMIT(x) (((x) >> S_ISCSILLIMIT) & M_ISCSILLIMIT) + +#define A_ULP_RX_ISCSI_ULIMIT 0x19160 + +#define S_ISCSIULIMIT 6 +#define M_ISCSIULIMIT 0x3ffffffU +#define V_ISCSIULIMIT(x) ((x) << S_ISCSIULIMIT) +#define G_ISCSIULIMIT(x) (((x) >> S_ISCSIULIMIT) & M_ISCSIULIMIT) + +#define A_ULP_RX_ISCSI_TAGMASK 0x19164 + +#define S_ISCSITAGMASK 6 +#define M_ISCSITAGMASK 0x3ffffffU +#define V_ISCSITAGMASK(x) ((x) << S_ISCSITAGMASK) +#define G_ISCSITAGMASK(x) (((x) >> S_ISCSITAGMASK) & M_ISCSITAGMASK) + +#define A_ULP_RX_ISCSI_PSZ 0x19168 + +#define S_HPZ3 24 +#define M_HPZ3 0xfU +#define V_HPZ3(x) ((x) << S_HPZ3) +#define G_HPZ3(x) (((x) >> S_HPZ3) & M_HPZ3) + +#define S_HPZ2 16 +#define M_HPZ2 0xfU +#define V_HPZ2(x) ((x) << S_HPZ2) +#define G_HPZ2(x) (((x) >> S_HPZ2) & M_HPZ2) + +#define S_HPZ1 8 +#define M_HPZ1 0xfU +#define V_HPZ1(x) ((x) << S_HPZ1) +#define G_HPZ1(x) (((x) >> S_HPZ1) & M_HPZ1) + +#define S_HPZ0 0 +#define M_HPZ0 0xfU +#define V_HPZ0(x) ((x) << S_HPZ0) +#define G_HPZ0(x) (((x) >> S_HPZ0) & M_HPZ0) + +#define A_ULP_RX_TDDP_LLIMIT 0x1916c + +#define S_TDDPLLIMIT 6 +#define M_TDDPLLIMIT 0x3ffffffU +#define V_TDDPLLIMIT(x) ((x) << S_TDDPLLIMIT) +#define G_TDDPLLIMIT(x) (((x) >> S_TDDPLLIMIT) & M_TDDPLLIMIT) + +#define A_ULP_RX_TDDP_ULIMIT 0x19170 + +#define S_TDDPULIMIT 6 +#define M_TDDPULIMIT 0x3ffffffU +#define V_TDDPULIMIT(x) ((x) << S_TDDPULIMIT) +#define G_TDDPULIMIT(x) (((x) >> S_TDDPULIMIT) & M_TDDPULIMIT) + +#define A_ULP_RX_TDDP_TAGMASK 0x19174 + +#define S_TDDPTAGMASK 6 +#define M_TDDPTAGMASK 0x3ffffffU +#define V_TDDPTAGMASK(x) ((x) << S_TDDPTAGMASK) +#define G_TDDPTAGMASK(x) (((x) >> S_TDDPTAGMASK) & M_TDDPTAGMASK) + +#define A_ULP_RX_TDDP_PSZ 0x19178 +#define A_ULP_RX_STAG_LLIMIT 0x1917c +#define A_ULP_RX_STAG_ULIMIT 0x19180 +#define A_ULP_RX_RQ_LLIMIT 0x19184 +#define A_ULP_RX_RQ_ULIMIT 0x19188 +#define A_ULP_RX_PBL_LLIMIT 0x1918c +#define A_ULP_RX_PBL_ULIMIT 0x19190 +#define A_ULP_RX_CTX_BASE 0x19194 +#define A_ULP_RX_PERR_ENABLE 0x1919c + +#define S_PERR_ENABLE_FF 22 +#define V_PERR_ENABLE_FF(x) ((x) << S_PERR_ENABLE_FF) +#define F_PERR_ENABLE_FF V_PERR_ENABLE_FF(1U) + +#define S_PERR_ENABLE_APF_1 21 +#define V_PERR_ENABLE_APF_1(x) ((x) << S_PERR_ENABLE_APF_1) +#define F_PERR_ENABLE_APF_1 V_PERR_ENABLE_APF_1(1U) + +#define S_PERR_ENABLE_APF_0 20 +#define V_PERR_ENABLE_APF_0(x) ((x) << S_PERR_ENABLE_APF_0) +#define F_PERR_ENABLE_APF_0 V_PERR_ENABLE_APF_0(1U) + +#define S_PERR_ENABLE_AF_1 19 +#define V_PERR_ENABLE_AF_1(x) ((x) << S_PERR_ENABLE_AF_1) +#define F_PERR_ENABLE_AF_1 V_PERR_ENABLE_AF_1(1U) + +#define S_PERR_ENABLE_AF_0 18 +#define V_PERR_ENABLE_AF_0(x) ((x) << S_PERR_ENABLE_AF_0) +#define F_PERR_ENABLE_AF_0 V_PERR_ENABLE_AF_0(1U) + +#define S_PERR_ENABLE_DDPDF_1 17 +#define V_PERR_ENABLE_DDPDF_1(x) ((x) << S_PERR_ENABLE_DDPDF_1) +#define F_PERR_ENABLE_DDPDF_1 V_PERR_ENABLE_DDPDF_1(1U) + +#define S_PERR_ENABLE_DDPMF_1 16 +#define V_PERR_ENABLE_DDPMF_1(x) ((x) << S_PERR_ENABLE_DDPMF_1) +#define F_PERR_ENABLE_DDPMF_1 V_PERR_ENABLE_DDPMF_1(1U) + +#define S_PERR_ENABLE_MEMRF_1 15 +#define V_PERR_ENABLE_MEMRF_1(x) ((x) << S_PERR_ENABLE_MEMRF_1) +#define F_PERR_ENABLE_MEMRF_1 V_PERR_ENABLE_MEMRF_1(1U) + +#define S_PERR_ENABLE_PRSDF_1 14 +#define V_PERR_ENABLE_PRSDF_1(x) ((x) << S_PERR_ENABLE_PRSDF_1) +#define F_PERR_ENABLE_PRSDF_1 V_PERR_ENABLE_PRSDF_1(1U) + +#define S_PERR_ENABLE_DDPDF_0 13 +#define V_PERR_ENABLE_DDPDF_0(x) ((x) << S_PERR_ENABLE_DDPDF_0) +#define F_PERR_ENABLE_DDPDF_0 V_PERR_ENABLE_DDPDF_0(1U) + +#define S_PERR_ENABLE_DDPMF_0 12 +#define V_PERR_ENABLE_DDPMF_0(x) ((x) << S_PERR_ENABLE_DDPMF_0) +#define F_PERR_ENABLE_DDPMF_0 V_PERR_ENABLE_DDPMF_0(1U) + +#define S_PERR_ENABLE_MEMRF_0 11 +#define V_PERR_ENABLE_MEMRF_0(x) ((x) << S_PERR_ENABLE_MEMRF_0) +#define F_PERR_ENABLE_MEMRF_0 V_PERR_ENABLE_MEMRF_0(1U) + +#define S_PERR_ENABLE_PRSDF_0 10 +#define V_PERR_ENABLE_PRSDF_0(x) ((x) << S_PERR_ENABLE_PRSDF_0) +#define F_PERR_ENABLE_PRSDF_0 V_PERR_ENABLE_PRSDF_0(1U) + +#define S_PERR_ENABLE_PCMDF_1 9 +#define V_PERR_ENABLE_PCMDF_1(x) ((x) << S_PERR_ENABLE_PCMDF_1) +#define F_PERR_ENABLE_PCMDF_1 V_PERR_ENABLE_PCMDF_1(1U) + +#define S_PERR_ENABLE_TPTCF_1 8 +#define V_PERR_ENABLE_TPTCF_1(x) ((x) << S_PERR_ENABLE_TPTCF_1) +#define F_PERR_ENABLE_TPTCF_1 V_PERR_ENABLE_TPTCF_1(1U) + +#define S_PERR_ENABLE_DDPCF_1 7 +#define V_PERR_ENABLE_DDPCF_1(x) ((x) << S_PERR_ENABLE_DDPCF_1) +#define F_PERR_ENABLE_DDPCF_1 V_PERR_ENABLE_DDPCF_1(1U) + +#define S_PERR_ENABLE_MPARF_1 6 +#define V_PERR_ENABLE_MPARF_1(x) ((x) << S_PERR_ENABLE_MPARF_1) +#define F_PERR_ENABLE_MPARF_1 V_PERR_ENABLE_MPARF_1(1U) + +#define S_PERR_ENABLE_MPARC_1 5 +#define V_PERR_ENABLE_MPARC_1(x) ((x) << S_PERR_ENABLE_MPARC_1) +#define F_PERR_ENABLE_MPARC_1 V_PERR_ENABLE_MPARC_1(1U) + +#define S_PERR_ENABLE_PCMDF_0 4 +#define V_PERR_ENABLE_PCMDF_0(x) ((x) << S_PERR_ENABLE_PCMDF_0) +#define F_PERR_ENABLE_PCMDF_0 V_PERR_ENABLE_PCMDF_0(1U) + +#define S_PERR_ENABLE_TPTCF_0 3 +#define V_PERR_ENABLE_TPTCF_0(x) ((x) << S_PERR_ENABLE_TPTCF_0) +#define F_PERR_ENABLE_TPTCF_0 V_PERR_ENABLE_TPTCF_0(1U) + +#define S_PERR_ENABLE_DDPCF_0 2 +#define V_PERR_ENABLE_DDPCF_0(x) ((x) << S_PERR_ENABLE_DDPCF_0) +#define F_PERR_ENABLE_DDPCF_0 V_PERR_ENABLE_DDPCF_0(1U) + +#define S_PERR_ENABLE_MPARF_0 1 +#define V_PERR_ENABLE_MPARF_0(x) ((x) << S_PERR_ENABLE_MPARF_0) +#define F_PERR_ENABLE_MPARF_0 V_PERR_ENABLE_MPARF_0(1U) + +#define S_PERR_ENABLE_MPARC_0 0 +#define V_PERR_ENABLE_MPARC_0(x) ((x) << S_PERR_ENABLE_MPARC_0) +#define F_PERR_ENABLE_MPARC_0 V_PERR_ENABLE_MPARC_0(1U) + +#define S_PERR_SE_CNT_MISMATCH_1 26 +#define V_PERR_SE_CNT_MISMATCH_1(x) ((x) << S_PERR_SE_CNT_MISMATCH_1) +#define F_PERR_SE_CNT_MISMATCH_1 V_PERR_SE_CNT_MISMATCH_1(1U) + +#define S_PERR_SE_CNT_MISMATCH_0 25 +#define V_PERR_SE_CNT_MISMATCH_0(x) ((x) << S_PERR_SE_CNT_MISMATCH_0) +#define F_PERR_SE_CNT_MISMATCH_0 V_PERR_SE_CNT_MISMATCH_0(1U) + +#define S_PERR_RSVD0 24 +#define V_PERR_RSVD0(x) ((x) << S_PERR_RSVD0) +#define F_PERR_RSVD0 V_PERR_RSVD0(1U) + +#define S_PERR_RSVD1 23 +#define V_PERR_RSVD1(x) ((x) << S_PERR_RSVD1) +#define F_PERR_RSVD1 V_PERR_RSVD1(1U) + +#define A_ULP_RX_PERR_INJECT 0x191a0 +#define A_ULP_RX_RQUDP_LLIMIT 0x191a4 +#define A_ULP_RX_RQUDP_ULIMIT 0x191a8 +#define A_ULP_RX_CTX_ACC_CH0 0x191ac + +#define S_REQ 21 +#define V_REQ(x) ((x) << S_REQ) +#define F_REQ V_REQ(1U) + +#define S_WB 20 +#define V_WB(x) ((x) << S_WB) +#define F_WB V_WB(1U) + +#define S_ULPRX_TID 0 +#define M_ULPRX_TID 0xfffffU +#define V_ULPRX_TID(x) ((x) << S_ULPRX_TID) +#define G_ULPRX_TID(x) (((x) >> S_ULPRX_TID) & M_ULPRX_TID) + +#define A_ULP_RX_CTX_ACC_CH1 0x191b0 +#define A_ULP_RX_SE_CNT_ERR 0x191d0 +#define A_ULP_RX_SE_CNT_CLR 0x191d4 + +#define S_CLRCHAN0 4 +#define M_CLRCHAN0 0xfU +#define V_CLRCHAN0(x) ((x) << S_CLRCHAN0) +#define G_CLRCHAN0(x) (((x) >> S_CLRCHAN0) & M_CLRCHAN0) + +#define S_CLRCHAN1 0 +#define M_CLRCHAN1 0xfU +#define V_CLRCHAN1(x) ((x) << S_CLRCHAN1) +#define G_CLRCHAN1(x) (((x) >> S_CLRCHAN1) & M_CLRCHAN1) + +#define A_ULP_RX_SE_CNT_CH0 0x191d8 + +#define S_SOP_CNT_OUT0 28 +#define M_SOP_CNT_OUT0 0xfU +#define V_SOP_CNT_OUT0(x) ((x) << S_SOP_CNT_OUT0) +#define G_SOP_CNT_OUT0(x) (((x) >> S_SOP_CNT_OUT0) & M_SOP_CNT_OUT0) + +#define S_EOP_CNT_OUT0 24 +#define M_EOP_CNT_OUT0 0xfU +#define V_EOP_CNT_OUT0(x) ((x) << S_EOP_CNT_OUT0) +#define G_EOP_CNT_OUT0(x) (((x) >> S_EOP_CNT_OUT0) & M_EOP_CNT_OUT0) + +#define S_SOP_CNT_AL0 20 +#define M_SOP_CNT_AL0 0xfU +#define V_SOP_CNT_AL0(x) ((x) << S_SOP_CNT_AL0) +#define G_SOP_CNT_AL0(x) (((x) >> S_SOP_CNT_AL0) & M_SOP_CNT_AL0) + +#define S_EOP_CNT_AL0 16 +#define M_EOP_CNT_AL0 0xfU +#define V_EOP_CNT_AL0(x) ((x) << S_EOP_CNT_AL0) +#define G_EOP_CNT_AL0(x) (((x) >> S_EOP_CNT_AL0) & M_EOP_CNT_AL0) + +#define S_SOP_CNT_MR0 12 +#define M_SOP_CNT_MR0 0xfU +#define V_SOP_CNT_MR0(x) ((x) << S_SOP_CNT_MR0) +#define G_SOP_CNT_MR0(x) (((x) >> S_SOP_CNT_MR0) & M_SOP_CNT_MR0) + +#define S_EOP_CNT_MR0 8 +#define M_EOP_CNT_MR0 0xfU +#define V_EOP_CNT_MR0(x) ((x) << S_EOP_CNT_MR0) +#define G_EOP_CNT_MR0(x) (((x) >> S_EOP_CNT_MR0) & M_EOP_CNT_MR0) + +#define S_SOP_CNT_IN0 4 +#define M_SOP_CNT_IN0 0xfU +#define V_SOP_CNT_IN0(x) ((x) << S_SOP_CNT_IN0) +#define G_SOP_CNT_IN0(x) (((x) >> S_SOP_CNT_IN0) & M_SOP_CNT_IN0) + +#define S_EOP_CNT_IN0 0 +#define M_EOP_CNT_IN0 0xfU +#define V_EOP_CNT_IN0(x) ((x) << S_EOP_CNT_IN0) +#define G_EOP_CNT_IN0(x) (((x) >> S_EOP_CNT_IN0) & M_EOP_CNT_IN0) + +#define A_ULP_RX_SE_CNT_CH1 0x191dc + +#define S_SOP_CNT_OUT1 28 +#define M_SOP_CNT_OUT1 0xfU +#define V_SOP_CNT_OUT1(x) ((x) << S_SOP_CNT_OUT1) +#define G_SOP_CNT_OUT1(x) (((x) >> S_SOP_CNT_OUT1) & M_SOP_CNT_OUT1) + +#define S_EOP_CNT_OUT1 24 +#define M_EOP_CNT_OUT1 0xfU +#define V_EOP_CNT_OUT1(x) ((x) << S_EOP_CNT_OUT1) +#define G_EOP_CNT_OUT1(x) (((x) >> S_EOP_CNT_OUT1) & M_EOP_CNT_OUT1) + +#define S_SOP_CNT_AL1 20 +#define M_SOP_CNT_AL1 0xfU +#define V_SOP_CNT_AL1(x) ((x) << S_SOP_CNT_AL1) +#define G_SOP_CNT_AL1(x) (((x) >> S_SOP_CNT_AL1) & M_SOP_CNT_AL1) + +#define S_EOP_CNT_AL1 16 +#define M_EOP_CNT_AL1 0xfU +#define V_EOP_CNT_AL1(x) ((x) << S_EOP_CNT_AL1) +#define G_EOP_CNT_AL1(x) (((x) >> S_EOP_CNT_AL1) & M_EOP_CNT_AL1) + +#define S_SOP_CNT_MR1 12 +#define M_SOP_CNT_MR1 0xfU +#define V_SOP_CNT_MR1(x) ((x) << S_SOP_CNT_MR1) +#define G_SOP_CNT_MR1(x) (((x) >> S_SOP_CNT_MR1) & M_SOP_CNT_MR1) + +#define S_EOP_CNT_MR1 8 +#define M_EOP_CNT_MR1 0xfU +#define V_EOP_CNT_MR1(x) ((x) << S_EOP_CNT_MR1) +#define G_EOP_CNT_MR1(x) (((x) >> S_EOP_CNT_MR1) & M_EOP_CNT_MR1) + +#define S_SOP_CNT_IN1 4 +#define M_SOP_CNT_IN1 0xfU +#define V_SOP_CNT_IN1(x) ((x) << S_SOP_CNT_IN1) +#define G_SOP_CNT_IN1(x) (((x) >> S_SOP_CNT_IN1) & M_SOP_CNT_IN1) + +#define S_EOP_CNT_IN1 0 +#define M_EOP_CNT_IN1 0xfU +#define V_EOP_CNT_IN1(x) ((x) << S_EOP_CNT_IN1) +#define G_EOP_CNT_IN1(x) (((x) >> S_EOP_CNT_IN1) & M_EOP_CNT_IN1) + +#define A_ULP_RX_DBG_CTL 0x191e0 + +#define S_EN_DBG_H 17 +#define V_EN_DBG_H(x) ((x) << S_EN_DBG_H) +#define F_EN_DBG_H V_EN_DBG_H(1U) + +#define S_EN_DBG_L 16 +#define V_EN_DBG_L(x) ((x) << S_EN_DBG_L) +#define F_EN_DBG_L V_EN_DBG_L(1U) + +#define S_SEL_H 8 +#define M_SEL_H 0xffU +#define V_SEL_H(x) ((x) << S_SEL_H) +#define G_SEL_H(x) (((x) >> S_SEL_H) & M_SEL_H) + +#define S_SEL_L 0 +#define M_SEL_L 0xffU +#define V_SEL_L(x) ((x) << S_SEL_L) +#define G_SEL_L(x) (((x) >> S_SEL_L) & M_SEL_L) + +#define A_ULP_RX_DBG_DATAH 0x191e4 +#define A_ULP_RX_DBG_DATAL 0x191e8 +#define A_ULP_RX_LA_CHNL 0x19238 + +#define S_CHNL_SEL 0 +#define V_CHNL_SEL(x) ((x) << S_CHNL_SEL) +#define F_CHNL_SEL V_CHNL_SEL(1U) + +#define A_ULP_RX_LA_CTL 0x1923c + +#define S_TRC_SEL 0 +#define V_TRC_SEL(x) ((x) << S_TRC_SEL) +#define F_TRC_SEL V_TRC_SEL(1U) + +#define A_ULP_RX_LA_RDPTR 0x19240 + +#define S_RD_PTR 0 +#define M_RD_PTR 0x1ffU +#define V_RD_PTR(x) ((x) << S_RD_PTR) +#define G_RD_PTR(x) (((x) >> S_RD_PTR) & M_RD_PTR) + +#define A_ULP_RX_LA_RDDATA 0x19244 +#define A_ULP_RX_LA_WRPTR 0x19248 + +#define S_WR_PTR 0 +#define M_WR_PTR 0x1ffU +#define V_WR_PTR(x) ((x) << S_WR_PTR) +#define G_WR_PTR(x) (((x) >> S_WR_PTR) & M_WR_PTR) + +#define A_ULP_RX_LA_RESERVED 0x1924c +#define A_ULP_RX_CQE_GEN_EN 0x19250 + +#define S_TERMIMATE_MSG 1 +#define V_TERMIMATE_MSG(x) ((x) << S_TERMIMATE_MSG) +#define F_TERMIMATE_MSG V_TERMIMATE_MSG(1U) + +#define S_TERMINATE_WITH_ERR 0 +#define V_TERMINATE_WITH_ERR(x) ((x) << S_TERMINATE_WITH_ERR) +#define F_TERMINATE_WITH_ERR V_TERMINATE_WITH_ERR(1U) + +#define A_ULP_RX_ATOMIC_OPCODES 0x19254 + +#define S_ATOMIC_REQ_QNO 22 +#define M_ATOMIC_REQ_QNO 0x3U +#define V_ATOMIC_REQ_QNO(x) ((x) << S_ATOMIC_REQ_QNO) +#define G_ATOMIC_REQ_QNO(x) (((x) >> S_ATOMIC_REQ_QNO) & M_ATOMIC_REQ_QNO) + +#define S_ATOMIC_RSP_QNO 20 +#define M_ATOMIC_RSP_QNO 0x3U +#define V_ATOMIC_RSP_QNO(x) ((x) << S_ATOMIC_RSP_QNO) +#define G_ATOMIC_RSP_QNO(x) (((x) >> S_ATOMIC_RSP_QNO) & M_ATOMIC_RSP_QNO) + +#define S_IMMEDIATE_QNO 18 +#define M_IMMEDIATE_QNO 0x3U +#define V_IMMEDIATE_QNO(x) ((x) << S_IMMEDIATE_QNO) +#define G_IMMEDIATE_QNO(x) (((x) >> S_IMMEDIATE_QNO) & M_IMMEDIATE_QNO) + +#define S_IMMEDIATE_WITH_SE_QNO 16 +#define M_IMMEDIATE_WITH_SE_QNO 0x3U +#define V_IMMEDIATE_WITH_SE_QNO(x) ((x) << S_IMMEDIATE_WITH_SE_QNO) +#define G_IMMEDIATE_WITH_SE_QNO(x) (((x) >> S_IMMEDIATE_WITH_SE_QNO) & M_IMMEDIATE_WITH_SE_QNO) + +#define S_ATOMIC_WR_OPCODE 12 +#define M_ATOMIC_WR_OPCODE 0xfU +#define V_ATOMIC_WR_OPCODE(x) ((x) << S_ATOMIC_WR_OPCODE) +#define G_ATOMIC_WR_OPCODE(x) (((x) >> S_ATOMIC_WR_OPCODE) & M_ATOMIC_WR_OPCODE) + +#define S_ATOMIC_RD_OPCODE 8 +#define M_ATOMIC_RD_OPCODE 0xfU +#define V_ATOMIC_RD_OPCODE(x) ((x) << S_ATOMIC_RD_OPCODE) +#define G_ATOMIC_RD_OPCODE(x) (((x) >> S_ATOMIC_RD_OPCODE) & M_ATOMIC_RD_OPCODE) + +#define S_IMMEDIATE_OPCODE 4 +#define M_IMMEDIATE_OPCODE 0xfU +#define V_IMMEDIATE_OPCODE(x) ((x) << S_IMMEDIATE_OPCODE) +#define G_IMMEDIATE_OPCODE(x) (((x) >> S_IMMEDIATE_OPCODE) & M_IMMEDIATE_OPCODE) + +#define S_IMMEDIATE_WITH_SE_OPCODE 0 +#define M_IMMEDIATE_WITH_SE_OPCODE 0xfU +#define V_IMMEDIATE_WITH_SE_OPCODE(x) ((x) << S_IMMEDIATE_WITH_SE_OPCODE) +#define G_IMMEDIATE_WITH_SE_OPCODE(x) (((x) >> S_IMMEDIATE_WITH_SE_OPCODE) & M_IMMEDIATE_WITH_SE_OPCODE) + +#define A_ULP_RX_T10_CRC_ENDIAN_SWITCHING 0x19258 + +#define S_EN_ORIG_DATA 0 +#define V_EN_ORIG_DATA(x) ((x) << S_EN_ORIG_DATA) +#define F_EN_ORIG_DATA V_EN_ORIG_DATA(1U) + +#define A_ULP_RX_MISC_FEATURE_ENABLE 0x1925c + +#define S_TERMINATE_STATUS_EN 4 +#define V_TERMINATE_STATUS_EN(x) ((x) << S_TERMINATE_STATUS_EN) +#define F_TERMINATE_STATUS_EN V_TERMINATE_STATUS_EN(1U) + +#define S_MULTIPLE_PREF_ENABLE 3 +#define V_MULTIPLE_PREF_ENABLE(x) ((x) << S_MULTIPLE_PREF_ENABLE) +#define F_MULTIPLE_PREF_ENABLE V_MULTIPLE_PREF_ENABLE(1U) + +#define S_UMUDP_PBL_PREF_ENABLE 2 +#define V_UMUDP_PBL_PREF_ENABLE(x) ((x) << S_UMUDP_PBL_PREF_ENABLE) +#define F_UMUDP_PBL_PREF_ENABLE V_UMUDP_PBL_PREF_ENABLE(1U) + +#define S_RDMA_PBL_PREF_EN 1 +#define V_RDMA_PBL_PREF_EN(x) ((x) << S_RDMA_PBL_PREF_EN) +#define F_RDMA_PBL_PREF_EN V_RDMA_PBL_PREF_EN(1U) + +#define S_SDC_CRC_PROT_EN 0 +#define V_SDC_CRC_PROT_EN(x) ((x) << S_SDC_CRC_PROT_EN) +#define F_SDC_CRC_PROT_EN V_SDC_CRC_PROT_EN(1U) + +#define A_ULP_RX_CH0_CGEN 0x19260 + +#define S_BYPASS_CGEN 7 +#define V_BYPASS_CGEN(x) ((x) << S_BYPASS_CGEN) +#define F_BYPASS_CGEN V_BYPASS_CGEN(1U) + +#define S_TDDP_CGEN 6 +#define V_TDDP_CGEN(x) ((x) << S_TDDP_CGEN) +#define F_TDDP_CGEN V_TDDP_CGEN(1U) + +#define S_ISCSI_CGEN 5 +#define V_ISCSI_CGEN(x) ((x) << S_ISCSI_CGEN) +#define F_ISCSI_CGEN V_ISCSI_CGEN(1U) + +#define S_RDMA_CGEN 4 +#define V_RDMA_CGEN(x) ((x) << S_RDMA_CGEN) +#define F_RDMA_CGEN V_RDMA_CGEN(1U) + +#define S_CHANNEL_CGEN 3 +#define V_CHANNEL_CGEN(x) ((x) << S_CHANNEL_CGEN) +#define F_CHANNEL_CGEN V_CHANNEL_CGEN(1U) + +#define S_ALL_DATAPATH_CGEN 2 +#define V_ALL_DATAPATH_CGEN(x) ((x) << S_ALL_DATAPATH_CGEN) +#define F_ALL_DATAPATH_CGEN V_ALL_DATAPATH_CGEN(1U) + +#define S_T10DIFF_DATAPATH_CGEN 1 +#define V_T10DIFF_DATAPATH_CGEN(x) ((x) << S_T10DIFF_DATAPATH_CGEN) +#define F_T10DIFF_DATAPATH_CGEN V_T10DIFF_DATAPATH_CGEN(1U) + +#define S_RDMA_DATAPATH_CGEN 0 +#define V_RDMA_DATAPATH_CGEN(x) ((x) << S_RDMA_DATAPATH_CGEN) +#define F_RDMA_DATAPATH_CGEN V_RDMA_DATAPATH_CGEN(1U) + +#define A_ULP_RX_CH1_CGEN 0x19264 +#define A_ULP_RX_RFE_DISABLE 0x19268 + +#define S_RQE_LIM_CHECK_RFE_DISABLE 0 +#define V_RQE_LIM_CHECK_RFE_DISABLE(x) ((x) << S_RQE_LIM_CHECK_RFE_DISABLE) +#define F_RQE_LIM_CHECK_RFE_DISABLE V_RQE_LIM_CHECK_RFE_DISABLE(1U) + +#define A_ULP_RX_INT_ENABLE_2 0x1926c + +#define S_ULPRX2MA_INTFPERR 8 +#define V_ULPRX2MA_INTFPERR(x) ((x) << S_ULPRX2MA_INTFPERR) +#define F_ULPRX2MA_INTFPERR V_ULPRX2MA_INTFPERR(1U) + +#define S_ALN_SDC_ERR_1 7 +#define V_ALN_SDC_ERR_1(x) ((x) << S_ALN_SDC_ERR_1) +#define F_ALN_SDC_ERR_1 V_ALN_SDC_ERR_1(1U) + +#define S_ALN_SDC_ERR_0 6 +#define V_ALN_SDC_ERR_0(x) ((x) << S_ALN_SDC_ERR_0) +#define F_ALN_SDC_ERR_0 V_ALN_SDC_ERR_0(1U) + +#define S_PF_UNTAGGED_TPT_1 5 +#define V_PF_UNTAGGED_TPT_1(x) ((x) << S_PF_UNTAGGED_TPT_1) +#define F_PF_UNTAGGED_TPT_1 V_PF_UNTAGGED_TPT_1(1U) + +#define S_PF_UNTAGGED_TPT_0 4 +#define V_PF_UNTAGGED_TPT_0(x) ((x) << S_PF_UNTAGGED_TPT_0) +#define F_PF_UNTAGGED_TPT_0 V_PF_UNTAGGED_TPT_0(1U) + +#define S_PF_PBL_1 3 +#define V_PF_PBL_1(x) ((x) << S_PF_PBL_1) +#define F_PF_PBL_1 V_PF_PBL_1(1U) + +#define S_PF_PBL_0 2 +#define V_PF_PBL_0(x) ((x) << S_PF_PBL_0) +#define F_PF_PBL_0 V_PF_PBL_0(1U) + +#define S_DDP_HINT_1 1 +#define V_DDP_HINT_1(x) ((x) << S_DDP_HINT_1) +#define F_DDP_HINT_1 V_DDP_HINT_1(1U) + +#define S_DDP_HINT_0 0 +#define V_DDP_HINT_0(x) ((x) << S_DDP_HINT_0) +#define F_DDP_HINT_0 V_DDP_HINT_0(1U) + +#define A_ULP_RX_INT_CAUSE_2 0x19270 +#define A_ULP_RX_PERR_ENABLE_2 0x19274 + +#define S_ENABLE_ULPRX2MA_INTFPERR 8 +#define V_ENABLE_ULPRX2MA_INTFPERR(x) ((x) << S_ENABLE_ULPRX2MA_INTFPERR) +#define F_ENABLE_ULPRX2MA_INTFPERR V_ENABLE_ULPRX2MA_INTFPERR(1U) + +#define S_ENABLE_ALN_SDC_ERR_1 7 +#define V_ENABLE_ALN_SDC_ERR_1(x) ((x) << S_ENABLE_ALN_SDC_ERR_1) +#define F_ENABLE_ALN_SDC_ERR_1 V_ENABLE_ALN_SDC_ERR_1(1U) + +#define S_ENABLE_ALN_SDC_ERR_0 6 +#define V_ENABLE_ALN_SDC_ERR_0(x) ((x) << S_ENABLE_ALN_SDC_ERR_0) +#define F_ENABLE_ALN_SDC_ERR_0 V_ENABLE_ALN_SDC_ERR_0(1U) + +#define S_ENABLE_PF_UNTAGGED_TPT_1 5 +#define V_ENABLE_PF_UNTAGGED_TPT_1(x) ((x) << S_ENABLE_PF_UNTAGGED_TPT_1) +#define F_ENABLE_PF_UNTAGGED_TPT_1 V_ENABLE_PF_UNTAGGED_TPT_1(1U) + +#define S_ENABLE_PF_UNTAGGED_TPT_0 4 +#define V_ENABLE_PF_UNTAGGED_TPT_0(x) ((x) << S_ENABLE_PF_UNTAGGED_TPT_0) +#define F_ENABLE_PF_UNTAGGED_TPT_0 V_ENABLE_PF_UNTAGGED_TPT_0(1U) + +#define S_ENABLE_PF_PBL_1 3 +#define V_ENABLE_PF_PBL_1(x) ((x) << S_ENABLE_PF_PBL_1) +#define F_ENABLE_PF_PBL_1 V_ENABLE_PF_PBL_1(1U) + +#define S_ENABLE_PF_PBL_0 2 +#define V_ENABLE_PF_PBL_0(x) ((x) << S_ENABLE_PF_PBL_0) +#define F_ENABLE_PF_PBL_0 V_ENABLE_PF_PBL_0(1U) + +#define S_ENABLE_DDP_HINT_1 1 +#define V_ENABLE_DDP_HINT_1(x) ((x) << S_ENABLE_DDP_HINT_1) +#define F_ENABLE_DDP_HINT_1 V_ENABLE_DDP_HINT_1(1U) + +#define S_ENABLE_DDP_HINT_0 0 +#define V_ENABLE_DDP_HINT_0(x) ((x) << S_ENABLE_DDP_HINT_0) +#define F_ENABLE_DDP_HINT_0 V_ENABLE_DDP_HINT_0(1U) + +#define A_ULP_RX_RQE_PBL_MULTIPLE_OUTSTANDING_CNT 0x19278 + +#define S_PIO_RQE_PBL_MULTIPLE_CNT 0 +#define M_PIO_RQE_PBL_MULTIPLE_CNT 0xfU +#define V_PIO_RQE_PBL_MULTIPLE_CNT(x) ((x) << S_PIO_RQE_PBL_MULTIPLE_CNT) +#define G_PIO_RQE_PBL_MULTIPLE_CNT(x) (((x) >> S_PIO_RQE_PBL_MULTIPLE_CNT) & M_PIO_RQE_PBL_MULTIPLE_CNT) + +#define A_ULP_RX_ATOMIC_LEN 0x1927c + +#define S_ATOMIC_RPL_LEN 16 +#define M_ATOMIC_RPL_LEN 0xffU +#define V_ATOMIC_RPL_LEN(x) ((x) << S_ATOMIC_RPL_LEN) +#define G_ATOMIC_RPL_LEN(x) (((x) >> S_ATOMIC_RPL_LEN) & M_ATOMIC_RPL_LEN) + +#define S_ATOMIC_REQ_LEN 8 +#define M_ATOMIC_REQ_LEN 0xffU +#define V_ATOMIC_REQ_LEN(x) ((x) << S_ATOMIC_REQ_LEN) +#define G_ATOMIC_REQ_LEN(x) (((x) >> S_ATOMIC_REQ_LEN) & M_ATOMIC_REQ_LEN) + +#define S_ATOMIC_IMMEDIATE_LEN 0 +#define M_ATOMIC_IMMEDIATE_LEN 0xffU +#define V_ATOMIC_IMMEDIATE_LEN(x) ((x) << S_ATOMIC_IMMEDIATE_LEN) +#define G_ATOMIC_IMMEDIATE_LEN(x) (((x) >> S_ATOMIC_IMMEDIATE_LEN) & M_ATOMIC_IMMEDIATE_LEN) + +#define A_ULP_RX_CGEN_GLOBAL 0x19280 +#define A_ULP_RX_CTX_SKIP_MA_REQ 0x19284 + +#define S_CLEAR_CTX_ERR_CNT1 3 +#define V_CLEAR_CTX_ERR_CNT1(x) ((x) << S_CLEAR_CTX_ERR_CNT1) +#define F_CLEAR_CTX_ERR_CNT1 V_CLEAR_CTX_ERR_CNT1(1U) + +#define S_CLEAR_CTX_ERR_CNT0 2 +#define V_CLEAR_CTX_ERR_CNT0(x) ((x) << S_CLEAR_CTX_ERR_CNT0) +#define F_CLEAR_CTX_ERR_CNT0 V_CLEAR_CTX_ERR_CNT0(1U) + +#define S_SKIP_MA_REQ_EN1 1 +#define V_SKIP_MA_REQ_EN1(x) ((x) << S_SKIP_MA_REQ_EN1) +#define F_SKIP_MA_REQ_EN1 V_SKIP_MA_REQ_EN1(1U) + +#define S_SKIP_MA_REQ_EN0 0 +#define V_SKIP_MA_REQ_EN0(x) ((x) << S_SKIP_MA_REQ_EN0) +#define F_SKIP_MA_REQ_EN0 V_SKIP_MA_REQ_EN0(1U) + +#define A_ULP_RX_CHNL0_CTX_ERROR_COUNT_PER_TID 0x19288 +#define A_ULP_RX_CHNL1_CTX_ERROR_COUNT_PER_TID 0x1928c +#define A_ULP_RX_MSN_CHECK_ENABLE 0x19290 + +#define S_RD_OR_TERM_MSN_CHECK_ENABLE 2 +#define V_RD_OR_TERM_MSN_CHECK_ENABLE(x) ((x) << S_RD_OR_TERM_MSN_CHECK_ENABLE) +#define F_RD_OR_TERM_MSN_CHECK_ENABLE V_RD_OR_TERM_MSN_CHECK_ENABLE(1U) + +#define S_ATOMIC_OP_MSN_CHECK_ENABLE 1 +#define V_ATOMIC_OP_MSN_CHECK_ENABLE(x) ((x) << S_ATOMIC_OP_MSN_CHECK_ENABLE) +#define F_ATOMIC_OP_MSN_CHECK_ENABLE V_ATOMIC_OP_MSN_CHECK_ENABLE(1U) + +#define S_SEND_MSN_CHECK_ENABLE 0 +#define V_SEND_MSN_CHECK_ENABLE(x) ((x) << S_SEND_MSN_CHECK_ENABLE) +#define F_SEND_MSN_CHECK_ENABLE V_SEND_MSN_CHECK_ENABLE(1U) + +/* registers for module SF */ +#define SF_BASE_ADDR 0x193f8 + +#define A_SF_DATA 0x193f8 +#define A_SF_OP 0x193fc + +#define S_SF_LOCK 4 +#define V_SF_LOCK(x) ((x) << S_SF_LOCK) +#define F_SF_LOCK V_SF_LOCK(1U) + +#define S_CONT 3 +#define V_CONT(x) ((x) << S_CONT) +#define F_CONT V_CONT(1U) + +#define S_BYTECNT 1 +#define M_BYTECNT 0x3U +#define V_BYTECNT(x) ((x) << S_BYTECNT) +#define G_BYTECNT(x) (((x) >> S_BYTECNT) & M_BYTECNT) + +/* registers for module PL */ +#define PL_BASE_ADDR 0x19400 + +#define A_PL_VF_WHOAMI 0x0 + +#define S_PORTXMAP 24 +#define M_PORTXMAP 0x7U +#define V_PORTXMAP(x) ((x) << S_PORTXMAP) +#define G_PORTXMAP(x) (((x) >> S_PORTXMAP) & M_PORTXMAP) + +#define S_SOURCEBUS 16 +#define M_SOURCEBUS 0x3U +#define V_SOURCEBUS(x) ((x) << S_SOURCEBUS) +#define G_SOURCEBUS(x) (((x) >> S_SOURCEBUS) & M_SOURCEBUS) + +#define S_SOURCEPF 8 +#define M_SOURCEPF 0x7U +#define V_SOURCEPF(x) ((x) << S_SOURCEPF) +#define G_SOURCEPF(x) (((x) >> S_SOURCEPF) & M_SOURCEPF) + +#define S_ISVF 7 +#define V_ISVF(x) ((x) << S_ISVF) +#define F_ISVF V_ISVF(1U) + +#define S_VFID 0 +#define M_VFID 0x7fU +#define V_VFID(x) ((x) << S_VFID) +#define G_VFID(x) (((x) >> S_VFID) & M_VFID) + +#define A_PL_VF_REV 0x4 + +#define S_CHIPID 4 +#define M_CHIPID 0xfU +#define V_CHIPID(x) ((x) << S_CHIPID) +#define G_CHIPID(x) (((x) >> S_CHIPID) & M_CHIPID) + +#define A_PL_VF_REVISION 0x8 +#define A_PL_PF_INT_CAUSE 0x3c0 + +#define S_PFSW 3 +#define V_PFSW(x) ((x) << S_PFSW) +#define F_PFSW V_PFSW(1U) + +#define S_PFSGE 2 +#define V_PFSGE(x) ((x) << S_PFSGE) +#define F_PFSGE V_PFSGE(1U) + +#define S_PFCIM 1 +#define V_PFCIM(x) ((x) << S_PFCIM) +#define F_PFCIM V_PFCIM(1U) + +#define S_PFMPS 0 +#define V_PFMPS(x) ((x) << S_PFMPS) +#define F_PFMPS V_PFMPS(1U) + +#define A_PL_PF_INT_ENABLE 0x3c4 +#define A_PL_PF_CTL 0x3c8 + +#define S_SWINT 0 +#define V_SWINT(x) ((x) << S_SWINT) +#define F_SWINT V_SWINT(1U) + +#define A_PL_WHOAMI 0x19400 +#define A_PL_PERR_CAUSE 0x19404 + +#define S_UART 28 +#define V_UART(x) ((x) << S_UART) +#define F_UART V_UART(1U) + +#define S_ULP_TX 27 +#define V_ULP_TX(x) ((x) << S_ULP_TX) +#define F_ULP_TX V_ULP_TX(1U) + +#define S_SGE 26 +#define V_SGE(x) ((x) << S_SGE) +#define F_SGE V_SGE(1U) + +#define S_HMA 25 +#define V_HMA(x) ((x) << S_HMA) +#define F_HMA V_HMA(1U) + +#define S_CPL_SWITCH 24 +#define V_CPL_SWITCH(x) ((x) << S_CPL_SWITCH) +#define F_CPL_SWITCH V_CPL_SWITCH(1U) + +#define S_ULP_RX 23 +#define V_ULP_RX(x) ((x) << S_ULP_RX) +#define F_ULP_RX V_ULP_RX(1U) + +#define S_PM_RX 22 +#define V_PM_RX(x) ((x) << S_PM_RX) +#define F_PM_RX V_PM_RX(1U) + +#define S_PM_TX 21 +#define V_PM_TX(x) ((x) << S_PM_TX) +#define F_PM_TX V_PM_TX(1U) + +#define S_MA 20 +#define V_MA(x) ((x) << S_MA) +#define F_MA V_MA(1U) + +#define S_TP 19 +#define V_TP(x) ((x) << S_TP) +#define F_TP V_TP(1U) + +#define S_LE 18 +#define V_LE(x) ((x) << S_LE) +#define F_LE V_LE(1U) + +#define S_EDC1 17 +#define V_EDC1(x) ((x) << S_EDC1) +#define F_EDC1 V_EDC1(1U) + +#define S_EDC0 16 +#define V_EDC0(x) ((x) << S_EDC0) +#define F_EDC0 V_EDC0(1U) + +#define S_MC 15 +#define V_MC(x) ((x) << S_MC) +#define F_MC V_MC(1U) + +#define S_PCIE 14 +#define V_PCIE(x) ((x) << S_PCIE) +#define F_PCIE V_PCIE(1U) + +#define S_PMU 13 +#define V_PMU(x) ((x) << S_PMU) +#define F_PMU V_PMU(1U) + +#define S_XGMAC_KR1 12 +#define V_XGMAC_KR1(x) ((x) << S_XGMAC_KR1) +#define F_XGMAC_KR1 V_XGMAC_KR1(1U) + +#define S_XGMAC_KR0 11 +#define V_XGMAC_KR0(x) ((x) << S_XGMAC_KR0) +#define F_XGMAC_KR0 V_XGMAC_KR0(1U) + +#define S_XGMAC1 10 +#define V_XGMAC1(x) ((x) << S_XGMAC1) +#define F_XGMAC1 V_XGMAC1(1U) + +#define S_XGMAC0 9 +#define V_XGMAC0(x) ((x) << S_XGMAC0) +#define F_XGMAC0 V_XGMAC0(1U) + +#define S_SMB 8 +#define V_SMB(x) ((x) << S_SMB) +#define F_SMB V_SMB(1U) + +#define S_SF 7 +#define V_SF(x) ((x) << S_SF) +#define F_SF V_SF(1U) + +#define S_PL 6 +#define V_PL(x) ((x) << S_PL) +#define F_PL V_PL(1U) + +#define S_NCSI 5 +#define V_NCSI(x) ((x) << S_NCSI) +#define F_NCSI V_NCSI(1U) + +#define S_MPS 4 +#define V_MPS(x) ((x) << S_MPS) +#define F_MPS V_MPS(1U) + +#define S_MI 3 +#define V_MI(x) ((x) << S_MI) +#define F_MI V_MI(1U) + +#define S_DBG 2 +#define V_DBG(x) ((x) << S_DBG) +#define F_DBG V_DBG(1U) + +#define S_I2CM 1 +#define V_I2CM(x) ((x) << S_I2CM) +#define F_I2CM V_I2CM(1U) + +#define S_CIM 0 +#define V_CIM(x) ((x) << S_CIM) +#define F_CIM V_CIM(1U) + +#define S_MC1 31 +#define V_MC1(x) ((x) << S_MC1) +#define F_MC1 V_MC1(1U) + +#define S_MC0 15 +#define V_MC0(x) ((x) << S_MC0) +#define F_MC0 V_MC0(1U) + +#define S_ANYMAC 9 +#define V_ANYMAC(x) ((x) << S_ANYMAC) +#define F_ANYMAC V_ANYMAC(1U) + +#define A_PL_PERR_ENABLE 0x19408 +#define A_PL_INT_CAUSE 0x1940c + +#define S_FLR 30 +#define V_FLR(x) ((x) << S_FLR) +#define F_FLR V_FLR(1U) + +#define S_SW_CIM 29 +#define V_SW_CIM(x) ((x) << S_SW_CIM) +#define F_SW_CIM V_SW_CIM(1U) + +#define S_MAC3 12 +#define V_MAC3(x) ((x) << S_MAC3) +#define F_MAC3 V_MAC3(1U) + +#define S_MAC2 11 +#define V_MAC2(x) ((x) << S_MAC2) +#define F_MAC2 V_MAC2(1U) + +#define S_MAC1 10 +#define V_MAC1(x) ((x) << S_MAC1) +#define F_MAC1 V_MAC1(1U) + +#define S_MAC0 9 +#define V_MAC0(x) ((x) << S_MAC0) +#define F_MAC0 V_MAC0(1U) + +#define A_PL_INT_ENABLE 0x19410 +#define A_PL_INT_MAP0 0x19414 + +#define S_MAPNCSI 16 +#define M_MAPNCSI 0x1ffU +#define V_MAPNCSI(x) ((x) << S_MAPNCSI) +#define G_MAPNCSI(x) (((x) >> S_MAPNCSI) & M_MAPNCSI) + +#define S_MAPDEFAULT 0 +#define M_MAPDEFAULT 0x1ffU +#define V_MAPDEFAULT(x) ((x) << S_MAPDEFAULT) +#define G_MAPDEFAULT(x) (((x) >> S_MAPDEFAULT) & M_MAPDEFAULT) + +#define A_PL_INT_MAP1 0x19418 + +#define S_MAPXGMAC1 16 +#define M_MAPXGMAC1 0x1ffU +#define V_MAPXGMAC1(x) ((x) << S_MAPXGMAC1) +#define G_MAPXGMAC1(x) (((x) >> S_MAPXGMAC1) & M_MAPXGMAC1) + +#define S_MAPXGMAC0 0 +#define M_MAPXGMAC0 0x1ffU +#define V_MAPXGMAC0(x) ((x) << S_MAPXGMAC0) +#define G_MAPXGMAC0(x) (((x) >> S_MAPXGMAC0) & M_MAPXGMAC0) + +#define S_MAPMAC1 16 +#define M_MAPMAC1 0x1ffU +#define V_MAPMAC1(x) ((x) << S_MAPMAC1) +#define G_MAPMAC1(x) (((x) >> S_MAPMAC1) & M_MAPMAC1) + +#define S_MAPMAC0 0 +#define M_MAPMAC0 0x1ffU +#define V_MAPMAC0(x) ((x) << S_MAPMAC0) +#define G_MAPMAC0(x) (((x) >> S_MAPMAC0) & M_MAPMAC0) + +#define A_PL_INT_MAP2 0x1941c + +#define S_MAPXGMAC_KR1 16 +#define M_MAPXGMAC_KR1 0x1ffU +#define V_MAPXGMAC_KR1(x) ((x) << S_MAPXGMAC_KR1) +#define G_MAPXGMAC_KR1(x) (((x) >> S_MAPXGMAC_KR1) & M_MAPXGMAC_KR1) + +#define S_MAPXGMAC_KR0 0 +#define M_MAPXGMAC_KR0 0x1ffU +#define V_MAPXGMAC_KR0(x) ((x) << S_MAPXGMAC_KR0) +#define G_MAPXGMAC_KR0(x) (((x) >> S_MAPXGMAC_KR0) & M_MAPXGMAC_KR0) + +#define S_MAPMAC3 16 +#define M_MAPMAC3 0x1ffU +#define V_MAPMAC3(x) ((x) << S_MAPMAC3) +#define G_MAPMAC3(x) (((x) >> S_MAPMAC3) & M_MAPMAC3) + +#define S_MAPMAC2 0 +#define M_MAPMAC2 0x1ffU +#define V_MAPMAC2(x) ((x) << S_MAPMAC2) +#define G_MAPMAC2(x) (((x) >> S_MAPMAC2) & M_MAPMAC2) + +#define A_PL_INT_MAP3 0x19420 + +#define S_MAPMI 16 +#define M_MAPMI 0x1ffU +#define V_MAPMI(x) ((x) << S_MAPMI) +#define G_MAPMI(x) (((x) >> S_MAPMI) & M_MAPMI) + +#define S_MAPSMB 0 +#define M_MAPSMB 0x1ffU +#define V_MAPSMB(x) ((x) << S_MAPSMB) +#define G_MAPSMB(x) (((x) >> S_MAPSMB) & M_MAPSMB) + +#define A_PL_INT_MAP4 0x19424 + +#define S_MAPDBG 16 +#define M_MAPDBG 0x1ffU +#define V_MAPDBG(x) ((x) << S_MAPDBG) +#define G_MAPDBG(x) (((x) >> S_MAPDBG) & M_MAPDBG) + +#define S_MAPI2CM 0 +#define M_MAPI2CM 0x1ffU +#define V_MAPI2CM(x) ((x) << S_MAPI2CM) +#define G_MAPI2CM(x) (((x) >> S_MAPI2CM) & M_MAPI2CM) + +#define A_PL_RST 0x19428 + +#define S_FATALPERREN 3 +#define V_FATALPERREN(x) ((x) << S_FATALPERREN) +#define F_FATALPERREN V_FATALPERREN(1U) + +#define S_SWINTCIM 2 +#define V_SWINTCIM(x) ((x) << S_SWINTCIM) +#define F_SWINTCIM V_SWINTCIM(1U) + +#define S_PIORST 1 +#define V_PIORST(x) ((x) << S_PIORST) +#define F_PIORST V_PIORST(1U) + +#define S_PIORSTMODE 0 +#define V_PIORSTMODE(x) ((x) << S_PIORSTMODE) +#define F_PIORSTMODE V_PIORSTMODE(1U) + +#define S_AUTOPCIEPAUSE 4 +#define V_AUTOPCIEPAUSE(x) ((x) << S_AUTOPCIEPAUSE) +#define F_AUTOPCIEPAUSE V_AUTOPCIEPAUSE(1U) + +#define A_PL_PL_PERR_INJECT 0x1942c + +#define S_PL_MEMSEL 1 +#define V_PL_MEMSEL(x) ((x) << S_PL_MEMSEL) +#define F_PL_MEMSEL V_PL_MEMSEL(1U) + +#define A_PL_PL_INT_CAUSE 0x19430 + +#define S_PF_ENABLEERR 5 +#define V_PF_ENABLEERR(x) ((x) << S_PF_ENABLEERR) +#define F_PF_ENABLEERR V_PF_ENABLEERR(1U) + +#define S_FATALPERR 4 +#define V_FATALPERR(x) ((x) << S_FATALPERR) +#define F_FATALPERR V_FATALPERR(1U) + +#define S_INVALIDACCESS 3 +#define V_INVALIDACCESS(x) ((x) << S_INVALIDACCESS) +#define F_INVALIDACCESS V_INVALIDACCESS(1U) + +#define S_TIMEOUT 2 +#define V_TIMEOUT(x) ((x) << S_TIMEOUT) +#define F_TIMEOUT V_TIMEOUT(1U) + +#define S_PLERR 1 +#define V_PLERR(x) ((x) << S_PLERR) +#define F_PLERR V_PLERR(1U) + +#define S_PERRVFID 0 +#define V_PERRVFID(x) ((x) << S_PERRVFID) +#define F_PERRVFID V_PERRVFID(1U) + +#define S_PL_BUSPERR 6 +#define V_PL_BUSPERR(x) ((x) << S_PL_BUSPERR) +#define F_PL_BUSPERR V_PL_BUSPERR(1U) + +#define A_PL_PL_INT_ENABLE 0x19434 +#define A_PL_PL_PERR_ENABLE 0x19438 +#define A_PL_REV 0x1943c + +#define S_REV 0 +#define M_REV 0xfU +#define V_REV(x) ((x) << S_REV) +#define G_REV(x) (((x) >> S_REV) & M_REV) + +#define A_PL_PCIE_LINK 0x19440 + +#define S_LN0_AESTAT 26 +#define M_LN0_AESTAT 0x7U +#define V_LN0_AESTAT(x) ((x) << S_LN0_AESTAT) +#define G_LN0_AESTAT(x) (((x) >> S_LN0_AESTAT) & M_LN0_AESTAT) + +#define S_LN0_AECMD 23 +#define M_LN0_AECMD 0x7U +#define V_LN0_AECMD(x) ((x) << S_LN0_AECMD) +#define G_LN0_AECMD(x) (((x) >> S_LN0_AECMD) & M_LN0_AECMD) + +#define S_PCIE_SPEED 8 +#define M_PCIE_SPEED 0x3U +#define V_PCIE_SPEED(x) ((x) << S_PCIE_SPEED) +#define G_PCIE_SPEED(x) (((x) >> S_PCIE_SPEED) & M_PCIE_SPEED) + +#define S_LTSSM 0 +#define M_LTSSM 0x3fU +#define V_LTSSM(x) ((x) << S_LTSSM) +#define G_LTSSM(x) (((x) >> S_LTSSM) & M_LTSSM) + +#define A_PL_PCIE_CTL_STAT 0x19444 + +#define S_PCIE_STATUS 16 +#define M_PCIE_STATUS 0xffffU +#define V_PCIE_STATUS(x) ((x) << S_PCIE_STATUS) +#define G_PCIE_STATUS(x) (((x) >> S_PCIE_STATUS) & M_PCIE_STATUS) + +#define S_PCIE_CONTROL 0 +#define M_PCIE_CONTROL 0xffffU +#define V_PCIE_CONTROL(x) ((x) << S_PCIE_CONTROL) +#define G_PCIE_CONTROL(x) (((x) >> S_PCIE_CONTROL) & M_PCIE_CONTROL) + +#define A_PL_SEMAPHORE_CTL 0x1944c + +#define S_LOCKSTATUS 16 +#define M_LOCKSTATUS 0xffU +#define V_LOCKSTATUS(x) ((x) << S_LOCKSTATUS) +#define G_LOCKSTATUS(x) (((x) >> S_LOCKSTATUS) & M_LOCKSTATUS) + +#define S_OWNEROVERRIDE 8 +#define V_OWNEROVERRIDE(x) ((x) << S_OWNEROVERRIDE) +#define F_OWNEROVERRIDE V_OWNEROVERRIDE(1U) + +#define S_ENABLEPF 0 +#define M_ENABLEPF 0xffU +#define V_ENABLEPF(x) ((x) << S_ENABLEPF) +#define G_ENABLEPF(x) (((x) >> S_ENABLEPF) & M_ENABLEPF) + +#define A_PL_SEMAPHORE_LOCK 0x19450 + +#define S_SEMLOCK 31 +#define V_SEMLOCK(x) ((x) << S_SEMLOCK) +#define F_SEMLOCK V_SEMLOCK(1U) + +#define S_SEMSRCBUS 3 +#define M_SEMSRCBUS 0x3U +#define V_SEMSRCBUS(x) ((x) << S_SEMSRCBUS) +#define G_SEMSRCBUS(x) (((x) >> S_SEMSRCBUS) & M_SEMSRCBUS) + +#define S_SEMSRCPF 0 +#define M_SEMSRCPF 0x7U +#define V_SEMSRCPF(x) ((x) << S_SEMSRCPF) +#define G_SEMSRCPF(x) (((x) >> S_SEMSRCPF) & M_SEMSRCPF) + +#define A_PL_PF_ENABLE 0x19470 + +#define S_PF_ENABLE 0 +#define M_PF_ENABLE 0xffU +#define V_PF_ENABLE(x) ((x) << S_PF_ENABLE) +#define G_PF_ENABLE(x) (((x) >> S_PF_ENABLE) & M_PF_ENABLE) + +#define A_PL_PORTX_MAP 0x19474 + +#define S_MAP7 28 +#define M_MAP7 0x7U +#define V_MAP7(x) ((x) << S_MAP7) +#define G_MAP7(x) (((x) >> S_MAP7) & M_MAP7) + +#define S_MAP6 24 +#define M_MAP6 0x7U +#define V_MAP6(x) ((x) << S_MAP6) +#define G_MAP6(x) (((x) >> S_MAP6) & M_MAP6) + +#define S_MAP5 20 +#define M_MAP5 0x7U +#define V_MAP5(x) ((x) << S_MAP5) +#define G_MAP5(x) (((x) >> S_MAP5) & M_MAP5) + +#define S_MAP4 16 +#define M_MAP4 0x7U +#define V_MAP4(x) ((x) << S_MAP4) +#define G_MAP4(x) (((x) >> S_MAP4) & M_MAP4) + +#define S_MAP3 12 +#define M_MAP3 0x7U +#define V_MAP3(x) ((x) << S_MAP3) +#define G_MAP3(x) (((x) >> S_MAP3) & M_MAP3) + +#define S_MAP2 8 +#define M_MAP2 0x7U +#define V_MAP2(x) ((x) << S_MAP2) +#define G_MAP2(x) (((x) >> S_MAP2) & M_MAP2) + +#define S_MAP1 4 +#define M_MAP1 0x7U +#define V_MAP1(x) ((x) << S_MAP1) +#define G_MAP1(x) (((x) >> S_MAP1) & M_MAP1) + +#define S_MAP0 0 +#define M_MAP0 0x7U +#define V_MAP0(x) ((x) << S_MAP0) +#define G_MAP0(x) (((x) >> S_MAP0) & M_MAP0) + +#define A_PL_VF_SLICE_L 0x19490 + +#define S_LIMITADDR 16 +#define M_LIMITADDR 0x3ffU +#define V_LIMITADDR(x) ((x) << S_LIMITADDR) +#define G_LIMITADDR(x) (((x) >> S_LIMITADDR) & M_LIMITADDR) + +#define S_SLICEBASEADDR 0 +#define M_SLICEBASEADDR 0x3ffU +#define V_SLICEBASEADDR(x) ((x) << S_SLICEBASEADDR) +#define G_SLICEBASEADDR(x) (((x) >> S_SLICEBASEADDR) & M_SLICEBASEADDR) + +#define A_PL_VF_SLICE_H 0x19494 + +#define S_MODINDX 16 +#define M_MODINDX 0x7U +#define V_MODINDX(x) ((x) << S_MODINDX) +#define G_MODINDX(x) (((x) >> S_MODINDX) & M_MODINDX) + +#define S_MODOFFSET 0 +#define M_MODOFFSET 0x3ffU +#define V_MODOFFSET(x) ((x) << S_MODOFFSET) +#define G_MODOFFSET(x) (((x) >> S_MODOFFSET) & M_MODOFFSET) + +#define A_PL_FLR_VF_STATUS 0x194d0 +#define A_PL_FLR_PF_STATUS 0x194e0 + +#define S_FLR_PF 0 +#define M_FLR_PF 0xffU +#define V_FLR_PF(x) ((x) << S_FLR_PF) +#define G_FLR_PF(x) (((x) >> S_FLR_PF) & M_FLR_PF) + +#define A_PL_TIMEOUT_CTL 0x194f0 + +#define S_PL_TIMEOUT 0 +#define M_PL_TIMEOUT 0xffffU +#define V_PL_TIMEOUT(x) ((x) << S_PL_TIMEOUT) +#define G_PL_TIMEOUT(x) (((x) >> S_PL_TIMEOUT) & M_PL_TIMEOUT) + +#define S_PERRCAPTURE 16 +#define V_PERRCAPTURE(x) ((x) << S_PERRCAPTURE) +#define F_PERRCAPTURE V_PERRCAPTURE(1U) + +#define A_PL_TIMEOUT_STATUS0 0x194f4 + +#define S_PL_TOADDR 2 +#define M_PL_TOADDR 0xfffffffU +#define V_PL_TOADDR(x) ((x) << S_PL_TOADDR) +#define G_PL_TOADDR(x) (((x) >> S_PL_TOADDR) & M_PL_TOADDR) + +#define A_PL_TIMEOUT_STATUS1 0x194f8 + +#define S_PL_TOVALID 31 +#define V_PL_TOVALID(x) ((x) << S_PL_TOVALID) +#define F_PL_TOVALID V_PL_TOVALID(1U) + +#define S_WRITE 22 +#define V_WRITE(x) ((x) << S_WRITE) +#define F_WRITE V_WRITE(1U) + +#define S_PL_TOBUS 20 +#define M_PL_TOBUS 0x3U +#define V_PL_TOBUS(x) ((x) << S_PL_TOBUS) +#define G_PL_TOBUS(x) (((x) >> S_PL_TOBUS) & M_PL_TOBUS) + +#define S_RGN 19 +#define V_RGN(x) ((x) << S_RGN) +#define F_RGN V_RGN(1U) + +#define S_PL_TOPF 16 +#define M_PL_TOPF 0x7U +#define V_PL_TOPF(x) ((x) << S_PL_TOPF) +#define G_PL_TOPF(x) (((x) >> S_PL_TOPF) & M_PL_TOPF) + +#define S_PL_TORID 0 +#define M_PL_TORID 0xffffU +#define V_PL_TORID(x) ((x) << S_PL_TORID) +#define G_PL_TORID(x) (((x) >> S_PL_TORID) & M_PL_TORID) + +#define S_VALIDPERR 30 +#define V_VALIDPERR(x) ((x) << S_VALIDPERR) +#define F_VALIDPERR V_VALIDPERR(1U) + +#define S_PL_TOVFID 0 +#define M_PL_TOVFID 0xffU +#define V_PL_TOVFID(x) ((x) << S_PL_TOVFID) +#define G_PL_TOVFID(x) (((x) >> S_PL_TOVFID) & M_PL_TOVFID) + +#define A_PL_VFID_MAP 0x19800 + +#define S_VFID_VLD 7 +#define V_VFID_VLD(x) ((x) << S_VFID_VLD) +#define F_VFID_VLD V_VFID_VLD(1U) + +/* registers for module LE */ +#define LE_BASE_ADDR 0x19c00 + +#define A_LE_BUF_CONFIG 0x19c00 +#define A_LE_DB_CONFIG 0x19c04 + +#define S_TCAMCMDOVLAPEN 21 +#define V_TCAMCMDOVLAPEN(x) ((x) << S_TCAMCMDOVLAPEN) +#define F_TCAMCMDOVLAPEN V_TCAMCMDOVLAPEN(1U) + +#define S_HASHEN 20 +#define V_HASHEN(x) ((x) << S_HASHEN) +#define F_HASHEN V_HASHEN(1U) + +#define S_ASBOTHSRCHEN 18 +#define V_ASBOTHSRCHEN(x) ((x) << S_ASBOTHSRCHEN) +#define F_ASBOTHSRCHEN V_ASBOTHSRCHEN(1U) + +#define S_ASLIPCOMPEN 17 +#define V_ASLIPCOMPEN(x) ((x) << S_ASLIPCOMPEN) +#define F_ASLIPCOMPEN V_ASLIPCOMPEN(1U) + +#define S_BUILD 16 +#define V_BUILD(x) ((x) << S_BUILD) +#define F_BUILD V_BUILD(1U) + +#define S_FILTEREN 11 +#define V_FILTEREN(x) ((x) << S_FILTEREN) +#define F_FILTEREN V_FILTEREN(1U) + +#define S_SYNMODE 7 +#define M_SYNMODE 0x3U +#define V_SYNMODE(x) ((x) << S_SYNMODE) +#define G_SYNMODE(x) (((x) >> S_SYNMODE) & M_SYNMODE) + +#define S_LEBUSEN 5 +#define V_LEBUSEN(x) ((x) << S_LEBUSEN) +#define F_LEBUSEN V_LEBUSEN(1U) + +#define S_ELOOKDUMEN 4 +#define V_ELOOKDUMEN(x) ((x) << S_ELOOKDUMEN) +#define F_ELOOKDUMEN V_ELOOKDUMEN(1U) + +#define S_IPV4ONLYEN 3 +#define V_IPV4ONLYEN(x) ((x) << S_IPV4ONLYEN) +#define F_IPV4ONLYEN V_IPV4ONLYEN(1U) + +#define S_MOSTCMDOEN 2 +#define V_MOSTCMDOEN(x) ((x) << S_MOSTCMDOEN) +#define F_MOSTCMDOEN V_MOSTCMDOEN(1U) + +#define S_DELACTSYNOEN 1 +#define V_DELACTSYNOEN(x) ((x) << S_DELACTSYNOEN) +#define F_DELACTSYNOEN V_DELACTSYNOEN(1U) + +#define S_CMDOVERLAPDIS 0 +#define V_CMDOVERLAPDIS(x) ((x) << S_CMDOVERLAPDIS) +#define F_CMDOVERLAPDIS V_CMDOVERLAPDIS(1U) + +#define S_MASKCMDOLAPDIS 26 +#define V_MASKCMDOLAPDIS(x) ((x) << S_MASKCMDOLAPDIS) +#define F_MASKCMDOLAPDIS V_MASKCMDOLAPDIS(1U) + +#define S_IPV4HASHSIZEEN 25 +#define V_IPV4HASHSIZEEN(x) ((x) << S_IPV4HASHSIZEEN) +#define F_IPV4HASHSIZEEN V_IPV4HASHSIZEEN(1U) + +#define S_PROTOCOLMASKEN 24 +#define V_PROTOCOLMASKEN(x) ((x) << S_PROTOCOLMASKEN) +#define F_PROTOCOLMASKEN V_PROTOCOLMASKEN(1U) + +#define S_TUPLESIZEEN 23 +#define V_TUPLESIZEEN(x) ((x) << S_TUPLESIZEEN) +#define F_TUPLESIZEEN V_TUPLESIZEEN(1U) + +#define S_SRVRSRAMEN 22 +#define V_SRVRSRAMEN(x) ((x) << S_SRVRSRAMEN) +#define F_SRVRSRAMEN V_SRVRSRAMEN(1U) + +#define S_ASBOTHSRCHENPR 19 +#define V_ASBOTHSRCHENPR(x) ((x) << S_ASBOTHSRCHENPR) +#define F_ASBOTHSRCHENPR V_ASBOTHSRCHENPR(1U) + +#define S_POCLIPTID0 15 +#define V_POCLIPTID0(x) ((x) << S_POCLIPTID0) +#define F_POCLIPTID0 V_POCLIPTID0(1U) + +#define S_TCAMARBOFF 14 +#define V_TCAMARBOFF(x) ((x) << S_TCAMARBOFF) +#define F_TCAMARBOFF V_TCAMARBOFF(1U) + +#define S_ACCNTFULLEN 13 +#define V_ACCNTFULLEN(x) ((x) << S_ACCNTFULLEN) +#define F_ACCNTFULLEN V_ACCNTFULLEN(1U) + +#define S_FILTERRWNOCLIP 12 +#define V_FILTERRWNOCLIP(x) ((x) << S_FILTERRWNOCLIP) +#define F_FILTERRWNOCLIP V_FILTERRWNOCLIP(1U) + +#define S_CRCHASH 10 +#define V_CRCHASH(x) ((x) << S_CRCHASH) +#define F_CRCHASH V_CRCHASH(1U) + +#define S_COMPTID 9 +#define V_COMPTID(x) ((x) << S_COMPTID) +#define F_COMPTID V_COMPTID(1U) + +#define S_SINGLETHREAD 6 +#define V_SINGLETHREAD(x) ((x) << S_SINGLETHREAD) +#define F_SINGLETHREAD V_SINGLETHREAD(1U) + +#define A_LE_MISC 0x19c08 + +#define S_CMPUNVAIL 0 +#define M_CMPUNVAIL 0xfU +#define V_CMPUNVAIL(x) ((x) << S_CMPUNVAIL) +#define G_CMPUNVAIL(x) (((x) >> S_CMPUNVAIL) & M_CMPUNVAIL) + +#define S_SRAMDEEPSLEEP_STAT 11 +#define V_SRAMDEEPSLEEP_STAT(x) ((x) << S_SRAMDEEPSLEEP_STAT) +#define F_SRAMDEEPSLEEP_STAT V_SRAMDEEPSLEEP_STAT(1U) + +#define S_TCAMDEEPSLEEP1_STAT 10 +#define V_TCAMDEEPSLEEP1_STAT(x) ((x) << S_TCAMDEEPSLEEP1_STAT) +#define F_TCAMDEEPSLEEP1_STAT V_TCAMDEEPSLEEP1_STAT(1U) + +#define S_TCAMDEEPSLEEP0_STAT 9 +#define V_TCAMDEEPSLEEP0_STAT(x) ((x) << S_TCAMDEEPSLEEP0_STAT) +#define F_TCAMDEEPSLEEP0_STAT V_TCAMDEEPSLEEP0_STAT(1U) + +#define S_SRAMDEEPSLEEP 8 +#define V_SRAMDEEPSLEEP(x) ((x) << S_SRAMDEEPSLEEP) +#define F_SRAMDEEPSLEEP V_SRAMDEEPSLEEP(1U) + +#define S_TCAMDEEPSLEEP1 7 +#define V_TCAMDEEPSLEEP1(x) ((x) << S_TCAMDEEPSLEEP1) +#define F_TCAMDEEPSLEEP1 V_TCAMDEEPSLEEP1(1U) + +#define S_TCAMDEEPSLEEP0 6 +#define V_TCAMDEEPSLEEP0(x) ((x) << S_TCAMDEEPSLEEP0) +#define F_TCAMDEEPSLEEP0 V_TCAMDEEPSLEEP0(1U) + +#define S_SRVRAMCLKOFF 5 +#define V_SRVRAMCLKOFF(x) ((x) << S_SRVRAMCLKOFF) +#define F_SRVRAMCLKOFF V_SRVRAMCLKOFF(1U) + +#define S_HASHCLKOFF 4 +#define V_HASHCLKOFF(x) ((x) << S_HASHCLKOFF) +#define F_HASHCLKOFF V_HASHCLKOFF(1U) + +#define A_LE_DB_ROUTING_TABLE_INDEX 0x19c10 + +#define S_RTINDX 7 +#define M_RTINDX 0x3fU +#define V_RTINDX(x) ((x) << S_RTINDX) +#define G_RTINDX(x) (((x) >> S_RTINDX) & M_RTINDX) + +#define A_LE_DB_FILTER_TABLE_INDEX 0x19c14 + +#define S_FTINDX 7 +#define M_FTINDX 0x3fU +#define V_FTINDX(x) ((x) << S_FTINDX) +#define G_FTINDX(x) (((x) >> S_FTINDX) & M_FTINDX) + +#define A_LE_DB_SERVER_INDEX 0x19c18 + +#define S_SRINDX 7 +#define M_SRINDX 0x3fU +#define V_SRINDX(x) ((x) << S_SRINDX) +#define G_SRINDX(x) (((x) >> S_SRINDX) & M_SRINDX) + +#define A_LE_DB_CLIP_TABLE_INDEX 0x19c1c + +#define S_CLIPTINDX 7 +#define M_CLIPTINDX 0x3fU +#define V_CLIPTINDX(x) ((x) << S_CLIPTINDX) +#define G_CLIPTINDX(x) (((x) >> S_CLIPTINDX) & M_CLIPTINDX) + +#define A_LE_DB_ACT_CNT_IPV4 0x19c20 + +#define S_ACTCNTIPV4 0 +#define M_ACTCNTIPV4 0xfffffU +#define V_ACTCNTIPV4(x) ((x) << S_ACTCNTIPV4) +#define G_ACTCNTIPV4(x) (((x) >> S_ACTCNTIPV4) & M_ACTCNTIPV4) + +#define A_LE_DB_ACT_CNT_IPV6 0x19c24 + +#define S_ACTCNTIPV6 0 +#define M_ACTCNTIPV6 0xfffffU +#define V_ACTCNTIPV6(x) ((x) << S_ACTCNTIPV6) +#define G_ACTCNTIPV6(x) (((x) >> S_ACTCNTIPV6) & M_ACTCNTIPV6) + +#define A_LE_DB_HASH_CONFIG 0x19c28 + +#define S_HASHTIDSIZE 16 +#define M_HASHTIDSIZE 0x3fU +#define V_HASHTIDSIZE(x) ((x) << S_HASHTIDSIZE) +#define G_HASHTIDSIZE(x) (((x) >> S_HASHTIDSIZE) & M_HASHTIDSIZE) + +#define S_HASHSIZE 0 +#define M_HASHSIZE 0x3fU +#define V_HASHSIZE(x) ((x) << S_HASHSIZE) +#define G_HASHSIZE(x) (((x) >> S_HASHSIZE) & M_HASHSIZE) + +#define A_LE_DB_HASH_TABLE_BASE 0x19c2c +#define A_LE_DB_HASH_TID_BASE 0x19c30 +#define A_LE_DB_SIZE 0x19c34 +#define A_LE_DB_INT_ENABLE 0x19c38 + +#define S_MSGSEL 27 +#define M_MSGSEL 0x1fU +#define V_MSGSEL(x) ((x) << S_MSGSEL) +#define G_MSGSEL(x) (((x) >> S_MSGSEL) & M_MSGSEL) + +#define S_REQQPARERR 16 +#define V_REQQPARERR(x) ((x) << S_REQQPARERR) +#define F_REQQPARERR V_REQQPARERR(1U) + +#define S_UNKNOWNCMD 15 +#define V_UNKNOWNCMD(x) ((x) << S_UNKNOWNCMD) +#define F_UNKNOWNCMD V_UNKNOWNCMD(1U) + +#define S_DROPFILTERHIT 13 +#define V_DROPFILTERHIT(x) ((x) << S_DROPFILTERHIT) +#define F_DROPFILTERHIT V_DROPFILTERHIT(1U) + +#define S_FILTERHIT 12 +#define V_FILTERHIT(x) ((x) << S_FILTERHIT) +#define F_FILTERHIT V_FILTERHIT(1U) + +#define S_SYNCOOKIEOFF 11 +#define V_SYNCOOKIEOFF(x) ((x) << S_SYNCOOKIEOFF) +#define F_SYNCOOKIEOFF V_SYNCOOKIEOFF(1U) + +#define S_SYNCOOKIEBAD 10 +#define V_SYNCOOKIEBAD(x) ((x) << S_SYNCOOKIEBAD) +#define F_SYNCOOKIEBAD V_SYNCOOKIEBAD(1U) + +#define S_SYNCOOKIE 9 +#define V_SYNCOOKIE(x) ((x) << S_SYNCOOKIE) +#define F_SYNCOOKIE V_SYNCOOKIE(1U) + +#define S_NFASRCHFAIL 8 +#define V_NFASRCHFAIL(x) ((x) << S_NFASRCHFAIL) +#define F_NFASRCHFAIL V_NFASRCHFAIL(1U) + +#define S_ACTRGNFULL 7 +#define V_ACTRGNFULL(x) ((x) << S_ACTRGNFULL) +#define F_ACTRGNFULL V_ACTRGNFULL(1U) + +#define S_PARITYERR 6 +#define V_PARITYERR(x) ((x) << S_PARITYERR) +#define F_PARITYERR V_PARITYERR(1U) + +#define S_LIPMISS 5 +#define V_LIPMISS(x) ((x) << S_LIPMISS) +#define F_LIPMISS V_LIPMISS(1U) + +#define S_LIP0 4 +#define V_LIP0(x) ((x) << S_LIP0) +#define F_LIP0 V_LIP0(1U) + +#define S_MISS 3 +#define V_MISS(x) ((x) << S_MISS) +#define F_MISS V_MISS(1U) + +#define S_ROUTINGHIT 2 +#define V_ROUTINGHIT(x) ((x) << S_ROUTINGHIT) +#define F_ROUTINGHIT V_ROUTINGHIT(1U) + +#define S_ACTIVEHIT 1 +#define V_ACTIVEHIT(x) ((x) << S_ACTIVEHIT) +#define F_ACTIVEHIT V_ACTIVEHIT(1U) + +#define S_SERVERHIT 0 +#define V_SERVERHIT(x) ((x) << S_SERVERHIT) +#define F_SERVERHIT V_SERVERHIT(1U) + +#define S_ACTCNTIPV6TZERO 21 +#define V_ACTCNTIPV6TZERO(x) ((x) << S_ACTCNTIPV6TZERO) +#define F_ACTCNTIPV6TZERO V_ACTCNTIPV6TZERO(1U) + +#define S_ACTCNTIPV4TZERO 20 +#define V_ACTCNTIPV4TZERO(x) ((x) << S_ACTCNTIPV4TZERO) +#define F_ACTCNTIPV4TZERO V_ACTCNTIPV4TZERO(1U) + +#define S_ACTCNTIPV6ZERO 19 +#define V_ACTCNTIPV6ZERO(x) ((x) << S_ACTCNTIPV6ZERO) +#define F_ACTCNTIPV6ZERO V_ACTCNTIPV6ZERO(1U) + +#define S_ACTCNTIPV4ZERO 18 +#define V_ACTCNTIPV4ZERO(x) ((x) << S_ACTCNTIPV4ZERO) +#define F_ACTCNTIPV4ZERO V_ACTCNTIPV4ZERO(1U) + +#define S_MARSPPARERR 17 +#define V_MARSPPARERR(x) ((x) << S_MARSPPARERR) +#define F_MARSPPARERR V_MARSPPARERR(1U) + +#define S_VFPARERR 14 +#define V_VFPARERR(x) ((x) << S_VFPARERR) +#define F_VFPARERR V_VFPARERR(1U) + +#define A_LE_DB_INT_CAUSE 0x19c3c +#define A_LE_DB_INT_TID 0x19c40 + +#define S_INTTID 0 +#define M_INTTID 0xfffffU +#define V_INTTID(x) ((x) << S_INTTID) +#define G_INTTID(x) (((x) >> S_INTTID) & M_INTTID) + +#define A_LE_DB_INT_PTID 0x19c44 + +#define S_INTPTID 0 +#define M_INTPTID 0xfffffU +#define V_INTPTID(x) ((x) << S_INTPTID) +#define G_INTPTID(x) (((x) >> S_INTPTID) & M_INTPTID) + +#define A_LE_DB_INT_INDEX 0x19c48 + +#define S_INTINDEX 0 +#define M_INTINDEX 0xfffffU +#define V_INTINDEX(x) ((x) << S_INTINDEX) +#define G_INTINDEX(x) (((x) >> S_INTINDEX) & M_INTINDEX) + +#define A_LE_DB_INT_CMD 0x19c4c + +#define S_INTCMD 0 +#define M_INTCMD 0xfU +#define V_INTCMD(x) ((x) << S_INTCMD) +#define G_INTCMD(x) (((x) >> S_INTCMD) & M_INTCMD) + +#define A_LE_DB_MASK_IPV4 0x19c50 +#define A_LE_T5_DB_MASK_IPV4 0x19c50 +#define A_LE_DB_ACT_CNT_IPV4_TCAM 0x19c94 +#define A_LE_DB_ACT_CNT_IPV6_TCAM 0x19c98 +#define A_LE_ACT_CNT_THRSH 0x19c9c + +#define S_ACT_CNT_THRSH 0 +#define M_ACT_CNT_THRSH 0x1fffffU +#define V_ACT_CNT_THRSH(x) ((x) << S_ACT_CNT_THRSH) +#define G_ACT_CNT_THRSH(x) (((x) >> S_ACT_CNT_THRSH) & M_ACT_CNT_THRSH) + +#define A_LE_DB_MASK_IPV6 0x19ca0 +#define A_LE_DB_REQ_RSP_CNT 0x19ce4 + +#define S_RSPCNTLE 16 +#define M_RSPCNTLE 0xffffU +#define V_RSPCNTLE(x) ((x) << S_RSPCNTLE) +#define G_RSPCNTLE(x) (((x) >> S_RSPCNTLE) & M_RSPCNTLE) + +#define S_REQCNTLE 0 +#define M_REQCNTLE 0xffffU +#define V_REQCNTLE(x) ((x) << S_REQCNTLE) +#define G_REQCNTLE(x) (((x) >> S_REQCNTLE) & M_REQCNTLE) + +#define A_LE_DB_DBGI_CONFIG 0x19cf0 + +#define S_DBGICMDPERR 31 +#define V_DBGICMDPERR(x) ((x) << S_DBGICMDPERR) +#define F_DBGICMDPERR V_DBGICMDPERR(1U) + +#define S_DBGICMDRANGE 22 +#define M_DBGICMDRANGE 0x7U +#define V_DBGICMDRANGE(x) ((x) << S_DBGICMDRANGE) +#define G_DBGICMDRANGE(x) (((x) >> S_DBGICMDRANGE) & M_DBGICMDRANGE) + +#define S_DBGICMDMSKTYPE 21 +#define V_DBGICMDMSKTYPE(x) ((x) << S_DBGICMDMSKTYPE) +#define F_DBGICMDMSKTYPE V_DBGICMDMSKTYPE(1U) + +#define S_DBGICMDSEARCH 20 +#define V_DBGICMDSEARCH(x) ((x) << S_DBGICMDSEARCH) +#define F_DBGICMDSEARCH V_DBGICMDSEARCH(1U) + +#define S_DBGICMDREAD 19 +#define V_DBGICMDREAD(x) ((x) << S_DBGICMDREAD) +#define F_DBGICMDREAD V_DBGICMDREAD(1U) + +#define S_DBGICMDLEARN 18 +#define V_DBGICMDLEARN(x) ((x) << S_DBGICMDLEARN) +#define F_DBGICMDLEARN V_DBGICMDLEARN(1U) + +#define S_DBGICMDERASE 17 +#define V_DBGICMDERASE(x) ((x) << S_DBGICMDERASE) +#define F_DBGICMDERASE V_DBGICMDERASE(1U) + +#define S_DBGICMDIPV6 16 +#define V_DBGICMDIPV6(x) ((x) << S_DBGICMDIPV6) +#define F_DBGICMDIPV6 V_DBGICMDIPV6(1U) + +#define S_DBGICMDTYPE 13 +#define M_DBGICMDTYPE 0x7U +#define V_DBGICMDTYPE(x) ((x) << S_DBGICMDTYPE) +#define G_DBGICMDTYPE(x) (((x) >> S_DBGICMDTYPE) & M_DBGICMDTYPE) + +#define S_DBGICMDACKERR 12 +#define V_DBGICMDACKERR(x) ((x) << S_DBGICMDACKERR) +#define F_DBGICMDACKERR V_DBGICMDACKERR(1U) + +#define S_DBGICMDBUSY 3 +#define V_DBGICMDBUSY(x) ((x) << S_DBGICMDBUSY) +#define F_DBGICMDBUSY V_DBGICMDBUSY(1U) + +#define S_DBGICMDSTRT 2 +#define V_DBGICMDSTRT(x) ((x) << S_DBGICMDSTRT) +#define F_DBGICMDSTRT V_DBGICMDSTRT(1U) + +#define S_DBGICMDMODE 0 +#define M_DBGICMDMODE 0x3U +#define V_DBGICMDMODE(x) ((x) << S_DBGICMDMODE) +#define G_DBGICMDMODE(x) (((x) >> S_DBGICMDMODE) & M_DBGICMDMODE) + +#define A_LE_DB_DBGI_REQ_TCAM_CMD 0x19cf4 + +#define S_DBGICMD 20 +#define M_DBGICMD 0xfU +#define V_DBGICMD(x) ((x) << S_DBGICMD) +#define G_DBGICMD(x) (((x) >> S_DBGICMD) & M_DBGICMD) + +#define S_DBGITINDEX 0 +#define M_DBGITINDEX 0xfffffU +#define V_DBGITINDEX(x) ((x) << S_DBGITINDEX) +#define G_DBGITINDEX(x) (((x) >> S_DBGITINDEX) & M_DBGITINDEX) + +#define A_LE_PERR_ENABLE 0x19cf8 + +#define S_REQQUEUE 1 +#define V_REQQUEUE(x) ((x) << S_REQQUEUE) +#define F_REQQUEUE V_REQQUEUE(1U) + +#define S_TCAM 0 +#define V_TCAM(x) ((x) << S_TCAM) +#define F_TCAM V_TCAM(1U) + +#define S_MARSPPARERRLE 17 +#define V_MARSPPARERRLE(x) ((x) << S_MARSPPARERRLE) +#define F_MARSPPARERRLE V_MARSPPARERRLE(1U) + +#define S_REQQUEUELE 16 +#define V_REQQUEUELE(x) ((x) << S_REQQUEUELE) +#define F_REQQUEUELE V_REQQUEUELE(1U) + +#define S_VFPARERRLE 14 +#define V_VFPARERRLE(x) ((x) << S_VFPARERRLE) +#define F_VFPARERRLE V_VFPARERRLE(1U) + +#define S_TCAMLE 6 +#define V_TCAMLE(x) ((x) << S_TCAMLE) +#define F_TCAMLE V_TCAMLE(1U) + +#define A_LE_SPARE 0x19cfc +#define A_LE_DB_DBGI_REQ_DATA 0x19d00 +#define A_LE_DB_DBGI_REQ_MASK 0x19d50 +#define A_LE_DB_DBGI_RSP_STATUS 0x19d94 + +#define S_DBGIRSPINDEX 12 +#define M_DBGIRSPINDEX 0xfffffU +#define V_DBGIRSPINDEX(x) ((x) << S_DBGIRSPINDEX) +#define G_DBGIRSPINDEX(x) (((x) >> S_DBGIRSPINDEX) & M_DBGIRSPINDEX) + +#define S_DBGIRSPMSG 8 +#define M_DBGIRSPMSG 0xfU +#define V_DBGIRSPMSG(x) ((x) << S_DBGIRSPMSG) +#define G_DBGIRSPMSG(x) (((x) >> S_DBGIRSPMSG) & M_DBGIRSPMSG) + +#define S_DBGIRSPMSGVLD 7 +#define V_DBGIRSPMSGVLD(x) ((x) << S_DBGIRSPMSGVLD) +#define F_DBGIRSPMSGVLD V_DBGIRSPMSGVLD(1U) + +#define S_DBGIRSPMHIT 2 +#define V_DBGIRSPMHIT(x) ((x) << S_DBGIRSPMHIT) +#define F_DBGIRSPMHIT V_DBGIRSPMHIT(1U) + +#define S_DBGIRSPHIT 1 +#define V_DBGIRSPHIT(x) ((x) << S_DBGIRSPHIT) +#define F_DBGIRSPHIT V_DBGIRSPHIT(1U) + +#define S_DBGIRSPVALID 0 +#define V_DBGIRSPVALID(x) ((x) << S_DBGIRSPVALID) +#define F_DBGIRSPVALID V_DBGIRSPVALID(1U) + +#define A_LE_DB_DBGI_RSP_DATA 0x19da0 +#define A_LE_DB_DBGI_RSP_LAST_CMD 0x19de4 + +#define S_LASTCMDB 16 +#define M_LASTCMDB 0x7ffU +#define V_LASTCMDB(x) ((x) << S_LASTCMDB) +#define G_LASTCMDB(x) (((x) >> S_LASTCMDB) & M_LASTCMDB) + +#define S_LASTCMDA 0 +#define M_LASTCMDA 0x7ffU +#define V_LASTCMDA(x) ((x) << S_LASTCMDA) +#define G_LASTCMDA(x) (((x) >> S_LASTCMDA) & M_LASTCMDA) + +#define A_LE_DB_DROP_FILTER_ENTRY 0x19de8 + +#define S_DROPFILTEREN 31 +#define V_DROPFILTEREN(x) ((x) << S_DROPFILTEREN) +#define F_DROPFILTEREN V_DROPFILTEREN(1U) + +#define S_DROPFILTERCLEAR 17 +#define V_DROPFILTERCLEAR(x) ((x) << S_DROPFILTERCLEAR) +#define F_DROPFILTERCLEAR V_DROPFILTERCLEAR(1U) + +#define S_DROPFILTERSET 16 +#define V_DROPFILTERSET(x) ((x) << S_DROPFILTERSET) +#define F_DROPFILTERSET V_DROPFILTERSET(1U) + +#define S_DROPFILTERFIDX 0 +#define M_DROPFILTERFIDX 0x1fffU +#define V_DROPFILTERFIDX(x) ((x) << S_DROPFILTERFIDX) +#define G_DROPFILTERFIDX(x) (((x) >> S_DROPFILTERFIDX) & M_DROPFILTERFIDX) + +#define A_LE_DB_PTID_SVRBASE 0x19df0 + +#define S_SVRBASE_ADDR 2 +#define M_SVRBASE_ADDR 0x3ffffU +#define V_SVRBASE_ADDR(x) ((x) << S_SVRBASE_ADDR) +#define G_SVRBASE_ADDR(x) (((x) >> S_SVRBASE_ADDR) & M_SVRBASE_ADDR) + +#define A_LE_DB_FTID_FLTRBASE 0x19df4 + +#define S_FLTRBASE_ADDR 2 +#define M_FLTRBASE_ADDR 0x3ffffU +#define V_FLTRBASE_ADDR(x) ((x) << S_FLTRBASE_ADDR) +#define G_FLTRBASE_ADDR(x) (((x) >> S_FLTRBASE_ADDR) & M_FLTRBASE_ADDR) + +#define A_LE_DB_TID_HASHBASE 0x19df8 + +#define S_HASHBASE_ADDR 2 +#define M_HASHBASE_ADDR 0xfffffU +#define V_HASHBASE_ADDR(x) ((x) << S_HASHBASE_ADDR) +#define G_HASHBASE_ADDR(x) (((x) >> S_HASHBASE_ADDR) & M_HASHBASE_ADDR) + +#define A_LE_PERR_INJECT 0x19dfc + +#define S_LEMEMSEL 1 +#define M_LEMEMSEL 0x7U +#define V_LEMEMSEL(x) ((x) << S_LEMEMSEL) +#define G_LEMEMSEL(x) (((x) >> S_LEMEMSEL) & M_LEMEMSEL) + +#define A_LE_DB_ACTIVE_MASK_IPV4 0x19e00 +#define A_LE_T5_DB_ACTIVE_MASK_IPV4 0x19e00 +#define A_LE_DB_ACTIVE_MASK_IPV6 0x19e50 +#define A_LE_HASH_MASK_GEN_IPV4 0x19ea0 +#define A_LE_HASH_MASK_GEN_IPV4T5 0x19ea0 +#define A_LE_HASH_MASK_GEN_IPV6 0x19eb0 +#define A_LE_HASH_MASK_GEN_IPV6T5 0x19eb4 +#define A_LE_HASH_MASK_CMP_IPV4 0x19ee0 +#define A_LE_HASH_MASK_CMP_IPV4T5 0x19ee4 +#define A_LE_HASH_MASK_CMP_IPV6 0x19ef0 +#define A_LE_HASH_MASK_CMP_IPV6T5 0x19ef8 +#define A_LE_DEBUG_LA_CONFIG 0x19f20 +#define A_LE_REQ_DEBUG_LA_DATA 0x19f24 +#define A_LE_REQ_DEBUG_LA_WRPTR 0x19f28 +#define A_LE_RSP_DEBUG_LA_DATA 0x19f2c +#define A_LE_RSP_DEBUG_LA_WRPTR 0x19f30 +#define A_LE_DEBUG_LA_SELECTOR 0x19f34 +#define A_LE_SRVR_SRAM_INIT 0x19f34 + +#define S_SRVRSRAMBASE 2 +#define M_SRVRSRAMBASE 0xfffffU +#define V_SRVRSRAMBASE(x) ((x) << S_SRVRSRAMBASE) +#define G_SRVRSRAMBASE(x) (((x) >> S_SRVRSRAMBASE) & M_SRVRSRAMBASE) + +#define S_SRVRINITBUSY 1 +#define V_SRVRINITBUSY(x) ((x) << S_SRVRINITBUSY) +#define F_SRVRINITBUSY V_SRVRINITBUSY(1U) + +#define S_SRVRINIT 0 +#define V_SRVRINIT(x) ((x) << S_SRVRINIT) +#define F_SRVRINIT V_SRVRINIT(1U) + +#define A_LE_DEBUG_LA_CAPTURED_DATA 0x19f38 +#define A_LE_SRVR_VF_SRCH_TABLE 0x19f38 + +#define S_RDWR 21 +#define V_RDWR(x) ((x) << S_RDWR) +#define F_RDWR V_RDWR(1U) + +#define S_VFINDEX 14 +#define M_VFINDEX 0x7fU +#define V_VFINDEX(x) ((x) << S_VFINDEX) +#define G_VFINDEX(x) (((x) >> S_VFINDEX) & M_VFINDEX) + +#define S_SRCHHADDR 7 +#define M_SRCHHADDR 0x7fU +#define V_SRCHHADDR(x) ((x) << S_SRCHHADDR) +#define G_SRCHHADDR(x) (((x) >> S_SRCHHADDR) & M_SRCHHADDR) + +#define S_SRCHLADDR 0 +#define M_SRCHLADDR 0x7fU +#define V_SRCHLADDR(x) ((x) << S_SRCHLADDR) +#define G_SRCHLADDR(x) (((x) >> S_SRCHLADDR) & M_SRCHLADDR) + +#define A_LE_MA_DEBUG_LA_DATA 0x19f3c +#define A_LE_RSP_DEBUG_LA_HASH_WRPTR 0x19f40 +#define A_LE_DB_SECOND_ACTIVE_MASK_IPV4 0x19f40 +#define A_LE_HASH_DEBUG_LA_DATA 0x19f44 +#define A_LE_RSP_DEBUG_LA_TCAM_WRPTR 0x19f48 +#define A_LE_TCAM_DEBUG_LA_DATA 0x19f4c +#define A_LE_DB_SECOND_GEN_HASH_MASK_IPV4 0x19f90 +#define A_LE_DB_SECOND_CMP_HASH_MASK_IPV4 0x19fa4 +#define A_LE_HASH_COLLISION 0x19fc4 +#define A_LE_GLOBAL_COLLISION 0x19fc8 +#define A_LE_FULL_CNT_COLLISION 0x19fcc +#define A_LE_DEBUG_LA_CONFIGT5 0x19fd0 +#define A_LE_REQ_DEBUG_LA_DATAT5 0x19fd4 +#define A_LE_REQ_DEBUG_LA_WRPTRT5 0x19fd8 +#define A_LE_RSP_DEBUG_LA_DATAT5 0x19fdc +#define A_LE_RSP_DEBUG_LA_WRPTRT5 0x19fe0 +#define A_LE_DEBUG_LA_SEL_DATA 0x19fe4 + +/* registers for module NCSI */ +#define NCSI_BASE_ADDR 0x1a000 + +#define A_NCSI_PORT_CFGREG 0x1a000 + +#define S_WIREEN 28 +#define M_WIREEN 0xfU +#define V_WIREEN(x) ((x) << S_WIREEN) +#define G_WIREEN(x) (((x) >> S_WIREEN) & M_WIREEN) + +#define S_STRP_CRC 24 +#define M_STRP_CRC 0xfU +#define V_STRP_CRC(x) ((x) << S_STRP_CRC) +#define G_STRP_CRC(x) (((x) >> S_STRP_CRC) & M_STRP_CRC) + +#define S_RX_HALT 22 +#define V_RX_HALT(x) ((x) << S_RX_HALT) +#define F_RX_HALT V_RX_HALT(1U) + +#define S_FLUSH_RX_FIFO 21 +#define V_FLUSH_RX_FIFO(x) ((x) << S_FLUSH_RX_FIFO) +#define F_FLUSH_RX_FIFO V_FLUSH_RX_FIFO(1U) + +#define S_HW_ARB_EN 20 +#define V_HW_ARB_EN(x) ((x) << S_HW_ARB_EN) +#define F_HW_ARB_EN V_HW_ARB_EN(1U) + +#define S_SOFT_PKG_SEL 19 +#define V_SOFT_PKG_SEL(x) ((x) << S_SOFT_PKG_SEL) +#define F_SOFT_PKG_SEL V_SOFT_PKG_SEL(1U) + +#define S_ERR_DISCARD_EN 18 +#define V_ERR_DISCARD_EN(x) ((x) << S_ERR_DISCARD_EN) +#define F_ERR_DISCARD_EN V_ERR_DISCARD_EN(1U) + +#define S_MAX_PKT_SIZE 4 +#define M_MAX_PKT_SIZE 0x3fffU +#define V_MAX_PKT_SIZE(x) ((x) << S_MAX_PKT_SIZE) +#define G_MAX_PKT_SIZE(x) (((x) >> S_MAX_PKT_SIZE) & M_MAX_PKT_SIZE) + +#define S_RX_BYTE_SWAP 3 +#define V_RX_BYTE_SWAP(x) ((x) << S_RX_BYTE_SWAP) +#define F_RX_BYTE_SWAP V_RX_BYTE_SWAP(1U) + +#define S_TX_BYTE_SWAP 2 +#define V_TX_BYTE_SWAP(x) ((x) << S_TX_BYTE_SWAP) +#define F_TX_BYTE_SWAP V_TX_BYTE_SWAP(1U) + +#define A_NCSI_RST_CTRL 0x1a004 + +#define S_MAC_REF_RST 2 +#define V_MAC_REF_RST(x) ((x) << S_MAC_REF_RST) +#define F_MAC_REF_RST V_MAC_REF_RST(1U) + +#define S_MAC_RX_RST 1 +#define V_MAC_RX_RST(x) ((x) << S_MAC_RX_RST) +#define F_MAC_RX_RST V_MAC_RX_RST(1U) + +#define S_MAC_TX_RST 0 +#define V_MAC_TX_RST(x) ((x) << S_MAC_TX_RST) +#define F_MAC_TX_RST V_MAC_TX_RST(1U) + +#define A_NCSI_CH0_SADDR_LOW 0x1a010 +#define A_NCSI_CH0_SADDR_HIGH 0x1a014 + +#define S_CHO_SADDR_EN 31 +#define V_CHO_SADDR_EN(x) ((x) << S_CHO_SADDR_EN) +#define F_CHO_SADDR_EN V_CHO_SADDR_EN(1U) + +#define S_CH0_SADDR_HIGH 0 +#define M_CH0_SADDR_HIGH 0xffffU +#define V_CH0_SADDR_HIGH(x) ((x) << S_CH0_SADDR_HIGH) +#define G_CH0_SADDR_HIGH(x) (((x) >> S_CH0_SADDR_HIGH) & M_CH0_SADDR_HIGH) + +#define A_NCSI_CH1_SADDR_LOW 0x1a018 +#define A_NCSI_CH1_SADDR_HIGH 0x1a01c + +#define S_CH1_SADDR_EN 31 +#define V_CH1_SADDR_EN(x) ((x) << S_CH1_SADDR_EN) +#define F_CH1_SADDR_EN V_CH1_SADDR_EN(1U) + +#define S_CH1_SADDR_HIGH 0 +#define M_CH1_SADDR_HIGH 0xffffU +#define V_CH1_SADDR_HIGH(x) ((x) << S_CH1_SADDR_HIGH) +#define G_CH1_SADDR_HIGH(x) (((x) >> S_CH1_SADDR_HIGH) & M_CH1_SADDR_HIGH) + +#define A_NCSI_CH2_SADDR_LOW 0x1a020 +#define A_NCSI_CH2_SADDR_HIGH 0x1a024 + +#define S_CH2_SADDR_EN 31 +#define V_CH2_SADDR_EN(x) ((x) << S_CH2_SADDR_EN) +#define F_CH2_SADDR_EN V_CH2_SADDR_EN(1U) + +#define S_CH2_SADDR_HIGH 0 +#define M_CH2_SADDR_HIGH 0xffffU +#define V_CH2_SADDR_HIGH(x) ((x) << S_CH2_SADDR_HIGH) +#define G_CH2_SADDR_HIGH(x) (((x) >> S_CH2_SADDR_HIGH) & M_CH2_SADDR_HIGH) + +#define A_NCSI_CH3_SADDR_LOW 0x1a028 +#define A_NCSI_CH3_SADDR_HIGH 0x1a02c + +#define S_CH3_SADDR_EN 31 +#define V_CH3_SADDR_EN(x) ((x) << S_CH3_SADDR_EN) +#define F_CH3_SADDR_EN V_CH3_SADDR_EN(1U) + +#define S_CH3_SADDR_HIGH 0 +#define M_CH3_SADDR_HIGH 0xffffU +#define V_CH3_SADDR_HIGH(x) ((x) << S_CH3_SADDR_HIGH) +#define G_CH3_SADDR_HIGH(x) (((x) >> S_CH3_SADDR_HIGH) & M_CH3_SADDR_HIGH) + +#define A_NCSI_WORK_REQHDR_0 0x1a030 +#define A_NCSI_WORK_REQHDR_1 0x1a034 +#define A_NCSI_WORK_REQHDR_2 0x1a038 +#define A_NCSI_WORK_REQHDR_3 0x1a03c +#define A_NCSI_MPS_HDR_LO 0x1a040 +#define A_NCSI_MPS_HDR_HI 0x1a044 +#define A_NCSI_CTL 0x1a048 + +#define S_STRIP_OVLAN 3 +#define V_STRIP_OVLAN(x) ((x) << S_STRIP_OVLAN) +#define F_STRIP_OVLAN V_STRIP_OVLAN(1U) + +#define S_BMC_DROP_NON_BC 2 +#define V_BMC_DROP_NON_BC(x) ((x) << S_BMC_DROP_NON_BC) +#define F_BMC_DROP_NON_BC V_BMC_DROP_NON_BC(1U) + +#define S_BMC_RX_FWD_ALL 1 +#define V_BMC_RX_FWD_ALL(x) ((x) << S_BMC_RX_FWD_ALL) +#define F_BMC_RX_FWD_ALL V_BMC_RX_FWD_ALL(1U) + +#define S_FWD_BMC 0 +#define V_FWD_BMC(x) ((x) << S_FWD_BMC) +#define F_FWD_BMC V_FWD_BMC(1U) + +#define A_NCSI_NCSI_ETYPE 0x1a04c + +#define S_NCSI_ETHERTYPE 0 +#define M_NCSI_ETHERTYPE 0xffffU +#define V_NCSI_ETHERTYPE(x) ((x) << S_NCSI_ETHERTYPE) +#define G_NCSI_ETHERTYPE(x) (((x) >> S_NCSI_ETHERTYPE) & M_NCSI_ETHERTYPE) + +#define A_NCSI_RX_FIFO_CNT 0x1a050 + +#define S_NCSI_RXFIFO_CNT 0 +#define M_NCSI_RXFIFO_CNT 0x7ffU +#define V_NCSI_RXFIFO_CNT(x) ((x) << S_NCSI_RXFIFO_CNT) +#define G_NCSI_RXFIFO_CNT(x) (((x) >> S_NCSI_RXFIFO_CNT) & M_NCSI_RXFIFO_CNT) + +#define A_NCSI_RX_ERR_CNT 0x1a054 +#define A_NCSI_RX_OF_CNT 0x1a058 +#define A_NCSI_RX_MS_CNT 0x1a05c +#define A_NCSI_RX_IE_CNT 0x1a060 +#define A_NCSI_MPS_DEMUX_CNT 0x1a064 + +#define S_MPS2CIM_CNT 16 +#define M_MPS2CIM_CNT 0x1ffU +#define V_MPS2CIM_CNT(x) ((x) << S_MPS2CIM_CNT) +#define G_MPS2CIM_CNT(x) (((x) >> S_MPS2CIM_CNT) & M_MPS2CIM_CNT) + +#define S_MPS2BMC_CNT 0 +#define M_MPS2BMC_CNT 0x1ffU +#define V_MPS2BMC_CNT(x) ((x) << S_MPS2BMC_CNT) +#define G_MPS2BMC_CNT(x) (((x) >> S_MPS2BMC_CNT) & M_MPS2BMC_CNT) + +#define A_NCSI_CIM_DEMUX_CNT 0x1a068 + +#define S_CIM2MPS_CNT 16 +#define M_CIM2MPS_CNT 0x1ffU +#define V_CIM2MPS_CNT(x) ((x) << S_CIM2MPS_CNT) +#define G_CIM2MPS_CNT(x) (((x) >> S_CIM2MPS_CNT) & M_CIM2MPS_CNT) + +#define S_CIM2BMC_CNT 0 +#define M_CIM2BMC_CNT 0x1ffU +#define V_CIM2BMC_CNT(x) ((x) << S_CIM2BMC_CNT) +#define G_CIM2BMC_CNT(x) (((x) >> S_CIM2BMC_CNT) & M_CIM2BMC_CNT) + +#define A_NCSI_TX_FIFO_CNT 0x1a06c + +#define S_TX_FIFO_CNT 0 +#define M_TX_FIFO_CNT 0x3ffU +#define V_TX_FIFO_CNT(x) ((x) << S_TX_FIFO_CNT) +#define G_TX_FIFO_CNT(x) (((x) >> S_TX_FIFO_CNT) & M_TX_FIFO_CNT) + +#define A_NCSI_SE_CNT_CTL 0x1a0b0 + +#define S_SE_CNT_CLR 0 +#define M_SE_CNT_CLR 0xfU +#define V_SE_CNT_CLR(x) ((x) << S_SE_CNT_CLR) +#define G_SE_CNT_CLR(x) (((x) >> S_SE_CNT_CLR) & M_SE_CNT_CLR) + +#define A_NCSI_SE_CNT_MPS 0x1a0b4 + +#define S_NC2MPS_SOP_CNT 24 +#define M_NC2MPS_SOP_CNT 0xffU +#define V_NC2MPS_SOP_CNT(x) ((x) << S_NC2MPS_SOP_CNT) +#define G_NC2MPS_SOP_CNT(x) (((x) >> S_NC2MPS_SOP_CNT) & M_NC2MPS_SOP_CNT) + +#define S_NC2MPS_EOP_CNT 16 +#define M_NC2MPS_EOP_CNT 0x3fU +#define V_NC2MPS_EOP_CNT(x) ((x) << S_NC2MPS_EOP_CNT) +#define G_NC2MPS_EOP_CNT(x) (((x) >> S_NC2MPS_EOP_CNT) & M_NC2MPS_EOP_CNT) + +#define S_MPS2NC_SOP_CNT 8 +#define M_MPS2NC_SOP_CNT 0xffU +#define V_MPS2NC_SOP_CNT(x) ((x) << S_MPS2NC_SOP_CNT) +#define G_MPS2NC_SOP_CNT(x) (((x) >> S_MPS2NC_SOP_CNT) & M_MPS2NC_SOP_CNT) + +#define S_MPS2NC_EOP_CNT 0 +#define M_MPS2NC_EOP_CNT 0xffU +#define V_MPS2NC_EOP_CNT(x) ((x) << S_MPS2NC_EOP_CNT) +#define G_MPS2NC_EOP_CNT(x) (((x) >> S_MPS2NC_EOP_CNT) & M_MPS2NC_EOP_CNT) + +#define A_NCSI_SE_CNT_CIM 0x1a0b8 + +#define S_NC2CIM_SOP_CNT 24 +#define M_NC2CIM_SOP_CNT 0xffU +#define V_NC2CIM_SOP_CNT(x) ((x) << S_NC2CIM_SOP_CNT) +#define G_NC2CIM_SOP_CNT(x) (((x) >> S_NC2CIM_SOP_CNT) & M_NC2CIM_SOP_CNT) + +#define S_NC2CIM_EOP_CNT 16 +#define M_NC2CIM_EOP_CNT 0x3fU +#define V_NC2CIM_EOP_CNT(x) ((x) << S_NC2CIM_EOP_CNT) +#define G_NC2CIM_EOP_CNT(x) (((x) >> S_NC2CIM_EOP_CNT) & M_NC2CIM_EOP_CNT) + +#define S_CIM2NC_SOP_CNT 8 +#define M_CIM2NC_SOP_CNT 0xffU +#define V_CIM2NC_SOP_CNT(x) ((x) << S_CIM2NC_SOP_CNT) +#define G_CIM2NC_SOP_CNT(x) (((x) >> S_CIM2NC_SOP_CNT) & M_CIM2NC_SOP_CNT) + +#define S_CIM2NC_EOP_CNT 0 +#define M_CIM2NC_EOP_CNT 0xffU +#define V_CIM2NC_EOP_CNT(x) ((x) << S_CIM2NC_EOP_CNT) +#define G_CIM2NC_EOP_CNT(x) (((x) >> S_CIM2NC_EOP_CNT) & M_CIM2NC_EOP_CNT) + +#define A_NCSI_BUS_DEBUG 0x1a0bc + +#define S_SOP_CNT_ERR 12 +#define M_SOP_CNT_ERR 0xfU +#define V_SOP_CNT_ERR(x) ((x) << S_SOP_CNT_ERR) +#define G_SOP_CNT_ERR(x) (((x) >> S_SOP_CNT_ERR) & M_SOP_CNT_ERR) + +#define S_BUS_STATE_MPS_OUT 6 +#define M_BUS_STATE_MPS_OUT 0x3U +#define V_BUS_STATE_MPS_OUT(x) ((x) << S_BUS_STATE_MPS_OUT) +#define G_BUS_STATE_MPS_OUT(x) (((x) >> S_BUS_STATE_MPS_OUT) & M_BUS_STATE_MPS_OUT) + +#define S_BUS_STATE_MPS_IN 4 +#define M_BUS_STATE_MPS_IN 0x3U +#define V_BUS_STATE_MPS_IN(x) ((x) << S_BUS_STATE_MPS_IN) +#define G_BUS_STATE_MPS_IN(x) (((x) >> S_BUS_STATE_MPS_IN) & M_BUS_STATE_MPS_IN) + +#define S_BUS_STATE_CIM_OUT 2 +#define M_BUS_STATE_CIM_OUT 0x3U +#define V_BUS_STATE_CIM_OUT(x) ((x) << S_BUS_STATE_CIM_OUT) +#define G_BUS_STATE_CIM_OUT(x) (((x) >> S_BUS_STATE_CIM_OUT) & M_BUS_STATE_CIM_OUT) + +#define S_BUS_STATE_CIM_IN 0 +#define M_BUS_STATE_CIM_IN 0x3U +#define V_BUS_STATE_CIM_IN(x) ((x) << S_BUS_STATE_CIM_IN) +#define G_BUS_STATE_CIM_IN(x) (((x) >> S_BUS_STATE_CIM_IN) & M_BUS_STATE_CIM_IN) + +#define A_NCSI_LA_RDPTR 0x1a0c0 +#define A_NCSI_LA_RDDATA 0x1a0c4 +#define A_NCSI_LA_WRPTR 0x1a0c8 +#define A_NCSI_LA_RESERVED 0x1a0cc +#define A_NCSI_LA_CTL 0x1a0d0 +#define A_NCSI_INT_ENABLE 0x1a0d4 + +#define S_CIM_DM_PRTY_ERR 8 +#define V_CIM_DM_PRTY_ERR(x) ((x) << S_CIM_DM_PRTY_ERR) +#define F_CIM_DM_PRTY_ERR V_CIM_DM_PRTY_ERR(1U) + +#define S_MPS_DM_PRTY_ERR 7 +#define V_MPS_DM_PRTY_ERR(x) ((x) << S_MPS_DM_PRTY_ERR) +#define F_MPS_DM_PRTY_ERR V_MPS_DM_PRTY_ERR(1U) + +#define S_TOKEN 6 +#define V_TOKEN(x) ((x) << S_TOKEN) +#define F_TOKEN V_TOKEN(1U) + +#define S_ARB_DONE 5 +#define V_ARB_DONE(x) ((x) << S_ARB_DONE) +#define F_ARB_DONE V_ARB_DONE(1U) + +#define S_ARB_STARTED 4 +#define V_ARB_STARTED(x) ((x) << S_ARB_STARTED) +#define F_ARB_STARTED V_ARB_STARTED(1U) + +#define S_WOL 3 +#define V_WOL(x) ((x) << S_WOL) +#define F_WOL V_WOL(1U) + +#define S_MACINT 2 +#define V_MACINT(x) ((x) << S_MACINT) +#define F_MACINT V_MACINT(1U) + +#define S_TXFIFO_PRTY_ERR 1 +#define V_TXFIFO_PRTY_ERR(x) ((x) << S_TXFIFO_PRTY_ERR) +#define F_TXFIFO_PRTY_ERR V_TXFIFO_PRTY_ERR(1U) + +#define S_RXFIFO_PRTY_ERR 0 +#define V_RXFIFO_PRTY_ERR(x) ((x) << S_RXFIFO_PRTY_ERR) +#define F_RXFIFO_PRTY_ERR V_RXFIFO_PRTY_ERR(1U) + +#define A_NCSI_INT_CAUSE 0x1a0d8 +#define A_NCSI_STATUS 0x1a0dc + +#define S_MASTER 1 +#define V_MASTER(x) ((x) << S_MASTER) +#define F_MASTER V_MASTER(1U) + +#define S_ARB_STATUS 0 +#define V_ARB_STATUS(x) ((x) << S_ARB_STATUS) +#define F_ARB_STATUS V_ARB_STATUS(1U) + +#define A_NCSI_PAUSE_CTRL 0x1a0e0 + +#define S_FORCEPAUSE 0 +#define V_FORCEPAUSE(x) ((x) << S_FORCEPAUSE) +#define F_FORCEPAUSE V_FORCEPAUSE(1U) + +#define A_NCSI_PAUSE_TIMEOUT 0x1a0e4 +#define A_NCSI_PAUSE_WM 0x1a0ec + +#define S_PAUSEHWM 16 +#define M_PAUSEHWM 0x7ffU +#define V_PAUSEHWM(x) ((x) << S_PAUSEHWM) +#define G_PAUSEHWM(x) (((x) >> S_PAUSEHWM) & M_PAUSEHWM) + +#define S_PAUSELWM 0 +#define M_PAUSELWM 0x7ffU +#define V_PAUSELWM(x) ((x) << S_PAUSELWM) +#define G_PAUSELWM(x) (((x) >> S_PAUSELWM) & M_PAUSELWM) + +#define A_NCSI_DEBUG 0x1a0f0 + +#define S_DEBUGSEL 0 +#define M_DEBUGSEL 0x3fU +#define V_DEBUGSEL(x) ((x) << S_DEBUGSEL) +#define G_DEBUGSEL(x) (((x) >> S_DEBUGSEL) & M_DEBUGSEL) + +#define S_TXFIFO_EMPTY 4 +#define V_TXFIFO_EMPTY(x) ((x) << S_TXFIFO_EMPTY) +#define F_TXFIFO_EMPTY V_TXFIFO_EMPTY(1U) + +#define S_TXFIFO_FULL 3 +#define V_TXFIFO_FULL(x) ((x) << S_TXFIFO_FULL) +#define F_TXFIFO_FULL V_TXFIFO_FULL(1U) + +#define S_PKG_ID 0 +#define M_PKG_ID 0x7U +#define V_PKG_ID(x) ((x) << S_PKG_ID) +#define G_PKG_ID(x) (((x) >> S_PKG_ID) & M_PKG_ID) + +#define A_NCSI_PERR_INJECT 0x1a0f4 + +#define S_MCSIMELSEL 1 +#define V_MCSIMELSEL(x) ((x) << S_MCSIMELSEL) +#define F_MCSIMELSEL V_MCSIMELSEL(1U) + +#define A_NCSI_PERR_ENABLE 0x1a0f8 +#define A_NCSI_MACB_NETWORK_CTRL 0x1a100 + +#define S_TXSNDZEROPAUSE 12 +#define V_TXSNDZEROPAUSE(x) ((x) << S_TXSNDZEROPAUSE) +#define F_TXSNDZEROPAUSE V_TXSNDZEROPAUSE(1U) + +#define S_TXSNDPAUSE 11 +#define V_TXSNDPAUSE(x) ((x) << S_TXSNDPAUSE) +#define F_TXSNDPAUSE V_TXSNDPAUSE(1U) + +#define S_TXSTOP 10 +#define V_TXSTOP(x) ((x) << S_TXSTOP) +#define F_TXSTOP V_TXSTOP(1U) + +#define S_TXSTART 9 +#define V_TXSTART(x) ((x) << S_TXSTART) +#define F_TXSTART V_TXSTART(1U) + +#define S_BACKPRESS 8 +#define V_BACKPRESS(x) ((x) << S_BACKPRESS) +#define F_BACKPRESS V_BACKPRESS(1U) + +#define S_STATWREN 7 +#define V_STATWREN(x) ((x) << S_STATWREN) +#define F_STATWREN V_STATWREN(1U) + +#define S_INCRSTAT 6 +#define V_INCRSTAT(x) ((x) << S_INCRSTAT) +#define F_INCRSTAT V_INCRSTAT(1U) + +#define S_CLEARSTAT 5 +#define V_CLEARSTAT(x) ((x) << S_CLEARSTAT) +#define F_CLEARSTAT V_CLEARSTAT(1U) + +#define S_ENMGMTPORT 4 +#define V_ENMGMTPORT(x) ((x) << S_ENMGMTPORT) +#define F_ENMGMTPORT V_ENMGMTPORT(1U) + +#define S_NCSITXEN 3 +#define V_NCSITXEN(x) ((x) << S_NCSITXEN) +#define F_NCSITXEN V_NCSITXEN(1U) + +#define S_NCSIRXEN 2 +#define V_NCSIRXEN(x) ((x) << S_NCSIRXEN) +#define F_NCSIRXEN V_NCSIRXEN(1U) + +#define S_LOOPLOCAL 1 +#define V_LOOPLOCAL(x) ((x) << S_LOOPLOCAL) +#define F_LOOPLOCAL V_LOOPLOCAL(1U) + +#define S_LOOPPHY 0 +#define V_LOOPPHY(x) ((x) << S_LOOPPHY) +#define F_LOOPPHY V_LOOPPHY(1U) + +#define A_NCSI_MACB_NETWORK_CFG 0x1a104 + +#define S_PCLKDIV128 22 +#define V_PCLKDIV128(x) ((x) << S_PCLKDIV128) +#define F_PCLKDIV128 V_PCLKDIV128(1U) + +#define S_COPYPAUSE 21 +#define V_COPYPAUSE(x) ((x) << S_COPYPAUSE) +#define F_COPYPAUSE V_COPYPAUSE(1U) + +#define S_NONSTDPREOK 20 +#define V_NONSTDPREOK(x) ((x) << S_NONSTDPREOK) +#define F_NONSTDPREOK V_NONSTDPREOK(1U) + +#define S_NOFCS 19 +#define V_NOFCS(x) ((x) << S_NOFCS) +#define F_NOFCS V_NOFCS(1U) + +#define S_RXENHALFDUP 18 +#define V_RXENHALFDUP(x) ((x) << S_RXENHALFDUP) +#define F_RXENHALFDUP V_RXENHALFDUP(1U) + +#define S_NOCOPYFCS 17 +#define V_NOCOPYFCS(x) ((x) << S_NOCOPYFCS) +#define F_NOCOPYFCS V_NOCOPYFCS(1U) + +#define S_LENCHKEN 16 +#define V_LENCHKEN(x) ((x) << S_LENCHKEN) +#define F_LENCHKEN V_LENCHKEN(1U) + +#define S_RXBUFOFFSET 14 +#define M_RXBUFOFFSET 0x3U +#define V_RXBUFOFFSET(x) ((x) << S_RXBUFOFFSET) +#define G_RXBUFOFFSET(x) (((x) >> S_RXBUFOFFSET) & M_RXBUFOFFSET) + +#define S_PAUSEEN 13 +#define V_PAUSEEN(x) ((x) << S_PAUSEEN) +#define F_PAUSEEN V_PAUSEEN(1U) + +#define S_RETRYTEST 12 +#define V_RETRYTEST(x) ((x) << S_RETRYTEST) +#define F_RETRYTEST V_RETRYTEST(1U) + +#define S_PCLKDIV 10 +#define M_PCLKDIV 0x3U +#define V_PCLKDIV(x) ((x) << S_PCLKDIV) +#define G_PCLKDIV(x) (((x) >> S_PCLKDIV) & M_PCLKDIV) + +#define S_EXTCLASS 9 +#define V_EXTCLASS(x) ((x) << S_EXTCLASS) +#define F_EXTCLASS V_EXTCLASS(1U) + +#define S_EN1536FRAME 8 +#define V_EN1536FRAME(x) ((x) << S_EN1536FRAME) +#define F_EN1536FRAME V_EN1536FRAME(1U) + +#define S_UCASTHASHEN 7 +#define V_UCASTHASHEN(x) ((x) << S_UCASTHASHEN) +#define F_UCASTHASHEN V_UCASTHASHEN(1U) + +#define S_MCASTHASHEN 6 +#define V_MCASTHASHEN(x) ((x) << S_MCASTHASHEN) +#define F_MCASTHASHEN V_MCASTHASHEN(1U) + +#define S_RXBCASTDIS 5 +#define V_RXBCASTDIS(x) ((x) << S_RXBCASTDIS) +#define F_RXBCASTDIS V_RXBCASTDIS(1U) + +#define S_NCSICOPYALLFRAMES 4 +#define V_NCSICOPYALLFRAMES(x) ((x) << S_NCSICOPYALLFRAMES) +#define F_NCSICOPYALLFRAMES V_NCSICOPYALLFRAMES(1U) + +#define S_JUMBOEN 3 +#define V_JUMBOEN(x) ((x) << S_JUMBOEN) +#define F_JUMBOEN V_JUMBOEN(1U) + +#define S_SEREN 2 +#define V_SEREN(x) ((x) << S_SEREN) +#define F_SEREN V_SEREN(1U) + +#define S_FULLDUPLEX 1 +#define V_FULLDUPLEX(x) ((x) << S_FULLDUPLEX) +#define F_FULLDUPLEX V_FULLDUPLEX(1U) + +#define S_SPEED 0 +#define V_SPEED(x) ((x) << S_SPEED) +#define F_SPEED V_SPEED(1U) + +#define A_NCSI_MACB_NETWORK_STATUS 0x1a108 + +#define S_PHYMGMTSTATUS 2 +#define V_PHYMGMTSTATUS(x) ((x) << S_PHYMGMTSTATUS) +#define F_PHYMGMTSTATUS V_PHYMGMTSTATUS(1U) + +#define S_MDISTATUS 1 +#define V_MDISTATUS(x) ((x) << S_MDISTATUS) +#define F_MDISTATUS V_MDISTATUS(1U) + +#define S_LINKSTATUS 0 +#define V_LINKSTATUS(x) ((x) << S_LINKSTATUS) +#define F_LINKSTATUS V_LINKSTATUS(1U) + +#define A_NCSI_MACB_TX_STATUS 0x1a114 + +#define S_UNDERRUNERR 6 +#define V_UNDERRUNERR(x) ((x) << S_UNDERRUNERR) +#define F_UNDERRUNERR V_UNDERRUNERR(1U) + +#define S_TXCOMPLETE 5 +#define V_TXCOMPLETE(x) ((x) << S_TXCOMPLETE) +#define F_TXCOMPLETE V_TXCOMPLETE(1U) + +#define S_BUFFEREXHAUSTED 4 +#define V_BUFFEREXHAUSTED(x) ((x) << S_BUFFEREXHAUSTED) +#define F_BUFFEREXHAUSTED V_BUFFEREXHAUSTED(1U) + +#define S_TXPROGRESS 3 +#define V_TXPROGRESS(x) ((x) << S_TXPROGRESS) +#define F_TXPROGRESS V_TXPROGRESS(1U) + +#define S_RETRYLIMIT 2 +#define V_RETRYLIMIT(x) ((x) << S_RETRYLIMIT) +#define F_RETRYLIMIT V_RETRYLIMIT(1U) + +#define S_COLEVENT 1 +#define V_COLEVENT(x) ((x) << S_COLEVENT) +#define F_COLEVENT V_COLEVENT(1U) + +#define S_USEDBITREAD 0 +#define V_USEDBITREAD(x) ((x) << S_USEDBITREAD) +#define F_USEDBITREAD V_USEDBITREAD(1U) + +#define A_NCSI_MACB_RX_BUF_QPTR 0x1a118 + +#define S_RXBUFQPTR 2 +#define M_RXBUFQPTR 0x3fffffffU +#define V_RXBUFQPTR(x) ((x) << S_RXBUFQPTR) +#define G_RXBUFQPTR(x) (((x) >> S_RXBUFQPTR) & M_RXBUFQPTR) + +#define A_NCSI_MACB_TX_BUF_QPTR 0x1a11c + +#define S_TXBUFQPTR 2 +#define M_TXBUFQPTR 0x3fffffffU +#define V_TXBUFQPTR(x) ((x) << S_TXBUFQPTR) +#define G_TXBUFQPTR(x) (((x) >> S_TXBUFQPTR) & M_TXBUFQPTR) + +#define A_NCSI_MACB_RX_STATUS 0x1a120 + +#define S_RXOVERRUNERR 2 +#define V_RXOVERRUNERR(x) ((x) << S_RXOVERRUNERR) +#define F_RXOVERRUNERR V_RXOVERRUNERR(1U) + +#define S_MACB_FRAMERCVD 1 +#define V_MACB_FRAMERCVD(x) ((x) << S_MACB_FRAMERCVD) +#define F_MACB_FRAMERCVD V_MACB_FRAMERCVD(1U) + +#define S_NORXBUF 0 +#define V_NORXBUF(x) ((x) << S_NORXBUF) +#define F_NORXBUF V_NORXBUF(1U) + +#define A_NCSI_MACB_INT_STATUS 0x1a124 + +#define S_PAUSETIMEZERO 13 +#define V_PAUSETIMEZERO(x) ((x) << S_PAUSETIMEZERO) +#define F_PAUSETIMEZERO V_PAUSETIMEZERO(1U) + +#define S_PAUSERCVD 12 +#define V_PAUSERCVD(x) ((x) << S_PAUSERCVD) +#define F_PAUSERCVD V_PAUSERCVD(1U) + +#define S_HRESPNOTOK 11 +#define V_HRESPNOTOK(x) ((x) << S_HRESPNOTOK) +#define F_HRESPNOTOK V_HRESPNOTOK(1U) + +#define S_RXOVERRUN 10 +#define V_RXOVERRUN(x) ((x) << S_RXOVERRUN) +#define F_RXOVERRUN V_RXOVERRUN(1U) + +#define S_LINKCHANGE 9 +#define V_LINKCHANGE(x) ((x) << S_LINKCHANGE) +#define F_LINKCHANGE V_LINKCHANGE(1U) + +#define S_INT_TXCOMPLETE 7 +#define V_INT_TXCOMPLETE(x) ((x) << S_INT_TXCOMPLETE) +#define F_INT_TXCOMPLETE V_INT_TXCOMPLETE(1U) + +#define S_TXBUFERR 6 +#define V_TXBUFERR(x) ((x) << S_TXBUFERR) +#define F_TXBUFERR V_TXBUFERR(1U) + +#define S_RETRYLIMITERR 5 +#define V_RETRYLIMITERR(x) ((x) << S_RETRYLIMITERR) +#define F_RETRYLIMITERR V_RETRYLIMITERR(1U) + +#define S_TXBUFUNDERRUN 4 +#define V_TXBUFUNDERRUN(x) ((x) << S_TXBUFUNDERRUN) +#define F_TXBUFUNDERRUN V_TXBUFUNDERRUN(1U) + +#define S_TXUSEDBITREAD 3 +#define V_TXUSEDBITREAD(x) ((x) << S_TXUSEDBITREAD) +#define F_TXUSEDBITREAD V_TXUSEDBITREAD(1U) + +#define S_RXUSEDBITREAD 2 +#define V_RXUSEDBITREAD(x) ((x) << S_RXUSEDBITREAD) +#define F_RXUSEDBITREAD V_RXUSEDBITREAD(1U) + +#define S_RXCOMPLETE 1 +#define V_RXCOMPLETE(x) ((x) << S_RXCOMPLETE) +#define F_RXCOMPLETE V_RXCOMPLETE(1U) + +#define S_MGMTFRAMESENT 0 +#define V_MGMTFRAMESENT(x) ((x) << S_MGMTFRAMESENT) +#define F_MGMTFRAMESENT V_MGMTFRAMESENT(1U) + +#define A_NCSI_MACB_INT_EN 0x1a128 +#define A_NCSI_MACB_INT_DIS 0x1a12c +#define A_NCSI_MACB_INT_MASK 0x1a130 +#define A_NCSI_MACB_PAUSE_TIME 0x1a138 + +#define S_PAUSETIME 0 +#define M_PAUSETIME 0xffffU +#define V_PAUSETIME(x) ((x) << S_PAUSETIME) +#define G_PAUSETIME(x) (((x) >> S_PAUSETIME) & M_PAUSETIME) + +#define A_NCSI_MACB_PAUSE_FRAMES_RCVD 0x1a13c + +#define S_PAUSEFRRCVD 0 +#define M_PAUSEFRRCVD 0xffffU +#define V_PAUSEFRRCVD(x) ((x) << S_PAUSEFRRCVD) +#define G_PAUSEFRRCVD(x) (((x) >> S_PAUSEFRRCVD) & M_PAUSEFRRCVD) + +#define A_NCSI_MACB_TX_FRAMES_OK 0x1a140 + +#define S_TXFRAMESOK 0 +#define M_TXFRAMESOK 0xffffffU +#define V_TXFRAMESOK(x) ((x) << S_TXFRAMESOK) +#define G_TXFRAMESOK(x) (((x) >> S_TXFRAMESOK) & M_TXFRAMESOK) + +#define A_NCSI_MACB_SINGLE_COL_FRAMES 0x1a144 + +#define S_SINGLECOLTXFRAMES 0 +#define M_SINGLECOLTXFRAMES 0xffffU +#define V_SINGLECOLTXFRAMES(x) ((x) << S_SINGLECOLTXFRAMES) +#define G_SINGLECOLTXFRAMES(x) (((x) >> S_SINGLECOLTXFRAMES) & M_SINGLECOLTXFRAMES) + +#define A_NCSI_MACB_MUL_COL_FRAMES 0x1a148 + +#define S_MULCOLTXFRAMES 0 +#define M_MULCOLTXFRAMES 0xffffU +#define V_MULCOLTXFRAMES(x) ((x) << S_MULCOLTXFRAMES) +#define G_MULCOLTXFRAMES(x) (((x) >> S_MULCOLTXFRAMES) & M_MULCOLTXFRAMES) + +#define A_NCSI_MACB_RX_FRAMES_OK 0x1a14c + +#define S_RXFRAMESOK 0 +#define M_RXFRAMESOK 0xffffffU +#define V_RXFRAMESOK(x) ((x) << S_RXFRAMESOK) +#define G_RXFRAMESOK(x) (((x) >> S_RXFRAMESOK) & M_RXFRAMESOK) + +#define A_NCSI_MACB_FCS_ERR 0x1a150 + +#define S_RXFCSERR 0 +#define M_RXFCSERR 0xffU +#define V_RXFCSERR(x) ((x) << S_RXFCSERR) +#define G_RXFCSERR(x) (((x) >> S_RXFCSERR) & M_RXFCSERR) + +#define A_NCSI_MACB_ALIGN_ERR 0x1a154 + +#define S_RXALIGNERR 0 +#define M_RXALIGNERR 0xffU +#define V_RXALIGNERR(x) ((x) << S_RXALIGNERR) +#define G_RXALIGNERR(x) (((x) >> S_RXALIGNERR) & M_RXALIGNERR) + +#define A_NCSI_MACB_DEF_TX_FRAMES 0x1a158 + +#define S_TXDEFERREDFRAMES 0 +#define M_TXDEFERREDFRAMES 0xffffU +#define V_TXDEFERREDFRAMES(x) ((x) << S_TXDEFERREDFRAMES) +#define G_TXDEFERREDFRAMES(x) (((x) >> S_TXDEFERREDFRAMES) & M_TXDEFERREDFRAMES) + +#define A_NCSI_MACB_LATE_COL 0x1a15c + +#define S_LATECOLLISIONS 0 +#define M_LATECOLLISIONS 0xffffU +#define V_LATECOLLISIONS(x) ((x) << S_LATECOLLISIONS) +#define G_LATECOLLISIONS(x) (((x) >> S_LATECOLLISIONS) & M_LATECOLLISIONS) + +#define A_NCSI_MACB_EXCESSIVE_COL 0x1a160 + +#define S_EXCESSIVECOLLISIONS 0 +#define M_EXCESSIVECOLLISIONS 0xffU +#define V_EXCESSIVECOLLISIONS(x) ((x) << S_EXCESSIVECOLLISIONS) +#define G_EXCESSIVECOLLISIONS(x) (((x) >> S_EXCESSIVECOLLISIONS) & M_EXCESSIVECOLLISIONS) + +#define A_NCSI_MACB_TX_UNDERRUN_ERR 0x1a164 + +#define S_TXUNDERRUNERR 0 +#define M_TXUNDERRUNERR 0xffU +#define V_TXUNDERRUNERR(x) ((x) << S_TXUNDERRUNERR) +#define G_TXUNDERRUNERR(x) (((x) >> S_TXUNDERRUNERR) & M_TXUNDERRUNERR) + +#define A_NCSI_MACB_CARRIER_SENSE_ERR 0x1a168 + +#define S_CARRIERSENSEERRS 0 +#define M_CARRIERSENSEERRS 0xffU +#define V_CARRIERSENSEERRS(x) ((x) << S_CARRIERSENSEERRS) +#define G_CARRIERSENSEERRS(x) (((x) >> S_CARRIERSENSEERRS) & M_CARRIERSENSEERRS) + +#define A_NCSI_MACB_RX_RESOURCE_ERR 0x1a16c + +#define S_RXRESOURCEERR 0 +#define M_RXRESOURCEERR 0xffffU +#define V_RXRESOURCEERR(x) ((x) << S_RXRESOURCEERR) +#define G_RXRESOURCEERR(x) (((x) >> S_RXRESOURCEERR) & M_RXRESOURCEERR) + +#define A_NCSI_MACB_RX_OVERRUN_ERR 0x1a170 + +#define S_RXOVERRUNERRCNT 0 +#define M_RXOVERRUNERRCNT 0xffU +#define V_RXOVERRUNERRCNT(x) ((x) << S_RXOVERRUNERRCNT) +#define G_RXOVERRUNERRCNT(x) (((x) >> S_RXOVERRUNERRCNT) & M_RXOVERRUNERRCNT) + +#define A_NCSI_MACB_RX_SYMBOL_ERR 0x1a174 + +#define S_RXSYMBOLERR 0 +#define M_RXSYMBOLERR 0xffU +#define V_RXSYMBOLERR(x) ((x) << S_RXSYMBOLERR) +#define G_RXSYMBOLERR(x) (((x) >> S_RXSYMBOLERR) & M_RXSYMBOLERR) + +#define A_NCSI_MACB_RX_OVERSIZE_FRAME 0x1a178 + +#define S_RXOVERSIZEERR 0 +#define M_RXOVERSIZEERR 0xffU +#define V_RXOVERSIZEERR(x) ((x) << S_RXOVERSIZEERR) +#define G_RXOVERSIZEERR(x) (((x) >> S_RXOVERSIZEERR) & M_RXOVERSIZEERR) + +#define A_NCSI_MACB_RX_JABBER_ERR 0x1a17c + +#define S_RXJABBERERR 0 +#define M_RXJABBERERR 0xffU +#define V_RXJABBERERR(x) ((x) << S_RXJABBERERR) +#define G_RXJABBERERR(x) (((x) >> S_RXJABBERERR) & M_RXJABBERERR) + +#define A_NCSI_MACB_RX_UNDERSIZE_FRAME 0x1a180 + +#define S_RXUNDERSIZEFR 0 +#define M_RXUNDERSIZEFR 0xffU +#define V_RXUNDERSIZEFR(x) ((x) << S_RXUNDERSIZEFR) +#define G_RXUNDERSIZEFR(x) (((x) >> S_RXUNDERSIZEFR) & M_RXUNDERSIZEFR) + +#define A_NCSI_MACB_SQE_TEST_ERR 0x1a184 + +#define S_SQETESTERR 0 +#define M_SQETESTERR 0xffU +#define V_SQETESTERR(x) ((x) << S_SQETESTERR) +#define G_SQETESTERR(x) (((x) >> S_SQETESTERR) & M_SQETESTERR) + +#define A_NCSI_MACB_LENGTH_ERR 0x1a188 + +#define S_LENGTHERR 0 +#define M_LENGTHERR 0xffU +#define V_LENGTHERR(x) ((x) << S_LENGTHERR) +#define G_LENGTHERR(x) (((x) >> S_LENGTHERR) & M_LENGTHERR) + +#define A_NCSI_MACB_TX_PAUSE_FRAMES 0x1a18c + +#define S_TXPAUSEFRAMES 0 +#define M_TXPAUSEFRAMES 0xffffU +#define V_TXPAUSEFRAMES(x) ((x) << S_TXPAUSEFRAMES) +#define G_TXPAUSEFRAMES(x) (((x) >> S_TXPAUSEFRAMES) & M_TXPAUSEFRAMES) + +#define A_NCSI_MACB_HASH_LOW 0x1a190 +#define A_NCSI_MACB_HASH_HIGH 0x1a194 +#define A_NCSI_MACB_SPECIFIC_1_LOW 0x1a198 +#define A_NCSI_MACB_SPECIFIC_1_HIGH 0x1a19c + +#define S_MATCHHIGH 0 +#define M_MATCHHIGH 0xffffU +#define V_MATCHHIGH(x) ((x) << S_MATCHHIGH) +#define G_MATCHHIGH(x) (((x) >> S_MATCHHIGH) & M_MATCHHIGH) + +#define A_NCSI_MACB_SPECIFIC_2_LOW 0x1a1a0 +#define A_NCSI_MACB_SPECIFIC_2_HIGH 0x1a1a4 +#define A_NCSI_MACB_SPECIFIC_3_LOW 0x1a1a8 +#define A_NCSI_MACB_SPECIFIC_3_HIGH 0x1a1ac +#define A_NCSI_MACB_SPECIFIC_4_LOW 0x1a1b0 +#define A_NCSI_MACB_SPECIFIC_4_HIGH 0x1a1b4 +#define A_NCSI_MACB_TYPE_ID 0x1a1b8 + +#define S_TYPEID 0 +#define M_TYPEID 0xffffU +#define V_TYPEID(x) ((x) << S_TYPEID) +#define G_TYPEID(x) (((x) >> S_TYPEID) & M_TYPEID) + +#define A_NCSI_MACB_TX_PAUSE_QUANTUM 0x1a1bc + +#define S_TXPAUSEQUANTUM 0 +#define M_TXPAUSEQUANTUM 0xffffU +#define V_TXPAUSEQUANTUM(x) ((x) << S_TXPAUSEQUANTUM) +#define G_TXPAUSEQUANTUM(x) (((x) >> S_TXPAUSEQUANTUM) & M_TXPAUSEQUANTUM) + +#define A_NCSI_MACB_USER_IO 0x1a1c0 + +#define S_USERPROGINPUT 16 +#define M_USERPROGINPUT 0xffffU +#define V_USERPROGINPUT(x) ((x) << S_USERPROGINPUT) +#define G_USERPROGINPUT(x) (((x) >> S_USERPROGINPUT) & M_USERPROGINPUT) + +#define S_USERPROGOUTPUT 0 +#define M_USERPROGOUTPUT 0xffffU +#define V_USERPROGOUTPUT(x) ((x) << S_USERPROGOUTPUT) +#define G_USERPROGOUTPUT(x) (((x) >> S_USERPROGOUTPUT) & M_USERPROGOUTPUT) + +#define A_NCSI_MACB_WOL_CFG 0x1a1c4 + +#define S_MCHASHEN 19 +#define V_MCHASHEN(x) ((x) << S_MCHASHEN) +#define F_MCHASHEN V_MCHASHEN(1U) + +#define S_SPECIFIC1EN 18 +#define V_SPECIFIC1EN(x) ((x) << S_SPECIFIC1EN) +#define F_SPECIFIC1EN V_SPECIFIC1EN(1U) + +#define S_ARPEN 17 +#define V_ARPEN(x) ((x) << S_ARPEN) +#define F_ARPEN V_ARPEN(1U) + +#define S_MAGICPKTEN 16 +#define V_MAGICPKTEN(x) ((x) << S_MAGICPKTEN) +#define F_MAGICPKTEN V_MAGICPKTEN(1U) + +#define S_ARPIPADDR 0 +#define M_ARPIPADDR 0xffffU +#define V_ARPIPADDR(x) ((x) << S_ARPIPADDR) +#define G_ARPIPADDR(x) (((x) >> S_ARPIPADDR) & M_ARPIPADDR) + +#define A_NCSI_MACB_REV_STATUS 0x1a1fc + +#define S_PARTREF 16 +#define M_PARTREF 0xffffU +#define V_PARTREF(x) ((x) << S_PARTREF) +#define G_PARTREF(x) (((x) >> S_PARTREF) & M_PARTREF) + +#define S_DESREV 0 +#define M_DESREV 0xffffU +#define V_DESREV(x) ((x) << S_DESREV) +#define G_DESREV(x) (((x) >> S_DESREV) & M_DESREV) + +/* registers for module XGMAC */ +#define XGMAC_BASE_ADDR 0x0 + +#define A_XGMAC_PORT_CFG 0x1000 + +#define S_XGMII_CLK_SEL 29 +#define M_XGMII_CLK_SEL 0x7U +#define V_XGMII_CLK_SEL(x) ((x) << S_XGMII_CLK_SEL) +#define G_XGMII_CLK_SEL(x) (((x) >> S_XGMII_CLK_SEL) & M_XGMII_CLK_SEL) + +#define S_SINKTX 27 +#define V_SINKTX(x) ((x) << S_SINKTX) +#define F_SINKTX V_SINKTX(1U) + +#define S_SINKTXONLINKDOWN 26 +#define V_SINKTXONLINKDOWN(x) ((x) << S_SINKTXONLINKDOWN) +#define F_SINKTXONLINKDOWN V_SINKTXONLINKDOWN(1U) + +#define S_XG2G_SPEED_MODE 25 +#define V_XG2G_SPEED_MODE(x) ((x) << S_XG2G_SPEED_MODE) +#define F_XG2G_SPEED_MODE V_XG2G_SPEED_MODE(1U) + +#define S_LOOPNOFWD 24 +#define V_LOOPNOFWD(x) ((x) << S_LOOPNOFWD) +#define F_LOOPNOFWD V_LOOPNOFWD(1U) + +#define S_XGM_TX_PAUSE_SIZE 23 +#define V_XGM_TX_PAUSE_SIZE(x) ((x) << S_XGM_TX_PAUSE_SIZE) +#define F_XGM_TX_PAUSE_SIZE V_XGM_TX_PAUSE_SIZE(1U) + +#define S_XGM_TX_PAUSE_FRAME 22 +#define V_XGM_TX_PAUSE_FRAME(x) ((x) << S_XGM_TX_PAUSE_FRAME) +#define F_XGM_TX_PAUSE_FRAME V_XGM_TX_PAUSE_FRAME(1U) + +#define S_XGM_TX_DISABLE_PRE 21 +#define V_XGM_TX_DISABLE_PRE(x) ((x) << S_XGM_TX_DISABLE_PRE) +#define F_XGM_TX_DISABLE_PRE V_XGM_TX_DISABLE_PRE(1U) + +#define S_XGM_TX_DISABLE_CRC 20 +#define V_XGM_TX_DISABLE_CRC(x) ((x) << S_XGM_TX_DISABLE_CRC) +#define F_XGM_TX_DISABLE_CRC V_XGM_TX_DISABLE_CRC(1U) + +#define S_SMUX_RX_LOOP 19 +#define V_SMUX_RX_LOOP(x) ((x) << S_SMUX_RX_LOOP) +#define F_SMUX_RX_LOOP V_SMUX_RX_LOOP(1U) + +#define S_RX_LANE_SWAP 18 +#define V_RX_LANE_SWAP(x) ((x) << S_RX_LANE_SWAP) +#define F_RX_LANE_SWAP V_RX_LANE_SWAP(1U) + +#define S_TX_LANE_SWAP 17 +#define V_TX_LANE_SWAP(x) ((x) << S_TX_LANE_SWAP) +#define F_TX_LANE_SWAP V_TX_LANE_SWAP(1U) + +#define S_SIGNAL_DET 14 +#define V_SIGNAL_DET(x) ((x) << S_SIGNAL_DET) +#define F_SIGNAL_DET V_SIGNAL_DET(1U) + +#define S_PMUX_RX_LOOP 13 +#define V_PMUX_RX_LOOP(x) ((x) << S_PMUX_RX_LOOP) +#define F_PMUX_RX_LOOP V_PMUX_RX_LOOP(1U) + +#define S_PMUX_TX_LOOP 12 +#define V_PMUX_TX_LOOP(x) ((x) << S_PMUX_TX_LOOP) +#define F_PMUX_TX_LOOP V_PMUX_TX_LOOP(1U) + +#define S_XGM_RX_SEL 10 +#define M_XGM_RX_SEL 0x3U +#define V_XGM_RX_SEL(x) ((x) << S_XGM_RX_SEL) +#define G_XGM_RX_SEL(x) (((x) >> S_XGM_RX_SEL) & M_XGM_RX_SEL) + +#define S_PCS_TX_SEL 8 +#define M_PCS_TX_SEL 0x3U +#define V_PCS_TX_SEL(x) ((x) << S_PCS_TX_SEL) +#define G_PCS_TX_SEL(x) (((x) >> S_PCS_TX_SEL) & M_PCS_TX_SEL) + +#define S_XAUI20_REM_PRE 5 +#define V_XAUI20_REM_PRE(x) ((x) << S_XAUI20_REM_PRE) +#define F_XAUI20_REM_PRE V_XAUI20_REM_PRE(1U) + +#define S_XAUI20_XGMII_SEL 4 +#define V_XAUI20_XGMII_SEL(x) ((x) << S_XAUI20_XGMII_SEL) +#define F_XAUI20_XGMII_SEL V_XAUI20_XGMII_SEL(1U) + +#define S_PORT_SEL 0 +#define V_PORT_SEL(x) ((x) << S_PORT_SEL) +#define F_PORT_SEL V_PORT_SEL(1U) + +#define A_XGMAC_PORT_RESET_CTRL 0x1004 + +#define S_AUXEXT_RESET 10 +#define V_AUXEXT_RESET(x) ((x) << S_AUXEXT_RESET) +#define F_AUXEXT_RESET V_AUXEXT_RESET(1U) + +#define S_TXFIFO_RESET 9 +#define V_TXFIFO_RESET(x) ((x) << S_TXFIFO_RESET) +#define F_TXFIFO_RESET V_TXFIFO_RESET(1U) + +#define S_RXFIFO_RESET 8 +#define V_RXFIFO_RESET(x) ((x) << S_RXFIFO_RESET) +#define F_RXFIFO_RESET V_RXFIFO_RESET(1U) + +#define S_BEAN_RESET 7 +#define V_BEAN_RESET(x) ((x) << S_BEAN_RESET) +#define F_BEAN_RESET V_BEAN_RESET(1U) + +#define S_XAUI_RESET 6 +#define V_XAUI_RESET(x) ((x) << S_XAUI_RESET) +#define F_XAUI_RESET V_XAUI_RESET(1U) + +#define S_AE_RESET 5 +#define V_AE_RESET(x) ((x) << S_AE_RESET) +#define F_AE_RESET V_AE_RESET(1U) + +#define S_XGM_RESET 4 +#define V_XGM_RESET(x) ((x) << S_XGM_RESET) +#define F_XGM_RESET V_XGM_RESET(1U) + +#define S_XG2G_RESET 3 +#define V_XG2G_RESET(x) ((x) << S_XG2G_RESET) +#define F_XG2G_RESET V_XG2G_RESET(1U) + +#define S_WOL_RESET 2 +#define V_WOL_RESET(x) ((x) << S_WOL_RESET) +#define F_WOL_RESET V_WOL_RESET(1U) + +#define S_XFI_PCS_RESET 1 +#define V_XFI_PCS_RESET(x) ((x) << S_XFI_PCS_RESET) +#define F_XFI_PCS_RESET V_XFI_PCS_RESET(1U) + +#define S_HSS_RESET 0 +#define V_HSS_RESET(x) ((x) << S_HSS_RESET) +#define F_HSS_RESET V_HSS_RESET(1U) + +#define A_XGMAC_PORT_LED_CFG 0x1008 + +#define S_LED1_CFG 5 +#define M_LED1_CFG 0x7U +#define V_LED1_CFG(x) ((x) << S_LED1_CFG) +#define G_LED1_CFG(x) (((x) >> S_LED1_CFG) & M_LED1_CFG) + +#define S_LED1_POLARITY_INV 4 +#define V_LED1_POLARITY_INV(x) ((x) << S_LED1_POLARITY_INV) +#define F_LED1_POLARITY_INV V_LED1_POLARITY_INV(1U) + +#define S_LED0_CFG 1 +#define M_LED0_CFG 0x7U +#define V_LED0_CFG(x) ((x) << S_LED0_CFG) +#define G_LED0_CFG(x) (((x) >> S_LED0_CFG) & M_LED0_CFG) + +#define S_LED0_POLARITY_INV 0 +#define V_LED0_POLARITY_INV(x) ((x) << S_LED0_POLARITY_INV) +#define F_LED0_POLARITY_INV V_LED0_POLARITY_INV(1U) + +#define A_XGMAC_PORT_LED_COUNTHI 0x100c + +#define S_LED_COUNT_HI 0 +#define M_LED_COUNT_HI 0x1ffffffU +#define V_LED_COUNT_HI(x) ((x) << S_LED_COUNT_HI) +#define G_LED_COUNT_HI(x) (((x) >> S_LED_COUNT_HI) & M_LED_COUNT_HI) + +#define A_XGMAC_PORT_LED_COUNTLO 0x1010 + +#define S_LED_COUNT_LO 0 +#define M_LED_COUNT_LO 0x1ffffffU +#define V_LED_COUNT_LO(x) ((x) << S_LED_COUNT_LO) +#define G_LED_COUNT_LO(x) (((x) >> S_LED_COUNT_LO) & M_LED_COUNT_LO) + +#define A_XGMAC_PORT_DEBUG_CFG 0x1014 + +#define S_TESTCLK_SEL 0 +#define M_TESTCLK_SEL 0xfU +#define V_TESTCLK_SEL(x) ((x) << S_TESTCLK_SEL) +#define G_TESTCLK_SEL(x) (((x) >> S_TESTCLK_SEL) & M_TESTCLK_SEL) + +#define A_XGMAC_PORT_CFG2 0x1018 + +#define S_RX_POLARITY_INV 28 +#define M_RX_POLARITY_INV 0xfU +#define V_RX_POLARITY_INV(x) ((x) << S_RX_POLARITY_INV) +#define G_RX_POLARITY_INV(x) (((x) >> S_RX_POLARITY_INV) & M_RX_POLARITY_INV) + +#define S_TX_POLARITY_INV 24 +#define M_TX_POLARITY_INV 0xfU +#define V_TX_POLARITY_INV(x) ((x) << S_TX_POLARITY_INV) +#define G_TX_POLARITY_INV(x) (((x) >> S_TX_POLARITY_INV) & M_TX_POLARITY_INV) + +#define S_INSTANCENUM 22 +#define M_INSTANCENUM 0x3U +#define V_INSTANCENUM(x) ((x) << S_INSTANCENUM) +#define G_INSTANCENUM(x) (((x) >> S_INSTANCENUM) & M_INSTANCENUM) + +#define S_STOPONPERR 21 +#define V_STOPONPERR(x) ((x) << S_STOPONPERR) +#define F_STOPONPERR V_STOPONPERR(1U) + +#define S_MACTXEN 20 +#define V_MACTXEN(x) ((x) << S_MACTXEN) +#define F_MACTXEN V_MACTXEN(1U) + +#define S_MACRXEN 19 +#define V_MACRXEN(x) ((x) << S_MACRXEN) +#define F_MACRXEN V_MACRXEN(1U) + +#define S_PATEN 18 +#define V_PATEN(x) ((x) << S_PATEN) +#define F_PATEN V_PATEN(1U) + +#define S_MAGICEN 17 +#define V_MAGICEN(x) ((x) << S_MAGICEN) +#define F_MAGICEN V_MAGICEN(1U) + +#define S_TX_IPG 4 +#define M_TX_IPG 0x1fffU +#define V_TX_IPG(x) ((x) << S_TX_IPG) +#define G_TX_IPG(x) (((x) >> S_TX_IPG) & M_TX_IPG) + +#define S_AEC_PMA_TX_READY 1 +#define V_AEC_PMA_TX_READY(x) ((x) << S_AEC_PMA_TX_READY) +#define F_AEC_PMA_TX_READY V_AEC_PMA_TX_READY(1U) + +#define S_AEC_PMA_RX_READY 0 +#define V_AEC_PMA_RX_READY(x) ((x) << S_AEC_PMA_RX_READY) +#define F_AEC_PMA_RX_READY V_AEC_PMA_RX_READY(1U) + +#define A_XGMAC_PORT_PKT_COUNT 0x101c + +#define S_TX_SOP_COUNT 24 +#define M_TX_SOP_COUNT 0xffU +#define V_TX_SOP_COUNT(x) ((x) << S_TX_SOP_COUNT) +#define G_TX_SOP_COUNT(x) (((x) >> S_TX_SOP_COUNT) & M_TX_SOP_COUNT) + +#define S_TX_EOP_COUNT 16 +#define M_TX_EOP_COUNT 0xffU +#define V_TX_EOP_COUNT(x) ((x) << S_TX_EOP_COUNT) +#define G_TX_EOP_COUNT(x) (((x) >> S_TX_EOP_COUNT) & M_TX_EOP_COUNT) + +#define S_RX_SOP_COUNT 8 +#define M_RX_SOP_COUNT 0xffU +#define V_RX_SOP_COUNT(x) ((x) << S_RX_SOP_COUNT) +#define G_RX_SOP_COUNT(x) (((x) >> S_RX_SOP_COUNT) & M_RX_SOP_COUNT) + +#define S_RX_EOP_COUNT 0 +#define M_RX_EOP_COUNT 0xffU +#define V_RX_EOP_COUNT(x) ((x) << S_RX_EOP_COUNT) +#define G_RX_EOP_COUNT(x) (((x) >> S_RX_EOP_COUNT) & M_RX_EOP_COUNT) + +#define A_XGMAC_PORT_PERR_INJECT 0x1020 + +#define S_XGMMEMSEL 1 +#define V_XGMMEMSEL(x) ((x) << S_XGMMEMSEL) +#define F_XGMMEMSEL V_XGMMEMSEL(1U) + +#define A_XGMAC_PORT_MAGIC_MACID_LO 0x1024 +#define A_XGMAC_PORT_MAGIC_MACID_HI 0x1028 + +#define S_MAC_WOL_DA 0 +#define M_MAC_WOL_DA 0xffffU +#define V_MAC_WOL_DA(x) ((x) << S_MAC_WOL_DA) +#define G_MAC_WOL_DA(x) (((x) >> S_MAC_WOL_DA) & M_MAC_WOL_DA) + +#define A_XGMAC_PORT_BUILD_REVISION 0x102c +#define A_XGMAC_PORT_XGMII_SE_COUNT 0x1030 + +#define S_TXSOP 24 +#define M_TXSOP 0xffU +#define V_TXSOP(x) ((x) << S_TXSOP) +#define G_TXSOP(x) (((x) >> S_TXSOP) & M_TXSOP) + +#define S_TXEOP 16 +#define M_TXEOP 0xffU +#define V_TXEOP(x) ((x) << S_TXEOP) +#define G_TXEOP(x) (((x) >> S_TXEOP) & M_TXEOP) + +#define S_RXSOP 8 +#define M_RXSOP 0xffU +#define V_RXSOP(x) ((x) << S_RXSOP) +#define G_RXSOP(x) (((x) >> S_RXSOP) & M_RXSOP) + +#define A_XGMAC_PORT_LINK_STATUS 0x1034 + +#define S_REMFLT 3 +#define V_REMFLT(x) ((x) << S_REMFLT) +#define F_REMFLT V_REMFLT(1U) + +#define S_LOCFLT 2 +#define V_LOCFLT(x) ((x) << S_LOCFLT) +#define F_LOCFLT V_LOCFLT(1U) + +#define S_LINKUP 1 +#define V_LINKUP(x) ((x) << S_LINKUP) +#define F_LINKUP V_LINKUP(1U) + +#define S_LINKDN 0 +#define V_LINKDN(x) ((x) << S_LINKDN) +#define F_LINKDN V_LINKDN(1U) + +#define A_XGMAC_PORT_CHECKIN 0x1038 + +#define S_PREAMBLE 1 +#define V_PREAMBLE(x) ((x) << S_PREAMBLE) +#define F_PREAMBLE V_PREAMBLE(1U) + +#define S_CHECKIN 0 +#define V_CHECKIN(x) ((x) << S_CHECKIN) +#define F_CHECKIN V_CHECKIN(1U) + +#define A_XGMAC_PORT_FAULT_TEST 0x103c + +#define S_FLTTYPE 1 +#define V_FLTTYPE(x) ((x) << S_FLTTYPE) +#define F_FLTTYPE V_FLTTYPE(1U) + +#define S_FLTCTRL 0 +#define V_FLTCTRL(x) ((x) << S_FLTCTRL) +#define F_FLTCTRL V_FLTCTRL(1U) + +#define A_XGMAC_PORT_SPARE 0x1040 +#define A_XGMAC_PORT_HSS_SIGDET_STATUS 0x1044 + +#define S_SIGNALDETECT 0 +#define M_SIGNALDETECT 0xfU +#define V_SIGNALDETECT(x) ((x) << S_SIGNALDETECT) +#define G_SIGNALDETECT(x) (((x) >> S_SIGNALDETECT) & M_SIGNALDETECT) + +#define A_XGMAC_PORT_EXT_LOS_STATUS 0x1048 +#define A_XGMAC_PORT_EXT_LOS_CTRL 0x104c + +#define S_CTRL 0 +#define M_CTRL 0xfU +#define V_CTRL(x) ((x) << S_CTRL) +#define G_CTRL(x) (((x) >> S_CTRL) & M_CTRL) + +#define A_XGMAC_PORT_FPGA_PAUSE_CTL 0x1050 + +#define S_CTL 31 +#define V_CTL(x) ((x) << S_CTL) +#define F_CTL V_CTL(1U) + +#define S_HWM 13 +#define M_HWM 0x1fffU +#define V_HWM(x) ((x) << S_HWM) +#define G_HWM(x) (((x) >> S_HWM) & M_HWM) + +#define S_LWM 0 +#define M_LWM 0x1fffU +#define V_LWM(x) ((x) << S_LWM) +#define G_LWM(x) (((x) >> S_LWM) & M_LWM) + +#define A_XGMAC_PORT_FPGA_ERRPKT_CNT 0x1054 +#define A_XGMAC_PORT_LA_TX_0 0x1058 +#define A_XGMAC_PORT_LA_RX_0 0x105c +#define A_XGMAC_PORT_FPGA_LA_CTL 0x1060 + +#define S_RXRST 5 +#define V_RXRST(x) ((x) << S_RXRST) +#define F_RXRST V_RXRST(1U) + +#define S_TXRST 4 +#define V_TXRST(x) ((x) << S_TXRST) +#define F_TXRST V_TXRST(1U) + +#define S_XGMII 3 +#define V_XGMII(x) ((x) << S_XGMII) +#define F_XGMII V_XGMII(1U) + +#define S_LAPAUSE 2 +#define V_LAPAUSE(x) ((x) << S_LAPAUSE) +#define F_LAPAUSE V_LAPAUSE(1U) + +#define S_STOPERR 1 +#define V_STOPERR(x) ((x) << S_STOPERR) +#define F_STOPERR V_STOPERR(1U) + +#define S_LASTOP 0 +#define V_LASTOP(x) ((x) << S_LASTOP) +#define F_LASTOP V_LASTOP(1U) + +#define A_XGMAC_PORT_EPIO_DATA0 0x10c0 +#define A_XGMAC_PORT_EPIO_DATA1 0x10c4 +#define A_XGMAC_PORT_EPIO_DATA2 0x10c8 +#define A_XGMAC_PORT_EPIO_DATA3 0x10cc +#define A_XGMAC_PORT_EPIO_OP 0x10d0 + +#define S_EPIOWR 8 +#define V_EPIOWR(x) ((x) << S_EPIOWR) +#define F_EPIOWR V_EPIOWR(1U) + +#define S_ADDRESS 0 +#define M_ADDRESS 0xffU +#define V_ADDRESS(x) ((x) << S_ADDRESS) +#define G_ADDRESS(x) (((x) >> S_ADDRESS) & M_ADDRESS) + +#define A_XGMAC_PORT_WOL_STATUS 0x10d4 + +#define S_MAGICDETECTED 31 +#define V_MAGICDETECTED(x) ((x) << S_MAGICDETECTED) +#define F_MAGICDETECTED V_MAGICDETECTED(1U) + +#define S_PATDETECTED 30 +#define V_PATDETECTED(x) ((x) << S_PATDETECTED) +#define F_PATDETECTED V_PATDETECTED(1U) + +#define S_CLEARMAGIC 4 +#define V_CLEARMAGIC(x) ((x) << S_CLEARMAGIC) +#define F_CLEARMAGIC V_CLEARMAGIC(1U) + +#define S_CLEARMATCH 3 +#define V_CLEARMATCH(x) ((x) << S_CLEARMATCH) +#define F_CLEARMATCH V_CLEARMATCH(1U) + +#define S_MATCHEDFILTER 0 +#define M_MATCHEDFILTER 0x7U +#define V_MATCHEDFILTER(x) ((x) << S_MATCHEDFILTER) +#define G_MATCHEDFILTER(x) (((x) >> S_MATCHEDFILTER) & M_MATCHEDFILTER) + +#define A_XGMAC_PORT_INT_EN 0x10d8 + +#define S_EXT_LOS 28 +#define V_EXT_LOS(x) ((x) << S_EXT_LOS) +#define F_EXT_LOS V_EXT_LOS(1U) + +#define S_INCMPTBL_LINK 27 +#define V_INCMPTBL_LINK(x) ((x) << S_INCMPTBL_LINK) +#define F_INCMPTBL_LINK V_INCMPTBL_LINK(1U) + +#define S_PATDETWAKE 26 +#define V_PATDETWAKE(x) ((x) << S_PATDETWAKE) +#define F_PATDETWAKE V_PATDETWAKE(1U) + +#define S_MAGICWAKE 25 +#define V_MAGICWAKE(x) ((x) << S_MAGICWAKE) +#define F_MAGICWAKE V_MAGICWAKE(1U) + +#define S_SIGDETCHG 24 +#define V_SIGDETCHG(x) ((x) << S_SIGDETCHG) +#define F_SIGDETCHG V_SIGDETCHG(1U) + +#define S_PCSR_FEC_CORR 23 +#define V_PCSR_FEC_CORR(x) ((x) << S_PCSR_FEC_CORR) +#define F_PCSR_FEC_CORR V_PCSR_FEC_CORR(1U) + +#define S_AE_TRAIN_LOCAL 22 +#define V_AE_TRAIN_LOCAL(x) ((x) << S_AE_TRAIN_LOCAL) +#define F_AE_TRAIN_LOCAL V_AE_TRAIN_LOCAL(1U) + +#define S_HSSPLL_LOCK 21 +#define V_HSSPLL_LOCK(x) ((x) << S_HSSPLL_LOCK) +#define F_HSSPLL_LOCK V_HSSPLL_LOCK(1U) + +#define S_HSSPRT_READY 20 +#define V_HSSPRT_READY(x) ((x) << S_HSSPRT_READY) +#define F_HSSPRT_READY V_HSSPRT_READY(1U) + +#define S_AUTONEG_DONE 19 +#define V_AUTONEG_DONE(x) ((x) << S_AUTONEG_DONE) +#define F_AUTONEG_DONE V_AUTONEG_DONE(1U) + +#define S_PCSR_HI_BER 18 +#define V_PCSR_HI_BER(x) ((x) << S_PCSR_HI_BER) +#define F_PCSR_HI_BER V_PCSR_HI_BER(1U) + +#define S_PCSR_FEC_ERROR 17 +#define V_PCSR_FEC_ERROR(x) ((x) << S_PCSR_FEC_ERROR) +#define F_PCSR_FEC_ERROR V_PCSR_FEC_ERROR(1U) + +#define S_PCSR_LINK_FAIL 16 +#define V_PCSR_LINK_FAIL(x) ((x) << S_PCSR_LINK_FAIL) +#define F_PCSR_LINK_FAIL V_PCSR_LINK_FAIL(1U) + +#define S_XAUI_DEC_ERROR 15 +#define V_XAUI_DEC_ERROR(x) ((x) << S_XAUI_DEC_ERROR) +#define F_XAUI_DEC_ERROR V_XAUI_DEC_ERROR(1U) + +#define S_XAUI_LINK_FAIL 14 +#define V_XAUI_LINK_FAIL(x) ((x) << S_XAUI_LINK_FAIL) +#define F_XAUI_LINK_FAIL V_XAUI_LINK_FAIL(1U) + +#define S_PCS_CTC_ERROR 13 +#define V_PCS_CTC_ERROR(x) ((x) << S_PCS_CTC_ERROR) +#define F_PCS_CTC_ERROR V_PCS_CTC_ERROR(1U) + +#define S_PCS_LINK_GOOD 12 +#define V_PCS_LINK_GOOD(x) ((x) << S_PCS_LINK_GOOD) +#define F_PCS_LINK_GOOD V_PCS_LINK_GOOD(1U) + +#define S_PCS_LINK_FAIL 11 +#define V_PCS_LINK_FAIL(x) ((x) << S_PCS_LINK_FAIL) +#define F_PCS_LINK_FAIL V_PCS_LINK_FAIL(1U) + +#define S_RXFIFOOVERFLOW 10 +#define V_RXFIFOOVERFLOW(x) ((x) << S_RXFIFOOVERFLOW) +#define F_RXFIFOOVERFLOW V_RXFIFOOVERFLOW(1U) + +#define S_HSSPRBSERR 9 +#define V_HSSPRBSERR(x) ((x) << S_HSSPRBSERR) +#define F_HSSPRBSERR V_HSSPRBSERR(1U) + +#define S_HSSEYEQUAL 8 +#define V_HSSEYEQUAL(x) ((x) << S_HSSEYEQUAL) +#define F_HSSEYEQUAL V_HSSEYEQUAL(1U) + +#define S_REMOTEFAULT 7 +#define V_REMOTEFAULT(x) ((x) << S_REMOTEFAULT) +#define F_REMOTEFAULT V_REMOTEFAULT(1U) + +#define S_LOCALFAULT 6 +#define V_LOCALFAULT(x) ((x) << S_LOCALFAULT) +#define F_LOCALFAULT V_LOCALFAULT(1U) + +#define S_MAC_LINK_DOWN 5 +#define V_MAC_LINK_DOWN(x) ((x) << S_MAC_LINK_DOWN) +#define F_MAC_LINK_DOWN V_MAC_LINK_DOWN(1U) + +#define S_MAC_LINK_UP 4 +#define V_MAC_LINK_UP(x) ((x) << S_MAC_LINK_UP) +#define F_MAC_LINK_UP V_MAC_LINK_UP(1U) + +#define S_BEAN_INT 3 +#define V_BEAN_INT(x) ((x) << S_BEAN_INT) +#define F_BEAN_INT V_BEAN_INT(1U) + +#define S_XGM_INT 2 +#define V_XGM_INT(x) ((x) << S_XGM_INT) +#define F_XGM_INT V_XGM_INT(1U) + +#define A_XGMAC_PORT_INT_CAUSE 0x10dc +#define A_XGMAC_PORT_HSS_CFG0 0x10e0 + +#define S_TXDTS 31 +#define V_TXDTS(x) ((x) << S_TXDTS) +#define F_TXDTS V_TXDTS(1U) + +#define S_TXCTS 30 +#define V_TXCTS(x) ((x) << S_TXCTS) +#define F_TXCTS V_TXCTS(1U) + +#define S_TXBTS 29 +#define V_TXBTS(x) ((x) << S_TXBTS) +#define F_TXBTS V_TXBTS(1U) + +#define S_TXATS 28 +#define V_TXATS(x) ((x) << S_TXATS) +#define F_TXATS V_TXATS(1U) + +#define S_TXDOBS 27 +#define V_TXDOBS(x) ((x) << S_TXDOBS) +#define F_TXDOBS V_TXDOBS(1U) + +#define S_TXCOBS 26 +#define V_TXCOBS(x) ((x) << S_TXCOBS) +#define F_TXCOBS V_TXCOBS(1U) + +#define S_TXBOBS 25 +#define V_TXBOBS(x) ((x) << S_TXBOBS) +#define F_TXBOBS V_TXBOBS(1U) + +#define S_TXAOBS 24 +#define V_TXAOBS(x) ((x) << S_TXAOBS) +#define F_TXAOBS V_TXAOBS(1U) + +#define S_HSSREFCLKSEL 20 +#define V_HSSREFCLKSEL(x) ((x) << S_HSSREFCLKSEL) +#define F_HSSREFCLKSEL V_HSSREFCLKSEL(1U) + +#define S_HSSAVDHI 17 +#define V_HSSAVDHI(x) ((x) << S_HSSAVDHI) +#define F_HSSAVDHI V_HSSAVDHI(1U) + +#define S_HSSRXTS 16 +#define V_HSSRXTS(x) ((x) << S_HSSRXTS) +#define F_HSSRXTS V_HSSRXTS(1U) + +#define S_HSSTXACMODE 15 +#define V_HSSTXACMODE(x) ((x) << S_HSSTXACMODE) +#define F_HSSTXACMODE V_HSSTXACMODE(1U) + +#define S_HSSRXACMODE 14 +#define V_HSSRXACMODE(x) ((x) << S_HSSRXACMODE) +#define F_HSSRXACMODE V_HSSRXACMODE(1U) + +#define S_HSSRESYNC 13 +#define V_HSSRESYNC(x) ((x) << S_HSSRESYNC) +#define F_HSSRESYNC V_HSSRESYNC(1U) + +#define S_HSSRECCAL 12 +#define V_HSSRECCAL(x) ((x) << S_HSSRECCAL) +#define F_HSSRECCAL V_HSSRECCAL(1U) + +#define S_HSSPDWNPLL 11 +#define V_HSSPDWNPLL(x) ((x) << S_HSSPDWNPLL) +#define F_HSSPDWNPLL V_HSSPDWNPLL(1U) + +#define S_HSSDIVSEL 9 +#define M_HSSDIVSEL 0x3U +#define V_HSSDIVSEL(x) ((x) << S_HSSDIVSEL) +#define G_HSSDIVSEL(x) (((x) >> S_HSSDIVSEL) & M_HSSDIVSEL) + +#define S_HSSREFDIV 8 +#define V_HSSREFDIV(x) ((x) << S_HSSREFDIV) +#define F_HSSREFDIV V_HSSREFDIV(1U) + +#define S_HSSPLLBYP 7 +#define V_HSSPLLBYP(x) ((x) << S_HSSPLLBYP) +#define F_HSSPLLBYP V_HSSPLLBYP(1U) + +#define S_HSSLOFREQPLL 6 +#define V_HSSLOFREQPLL(x) ((x) << S_HSSLOFREQPLL) +#define F_HSSLOFREQPLL V_HSSLOFREQPLL(1U) + +#define S_HSSLOFREQ2PLL 5 +#define V_HSSLOFREQ2PLL(x) ((x) << S_HSSLOFREQ2PLL) +#define F_HSSLOFREQ2PLL V_HSSLOFREQ2PLL(1U) + +#define S_HSSEXTC16SEL 4 +#define V_HSSEXTC16SEL(x) ((x) << S_HSSEXTC16SEL) +#define F_HSSEXTC16SEL V_HSSEXTC16SEL(1U) + +#define S_HSSRSTCONFIG 1 +#define M_HSSRSTCONFIG 0x7U +#define V_HSSRSTCONFIG(x) ((x) << S_HSSRSTCONFIG) +#define G_HSSRSTCONFIG(x) (((x) >> S_HSSRSTCONFIG) & M_HSSRSTCONFIG) + +#define S_HSSPRBSEN 0 +#define V_HSSPRBSEN(x) ((x) << S_HSSPRBSEN) +#define F_HSSPRBSEN V_HSSPRBSEN(1U) + +#define A_XGMAC_PORT_HSS_CFG1 0x10e4 + +#define S_RXDPRBSRST 28 +#define V_RXDPRBSRST(x) ((x) << S_RXDPRBSRST) +#define F_RXDPRBSRST V_RXDPRBSRST(1U) + +#define S_RXDPRBSEN 27 +#define V_RXDPRBSEN(x) ((x) << S_RXDPRBSEN) +#define F_RXDPRBSEN V_RXDPRBSEN(1U) + +#define S_RXDPRBSFRCERR 26 +#define V_RXDPRBSFRCERR(x) ((x) << S_RXDPRBSFRCERR) +#define F_RXDPRBSFRCERR V_RXDPRBSFRCERR(1U) + +#define S_TXDPRBSRST 25 +#define V_TXDPRBSRST(x) ((x) << S_TXDPRBSRST) +#define F_TXDPRBSRST V_TXDPRBSRST(1U) + +#define S_TXDPRBSEN 24 +#define V_TXDPRBSEN(x) ((x) << S_TXDPRBSEN) +#define F_TXDPRBSEN V_TXDPRBSEN(1U) + +#define S_RXCPRBSRST 20 +#define V_RXCPRBSRST(x) ((x) << S_RXCPRBSRST) +#define F_RXCPRBSRST V_RXCPRBSRST(1U) + +#define S_RXCPRBSEN 19 +#define V_RXCPRBSEN(x) ((x) << S_RXCPRBSEN) +#define F_RXCPRBSEN V_RXCPRBSEN(1U) + +#define S_RXCPRBSFRCERR 18 +#define V_RXCPRBSFRCERR(x) ((x) << S_RXCPRBSFRCERR) +#define F_RXCPRBSFRCERR V_RXCPRBSFRCERR(1U) + +#define S_TXCPRBSRST 17 +#define V_TXCPRBSRST(x) ((x) << S_TXCPRBSRST) +#define F_TXCPRBSRST V_TXCPRBSRST(1U) + +#define S_TXCPRBSEN 16 +#define V_TXCPRBSEN(x) ((x) << S_TXCPRBSEN) +#define F_TXCPRBSEN V_TXCPRBSEN(1U) + +#define S_RXBPRBSRST 12 +#define V_RXBPRBSRST(x) ((x) << S_RXBPRBSRST) +#define F_RXBPRBSRST V_RXBPRBSRST(1U) + +#define S_RXBPRBSEN 11 +#define V_RXBPRBSEN(x) ((x) << S_RXBPRBSEN) +#define F_RXBPRBSEN V_RXBPRBSEN(1U) + +#define S_RXBPRBSFRCERR 10 +#define V_RXBPRBSFRCERR(x) ((x) << S_RXBPRBSFRCERR) +#define F_RXBPRBSFRCERR V_RXBPRBSFRCERR(1U) + +#define S_TXBPRBSRST 9 +#define V_TXBPRBSRST(x) ((x) << S_TXBPRBSRST) +#define F_TXBPRBSRST V_TXBPRBSRST(1U) + +#define S_TXBPRBSEN 8 +#define V_TXBPRBSEN(x) ((x) << S_TXBPRBSEN) +#define F_TXBPRBSEN V_TXBPRBSEN(1U) + +#define S_RXAPRBSRST 4 +#define V_RXAPRBSRST(x) ((x) << S_RXAPRBSRST) +#define F_RXAPRBSRST V_RXAPRBSRST(1U) + +#define S_RXAPRBSEN 3 +#define V_RXAPRBSEN(x) ((x) << S_RXAPRBSEN) +#define F_RXAPRBSEN V_RXAPRBSEN(1U) + +#define S_RXAPRBSFRCERR 2 +#define V_RXAPRBSFRCERR(x) ((x) << S_RXAPRBSFRCERR) +#define F_RXAPRBSFRCERR V_RXAPRBSFRCERR(1U) + +#define S_TXAPRBSRST 1 +#define V_TXAPRBSRST(x) ((x) << S_TXAPRBSRST) +#define F_TXAPRBSRST V_TXAPRBSRST(1U) + +#define S_TXAPRBSEN 0 +#define V_TXAPRBSEN(x) ((x) << S_TXAPRBSEN) +#define F_TXAPRBSEN V_TXAPRBSEN(1U) + +#define A_XGMAC_PORT_HSS_CFG2 0x10e8 + +#define S_RXDDATASYNC 23 +#define V_RXDDATASYNC(x) ((x) << S_RXDDATASYNC) +#define F_RXDDATASYNC V_RXDDATASYNC(1U) + +#define S_RXCDATASYNC 22 +#define V_RXCDATASYNC(x) ((x) << S_RXCDATASYNC) +#define F_RXCDATASYNC V_RXCDATASYNC(1U) + +#define S_RXBDATASYNC 21 +#define V_RXBDATASYNC(x) ((x) << S_RXBDATASYNC) +#define F_RXBDATASYNC V_RXBDATASYNC(1U) + +#define S_RXADATASYNC 20 +#define V_RXADATASYNC(x) ((x) << S_RXADATASYNC) +#define F_RXADATASYNC V_RXADATASYNC(1U) + +#define S_RXDEARLYIN 19 +#define V_RXDEARLYIN(x) ((x) << S_RXDEARLYIN) +#define F_RXDEARLYIN V_RXDEARLYIN(1U) + +#define S_RXDLATEIN 18 +#define V_RXDLATEIN(x) ((x) << S_RXDLATEIN) +#define F_RXDLATEIN V_RXDLATEIN(1U) + +#define S_RXDPHSLOCK 17 +#define V_RXDPHSLOCK(x) ((x) << S_RXDPHSLOCK) +#define F_RXDPHSLOCK V_RXDPHSLOCK(1U) + +#define S_RXDPHSDNIN 16 +#define V_RXDPHSDNIN(x) ((x) << S_RXDPHSDNIN) +#define F_RXDPHSDNIN V_RXDPHSDNIN(1U) + +#define S_RXDPHSUPIN 15 +#define V_RXDPHSUPIN(x) ((x) << S_RXDPHSUPIN) +#define F_RXDPHSUPIN V_RXDPHSUPIN(1U) + +#define S_RXCEARLYIN 14 +#define V_RXCEARLYIN(x) ((x) << S_RXCEARLYIN) +#define F_RXCEARLYIN V_RXCEARLYIN(1U) + +#define S_RXCLATEIN 13 +#define V_RXCLATEIN(x) ((x) << S_RXCLATEIN) +#define F_RXCLATEIN V_RXCLATEIN(1U) + +#define S_RXCPHSLOCK 12 +#define V_RXCPHSLOCK(x) ((x) << S_RXCPHSLOCK) +#define F_RXCPHSLOCK V_RXCPHSLOCK(1U) + +#define S_RXCPHSDNIN 11 +#define V_RXCPHSDNIN(x) ((x) << S_RXCPHSDNIN) +#define F_RXCPHSDNIN V_RXCPHSDNIN(1U) + +#define S_RXCPHSUPIN 10 +#define V_RXCPHSUPIN(x) ((x) << S_RXCPHSUPIN) +#define F_RXCPHSUPIN V_RXCPHSUPIN(1U) + +#define S_RXBEARLYIN 9 +#define V_RXBEARLYIN(x) ((x) << S_RXBEARLYIN) +#define F_RXBEARLYIN V_RXBEARLYIN(1U) + +#define S_RXBLATEIN 8 +#define V_RXBLATEIN(x) ((x) << S_RXBLATEIN) +#define F_RXBLATEIN V_RXBLATEIN(1U) + +#define S_RXBPHSLOCK 7 +#define V_RXBPHSLOCK(x) ((x) << S_RXBPHSLOCK) +#define F_RXBPHSLOCK V_RXBPHSLOCK(1U) + +#define S_RXBPHSDNIN 6 +#define V_RXBPHSDNIN(x) ((x) << S_RXBPHSDNIN) +#define F_RXBPHSDNIN V_RXBPHSDNIN(1U) + +#define S_RXBPHSUPIN 5 +#define V_RXBPHSUPIN(x) ((x) << S_RXBPHSUPIN) +#define F_RXBPHSUPIN V_RXBPHSUPIN(1U) + +#define S_RXAEARLYIN 4 +#define V_RXAEARLYIN(x) ((x) << S_RXAEARLYIN) +#define F_RXAEARLYIN V_RXAEARLYIN(1U) + +#define S_RXALATEIN 3 +#define V_RXALATEIN(x) ((x) << S_RXALATEIN) +#define F_RXALATEIN V_RXALATEIN(1U) + +#define S_RXAPHSLOCK 2 +#define V_RXAPHSLOCK(x) ((x) << S_RXAPHSLOCK) +#define F_RXAPHSLOCK V_RXAPHSLOCK(1U) + +#define S_RXAPHSDNIN 1 +#define V_RXAPHSDNIN(x) ((x) << S_RXAPHSDNIN) +#define F_RXAPHSDNIN V_RXAPHSDNIN(1U) + +#define S_RXAPHSUPIN 0 +#define V_RXAPHSUPIN(x) ((x) << S_RXAPHSUPIN) +#define F_RXAPHSUPIN V_RXAPHSUPIN(1U) + +#define A_XGMAC_PORT_HSS_STATUS 0x10ec + +#define S_RXDPRBSSYNC 15 +#define V_RXDPRBSSYNC(x) ((x) << S_RXDPRBSSYNC) +#define F_RXDPRBSSYNC V_RXDPRBSSYNC(1U) + +#define S_RXCPRBSSYNC 14 +#define V_RXCPRBSSYNC(x) ((x) << S_RXCPRBSSYNC) +#define F_RXCPRBSSYNC V_RXCPRBSSYNC(1U) + +#define S_RXBPRBSSYNC 13 +#define V_RXBPRBSSYNC(x) ((x) << S_RXBPRBSSYNC) +#define F_RXBPRBSSYNC V_RXBPRBSSYNC(1U) + +#define S_RXAPRBSSYNC 12 +#define V_RXAPRBSSYNC(x) ((x) << S_RXAPRBSSYNC) +#define F_RXAPRBSSYNC V_RXAPRBSSYNC(1U) + +#define S_RXDPRBSERR 11 +#define V_RXDPRBSERR(x) ((x) << S_RXDPRBSERR) +#define F_RXDPRBSERR V_RXDPRBSERR(1U) + +#define S_RXCPRBSERR 10 +#define V_RXCPRBSERR(x) ((x) << S_RXCPRBSERR) +#define F_RXCPRBSERR V_RXCPRBSERR(1U) + +#define S_RXBPRBSERR 9 +#define V_RXBPRBSERR(x) ((x) << S_RXBPRBSERR) +#define F_RXBPRBSERR V_RXBPRBSERR(1U) + +#define S_RXAPRBSERR 8 +#define V_RXAPRBSERR(x) ((x) << S_RXAPRBSERR) +#define F_RXAPRBSERR V_RXAPRBSERR(1U) + +#define S_RXDSIGDET 7 +#define V_RXDSIGDET(x) ((x) << S_RXDSIGDET) +#define F_RXDSIGDET V_RXDSIGDET(1U) + +#define S_RXCSIGDET 6 +#define V_RXCSIGDET(x) ((x) << S_RXCSIGDET) +#define F_RXCSIGDET V_RXCSIGDET(1U) + +#define S_RXBSIGDET 5 +#define V_RXBSIGDET(x) ((x) << S_RXBSIGDET) +#define F_RXBSIGDET V_RXBSIGDET(1U) + +#define S_RXASIGDET 4 +#define V_RXASIGDET(x) ((x) << S_RXASIGDET) +#define F_RXASIGDET V_RXASIGDET(1U) + +#define S_HSSPLLLOCK 1 +#define V_HSSPLLLOCK(x) ((x) << S_HSSPLLLOCK) +#define F_HSSPLLLOCK V_HSSPLLLOCK(1U) + +#define S_HSSPRTREADY 0 +#define V_HSSPRTREADY(x) ((x) << S_HSSPRTREADY) +#define F_HSSPRTREADY V_HSSPRTREADY(1U) + +#define A_XGMAC_PORT_XGM_TX_CTRL 0x1200 + +#define S_SENDPAUSE 2 +#define V_SENDPAUSE(x) ((x) << S_SENDPAUSE) +#define F_SENDPAUSE V_SENDPAUSE(1U) + +#define S_SENDZEROPAUSE 1 +#define V_SENDZEROPAUSE(x) ((x) << S_SENDZEROPAUSE) +#define F_SENDZEROPAUSE V_SENDZEROPAUSE(1U) + +#define S_XGM_TXEN 0 +#define V_XGM_TXEN(x) ((x) << S_XGM_TXEN) +#define F_XGM_TXEN V_XGM_TXEN(1U) + +#define A_XGMAC_PORT_XGM_TX_CFG 0x1204 + +#define S_CRCCAL 8 +#define M_CRCCAL 0x3U +#define V_CRCCAL(x) ((x) << S_CRCCAL) +#define G_CRCCAL(x) (((x) >> S_CRCCAL) & M_CRCCAL) + +#define S_DISDEFIDLECNT 7 +#define V_DISDEFIDLECNT(x) ((x) << S_DISDEFIDLECNT) +#define F_DISDEFIDLECNT V_DISDEFIDLECNT(1U) + +#define S_DECAVGTXIPG 6 +#define V_DECAVGTXIPG(x) ((x) << S_DECAVGTXIPG) +#define F_DECAVGTXIPG V_DECAVGTXIPG(1U) + +#define S_UNIDIRTXEN 5 +#define V_UNIDIRTXEN(x) ((x) << S_UNIDIRTXEN) +#define F_UNIDIRTXEN V_UNIDIRTXEN(1U) + +#define S_CFGCLKSPEED 2 +#define M_CFGCLKSPEED 0x7U +#define V_CFGCLKSPEED(x) ((x) << S_CFGCLKSPEED) +#define G_CFGCLKSPEED(x) (((x) >> S_CFGCLKSPEED) & M_CFGCLKSPEED) + +#define S_STRETCHMODE 1 +#define V_STRETCHMODE(x) ((x) << S_STRETCHMODE) +#define F_STRETCHMODE V_STRETCHMODE(1U) + +#define S_TXPAUSEEN 0 +#define V_TXPAUSEEN(x) ((x) << S_TXPAUSEEN) +#define F_TXPAUSEEN V_TXPAUSEEN(1U) + +#define A_XGMAC_PORT_XGM_TX_PAUSE_QUANTA 0x1208 + +#define S_TXPAUSEQUANTA 0 +#define M_TXPAUSEQUANTA 0xffffU +#define V_TXPAUSEQUANTA(x) ((x) << S_TXPAUSEQUANTA) +#define G_TXPAUSEQUANTA(x) (((x) >> S_TXPAUSEQUANTA) & M_TXPAUSEQUANTA) + +#define A_XGMAC_PORT_XGM_RX_CTRL 0x120c +#define A_XGMAC_PORT_XGM_RX_CFG 0x1210 + +#define S_RXCRCCAL 16 +#define M_RXCRCCAL 0x3U +#define V_RXCRCCAL(x) ((x) << S_RXCRCCAL) +#define G_RXCRCCAL(x) (((x) >> S_RXCRCCAL) & M_RXCRCCAL) + +#define S_STATLOCALFAULT 15 +#define V_STATLOCALFAULT(x) ((x) << S_STATLOCALFAULT) +#define F_STATLOCALFAULT V_STATLOCALFAULT(1U) + +#define S_STATREMOTEFAULT 14 +#define V_STATREMOTEFAULT(x) ((x) << S_STATREMOTEFAULT) +#define F_STATREMOTEFAULT V_STATREMOTEFAULT(1U) + +#define S_LENERRFRAMEDIS 13 +#define V_LENERRFRAMEDIS(x) ((x) << S_LENERRFRAMEDIS) +#define F_LENERRFRAMEDIS V_LENERRFRAMEDIS(1U) + +#define S_CON802_3PREAMBLE 12 +#define V_CON802_3PREAMBLE(x) ((x) << S_CON802_3PREAMBLE) +#define F_CON802_3PREAMBLE V_CON802_3PREAMBLE(1U) + +#define S_ENNON802_3PREAMBLE 11 +#define V_ENNON802_3PREAMBLE(x) ((x) << S_ENNON802_3PREAMBLE) +#define F_ENNON802_3PREAMBLE V_ENNON802_3PREAMBLE(1U) + +#define S_COPYPREAMBLE 10 +#define V_COPYPREAMBLE(x) ((x) << S_COPYPREAMBLE) +#define F_COPYPREAMBLE V_COPYPREAMBLE(1U) + +#define S_DISPAUSEFRAMES 9 +#define V_DISPAUSEFRAMES(x) ((x) << S_DISPAUSEFRAMES) +#define F_DISPAUSEFRAMES V_DISPAUSEFRAMES(1U) + +#define S_EN1536BFRAMES 8 +#define V_EN1536BFRAMES(x) ((x) << S_EN1536BFRAMES) +#define F_EN1536BFRAMES V_EN1536BFRAMES(1U) + +#define S_ENJUMBO 7 +#define V_ENJUMBO(x) ((x) << S_ENJUMBO) +#define F_ENJUMBO V_ENJUMBO(1U) + +#define S_RMFCS 6 +#define V_RMFCS(x) ((x) << S_RMFCS) +#define F_RMFCS V_RMFCS(1U) + +#define S_DISNONVLAN 5 +#define V_DISNONVLAN(x) ((x) << S_DISNONVLAN) +#define F_DISNONVLAN V_DISNONVLAN(1U) + +#define S_ENEXTMATCH 4 +#define V_ENEXTMATCH(x) ((x) << S_ENEXTMATCH) +#define F_ENEXTMATCH V_ENEXTMATCH(1U) + +#define S_ENHASHUCAST 3 +#define V_ENHASHUCAST(x) ((x) << S_ENHASHUCAST) +#define F_ENHASHUCAST V_ENHASHUCAST(1U) + +#define S_ENHASHMCAST 2 +#define V_ENHASHMCAST(x) ((x) << S_ENHASHMCAST) +#define F_ENHASHMCAST V_ENHASHMCAST(1U) + +#define S_DISBCAST 1 +#define V_DISBCAST(x) ((x) << S_DISBCAST) +#define F_DISBCAST V_DISBCAST(1U) + +#define S_COPYALLFRAMES 0 +#define V_COPYALLFRAMES(x) ((x) << S_COPYALLFRAMES) +#define F_COPYALLFRAMES V_COPYALLFRAMES(1U) + +#define A_XGMAC_PORT_XGM_RX_HASH_LOW 0x1214 +#define A_XGMAC_PORT_XGM_RX_HASH_HIGH 0x1218 +#define A_XGMAC_PORT_XGM_RX_EXACT_MATCH_LOW_1 0x121c +#define A_XGMAC_PORT_XGM_RX_EXACT_MATCH_HIGH_1 0x1220 + +#define S_ADDRESS_HIGH 0 +#define M_ADDRESS_HIGH 0xffffU +#define V_ADDRESS_HIGH(x) ((x) << S_ADDRESS_HIGH) +#define G_ADDRESS_HIGH(x) (((x) >> S_ADDRESS_HIGH) & M_ADDRESS_HIGH) + +#define A_XGMAC_PORT_XGM_RX_EXACT_MATCH_LOW_2 0x1224 +#define A_XGMAC_PORT_XGM_RX_EXACT_MATCH_HIGH_2 0x1228 +#define A_XGMAC_PORT_XGM_RX_EXACT_MATCH_LOW_3 0x122c +#define A_XGMAC_PORT_XGM_RX_EXACT_MATCH_HIGH_3 0x1230 +#define A_XGMAC_PORT_XGM_RX_EXACT_MATCH_LOW_4 0x1234 +#define A_XGMAC_PORT_XGM_RX_EXACT_MATCH_HIGH_4 0x1238 +#define A_XGMAC_PORT_XGM_RX_EXACT_MATCH_LOW_5 0x123c +#define A_XGMAC_PORT_XGM_RX_EXACT_MATCH_HIGH_5 0x1240 +#define A_XGMAC_PORT_XGM_RX_EXACT_MATCH_LOW_6 0x1244 +#define A_XGMAC_PORT_XGM_RX_EXACT_MATCH_HIGH_6 0x1248 +#define A_XGMAC_PORT_XGM_RX_EXACT_MATCH_LOW_7 0x124c +#define A_XGMAC_PORT_XGM_RX_EXACT_MATCH_HIGH_7 0x1250 +#define A_XGMAC_PORT_XGM_RX_EXACT_MATCH_LOW_8 0x1254 +#define A_XGMAC_PORT_XGM_RX_EXACT_MATCH_HIGH_8 0x1258 +#define A_XGMAC_PORT_XGM_RX_TYPE_MATCH_1 0x125c + +#define S_ENTYPEMATCH 31 +#define V_ENTYPEMATCH(x) ((x) << S_ENTYPEMATCH) +#define F_ENTYPEMATCH V_ENTYPEMATCH(1U) + +#define S_TYPE 0 +#define M_TYPE 0xffffU +#define V_TYPE(x) ((x) << S_TYPE) +#define G_TYPE(x) (((x) >> S_TYPE) & M_TYPE) + +#define A_XGMAC_PORT_XGM_RX_TYPE_MATCH_2 0x1260 +#define A_XGMAC_PORT_XGM_RX_TYPE_MATCH_3 0x1264 +#define A_XGMAC_PORT_XGM_RX_TYPE_MATCH_4 0x1268 +#define A_XGMAC_PORT_XGM_INT_STATUS 0x126c + +#define S_XGMIIEXTINT 10 +#define V_XGMIIEXTINT(x) ((x) << S_XGMIIEXTINT) +#define F_XGMIIEXTINT V_XGMIIEXTINT(1U) + +#define S_LINKFAULTCHANGE 9 +#define V_LINKFAULTCHANGE(x) ((x) << S_LINKFAULTCHANGE) +#define F_LINKFAULTCHANGE V_LINKFAULTCHANGE(1U) + +#define S_PHYFRAMECOMPLETE 8 +#define V_PHYFRAMECOMPLETE(x) ((x) << S_PHYFRAMECOMPLETE) +#define F_PHYFRAMECOMPLETE V_PHYFRAMECOMPLETE(1U) + +#define S_PAUSEFRAMETXMT 7 +#define V_PAUSEFRAMETXMT(x) ((x) << S_PAUSEFRAMETXMT) +#define F_PAUSEFRAMETXMT V_PAUSEFRAMETXMT(1U) + +#define S_PAUSECNTRTIMEOUT 6 +#define V_PAUSECNTRTIMEOUT(x) ((x) << S_PAUSECNTRTIMEOUT) +#define F_PAUSECNTRTIMEOUT V_PAUSECNTRTIMEOUT(1U) + +#define S_NON0PAUSERCVD 5 +#define V_NON0PAUSERCVD(x) ((x) << S_NON0PAUSERCVD) +#define F_NON0PAUSERCVD V_NON0PAUSERCVD(1U) + +#define S_STATOFLOW 4 +#define V_STATOFLOW(x) ((x) << S_STATOFLOW) +#define F_STATOFLOW V_STATOFLOW(1U) + +#define S_TXERRFIFO 3 +#define V_TXERRFIFO(x) ((x) << S_TXERRFIFO) +#define F_TXERRFIFO V_TXERRFIFO(1U) + +#define S_TXUFLOW 2 +#define V_TXUFLOW(x) ((x) << S_TXUFLOW) +#define F_TXUFLOW V_TXUFLOW(1U) + +#define S_FRAMETXMT 1 +#define V_FRAMETXMT(x) ((x) << S_FRAMETXMT) +#define F_FRAMETXMT V_FRAMETXMT(1U) + +#define S_FRAMERCVD 0 +#define V_FRAMERCVD(x) ((x) << S_FRAMERCVD) +#define F_FRAMERCVD V_FRAMERCVD(1U) + +#define A_XGMAC_PORT_XGM_INT_MASK 0x1270 +#define A_XGMAC_PORT_XGM_INT_EN 0x1274 +#define A_XGMAC_PORT_XGM_INT_DISABLE 0x1278 +#define A_XGMAC_PORT_XGM_TX_PAUSE_TIMER 0x127c + +#define S_CURPAUSETIMER 0 +#define M_CURPAUSETIMER 0xffffU +#define V_CURPAUSETIMER(x) ((x) << S_CURPAUSETIMER) +#define G_CURPAUSETIMER(x) (((x) >> S_CURPAUSETIMER) & M_CURPAUSETIMER) + +#define A_XGMAC_PORT_XGM_STAT_CTRL 0x1280 + +#define S_READSNPSHOT 4 +#define V_READSNPSHOT(x) ((x) << S_READSNPSHOT) +#define F_READSNPSHOT V_READSNPSHOT(1U) + +#define S_TAKESNPSHOT 3 +#define V_TAKESNPSHOT(x) ((x) << S_TAKESNPSHOT) +#define F_TAKESNPSHOT V_TAKESNPSHOT(1U) + +#define S_CLRSTATS 2 +#define V_CLRSTATS(x) ((x) << S_CLRSTATS) +#define F_CLRSTATS V_CLRSTATS(1U) + +#define S_INCRSTATS 1 +#define V_INCRSTATS(x) ((x) << S_INCRSTATS) +#define F_INCRSTATS V_INCRSTATS(1U) + +#define S_ENTESTMODEWR 0 +#define V_ENTESTMODEWR(x) ((x) << S_ENTESTMODEWR) +#define F_ENTESTMODEWR V_ENTESTMODEWR(1U) + +#define A_XGMAC_PORT_XGM_MDIO_CTRL 0x1284 + +#define S_FRAMETYPE 30 +#define M_FRAMETYPE 0x3U +#define V_FRAMETYPE(x) ((x) << S_FRAMETYPE) +#define G_FRAMETYPE(x) (((x) >> S_FRAMETYPE) & M_FRAMETYPE) + +#define S_OPERATION 28 +#define M_OPERATION 0x3U +#define V_OPERATION(x) ((x) << S_OPERATION) +#define G_OPERATION(x) (((x) >> S_OPERATION) & M_OPERATION) + +#define S_PORTADDR 23 +#define M_PORTADDR 0x1fU +#define V_PORTADDR(x) ((x) << S_PORTADDR) +#define G_PORTADDR(x) (((x) >> S_PORTADDR) & M_PORTADDR) + +#define S_DEVADDR 18 +#define M_DEVADDR 0x1fU +#define V_DEVADDR(x) ((x) << S_DEVADDR) +#define G_DEVADDR(x) (((x) >> S_DEVADDR) & M_DEVADDR) + +#define S_RESRV 16 +#define M_RESRV 0x3U +#define V_RESRV(x) ((x) << S_RESRV) +#define G_RESRV(x) (((x) >> S_RESRV) & M_RESRV) + +#define S_DATA 0 +#define M_DATA 0xffffU +#define V_DATA(x) ((x) << S_DATA) +#define G_DATA(x) (((x) >> S_DATA) & M_DATA) + +#define A_XGMAC_PORT_XGM_MODULE_ID 0x12fc + +#define S_MODULEID 16 +#define M_MODULEID 0xffffU +#define V_MODULEID(x) ((x) << S_MODULEID) +#define G_MODULEID(x) (((x) >> S_MODULEID) & M_MODULEID) + +#define S_MODULEREV 0 +#define M_MODULEREV 0xffffU +#define V_MODULEREV(x) ((x) << S_MODULEREV) +#define G_MODULEREV(x) (((x) >> S_MODULEREV) & M_MODULEREV) + +#define A_XGMAC_PORT_XGM_STAT_TX_BYTE_LOW 0x1300 +#define A_XGMAC_PORT_XGM_STAT_TX_BYTE_HIGH 0x1304 + +#define S_TXBYTES_HIGH 0 +#define M_TXBYTES_HIGH 0x1fffU +#define V_TXBYTES_HIGH(x) ((x) << S_TXBYTES_HIGH) +#define G_TXBYTES_HIGH(x) (((x) >> S_TXBYTES_HIGH) & M_TXBYTES_HIGH) + +#define A_XGMAC_PORT_XGM_STAT_TX_FRAME_LOW 0x1308 +#define A_XGMAC_PORT_XGM_STAT_TX_FRAME_HIGH 0x130c + +#define S_TXFRAMES_HIGH 0 +#define M_TXFRAMES_HIGH 0xfU +#define V_TXFRAMES_HIGH(x) ((x) << S_TXFRAMES_HIGH) +#define G_TXFRAMES_HIGH(x) (((x) >> S_TXFRAMES_HIGH) & M_TXFRAMES_HIGH) + +#define A_XGMAC_PORT_XGM_STAT_TX_BCAST 0x1310 +#define A_XGMAC_PORT_XGM_STAT_TX_MCAST 0x1314 +#define A_XGMAC_PORT_XGM_STAT_TX_PAUSE 0x1318 +#define A_XGMAC_PORT_XGM_STAT_TX_64B_FRAMES 0x131c +#define A_XGMAC_PORT_XGM_STAT_TX_65_127B_FRAMES 0x1320 +#define A_XGMAC_PORT_XGM_STAT_TX_128_255B_FRAMES 0x1324 +#define A_XGMAC_PORT_XGM_STAT_TX_256_511B_FRAMES 0x1328 +#define A_XGMAC_PORT_XGM_STAT_TX_512_1023B_FRAMES 0x132c +#define A_XGMAC_PORT_XGM_STAT_TX_1024_1518B_FRAMES 0x1330 +#define A_XGMAC_PORT_XGM_STAT_TX_1519_MAXB_FRAMES 0x1334 +#define A_XGMAC_PORT_XGM_STAT_TX_ERR_FRAMES 0x1338 +#define A_XGMAC_PORT_XGM_STAT_RX_BYTES_LOW 0x133c +#define A_XGMAC_PORT_XGM_STAT_RX_BYTES_HIGH 0x1340 + +#define S_RXBYTES_HIGH 0 +#define M_RXBYTES_HIGH 0x1fffU +#define V_RXBYTES_HIGH(x) ((x) << S_RXBYTES_HIGH) +#define G_RXBYTES_HIGH(x) (((x) >> S_RXBYTES_HIGH) & M_RXBYTES_HIGH) + +#define A_XGMAC_PORT_XGM_STAT_RX_FRAMES_LOW 0x1344 +#define A_XGMAC_PORT_XGM_STAT_RX_FRAMES_HIGH 0x1348 + +#define S_RXFRAMES_HIGH 0 +#define M_RXFRAMES_HIGH 0xfU +#define V_RXFRAMES_HIGH(x) ((x) << S_RXFRAMES_HIGH) +#define G_RXFRAMES_HIGH(x) (((x) >> S_RXFRAMES_HIGH) & M_RXFRAMES_HIGH) + +#define A_XGMAC_PORT_XGM_STAT_RX_BCAST_FRAMES 0x134c +#define A_XGMAC_PORT_XGM_STAT_RX_MCAST_FRAMES 0x1350 +#define A_XGMAC_PORT_XGM_STAT_RX_PAUSE_FRAMES 0x1354 + +#define S_RXPAUSEFRAMES 0 +#define M_RXPAUSEFRAMES 0xffffU +#define V_RXPAUSEFRAMES(x) ((x) << S_RXPAUSEFRAMES) +#define G_RXPAUSEFRAMES(x) (((x) >> S_RXPAUSEFRAMES) & M_RXPAUSEFRAMES) + +#define A_XGMAC_PORT_XGM_STAT_RX_64B_FRAMES 0x1358 +#define A_XGMAC_PORT_XGM_STAT_RX_65_127B_FRAMES 0x135c +#define A_XGMAC_PORT_XGM_STAT_RX_128_255B_FRAMES 0x1360 +#define A_XGMAC_PORT_XGM_STAT_RX_256_511B_FRAMES 0x1364 +#define A_XGMAC_PORT_XGM_STAT_RX_512_1023B_FRAMES 0x1368 +#define A_XGMAC_PORT_XGM_STAT_RX_1024_1518B_FRAMES 0x136c +#define A_XGMAC_PORT_XGM_STAT_RX_1519_MAXB_FRAMES 0x1370 +#define A_XGMAC_PORT_XGM_STAT_RX_SHORT_FRAMES 0x1374 + +#define S_RXSHORTFRAMES 0 +#define M_RXSHORTFRAMES 0xffffU +#define V_RXSHORTFRAMES(x) ((x) << S_RXSHORTFRAMES) +#define G_RXSHORTFRAMES(x) (((x) >> S_RXSHORTFRAMES) & M_RXSHORTFRAMES) + +#define A_XGMAC_PORT_XGM_STAT_RX_OVERSIZE_FRAMES 0x1378 + +#define S_RXOVERSIZEFRAMES 0 +#define M_RXOVERSIZEFRAMES 0xffffU +#define V_RXOVERSIZEFRAMES(x) ((x) << S_RXOVERSIZEFRAMES) +#define G_RXOVERSIZEFRAMES(x) (((x) >> S_RXOVERSIZEFRAMES) & M_RXOVERSIZEFRAMES) + +#define A_XGMAC_PORT_XGM_STAT_RX_JABBER_FRAMES 0x137c + +#define S_RXJABBERFRAMES 0 +#define M_RXJABBERFRAMES 0xffffU +#define V_RXJABBERFRAMES(x) ((x) << S_RXJABBERFRAMES) +#define G_RXJABBERFRAMES(x) (((x) >> S_RXJABBERFRAMES) & M_RXJABBERFRAMES) + +#define A_XGMAC_PORT_XGM_STAT_RX_CRC_ERR_FRAMES 0x1380 + +#define S_RXCRCERRFRAMES 0 +#define M_RXCRCERRFRAMES 0xffffU +#define V_RXCRCERRFRAMES(x) ((x) << S_RXCRCERRFRAMES) +#define G_RXCRCERRFRAMES(x) (((x) >> S_RXCRCERRFRAMES) & M_RXCRCERRFRAMES) + +#define A_XGMAC_PORT_XGM_STAT_RX_LENGTH_ERR_FRAMES 0x1384 + +#define S_RXLENGTHERRFRAMES 0 +#define M_RXLENGTHERRFRAMES 0xffffU +#define V_RXLENGTHERRFRAMES(x) ((x) << S_RXLENGTHERRFRAMES) +#define G_RXLENGTHERRFRAMES(x) (((x) >> S_RXLENGTHERRFRAMES) & M_RXLENGTHERRFRAMES) + +#define A_XGMAC_PORT_XGM_STAT_RX_SYM_CODE_ERR_FRAMES 0x1388 + +#define S_RXSYMCODEERRFRAMES 0 +#define M_RXSYMCODEERRFRAMES 0xffffU +#define V_RXSYMCODEERRFRAMES(x) ((x) << S_RXSYMCODEERRFRAMES) +#define G_RXSYMCODEERRFRAMES(x) (((x) >> S_RXSYMCODEERRFRAMES) & M_RXSYMCODEERRFRAMES) + +#define A_XGMAC_PORT_XAUI_CTRL 0x1400 + +#define S_POLARITY_INV_RX 8 +#define M_POLARITY_INV_RX 0xfU +#define V_POLARITY_INV_RX(x) ((x) << S_POLARITY_INV_RX) +#define G_POLARITY_INV_RX(x) (((x) >> S_POLARITY_INV_RX) & M_POLARITY_INV_RX) + +#define S_POLARITY_INV_TX 4 +#define M_POLARITY_INV_TX 0xfU +#define V_POLARITY_INV_TX(x) ((x) << S_POLARITY_INV_TX) +#define G_POLARITY_INV_TX(x) (((x) >> S_POLARITY_INV_TX) & M_POLARITY_INV_TX) + +#define S_TEST_SEL 2 +#define M_TEST_SEL 0x3U +#define V_TEST_SEL(x) ((x) << S_TEST_SEL) +#define G_TEST_SEL(x) (((x) >> S_TEST_SEL) & M_TEST_SEL) + +#define S_TEST_EN 0 +#define V_TEST_EN(x) ((x) << S_TEST_EN) +#define F_TEST_EN V_TEST_EN(1U) + +#define A_XGMAC_PORT_XAUI_STATUS 0x1404 + +#define S_DECODE_ERROR 12 +#define M_DECODE_ERROR 0xffU +#define V_DECODE_ERROR(x) ((x) << S_DECODE_ERROR) +#define G_DECODE_ERROR(x) (((x) >> S_DECODE_ERROR) & M_DECODE_ERROR) + +#define S_LANE3_CTC_STATUS 11 +#define V_LANE3_CTC_STATUS(x) ((x) << S_LANE3_CTC_STATUS) +#define F_LANE3_CTC_STATUS V_LANE3_CTC_STATUS(1U) + +#define S_LANE2_CTC_STATUS 10 +#define V_LANE2_CTC_STATUS(x) ((x) << S_LANE2_CTC_STATUS) +#define F_LANE2_CTC_STATUS V_LANE2_CTC_STATUS(1U) + +#define S_LANE1_CTC_STATUS 9 +#define V_LANE1_CTC_STATUS(x) ((x) << S_LANE1_CTC_STATUS) +#define F_LANE1_CTC_STATUS V_LANE1_CTC_STATUS(1U) + +#define S_LANE0_CTC_STATUS 8 +#define V_LANE0_CTC_STATUS(x) ((x) << S_LANE0_CTC_STATUS) +#define F_LANE0_CTC_STATUS V_LANE0_CTC_STATUS(1U) + +#define S_ALIGN_STATUS 4 +#define V_ALIGN_STATUS(x) ((x) << S_ALIGN_STATUS) +#define F_ALIGN_STATUS V_ALIGN_STATUS(1U) + +#define S_LANE3_SYNC_STATUS 3 +#define V_LANE3_SYNC_STATUS(x) ((x) << S_LANE3_SYNC_STATUS) +#define F_LANE3_SYNC_STATUS V_LANE3_SYNC_STATUS(1U) + +#define S_LANE2_SYNC_STATUS 2 +#define V_LANE2_SYNC_STATUS(x) ((x) << S_LANE2_SYNC_STATUS) +#define F_LANE2_SYNC_STATUS V_LANE2_SYNC_STATUS(1U) + +#define S_LANE1_SYNC_STATUS 1 +#define V_LANE1_SYNC_STATUS(x) ((x) << S_LANE1_SYNC_STATUS) +#define F_LANE1_SYNC_STATUS V_LANE1_SYNC_STATUS(1U) + +#define S_LANE0_SYNC_STATUS 0 +#define V_LANE0_SYNC_STATUS(x) ((x) << S_LANE0_SYNC_STATUS) +#define F_LANE0_SYNC_STATUS V_LANE0_SYNC_STATUS(1U) + +#define A_XGMAC_PORT_PCSR_CTRL 0x1500 + +#define S_RX_CLK_SPEED 7 +#define V_RX_CLK_SPEED(x) ((x) << S_RX_CLK_SPEED) +#define F_RX_CLK_SPEED V_RX_CLK_SPEED(1U) + +#define S_SCRBYPASS 6 +#define V_SCRBYPASS(x) ((x) << S_SCRBYPASS) +#define F_SCRBYPASS V_SCRBYPASS(1U) + +#define S_FECERRINDEN 5 +#define V_FECERRINDEN(x) ((x) << S_FECERRINDEN) +#define F_FECERRINDEN V_FECERRINDEN(1U) + +#define S_FECEN 4 +#define V_FECEN(x) ((x) << S_FECEN) +#define F_FECEN V_FECEN(1U) + +#define S_TESTSEL 2 +#define M_TESTSEL 0x3U +#define V_TESTSEL(x) ((x) << S_TESTSEL) +#define G_TESTSEL(x) (((x) >> S_TESTSEL) & M_TESTSEL) + +#define S_SCRLOOPEN 1 +#define V_SCRLOOPEN(x) ((x) << S_SCRLOOPEN) +#define F_SCRLOOPEN V_SCRLOOPEN(1U) + +#define S_XGMIILOOPEN 0 +#define V_XGMIILOOPEN(x) ((x) << S_XGMIILOOPEN) +#define F_XGMIILOOPEN V_XGMIILOOPEN(1U) + +#define A_XGMAC_PORT_PCSR_TXTEST_CTRL 0x1510 + +#define S_TX_PRBS9_EN 4 +#define V_TX_PRBS9_EN(x) ((x) << S_TX_PRBS9_EN) +#define F_TX_PRBS9_EN V_TX_PRBS9_EN(1U) + +#define S_TX_PRBS31_EN 3 +#define V_TX_PRBS31_EN(x) ((x) << S_TX_PRBS31_EN) +#define F_TX_PRBS31_EN V_TX_PRBS31_EN(1U) + +#define S_TX_TST_DAT_SEL 2 +#define V_TX_TST_DAT_SEL(x) ((x) << S_TX_TST_DAT_SEL) +#define F_TX_TST_DAT_SEL V_TX_TST_DAT_SEL(1U) + +#define S_TX_TST_SEL 1 +#define V_TX_TST_SEL(x) ((x) << S_TX_TST_SEL) +#define F_TX_TST_SEL V_TX_TST_SEL(1U) + +#define S_TX_TST_EN 0 +#define V_TX_TST_EN(x) ((x) << S_TX_TST_EN) +#define F_TX_TST_EN V_TX_TST_EN(1U) + +#define A_XGMAC_PORT_PCSR_TXTEST_SEEDA_LOWER 0x1514 +#define A_XGMAC_PORT_PCSR_TXTEST_SEEDA_UPPER 0x1518 + +#define S_SEEDA_UPPER 0 +#define M_SEEDA_UPPER 0x3ffffffU +#define V_SEEDA_UPPER(x) ((x) << S_SEEDA_UPPER) +#define G_SEEDA_UPPER(x) (((x) >> S_SEEDA_UPPER) & M_SEEDA_UPPER) + +#define A_XGMAC_PORT_PCSR_TXTEST_SEEDB_LOWER 0x152c +#define A_XGMAC_PORT_PCSR_TXTEST_SEEDB_UPPER 0x1530 + +#define S_SEEDB_UPPER 0 +#define M_SEEDB_UPPER 0x3ffffffU +#define V_SEEDB_UPPER(x) ((x) << S_SEEDB_UPPER) +#define G_SEEDB_UPPER(x) (((x) >> S_SEEDB_UPPER) & M_SEEDB_UPPER) + +#define A_XGMAC_PORT_PCSR_RXTEST_CTRL 0x153c + +#define S_TPTER_CNT_RST 7 +#define V_TPTER_CNT_RST(x) ((x) << S_TPTER_CNT_RST) +#define F_TPTER_CNT_RST V_TPTER_CNT_RST(1U) + +#define S_TEST_CNT_125US 6 +#define V_TEST_CNT_125US(x) ((x) << S_TEST_CNT_125US) +#define F_TEST_CNT_125US V_TEST_CNT_125US(1U) + +#define S_TEST_CNT_PRE 5 +#define V_TEST_CNT_PRE(x) ((x) << S_TEST_CNT_PRE) +#define F_TEST_CNT_PRE V_TEST_CNT_PRE(1U) + +#define S_BER_CNT_RST 4 +#define V_BER_CNT_RST(x) ((x) << S_BER_CNT_RST) +#define F_BER_CNT_RST V_BER_CNT_RST(1U) + +#define S_ERR_BLK_CNT_RST 3 +#define V_ERR_BLK_CNT_RST(x) ((x) << S_ERR_BLK_CNT_RST) +#define F_ERR_BLK_CNT_RST V_ERR_BLK_CNT_RST(1U) + +#define S_RX_PRBS31_EN 2 +#define V_RX_PRBS31_EN(x) ((x) << S_RX_PRBS31_EN) +#define F_RX_PRBS31_EN V_RX_PRBS31_EN(1U) + +#define S_RX_TST_DAT_SEL 1 +#define V_RX_TST_DAT_SEL(x) ((x) << S_RX_TST_DAT_SEL) +#define F_RX_TST_DAT_SEL V_RX_TST_DAT_SEL(1U) + +#define S_RX_TST_EN 0 +#define V_RX_TST_EN(x) ((x) << S_RX_TST_EN) +#define F_RX_TST_EN V_RX_TST_EN(1U) + +#define A_XGMAC_PORT_PCSR_STATUS 0x1550 + +#define S_ERR_BLK_CNT 16 +#define M_ERR_BLK_CNT 0xffU +#define V_ERR_BLK_CNT(x) ((x) << S_ERR_BLK_CNT) +#define G_ERR_BLK_CNT(x) (((x) >> S_ERR_BLK_CNT) & M_ERR_BLK_CNT) + +#define S_BER_COUNT 8 +#define M_BER_COUNT 0x3fU +#define V_BER_COUNT(x) ((x) << S_BER_COUNT) +#define G_BER_COUNT(x) (((x) >> S_BER_COUNT) & M_BER_COUNT) + +#define S_HI_BER 2 +#define V_HI_BER(x) ((x) << S_HI_BER) +#define F_HI_BER V_HI_BER(1U) + +#define S_RX_FAULT 1 +#define V_RX_FAULT(x) ((x) << S_RX_FAULT) +#define F_RX_FAULT V_RX_FAULT(1U) + +#define S_TX_FAULT 0 +#define V_TX_FAULT(x) ((x) << S_TX_FAULT) +#define F_TX_FAULT V_TX_FAULT(1U) + +#define A_XGMAC_PORT_PCSR_TEST_STATUS 0x1554 + +#define S_TPT_ERR_CNT 0 +#define M_TPT_ERR_CNT 0xffffU +#define V_TPT_ERR_CNT(x) ((x) << S_TPT_ERR_CNT) +#define G_TPT_ERR_CNT(x) (((x) >> S_TPT_ERR_CNT) & M_TPT_ERR_CNT) + +#define A_XGMAC_PORT_AN_CONTROL 0x1600 + +#define S_SOFT_RESET 15 +#define V_SOFT_RESET(x) ((x) << S_SOFT_RESET) +#define F_SOFT_RESET V_SOFT_RESET(1U) + +#define S_AN_ENABLE 12 +#define V_AN_ENABLE(x) ((x) << S_AN_ENABLE) +#define F_AN_ENABLE V_AN_ENABLE(1U) + +#define S_RESTART_AN 9 +#define V_RESTART_AN(x) ((x) << S_RESTART_AN) +#define F_RESTART_AN V_RESTART_AN(1U) + +#define A_XGMAC_PORT_AN_STATUS 0x1604 + +#define S_NONCER_MATCH 31 +#define V_NONCER_MATCH(x) ((x) << S_NONCER_MATCH) +#define F_NONCER_MATCH V_NONCER_MATCH(1U) + +#define S_PARALLEL_DET_FAULT 9 +#define V_PARALLEL_DET_FAULT(x) ((x) << S_PARALLEL_DET_FAULT) +#define F_PARALLEL_DET_FAULT V_PARALLEL_DET_FAULT(1U) + +#define S_PAGE_RECEIVED 6 +#define V_PAGE_RECEIVED(x) ((x) << S_PAGE_RECEIVED) +#define F_PAGE_RECEIVED V_PAGE_RECEIVED(1U) + +#define S_AN_COMPLETE 5 +#define V_AN_COMPLETE(x) ((x) << S_AN_COMPLETE) +#define F_AN_COMPLETE V_AN_COMPLETE(1U) + +#define S_STAT_REMFAULT 4 +#define V_STAT_REMFAULT(x) ((x) << S_STAT_REMFAULT) +#define F_STAT_REMFAULT V_STAT_REMFAULT(1U) + +#define S_AN_ABILITY 3 +#define V_AN_ABILITY(x) ((x) << S_AN_ABILITY) +#define F_AN_ABILITY V_AN_ABILITY(1U) + +#define S_LINK_STATUS 2 +#define V_LINK_STATUS(x) ((x) << S_LINK_STATUS) +#define F_LINK_STATUS V_LINK_STATUS(1U) + +#define S_PARTNER_AN_ABILITY 0 +#define V_PARTNER_AN_ABILITY(x) ((x) << S_PARTNER_AN_ABILITY) +#define F_PARTNER_AN_ABILITY V_PARTNER_AN_ABILITY(1U) + +#define A_XGMAC_PORT_AN_ADVERTISEMENT 0x1608 + +#define S_FEC_ENABLE 31 +#define V_FEC_ENABLE(x) ((x) << S_FEC_ENABLE) +#define F_FEC_ENABLE V_FEC_ENABLE(1U) + +#define S_FEC_ABILITY 30 +#define V_FEC_ABILITY(x) ((x) << S_FEC_ABILITY) +#define F_FEC_ABILITY V_FEC_ABILITY(1U) + +#define S_10GBASE_KR_CAPABLE 23 +#define V_10GBASE_KR_CAPABLE(x) ((x) << S_10GBASE_KR_CAPABLE) +#define F_10GBASE_KR_CAPABLE V_10GBASE_KR_CAPABLE(1U) + +#define S_10GBASE_KX4_CAPABLE 22 +#define V_10GBASE_KX4_CAPABLE(x) ((x) << S_10GBASE_KX4_CAPABLE) +#define F_10GBASE_KX4_CAPABLE V_10GBASE_KX4_CAPABLE(1U) + +#define S_1000BASE_KX_CAPABLE 21 +#define V_1000BASE_KX_CAPABLE(x) ((x) << S_1000BASE_KX_CAPABLE) +#define F_1000BASE_KX_CAPABLE V_1000BASE_KX_CAPABLE(1U) + +#define S_TRANSMITTED_NONCE 16 +#define M_TRANSMITTED_NONCE 0x1fU +#define V_TRANSMITTED_NONCE(x) ((x) << S_TRANSMITTED_NONCE) +#define G_TRANSMITTED_NONCE(x) (((x) >> S_TRANSMITTED_NONCE) & M_TRANSMITTED_NONCE) + +#define S_NP 15 +#define V_NP(x) ((x) << S_NP) +#define F_NP V_NP(1U) + +#define S_ACK 14 +#define V_ACK(x) ((x) << S_ACK) +#define F_ACK V_ACK(1U) + +#define S_REMOTE_FAULT 13 +#define V_REMOTE_FAULT(x) ((x) << S_REMOTE_FAULT) +#define F_REMOTE_FAULT V_REMOTE_FAULT(1U) + +#define S_ASM_DIR 11 +#define V_ASM_DIR(x) ((x) << S_ASM_DIR) +#define F_ASM_DIR V_ASM_DIR(1U) + +#define S_PAUSE 10 +#define V_PAUSE(x) ((x) << S_PAUSE) +#define F_PAUSE V_PAUSE(1U) + +#define S_ECHOED_NONCE 5 +#define M_ECHOED_NONCE 0x1fU +#define V_ECHOED_NONCE(x) ((x) << S_ECHOED_NONCE) +#define G_ECHOED_NONCE(x) (((x) >> S_ECHOED_NONCE) & M_ECHOED_NONCE) + +#define A_XGMAC_PORT_AN_LINK_PARTNER_ABILITY 0x160c + +#define S_SELECTOR_FIELD 0 +#define M_SELECTOR_FIELD 0x1fU +#define V_SELECTOR_FIELD(x) ((x) << S_SELECTOR_FIELD) +#define G_SELECTOR_FIELD(x) (((x) >> S_SELECTOR_FIELD) & M_SELECTOR_FIELD) + +#define A_XGMAC_PORT_AN_NP_LOWER_TRANSMIT 0x1610 + +#define S_NP_INFO 16 +#define M_NP_INFO 0xffffU +#define V_NP_INFO(x) ((x) << S_NP_INFO) +#define G_NP_INFO(x) (((x) >> S_NP_INFO) & M_NP_INFO) + +#define S_NP_INDICATION 15 +#define V_NP_INDICATION(x) ((x) << S_NP_INDICATION) +#define F_NP_INDICATION V_NP_INDICATION(1U) + +#define S_MESSAGE_PAGE 13 +#define V_MESSAGE_PAGE(x) ((x) << S_MESSAGE_PAGE) +#define F_MESSAGE_PAGE V_MESSAGE_PAGE(1U) + +#define S_ACK_2 12 +#define V_ACK_2(x) ((x) << S_ACK_2) +#define F_ACK_2 V_ACK_2(1U) + +#define S_TOGGLE 11 +#define V_TOGGLE(x) ((x) << S_TOGGLE) +#define F_TOGGLE V_TOGGLE(1U) + +#define A_XGMAC_PORT_AN_NP_UPPER_TRANSMIT 0x1614 + +#define S_NP_INFO_HI 0 +#define M_NP_INFO_HI 0xffffU +#define V_NP_INFO_HI(x) ((x) << S_NP_INFO_HI) +#define G_NP_INFO_HI(x) (((x) >> S_NP_INFO_HI) & M_NP_INFO_HI) + +#define A_XGMAC_PORT_AN_LP_NP_LOWER 0x1618 +#define A_XGMAC_PORT_AN_LP_NP_UPPER 0x161c +#define A_XGMAC_PORT_AN_BACKPLANE_ETHERNET_STATUS 0x1624 + +#define S_TX_PAUSE_OKAY 6 +#define V_TX_PAUSE_OKAY(x) ((x) << S_TX_PAUSE_OKAY) +#define F_TX_PAUSE_OKAY V_TX_PAUSE_OKAY(1U) + +#define S_RX_PAUSE_OKAY 5 +#define V_RX_PAUSE_OKAY(x) ((x) << S_RX_PAUSE_OKAY) +#define F_RX_PAUSE_OKAY V_RX_PAUSE_OKAY(1U) + +#define S_10GBASE_KR_FEC_NEG 4 +#define V_10GBASE_KR_FEC_NEG(x) ((x) << S_10GBASE_KR_FEC_NEG) +#define F_10GBASE_KR_FEC_NEG V_10GBASE_KR_FEC_NEG(1U) + +#define S_10GBASE_KR_NEG 3 +#define V_10GBASE_KR_NEG(x) ((x) << S_10GBASE_KR_NEG) +#define F_10GBASE_KR_NEG V_10GBASE_KR_NEG(1U) + +#define S_10GBASE_KX4_NEG 2 +#define V_10GBASE_KX4_NEG(x) ((x) << S_10GBASE_KX4_NEG) +#define F_10GBASE_KX4_NEG V_10GBASE_KX4_NEG(1U) + +#define S_1000BASE_KX_NEG 1 +#define V_1000BASE_KX_NEG(x) ((x) << S_1000BASE_KX_NEG) +#define F_1000BASE_KX_NEG V_1000BASE_KX_NEG(1U) + +#define S_BP_AN_ABILITY 0 +#define V_BP_AN_ABILITY(x) ((x) << S_BP_AN_ABILITY) +#define F_BP_AN_ABILITY V_BP_AN_ABILITY(1U) + +#define A_XGMAC_PORT_AN_TX_NONCE_CONTROL 0x1628 + +#define S_BYPASS_LFSR 15 +#define V_BYPASS_LFSR(x) ((x) << S_BYPASS_LFSR) +#define F_BYPASS_LFSR V_BYPASS_LFSR(1U) + +#define S_LFSR_INIT 0 +#define M_LFSR_INIT 0x7fffU +#define V_LFSR_INIT(x) ((x) << S_LFSR_INIT) +#define G_LFSR_INIT(x) (((x) >> S_LFSR_INIT) & M_LFSR_INIT) + +#define A_XGMAC_PORT_AN_INTERRUPT_STATUS 0x162c + +#define S_NP_FROM_LP 3 +#define V_NP_FROM_LP(x) ((x) << S_NP_FROM_LP) +#define F_NP_FROM_LP V_NP_FROM_LP(1U) + +#define S_PARALLELDETFAULTINT 2 +#define V_PARALLELDETFAULTINT(x) ((x) << S_PARALLELDETFAULTINT) +#define F_PARALLELDETFAULTINT V_PARALLELDETFAULTINT(1U) + +#define S_BP_FROM_LP 1 +#define V_BP_FROM_LP(x) ((x) << S_BP_FROM_LP) +#define F_BP_FROM_LP V_BP_FROM_LP(1U) + +#define S_PCS_AN_COMPLETE 0 +#define V_PCS_AN_COMPLETE(x) ((x) << S_PCS_AN_COMPLETE) +#define F_PCS_AN_COMPLETE V_PCS_AN_COMPLETE(1U) + +#define A_XGMAC_PORT_AN_GENERIC_TIMER_TIMEOUT 0x1630 + +#define S_GENERIC_TIMEOUT 0 +#define M_GENERIC_TIMEOUT 0x7fffffU +#define V_GENERIC_TIMEOUT(x) ((x) << S_GENERIC_TIMEOUT) +#define G_GENERIC_TIMEOUT(x) (((x) >> S_GENERIC_TIMEOUT) & M_GENERIC_TIMEOUT) + +#define A_XGMAC_PORT_AN_BREAK_LINK_TIMEOUT 0x1634 + +#define S_BREAK_LINK_TIMEOUT 0 +#define M_BREAK_LINK_TIMEOUT 0xffffffU +#define V_BREAK_LINK_TIMEOUT(x) ((x) << S_BREAK_LINK_TIMEOUT) +#define G_BREAK_LINK_TIMEOUT(x) (((x) >> S_BREAK_LINK_TIMEOUT) & M_BREAK_LINK_TIMEOUT) + +#define A_XGMAC_PORT_AN_MODULE_ID 0x163c + +#define S_MODULE_ID 16 +#define M_MODULE_ID 0xffffU +#define V_MODULE_ID(x) ((x) << S_MODULE_ID) +#define G_MODULE_ID(x) (((x) >> S_MODULE_ID) & M_MODULE_ID) + +#define S_MODULE_REVISION 0 +#define M_MODULE_REVISION 0xffffU +#define V_MODULE_REVISION(x) ((x) << S_MODULE_REVISION) +#define G_MODULE_REVISION(x) (((x) >> S_MODULE_REVISION) & M_MODULE_REVISION) + +#define A_XGMAC_PORT_AE_RX_COEF_REQ 0x1700 + +#define S_RXREQ_CPRE 13 +#define V_RXREQ_CPRE(x) ((x) << S_RXREQ_CPRE) +#define F_RXREQ_CPRE V_RXREQ_CPRE(1U) + +#define S_RXREQ_CINIT 12 +#define V_RXREQ_CINIT(x) ((x) << S_RXREQ_CINIT) +#define F_RXREQ_CINIT V_RXREQ_CINIT(1U) + +#define S_RXREQ_C0 4 +#define M_RXREQ_C0 0x3U +#define V_RXREQ_C0(x) ((x) << S_RXREQ_C0) +#define G_RXREQ_C0(x) (((x) >> S_RXREQ_C0) & M_RXREQ_C0) + +#define S_RXREQ_C1 2 +#define M_RXREQ_C1 0x3U +#define V_RXREQ_C1(x) ((x) << S_RXREQ_C1) +#define G_RXREQ_C1(x) (((x) >> S_RXREQ_C1) & M_RXREQ_C1) + +#define S_RXREQ_C2 0 +#define M_RXREQ_C2 0x3U +#define V_RXREQ_C2(x) ((x) << S_RXREQ_C2) +#define G_RXREQ_C2(x) (((x) >> S_RXREQ_C2) & M_RXREQ_C2) + +#define A_XGMAC_PORT_AE_RX_COEF_STAT 0x1704 + +#define S_RXSTAT_RDY 15 +#define V_RXSTAT_RDY(x) ((x) << S_RXSTAT_RDY) +#define F_RXSTAT_RDY V_RXSTAT_RDY(1U) + +#define S_RXSTAT_C0 4 +#define M_RXSTAT_C0 0x3U +#define V_RXSTAT_C0(x) ((x) << S_RXSTAT_C0) +#define G_RXSTAT_C0(x) (((x) >> S_RXSTAT_C0) & M_RXSTAT_C0) + +#define S_RXSTAT_C1 2 +#define M_RXSTAT_C1 0x3U +#define V_RXSTAT_C1(x) ((x) << S_RXSTAT_C1) +#define G_RXSTAT_C1(x) (((x) >> S_RXSTAT_C1) & M_RXSTAT_C1) + +#define S_RXSTAT_C2 0 +#define M_RXSTAT_C2 0x3U +#define V_RXSTAT_C2(x) ((x) << S_RXSTAT_C2) +#define G_RXSTAT_C2(x) (((x) >> S_RXSTAT_C2) & M_RXSTAT_C2) + +#define A_XGMAC_PORT_AE_TX_COEF_REQ 0x1708 + +#define S_TXREQ_CPRE 13 +#define V_TXREQ_CPRE(x) ((x) << S_TXREQ_CPRE) +#define F_TXREQ_CPRE V_TXREQ_CPRE(1U) + +#define S_TXREQ_CINIT 12 +#define V_TXREQ_CINIT(x) ((x) << S_TXREQ_CINIT) +#define F_TXREQ_CINIT V_TXREQ_CINIT(1U) + +#define S_TXREQ_C0 4 +#define M_TXREQ_C0 0x3U +#define V_TXREQ_C0(x) ((x) << S_TXREQ_C0) +#define G_TXREQ_C0(x) (((x) >> S_TXREQ_C0) & M_TXREQ_C0) + +#define S_TXREQ_C1 2 +#define M_TXREQ_C1 0x3U +#define V_TXREQ_C1(x) ((x) << S_TXREQ_C1) +#define G_TXREQ_C1(x) (((x) >> S_TXREQ_C1) & M_TXREQ_C1) + +#define S_TXREQ_C2 0 +#define M_TXREQ_C2 0x3U +#define V_TXREQ_C2(x) ((x) << S_TXREQ_C2) +#define G_TXREQ_C2(x) (((x) >> S_TXREQ_C2) & M_TXREQ_C2) + +#define A_XGMAC_PORT_AE_TX_COEF_STAT 0x170c + +#define S_TXSTAT_RDY 15 +#define V_TXSTAT_RDY(x) ((x) << S_TXSTAT_RDY) +#define F_TXSTAT_RDY V_TXSTAT_RDY(1U) + +#define S_TXSTAT_C0 4 +#define M_TXSTAT_C0 0x3U +#define V_TXSTAT_C0(x) ((x) << S_TXSTAT_C0) +#define G_TXSTAT_C0(x) (((x) >> S_TXSTAT_C0) & M_TXSTAT_C0) + +#define S_TXSTAT_C1 2 +#define M_TXSTAT_C1 0x3U +#define V_TXSTAT_C1(x) ((x) << S_TXSTAT_C1) +#define G_TXSTAT_C1(x) (((x) >> S_TXSTAT_C1) & M_TXSTAT_C1) + +#define S_TXSTAT_C2 0 +#define M_TXSTAT_C2 0x3U +#define V_TXSTAT_C2(x) ((x) << S_TXSTAT_C2) +#define G_TXSTAT_C2(x) (((x) >> S_TXSTAT_C2) & M_TXSTAT_C2) + +#define A_XGMAC_PORT_AE_REG_MODE 0x1710 + +#define S_MAN_DEC 4 +#define M_MAN_DEC 0x3U +#define V_MAN_DEC(x) ((x) << S_MAN_DEC) +#define G_MAN_DEC(x) (((x) >> S_MAN_DEC) & M_MAN_DEC) + +#define S_MANUAL_RDY 3 +#define V_MANUAL_RDY(x) ((x) << S_MANUAL_RDY) +#define F_MANUAL_RDY V_MANUAL_RDY(1U) + +#define S_MWT_DISABLE 2 +#define V_MWT_DISABLE(x) ((x) << S_MWT_DISABLE) +#define F_MWT_DISABLE V_MWT_DISABLE(1U) + +#define S_MDIO_OVR 1 +#define V_MDIO_OVR(x) ((x) << S_MDIO_OVR) +#define F_MDIO_OVR V_MDIO_OVR(1U) + +#define S_STICKY_MODE 0 +#define V_STICKY_MODE(x) ((x) << S_STICKY_MODE) +#define F_STICKY_MODE V_STICKY_MODE(1U) + +#define A_XGMAC_PORT_AE_PRBS_CTL 0x1714 + +#define S_PRBS_CHK_ERRCNT 8 +#define M_PRBS_CHK_ERRCNT 0xffU +#define V_PRBS_CHK_ERRCNT(x) ((x) << S_PRBS_CHK_ERRCNT) +#define G_PRBS_CHK_ERRCNT(x) (((x) >> S_PRBS_CHK_ERRCNT) & M_PRBS_CHK_ERRCNT) + +#define S_PRBS_SYNCCNT 5 +#define M_PRBS_SYNCCNT 0x7U +#define V_PRBS_SYNCCNT(x) ((x) << S_PRBS_SYNCCNT) +#define G_PRBS_SYNCCNT(x) (((x) >> S_PRBS_SYNCCNT) & M_PRBS_SYNCCNT) + +#define S_PRBS_CHK_SYNC 4 +#define V_PRBS_CHK_SYNC(x) ((x) << S_PRBS_CHK_SYNC) +#define F_PRBS_CHK_SYNC V_PRBS_CHK_SYNC(1U) + +#define S_PRBS_CHK_RST 3 +#define V_PRBS_CHK_RST(x) ((x) << S_PRBS_CHK_RST) +#define F_PRBS_CHK_RST V_PRBS_CHK_RST(1U) + +#define S_PRBS_CHK_OFF 2 +#define V_PRBS_CHK_OFF(x) ((x) << S_PRBS_CHK_OFF) +#define F_PRBS_CHK_OFF V_PRBS_CHK_OFF(1U) + +#define S_PRBS_GEN_FRCERR 1 +#define V_PRBS_GEN_FRCERR(x) ((x) << S_PRBS_GEN_FRCERR) +#define F_PRBS_GEN_FRCERR V_PRBS_GEN_FRCERR(1U) + +#define S_PRBS_GEN_OFF 0 +#define V_PRBS_GEN_OFF(x) ((x) << S_PRBS_GEN_OFF) +#define F_PRBS_GEN_OFF V_PRBS_GEN_OFF(1U) + +#define A_XGMAC_PORT_AE_FSM_CTL 0x1718 + +#define S_FSM_TR_LCL 14 +#define V_FSM_TR_LCL(x) ((x) << S_FSM_TR_LCL) +#define F_FSM_TR_LCL V_FSM_TR_LCL(1U) + +#define S_FSM_GDMRK 11 +#define M_FSM_GDMRK 0x7U +#define V_FSM_GDMRK(x) ((x) << S_FSM_GDMRK) +#define G_FSM_GDMRK(x) (((x) >> S_FSM_GDMRK) & M_FSM_GDMRK) + +#define S_FSM_BADMRK 8 +#define M_FSM_BADMRK 0x7U +#define V_FSM_BADMRK(x) ((x) << S_FSM_BADMRK) +#define G_FSM_BADMRK(x) (((x) >> S_FSM_BADMRK) & M_FSM_BADMRK) + +#define S_FSM_TR_FAIL 7 +#define V_FSM_TR_FAIL(x) ((x) << S_FSM_TR_FAIL) +#define F_FSM_TR_FAIL V_FSM_TR_FAIL(1U) + +#define S_FSM_TR_ACT 6 +#define V_FSM_TR_ACT(x) ((x) << S_FSM_TR_ACT) +#define F_FSM_TR_ACT V_FSM_TR_ACT(1U) + +#define S_FSM_FRM_LCK 5 +#define V_FSM_FRM_LCK(x) ((x) << S_FSM_FRM_LCK) +#define F_FSM_FRM_LCK V_FSM_FRM_LCK(1U) + +#define S_FSM_TR_COMP 4 +#define V_FSM_TR_COMP(x) ((x) << S_FSM_TR_COMP) +#define F_FSM_TR_COMP V_FSM_TR_COMP(1U) + +#define S_MC_RX_RDY 3 +#define V_MC_RX_RDY(x) ((x) << S_MC_RX_RDY) +#define F_MC_RX_RDY V_MC_RX_RDY(1U) + +#define S_FSM_CU_DIS 2 +#define V_FSM_CU_DIS(x) ((x) << S_FSM_CU_DIS) +#define F_FSM_CU_DIS V_FSM_CU_DIS(1U) + +#define S_FSM_TR_RST 1 +#define V_FSM_TR_RST(x) ((x) << S_FSM_TR_RST) +#define F_FSM_TR_RST V_FSM_TR_RST(1U) + +#define S_FSM_TR_EN 0 +#define V_FSM_TR_EN(x) ((x) << S_FSM_TR_EN) +#define F_FSM_TR_EN V_FSM_TR_EN(1U) + +#define A_XGMAC_PORT_AE_FSM_STATE 0x171c + +#define S_CC2FSM_STATE 13 +#define M_CC2FSM_STATE 0x7U +#define V_CC2FSM_STATE(x) ((x) << S_CC2FSM_STATE) +#define G_CC2FSM_STATE(x) (((x) >> S_CC2FSM_STATE) & M_CC2FSM_STATE) + +#define S_CC1FSM_STATE 10 +#define M_CC1FSM_STATE 0x7U +#define V_CC1FSM_STATE(x) ((x) << S_CC1FSM_STATE) +#define G_CC1FSM_STATE(x) (((x) >> S_CC1FSM_STATE) & M_CC1FSM_STATE) + +#define S_CC0FSM_STATE 7 +#define M_CC0FSM_STATE 0x7U +#define V_CC0FSM_STATE(x) ((x) << S_CC0FSM_STATE) +#define G_CC0FSM_STATE(x) (((x) >> S_CC0FSM_STATE) & M_CC0FSM_STATE) + +#define S_FLFSM_STATE 4 +#define M_FLFSM_STATE 0x7U +#define V_FLFSM_STATE(x) ((x) << S_FLFSM_STATE) +#define G_FLFSM_STATE(x) (((x) >> S_FLFSM_STATE) & M_FLFSM_STATE) + +#define S_TFSM_STATE 0 +#define M_TFSM_STATE 0x7U +#define V_TFSM_STATE(x) ((x) << S_TFSM_STATE) +#define G_TFSM_STATE(x) (((x) >> S_TFSM_STATE) & M_TFSM_STATE) + +#define A_XGMAC_PORT_AE_TX_DIS 0x1780 + +#define S_PMD_TX_DIS 0 +#define V_PMD_TX_DIS(x) ((x) << S_PMD_TX_DIS) +#define F_PMD_TX_DIS V_PMD_TX_DIS(1U) + +#define A_XGMAC_PORT_AE_KR_CTRL 0x1784 + +#define S_TRAINING_ENABLE 1 +#define V_TRAINING_ENABLE(x) ((x) << S_TRAINING_ENABLE) +#define F_TRAINING_ENABLE V_TRAINING_ENABLE(1U) + +#define S_RESTART_TRAINING 0 +#define V_RESTART_TRAINING(x) ((x) << S_RESTART_TRAINING) +#define F_RESTART_TRAINING V_RESTART_TRAINING(1U) + +#define A_XGMAC_PORT_AE_RX_SIGDET 0x1788 + +#define S_PMD_SIGDET 0 +#define V_PMD_SIGDET(x) ((x) << S_PMD_SIGDET) +#define F_PMD_SIGDET V_PMD_SIGDET(1U) + +#define A_XGMAC_PORT_AE_KR_STATUS 0x178c + +#define S_TRAINING_FAILURE 3 +#define V_TRAINING_FAILURE(x) ((x) << S_TRAINING_FAILURE) +#define F_TRAINING_FAILURE V_TRAINING_FAILURE(1U) + +#define S_TRAINING 2 +#define V_TRAINING(x) ((x) << S_TRAINING) +#define F_TRAINING V_TRAINING(1U) + +#define S_FRAME_LOCK 1 +#define V_FRAME_LOCK(x) ((x) << S_FRAME_LOCK) +#define F_FRAME_LOCK V_FRAME_LOCK(1U) + +#define S_RX_TRAINED 0 +#define V_RX_TRAINED(x) ((x) << S_RX_TRAINED) +#define F_RX_TRAINED V_RX_TRAINED(1U) + +#define A_XGMAC_PORT_HSS_TXA_MODE_CFG 0x1800 + +#define S_BWSEL 2 +#define M_BWSEL 0x3U +#define V_BWSEL(x) ((x) << S_BWSEL) +#define G_BWSEL(x) (((x) >> S_BWSEL) & M_BWSEL) + +#define S_RTSEL 0 +#define M_RTSEL 0x3U +#define V_RTSEL(x) ((x) << S_RTSEL) +#define G_RTSEL(x) (((x) >> S_RTSEL) & M_RTSEL) + +#define A_XGMAC_PORT_HSS_TXA_TEST_CTRL 0x1804 + +#define S_TWDP 5 +#define V_TWDP(x) ((x) << S_TWDP) +#define F_TWDP V_TWDP(1U) + +#define S_TPGRST 4 +#define V_TPGRST(x) ((x) << S_TPGRST) +#define F_TPGRST V_TPGRST(1U) + +#define S_TPGEN 3 +#define V_TPGEN(x) ((x) << S_TPGEN) +#define F_TPGEN V_TPGEN(1U) + +#define S_TPSEL 0 +#define M_TPSEL 0x7U +#define V_TPSEL(x) ((x) << S_TPSEL) +#define G_TPSEL(x) (((x) >> S_TPSEL) & M_TPSEL) + +#define A_XGMAC_PORT_HSS_TXA_COEFF_CTRL 0x1808 + +#define S_AEINVPOL 6 +#define V_AEINVPOL(x) ((x) << S_AEINVPOL) +#define F_AEINVPOL V_AEINVPOL(1U) + +#define S_AESOURCE 5 +#define V_AESOURCE(x) ((x) << S_AESOURCE) +#define F_AESOURCE V_AESOURCE(1U) + +#define S_EQMODE 4 +#define V_EQMODE(x) ((x) << S_EQMODE) +#define F_EQMODE V_EQMODE(1U) + +#define S_OCOEF 3 +#define V_OCOEF(x) ((x) << S_OCOEF) +#define F_OCOEF V_OCOEF(1U) + +#define S_COEFRST 2 +#define V_COEFRST(x) ((x) << S_COEFRST) +#define F_COEFRST V_COEFRST(1U) + +#define S_SPEN 1 +#define V_SPEN(x) ((x) << S_SPEN) +#define F_SPEN V_SPEN(1U) + +#define S_ALOAD 0 +#define V_ALOAD(x) ((x) << S_ALOAD) +#define F_ALOAD V_ALOAD(1U) + +#define A_XGMAC_PORT_HSS_TXA_DRIVER_MODE 0x180c + +#define S_DRVOFFT 5 +#define V_DRVOFFT(x) ((x) << S_DRVOFFT) +#define F_DRVOFFT V_DRVOFFT(1U) + +#define S_SLEW 2 +#define M_SLEW 0x7U +#define V_SLEW(x) ((x) << S_SLEW) +#define G_SLEW(x) (((x) >> S_SLEW) & M_SLEW) + +#define S_FFE 0 +#define M_FFE 0x3U +#define V_FFE(x) ((x) << S_FFE) +#define G_FFE(x) (((x) >> S_FFE) & M_FFE) + +#define A_XGMAC_PORT_HSS_TXA_DRIVER_OVR_CTRL 0x1810 + +#define S_VLINC 7 +#define V_VLINC(x) ((x) << S_VLINC) +#define F_VLINC V_VLINC(1U) + +#define S_VLDEC 6 +#define V_VLDEC(x) ((x) << S_VLDEC) +#define F_VLDEC V_VLDEC(1U) + +#define S_LOPWR 5 +#define V_LOPWR(x) ((x) << S_LOPWR) +#define F_LOPWR V_LOPWR(1U) + +#define S_TDMEN 4 +#define V_TDMEN(x) ((x) << S_TDMEN) +#define F_TDMEN V_TDMEN(1U) + +#define S_DCCEN 3 +#define V_DCCEN(x) ((x) << S_DCCEN) +#define F_DCCEN V_DCCEN(1U) + +#define S_VHSEL 2 +#define V_VHSEL(x) ((x) << S_VHSEL) +#define F_VHSEL V_VHSEL(1U) + +#define S_IDAC 0 +#define M_IDAC 0x3U +#define V_IDAC(x) ((x) << S_IDAC) +#define G_IDAC(x) (((x) >> S_IDAC) & M_IDAC) + +#define A_XGMAC_PORT_HSS_TXA_TDM_BIASGEN_STANDBY_TIMER 0x1814 + +#define S_STBY 0 +#define M_STBY 0xffffU +#define V_STBY(x) ((x) << S_STBY) +#define G_STBY(x) (((x) >> S_STBY) & M_STBY) + +#define A_XGMAC_PORT_HSS_TXA_TDM_BIASGEN_PWRON_TIMER 0x1818 + +#define S_PON 0 +#define M_PON 0xffffU +#define V_PON(x) ((x) << S_PON) +#define G_PON(x) (((x) >> S_PON) & M_PON) + +#define A_XGMAC_PORT_HSS_TXA_TAP0_COEFF 0x1820 + +#define S_NXTT0 0 +#define M_NXTT0 0xfU +#define V_NXTT0(x) ((x) << S_NXTT0) +#define G_NXTT0(x) (((x) >> S_NXTT0) & M_NXTT0) + +#define A_XGMAC_PORT_HSS_TXA_TAP1_COEFF 0x1824 + +#define S_NXTT1 0 +#define M_NXTT1 0x3fU +#define V_NXTT1(x) ((x) << S_NXTT1) +#define G_NXTT1(x) (((x) >> S_NXTT1) & M_NXTT1) + +#define A_XGMAC_PORT_HSS_TXA_TAP2_COEFF 0x1828 + +#define S_NXTT2 0 +#define M_NXTT2 0x1fU +#define V_NXTT2(x) ((x) << S_NXTT2) +#define G_NXTT2(x) (((x) >> S_NXTT2) & M_NXTT2) + +#define A_XGMAC_PORT_HSS_TXA_PWR 0x1830 + +#define S_TXPWR 0 +#define M_TXPWR 0x7fU +#define V_TXPWR(x) ((x) << S_TXPWR) +#define G_TXPWR(x) (((x) >> S_TXPWR) & M_TXPWR) + +#define A_XGMAC_PORT_HSS_TXA_POLARITY 0x1834 + +#define S_TXPOL 4 +#define M_TXPOL 0x7U +#define V_TXPOL(x) ((x) << S_TXPOL) +#define G_TXPOL(x) (((x) >> S_TXPOL) & M_TXPOL) + +#define S_NTXPOL 0 +#define M_NTXPOL 0x7U +#define V_NTXPOL(x) ((x) << S_NTXPOL) +#define G_NTXPOL(x) (((x) >> S_NTXPOL) & M_NTXPOL) + +#define A_XGMAC_PORT_HSS_TXA_8023AP_AE_CMD 0x1838 + +#define S_CXPRESET 13 +#define V_CXPRESET(x) ((x) << S_CXPRESET) +#define F_CXPRESET V_CXPRESET(1U) + +#define S_CXINIT 12 +#define V_CXINIT(x) ((x) << S_CXINIT) +#define F_CXINIT V_CXINIT(1U) + +#define S_C2UPDT 4 +#define M_C2UPDT 0x3U +#define V_C2UPDT(x) ((x) << S_C2UPDT) +#define G_C2UPDT(x) (((x) >> S_C2UPDT) & M_C2UPDT) + +#define S_C1UPDT 2 +#define M_C1UPDT 0x3U +#define V_C1UPDT(x) ((x) << S_C1UPDT) +#define G_C1UPDT(x) (((x) >> S_C1UPDT) & M_C1UPDT) + +#define S_C0UPDT 0 +#define M_C0UPDT 0x3U +#define V_C0UPDT(x) ((x) << S_C0UPDT) +#define G_C0UPDT(x) (((x) >> S_C0UPDT) & M_C0UPDT) + +#define A_XGMAC_PORT_HSS_TXA_8023AP_AE_STATUS 0x183c + +#define S_C2STAT 4 +#define M_C2STAT 0x3U +#define V_C2STAT(x) ((x) << S_C2STAT) +#define G_C2STAT(x) (((x) >> S_C2STAT) & M_C2STAT) + +#define S_C1STAT 2 +#define M_C1STAT 0x3U +#define V_C1STAT(x) ((x) << S_C1STAT) +#define G_C1STAT(x) (((x) >> S_C1STAT) & M_C1STAT) + +#define S_C0STAT 0 +#define M_C0STAT 0x3U +#define V_C0STAT(x) ((x) << S_C0STAT) +#define G_C0STAT(x) (((x) >> S_C0STAT) & M_C0STAT) + +#define A_XGMAC_PORT_HSS_TXA_TAP0_IDAC_OVR 0x1840 + +#define S_NIDAC0 0 +#define M_NIDAC0 0x1fU +#define V_NIDAC0(x) ((x) << S_NIDAC0) +#define G_NIDAC0(x) (((x) >> S_NIDAC0) & M_NIDAC0) + +#define A_XGMAC_PORT_HSS_TXA_TAP1_IDAC_OVR 0x1844 + +#define S_NIDAC1 0 +#define M_NIDAC1 0x7fU +#define V_NIDAC1(x) ((x) << S_NIDAC1) +#define G_NIDAC1(x) (((x) >> S_NIDAC1) & M_NIDAC1) + +#define A_XGMAC_PORT_HSS_TXA_TAP2_IDAC_OVR 0x1848 + +#define S_NIDAC2 0 +#define M_NIDAC2 0x3fU +#define V_NIDAC2(x) ((x) << S_NIDAC2) +#define G_NIDAC2(x) (((x) >> S_NIDAC2) & M_NIDAC2) + +#define A_XGMAC_PORT_HSS_TXA_PWR_DAC_OVR 0x1850 + +#define S_OPEN 7 +#define V_OPEN(x) ((x) << S_OPEN) +#define F_OPEN V_OPEN(1U) + +#define S_OPVAL 0 +#define M_OPVAL 0x1fU +#define V_OPVAL(x) ((x) << S_OPVAL) +#define G_OPVAL(x) (((x) >> S_OPVAL) & M_OPVAL) + +#define A_XGMAC_PORT_HSS_TXA_PWR_DAC 0x1854 + +#define S_PDAC 0 +#define M_PDAC 0x1fU +#define V_PDAC(x) ((x) << S_PDAC) +#define G_PDAC(x) (((x) >> S_PDAC) & M_PDAC) + +#define A_XGMAC_PORT_HSS_TXA_TAP0_IDAC_APP 0x1860 + +#define S_AIDAC0 0 +#define M_AIDAC0 0x1fU +#define V_AIDAC0(x) ((x) << S_AIDAC0) +#define G_AIDAC0(x) (((x) >> S_AIDAC0) & M_AIDAC0) + +#define A_XGMAC_PORT_HSS_TXA_TAP1_IDAC_APP 0x1864 + +#define S_AIDAC1 0 +#define M_AIDAC1 0x1fU +#define V_AIDAC1(x) ((x) << S_AIDAC1) +#define G_AIDAC1(x) (((x) >> S_AIDAC1) & M_AIDAC1) + +#define A_XGMAC_PORT_HSS_TXA_TAP2_IDAC_APP 0x1868 + +#define S_TXA_AIDAC2 0 +#define M_TXA_AIDAC2 0x1fU +#define V_TXA_AIDAC2(x) ((x) << S_TXA_AIDAC2) +#define G_TXA_AIDAC2(x) (((x) >> S_TXA_AIDAC2) & M_TXA_AIDAC2) + +#define A_XGMAC_PORT_HSS_TXA_SEG_DIS_APP 0x1870 + +#define S_CURSD 0 +#define M_CURSD 0x7fU +#define V_CURSD(x) ((x) << S_CURSD) +#define G_CURSD(x) (((x) >> S_CURSD) & M_CURSD) + +#define A_XGMAC_PORT_HSS_TXA_EXT_ADDR_DATA 0x1878 + +#define S_XDATA 0 +#define M_XDATA 0xffffU +#define V_XDATA(x) ((x) << S_XDATA) +#define G_XDATA(x) (((x) >> S_XDATA) & M_XDATA) + +#define A_XGMAC_PORT_HSS_TXA_EXT_ADDR 0x187c + +#define S_EXTADDR 1 +#define M_EXTADDR 0x1fU +#define V_EXTADDR(x) ((x) << S_EXTADDR) +#define G_EXTADDR(x) (((x) >> S_EXTADDR) & M_EXTADDR) + +#define S_XWR 0 +#define V_XWR(x) ((x) << S_XWR) +#define F_XWR V_XWR(1U) + +#define A_XGMAC_PORT_HSS_TXB_MODE_CFG 0x1880 +#define A_XGMAC_PORT_HSS_TXB_TEST_CTRL 0x1884 +#define A_XGMAC_PORT_HSS_TXB_COEFF_CTRL 0x1888 +#define A_XGMAC_PORT_HSS_TXB_DRIVER_MODE 0x188c +#define A_XGMAC_PORT_HSS_TXB_DRIVER_OVR_CTRL 0x1890 +#define A_XGMAC_PORT_HSS_TXB_TDM_BIASGEN_STANDBY_TIMER 0x1894 +#define A_XGMAC_PORT_HSS_TXB_TDM_BIASGEN_PWRON_TIMER 0x1898 +#define A_XGMAC_PORT_HSS_TXB_TAP0_COEFF 0x18a0 +#define A_XGMAC_PORT_HSS_TXB_TAP1_COEFF 0x18a4 +#define A_XGMAC_PORT_HSS_TXB_TAP2_COEFF 0x18a8 +#define A_XGMAC_PORT_HSS_TXB_PWR 0x18b0 +#define A_XGMAC_PORT_HSS_TXB_POLARITY 0x18b4 +#define A_XGMAC_PORT_HSS_TXB_8023AP_AE_CMD 0x18b8 +#define A_XGMAC_PORT_HSS_TXB_8023AP_AE_STATUS 0x18bc +#define A_XGMAC_PORT_HSS_TXB_TAP0_IDAC_OVR 0x18c0 +#define A_XGMAC_PORT_HSS_TXB_TAP1_IDAC_OVR 0x18c4 +#define A_XGMAC_PORT_HSS_TXB_TAP2_IDAC_OVR 0x18c8 +#define A_XGMAC_PORT_HSS_TXB_PWR_DAC_OVR 0x18d0 +#define A_XGMAC_PORT_HSS_TXB_PWR_DAC 0x18d4 +#define A_XGMAC_PORT_HSS_TXB_TAP0_IDAC_APP 0x18e0 +#define A_XGMAC_PORT_HSS_TXB_TAP1_IDAC_APP 0x18e4 +#define A_XGMAC_PORT_HSS_TXB_TAP2_IDAC_APP 0x18e8 + +#define S_AIDAC2 0 +#define M_AIDAC2 0x3fU +#define V_AIDAC2(x) ((x) << S_AIDAC2) +#define G_AIDAC2(x) (((x) >> S_AIDAC2) & M_AIDAC2) + +#define A_XGMAC_PORT_HSS_TXB_SEG_DIS_APP 0x18f0 +#define A_XGMAC_PORT_HSS_TXB_EXT_ADDR_DATA 0x18f8 +#define A_XGMAC_PORT_HSS_TXB_EXT_ADDR 0x18fc + +#define S_XADDR 2 +#define M_XADDR 0xfU +#define V_XADDR(x) ((x) << S_XADDR) +#define G_XADDR(x) (((x) >> S_XADDR) & M_XADDR) + +#define A_XGMAC_PORT_HSS_RXA_CFG_MODE 0x1900 + +#define S_BW810 8 +#define V_BW810(x) ((x) << S_BW810) +#define F_BW810 V_BW810(1U) + +#define S_AUXCLK 7 +#define V_AUXCLK(x) ((x) << S_AUXCLK) +#define F_AUXCLK V_AUXCLK(1U) + +#define S_DMSEL 4 +#define M_DMSEL 0x7U +#define V_DMSEL(x) ((x) << S_DMSEL) +#define G_DMSEL(x) (((x) >> S_DMSEL) & M_DMSEL) + +#define A_XGMAC_PORT_HSS_RXA_TEST_CTRL 0x1904 + +#define S_RCLKEN 15 +#define V_RCLKEN(x) ((x) << S_RCLKEN) +#define F_RCLKEN V_RCLKEN(1U) + +#define S_RRATE 13 +#define M_RRATE 0x3U +#define V_RRATE(x) ((x) << S_RRATE) +#define G_RRATE(x) (((x) >> S_RRATE) & M_RRATE) + +#define S_LBFRCERROR 10 +#define V_LBFRCERROR(x) ((x) << S_LBFRCERROR) +#define F_LBFRCERROR V_LBFRCERROR(1U) + +#define S_LBERROR 9 +#define V_LBERROR(x) ((x) << S_LBERROR) +#define F_LBERROR V_LBERROR(1U) + +#define S_LBSYNC 8 +#define V_LBSYNC(x) ((x) << S_LBSYNC) +#define F_LBSYNC V_LBSYNC(1U) + +#define S_FDWRAPCLK 7 +#define V_FDWRAPCLK(x) ((x) << S_FDWRAPCLK) +#define F_FDWRAPCLK V_FDWRAPCLK(1U) + +#define S_FDWRAP 6 +#define V_FDWRAP(x) ((x) << S_FDWRAP) +#define F_FDWRAP V_FDWRAP(1U) + +#define S_PRST 4 +#define V_PRST(x) ((x) << S_PRST) +#define F_PRST V_PRST(1U) + +#define S_PCHKEN 3 +#define V_PCHKEN(x) ((x) << S_PCHKEN) +#define F_PCHKEN V_PCHKEN(1U) + +#define S_PRBSSEL 0 +#define M_PRBSSEL 0x7U +#define V_PRBSSEL(x) ((x) << S_PRBSSEL) +#define G_PRBSSEL(x) (((x) >> S_PRBSSEL) & M_PRBSSEL) + +#define A_XGMAC_PORT_HSS_RXA_PH_ROTATOR_CTRL 0x1908 + +#define S_FTHROT 12 +#define M_FTHROT 0xfU +#define V_FTHROT(x) ((x) << S_FTHROT) +#define G_FTHROT(x) (((x) >> S_FTHROT) & M_FTHROT) + +#define S_RTHROT 11 +#define V_RTHROT(x) ((x) << S_RTHROT) +#define F_RTHROT V_RTHROT(1U) + +#define S_FILTCTL 7 +#define M_FILTCTL 0xfU +#define V_FILTCTL(x) ((x) << S_FILTCTL) +#define G_FILTCTL(x) (((x) >> S_FILTCTL) & M_FILTCTL) + +#define S_RSRVO 5 +#define M_RSRVO 0x3U +#define V_RSRVO(x) ((x) << S_RSRVO) +#define G_RSRVO(x) (((x) >> S_RSRVO) & M_RSRVO) + +#define S_EXTEL 4 +#define V_EXTEL(x) ((x) << S_EXTEL) +#define F_EXTEL V_EXTEL(1U) + +#define S_RSTONSTUCK 3 +#define V_RSTONSTUCK(x) ((x) << S_RSTONSTUCK) +#define F_RSTONSTUCK V_RSTONSTUCK(1U) + +#define S_FREEZEFW 2 +#define V_FREEZEFW(x) ((x) << S_FREEZEFW) +#define F_FREEZEFW V_FREEZEFW(1U) + +#define S_RESETFW 1 +#define V_RESETFW(x) ((x) << S_RESETFW) +#define F_RESETFW V_RESETFW(1U) + +#define S_SSCENABLE 0 +#define V_SSCENABLE(x) ((x) << S_SSCENABLE) +#define F_SSCENABLE V_SSCENABLE(1U) + +#define A_XGMAC_PORT_HSS_RXA_PH_ROTATOR_OFFSET_CTRL 0x190c + +#define S_RSNP 11 +#define V_RSNP(x) ((x) << S_RSNP) +#define F_RSNP V_RSNP(1U) + +#define S_TSOEN 10 +#define V_TSOEN(x) ((x) << S_TSOEN) +#define F_TSOEN V_TSOEN(1U) + +#define S_OFFEN 9 +#define V_OFFEN(x) ((x) << S_OFFEN) +#define F_OFFEN V_OFFEN(1U) + +#define S_TMSCAL 7 +#define M_TMSCAL 0x3U +#define V_TMSCAL(x) ((x) << S_TMSCAL) +#define G_TMSCAL(x) (((x) >> S_TMSCAL) & M_TMSCAL) + +#define S_APADJ 6 +#define V_APADJ(x) ((x) << S_APADJ) +#define F_APADJ V_APADJ(1U) + +#define S_RSEL 5 +#define V_RSEL(x) ((x) << S_RSEL) +#define F_RSEL V_RSEL(1U) + +#define S_PHOFFS 0 +#define M_PHOFFS 0x1fU +#define V_PHOFFS(x) ((x) << S_PHOFFS) +#define G_PHOFFS(x) (((x) >> S_PHOFFS) & M_PHOFFS) + +#define A_XGMAC_PORT_HSS_RXA_PH_ROTATOR_POSITION1 0x1910 + +#define S_ROT0A 8 +#define M_ROT0A 0x3fU +#define V_ROT0A(x) ((x) << S_ROT0A) +#define G_ROT0A(x) (((x) >> S_ROT0A) & M_ROT0A) + +#define S_RTSEL_SNAPSHOT 0 +#define M_RTSEL_SNAPSHOT 0x3fU +#define V_RTSEL_SNAPSHOT(x) ((x) << S_RTSEL_SNAPSHOT) +#define G_RTSEL_SNAPSHOT(x) (((x) >> S_RTSEL_SNAPSHOT) & M_RTSEL_SNAPSHOT) + +#define A_XGMAC_PORT_HSS_RXA_PH_ROTATOR_POSITION2 0x1914 + +#define S_ROT90 0 +#define M_ROT90 0x3fU +#define V_ROT90(x) ((x) << S_ROT90) +#define G_ROT90(x) (((x) >> S_ROT90) & M_ROT90) + +#define A_XGMAC_PORT_HSS_RXA_PH_ROTATOR_STATIC_PH_OFFSET 0x1918 + +#define S_RCALER 15 +#define V_RCALER(x) ((x) << S_RCALER) +#define F_RCALER V_RCALER(1U) + +#define S_RAOOFF 10 +#define M_RAOOFF 0x1fU +#define V_RAOOFF(x) ((x) << S_RAOOFF) +#define G_RAOOFF(x) (((x) >> S_RAOOFF) & M_RAOOFF) + +#define S_RAEOFF 5 +#define M_RAEOFF 0x1fU +#define V_RAEOFF(x) ((x) << S_RAEOFF) +#define G_RAEOFF(x) (((x) >> S_RAEOFF) & M_RAEOFF) + +#define S_RDOFF 0 +#define M_RDOFF 0x1fU +#define V_RDOFF(x) ((x) << S_RDOFF) +#define G_RDOFF(x) (((x) >> S_RDOFF) & M_RDOFF) + +#define A_XGMAC_PORT_HSS_RXA_SIGDET_CTRL 0x191c + +#define S_SIGNSD 13 +#define M_SIGNSD 0x3U +#define V_SIGNSD(x) ((x) << S_SIGNSD) +#define G_SIGNSD(x) (((x) >> S_SIGNSD) & M_SIGNSD) + +#define S_DACSD 8 +#define M_DACSD 0x1fU +#define V_DACSD(x) ((x) << S_DACSD) +#define G_DACSD(x) (((x) >> S_DACSD) & M_DACSD) + +#define S_SDPDN 6 +#define V_SDPDN(x) ((x) << S_SDPDN) +#define F_SDPDN V_SDPDN(1U) + +#define S_SIGDET 5 +#define V_SIGDET(x) ((x) << S_SIGDET) +#define F_SIGDET V_SIGDET(1U) + +#define S_SDLVL 0 +#define M_SDLVL 0x1fU +#define V_SDLVL(x) ((x) << S_SDLVL) +#define G_SDLVL(x) (((x) >> S_SDLVL) & M_SDLVL) + +#define A_XGMAC_PORT_HSS_RXA_DFE_CTRL 0x1920 + +#define S_REQCMP 15 +#define V_REQCMP(x) ((x) << S_REQCMP) +#define F_REQCMP V_REQCMP(1U) + +#define S_DFEREQ 14 +#define V_DFEREQ(x) ((x) << S_DFEREQ) +#define F_DFEREQ V_DFEREQ(1U) + +#define S_SPCEN 13 +#define V_SPCEN(x) ((x) << S_SPCEN) +#define F_SPCEN V_SPCEN(1U) + +#define S_GATEEN 12 +#define V_GATEEN(x) ((x) << S_GATEEN) +#define F_GATEEN V_GATEEN(1U) + +#define S_SPIFMT 9 +#define M_SPIFMT 0x7U +#define V_SPIFMT(x) ((x) << S_SPIFMT) +#define G_SPIFMT(x) (((x) >> S_SPIFMT) & M_SPIFMT) + +#define S_DFEPWR 6 +#define M_DFEPWR 0x7U +#define V_DFEPWR(x) ((x) << S_DFEPWR) +#define G_DFEPWR(x) (((x) >> S_DFEPWR) & M_DFEPWR) + +#define S_STNDBY 5 +#define V_STNDBY(x) ((x) << S_STNDBY) +#define F_STNDBY V_STNDBY(1U) + +#define S_FRCH 4 +#define V_FRCH(x) ((x) << S_FRCH) +#define F_FRCH V_FRCH(1U) + +#define S_NONRND 3 +#define V_NONRND(x) ((x) << S_NONRND) +#define F_NONRND V_NONRND(1U) + +#define S_NONRNF 2 +#define V_NONRNF(x) ((x) << S_NONRNF) +#define F_NONRNF V_NONRNF(1U) + +#define S_FSTLCK 1 +#define V_FSTLCK(x) ((x) << S_FSTLCK) +#define F_FSTLCK V_FSTLCK(1U) + +#define S_DFERST 0 +#define V_DFERST(x) ((x) << S_DFERST) +#define F_DFERST V_DFERST(1U) + +#define A_XGMAC_PORT_HSS_RXA_DFE_DATA_EDGE_SAMPLE 0x1924 + +#define S_ESAMP 8 +#define M_ESAMP 0xffU +#define V_ESAMP(x) ((x) << S_ESAMP) +#define G_ESAMP(x) (((x) >> S_ESAMP) & M_ESAMP) + +#define S_DSAMP 0 +#define M_DSAMP 0xffU +#define V_DSAMP(x) ((x) << S_DSAMP) +#define G_DSAMP(x) (((x) >> S_DSAMP) & M_DSAMP) + +#define A_XGMAC_PORT_HSS_RXA_DFE_AMP_SAMPLE 0x1928 + +#define S_SMODE 8 +#define M_SMODE 0xfU +#define V_SMODE(x) ((x) << S_SMODE) +#define G_SMODE(x) (((x) >> S_SMODE) & M_SMODE) + +#define S_ADCORR 7 +#define V_ADCORR(x) ((x) << S_ADCORR) +#define F_ADCORR V_ADCORR(1U) + +#define S_TRAINEN 6 +#define V_TRAINEN(x) ((x) << S_TRAINEN) +#define F_TRAINEN V_TRAINEN(1U) + +#define S_ASAMPQ 3 +#define M_ASAMPQ 0x7U +#define V_ASAMPQ(x) ((x) << S_ASAMPQ) +#define G_ASAMPQ(x) (((x) >> S_ASAMPQ) & M_ASAMPQ) + +#define S_ASAMP 0 +#define M_ASAMP 0x7U +#define V_ASAMP(x) ((x) << S_ASAMP) +#define G_ASAMP(x) (((x) >> S_ASAMP) & M_ASAMP) + +#define A_XGMAC_PORT_HSS_RXA_VGA_CTRL1 0x192c + +#define S_POLE 12 +#define M_POLE 0x3U +#define V_POLE(x) ((x) << S_POLE) +#define G_POLE(x) (((x) >> S_POLE) & M_POLE) + +#define S_PEAK 8 +#define M_PEAK 0x7U +#define V_PEAK(x) ((x) << S_PEAK) +#define G_PEAK(x) (((x) >> S_PEAK) & M_PEAK) + +#define S_VOFFSN 6 +#define M_VOFFSN 0x3U +#define V_VOFFSN(x) ((x) << S_VOFFSN) +#define G_VOFFSN(x) (((x) >> S_VOFFSN) & M_VOFFSN) + +#define S_VOFFA 0 +#define M_VOFFA 0x3fU +#define V_VOFFA(x) ((x) << S_VOFFA) +#define G_VOFFA(x) (((x) >> S_VOFFA) & M_VOFFA) + +#define A_XGMAC_PORT_HSS_RXA_VGA_CTRL2 0x1930 + +#define S_SHORTV 10 +#define V_SHORTV(x) ((x) << S_SHORTV) +#define F_SHORTV V_SHORTV(1U) + +#define S_VGAIN 0 +#define M_VGAIN 0xfU +#define V_VGAIN(x) ((x) << S_VGAIN) +#define G_VGAIN(x) (((x) >> S_VGAIN) & M_VGAIN) + +#define A_XGMAC_PORT_HSS_RXA_VGA_CTRL3 0x1934 + +#define S_HBND1 10 +#define V_HBND1(x) ((x) << S_HBND1) +#define F_HBND1 V_HBND1(1U) + +#define S_HBND0 9 +#define V_HBND0(x) ((x) << S_HBND0) +#define F_HBND0 V_HBND0(1U) + +#define S_VLCKD 8 +#define V_VLCKD(x) ((x) << S_VLCKD) +#define F_VLCKD V_VLCKD(1U) + +#define S_VLCKDF 7 +#define V_VLCKDF(x) ((x) << S_VLCKDF) +#define F_VLCKDF V_VLCKDF(1U) + +#define S_AMAXT 0 +#define M_AMAXT 0x7fU +#define V_AMAXT(x) ((x) << S_AMAXT) +#define G_AMAXT(x) (((x) >> S_AMAXT) & M_AMAXT) + +#define A_XGMAC_PORT_HSS_RXA_DFE_D00_D01_OFFSET 0x1938 + +#define S_D01SN 13 +#define M_D01SN 0x3U +#define V_D01SN(x) ((x) << S_D01SN) +#define G_D01SN(x) (((x) >> S_D01SN) & M_D01SN) + +#define S_D01AMP 8 +#define M_D01AMP 0x1fU +#define V_D01AMP(x) ((x) << S_D01AMP) +#define G_D01AMP(x) (((x) >> S_D01AMP) & M_D01AMP) + +#define S_D00SN 5 +#define M_D00SN 0x3U +#define V_D00SN(x) ((x) << S_D00SN) +#define G_D00SN(x) (((x) >> S_D00SN) & M_D00SN) + +#define S_D00AMP 0 +#define M_D00AMP 0x1fU +#define V_D00AMP(x) ((x) << S_D00AMP) +#define G_D00AMP(x) (((x) >> S_D00AMP) & M_D00AMP) + +#define A_XGMAC_PORT_HSS_RXA_DFE_D10_D11_OFFSET 0x193c + +#define S_D11SN 13 +#define M_D11SN 0x3U +#define V_D11SN(x) ((x) << S_D11SN) +#define G_D11SN(x) (((x) >> S_D11SN) & M_D11SN) + +#define S_D11AMP 8 +#define M_D11AMP 0x1fU +#define V_D11AMP(x) ((x) << S_D11AMP) +#define G_D11AMP(x) (((x) >> S_D11AMP) & M_D11AMP) + +#define S_D10SN 5 +#define M_D10SN 0x3U +#define V_D10SN(x) ((x) << S_D10SN) +#define G_D10SN(x) (((x) >> S_D10SN) & M_D10SN) + +#define S_D10AMP 0 +#define M_D10AMP 0x1fU +#define V_D10AMP(x) ((x) << S_D10AMP) +#define G_D10AMP(x) (((x) >> S_D10AMP) & M_D10AMP) + +#define A_XGMAC_PORT_HSS_RXA_DFE_E0_E1_OFFSET 0x1940 + +#define S_E1SN 13 +#define M_E1SN 0x3U +#define V_E1SN(x) ((x) << S_E1SN) +#define G_E1SN(x) (((x) >> S_E1SN) & M_E1SN) + +#define S_E1AMP 8 +#define M_E1AMP 0x1fU +#define V_E1AMP(x) ((x) << S_E1AMP) +#define G_E1AMP(x) (((x) >> S_E1AMP) & M_E1AMP) + +#define S_E0SN 5 +#define M_E0SN 0x3U +#define V_E0SN(x) ((x) << S_E0SN) +#define G_E0SN(x) (((x) >> S_E0SN) & M_E0SN) + +#define S_E0AMP 0 +#define M_E0AMP 0x1fU +#define V_E0AMP(x) ((x) << S_E0AMP) +#define G_E0AMP(x) (((x) >> S_E0AMP) & M_E0AMP) + +#define A_XGMAC_PORT_HSS_RXA_DACA_OFFSET 0x1944 + +#define S_AOFFO 8 +#define M_AOFFO 0x3fU +#define V_AOFFO(x) ((x) << S_AOFFO) +#define G_AOFFO(x) (((x) >> S_AOFFO) & M_AOFFO) + +#define S_AOFFE 0 +#define M_AOFFE 0x3fU +#define V_AOFFE(x) ((x) << S_AOFFE) +#define G_AOFFE(x) (((x) >> S_AOFFE) & M_AOFFE) + +#define A_XGMAC_PORT_HSS_RXA_DACAP_DAC_AN_OFFSET 0x1948 + +#define S_DACAN 8 +#define M_DACAN 0xffU +#define V_DACAN(x) ((x) << S_DACAN) +#define G_DACAN(x) (((x) >> S_DACAN) & M_DACAN) + +#define S_DACAP 0 +#define M_DACAP 0xffU +#define V_DACAP(x) ((x) << S_DACAP) +#define G_DACAP(x) (((x) >> S_DACAP) & M_DACAP) + +#define A_XGMAC_PORT_HSS_RXA_DACA_MIN 0x194c + +#define S_DACAZ 8 +#define M_DACAZ 0xffU +#define V_DACAZ(x) ((x) << S_DACAZ) +#define G_DACAZ(x) (((x) >> S_DACAZ) & M_DACAZ) + +#define S_DACAM 0 +#define M_DACAM 0xffU +#define V_DACAM(x) ((x) << S_DACAM) +#define G_DACAM(x) (((x) >> S_DACAM) & M_DACAM) + +#define A_XGMAC_PORT_HSS_RXA_ADAC_CTRL 0x1950 + +#define S_ADSN 7 +#define M_ADSN 0x3U +#define V_ADSN(x) ((x) << S_ADSN) +#define G_ADSN(x) (((x) >> S_ADSN) & M_ADSN) + +#define S_ADMAG 0 +#define M_ADMAG 0x7fU +#define V_ADMAG(x) ((x) << S_ADMAG) +#define G_ADMAG(x) (((x) >> S_ADMAG) & M_ADMAG) + +#define A_XGMAC_PORT_HSS_RXA_DIGITAL_EYE_CTRL 0x1954 + +#define S_BLKAZ 15 +#define V_BLKAZ(x) ((x) << S_BLKAZ) +#define F_BLKAZ V_BLKAZ(1U) + +#define S_WIDTH 10 +#define M_WIDTH 0x1fU +#define V_WIDTH(x) ((x) << S_WIDTH) +#define G_WIDTH(x) (((x) >> S_WIDTH) & M_WIDTH) + +#define S_MINWIDTH 5 +#define M_MINWIDTH 0x1fU +#define V_MINWIDTH(x) ((x) << S_MINWIDTH) +#define G_MINWIDTH(x) (((x) >> S_MINWIDTH) & M_MINWIDTH) + +#define S_MINAMP 0 +#define M_MINAMP 0x1fU +#define V_MINAMP(x) ((x) << S_MINAMP) +#define G_MINAMP(x) (((x) >> S_MINAMP) & M_MINAMP) + +#define A_XGMAC_PORT_HSS_RXA_DIGITAL_EYE_METRICS 0x1958 + +#define S_EMBRDY 10 +#define V_EMBRDY(x) ((x) << S_EMBRDY) +#define F_EMBRDY V_EMBRDY(1U) + +#define S_EMBUMP 7 +#define V_EMBUMP(x) ((x) << S_EMBUMP) +#define F_EMBUMP V_EMBUMP(1U) + +#define S_EMMD 5 +#define M_EMMD 0x3U +#define V_EMMD(x) ((x) << S_EMMD) +#define G_EMMD(x) (((x) >> S_EMMD) & M_EMMD) + +#define S_EMPAT 1 +#define V_EMPAT(x) ((x) << S_EMPAT) +#define F_EMPAT V_EMPAT(1U) + +#define S_EMEN 0 +#define V_EMEN(x) ((x) << S_EMEN) +#define F_EMEN V_EMEN(1U) + +#define A_XGMAC_PORT_HSS_RXA_DFE_H1 0x195c + +#define S_H1OSN 14 +#define M_H1OSN 0x3U +#define V_H1OSN(x) ((x) << S_H1OSN) +#define G_H1OSN(x) (((x) >> S_H1OSN) & M_H1OSN) + +#define S_H1OMAG 8 +#define M_H1OMAG 0x3fU +#define V_H1OMAG(x) ((x) << S_H1OMAG) +#define G_H1OMAG(x) (((x) >> S_H1OMAG) & M_H1OMAG) + +#define S_H1ESN 6 +#define M_H1ESN 0x3U +#define V_H1ESN(x) ((x) << S_H1ESN) +#define G_H1ESN(x) (((x) >> S_H1ESN) & M_H1ESN) + +#define S_H1EMAG 0 +#define M_H1EMAG 0x3fU +#define V_H1EMAG(x) ((x) << S_H1EMAG) +#define G_H1EMAG(x) (((x) >> S_H1EMAG) & M_H1EMAG) + +#define A_XGMAC_PORT_HSS_RXA_DFE_H2 0x1960 + +#define S_H2OSN 13 +#define M_H2OSN 0x3U +#define V_H2OSN(x) ((x) << S_H2OSN) +#define G_H2OSN(x) (((x) >> S_H2OSN) & M_H2OSN) + +#define S_H2OMAG 8 +#define M_H2OMAG 0x1fU +#define V_H2OMAG(x) ((x) << S_H2OMAG) +#define G_H2OMAG(x) (((x) >> S_H2OMAG) & M_H2OMAG) + +#define S_H2ESN 5 +#define M_H2ESN 0x3U +#define V_H2ESN(x) ((x) << S_H2ESN) +#define G_H2ESN(x) (((x) >> S_H2ESN) & M_H2ESN) + +#define S_H2EMAG 0 +#define M_H2EMAG 0x1fU +#define V_H2EMAG(x) ((x) << S_H2EMAG) +#define G_H2EMAG(x) (((x) >> S_H2EMAG) & M_H2EMAG) + +#define A_XGMAC_PORT_HSS_RXA_DFE_H3 0x1964 + +#define S_H3OSN 12 +#define M_H3OSN 0x3U +#define V_H3OSN(x) ((x) << S_H3OSN) +#define G_H3OSN(x) (((x) >> S_H3OSN) & M_H3OSN) + +#define S_H3OMAG 8 +#define M_H3OMAG 0xfU +#define V_H3OMAG(x) ((x) << S_H3OMAG) +#define G_H3OMAG(x) (((x) >> S_H3OMAG) & M_H3OMAG) + +#define S_H3ESN 4 +#define M_H3ESN 0x3U +#define V_H3ESN(x) ((x) << S_H3ESN) +#define G_H3ESN(x) (((x) >> S_H3ESN) & M_H3ESN) + +#define S_H3EMAG 0 +#define M_H3EMAG 0xfU +#define V_H3EMAG(x) ((x) << S_H3EMAG) +#define G_H3EMAG(x) (((x) >> S_H3EMAG) & M_H3EMAG) + +#define A_XGMAC_PORT_HSS_RXA_DFE_H4 0x1968 + +#define S_H4OSN 12 +#define M_H4OSN 0x3U +#define V_H4OSN(x) ((x) << S_H4OSN) +#define G_H4OSN(x) (((x) >> S_H4OSN) & M_H4OSN) + +#define S_H4OMAG 8 +#define M_H4OMAG 0xfU +#define V_H4OMAG(x) ((x) << S_H4OMAG) +#define G_H4OMAG(x) (((x) >> S_H4OMAG) & M_H4OMAG) + +#define S_H4ESN 4 +#define M_H4ESN 0x3U +#define V_H4ESN(x) ((x) << S_H4ESN) +#define G_H4ESN(x) (((x) >> S_H4ESN) & M_H4ESN) + +#define S_H4EMAG 0 +#define M_H4EMAG 0xfU +#define V_H4EMAG(x) ((x) << S_H4EMAG) +#define G_H4EMAG(x) (((x) >> S_H4EMAG) & M_H4EMAG) + +#define A_XGMAC_PORT_HSS_RXA_DFE_H5 0x196c + +#define S_H5OSN 12 +#define M_H5OSN 0x3U +#define V_H5OSN(x) ((x) << S_H5OSN) +#define G_H5OSN(x) (((x) >> S_H5OSN) & M_H5OSN) + +#define S_H5OMAG 8 +#define M_H5OMAG 0xfU +#define V_H5OMAG(x) ((x) << S_H5OMAG) +#define G_H5OMAG(x) (((x) >> S_H5OMAG) & M_H5OMAG) + +#define S_H5ESN 4 +#define M_H5ESN 0x3U +#define V_H5ESN(x) ((x) << S_H5ESN) +#define G_H5ESN(x) (((x) >> S_H5ESN) & M_H5ESN) + +#define S_H5EMAG 0 +#define M_H5EMAG 0xfU +#define V_H5EMAG(x) ((x) << S_H5EMAG) +#define G_H5EMAG(x) (((x) >> S_H5EMAG) & M_H5EMAG) + +#define A_XGMAC_PORT_HSS_RXA_DAC_DPC 0x1970 + +#define S_DPCCVG 13 +#define V_DPCCVG(x) ((x) << S_DPCCVG) +#define F_DPCCVG V_DPCCVG(1U) + +#define S_DACCVG 12 +#define V_DACCVG(x) ((x) << S_DACCVG) +#define F_DACCVG V_DACCVG(1U) + +#define S_DPCTGT 9 +#define M_DPCTGT 0x7U +#define V_DPCTGT(x) ((x) << S_DPCTGT) +#define G_DPCTGT(x) (((x) >> S_DPCTGT) & M_DPCTGT) + +#define S_BLKH1T 8 +#define V_BLKH1T(x) ((x) << S_BLKH1T) +#define F_BLKH1T V_BLKH1T(1U) + +#define S_BLKOAE 7 +#define V_BLKOAE(x) ((x) << S_BLKOAE) +#define F_BLKOAE V_BLKOAE(1U) + +#define S_H1TGT 4 +#define M_H1TGT 0x7U +#define V_H1TGT(x) ((x) << S_H1TGT) +#define G_H1TGT(x) (((x) >> S_H1TGT) & M_H1TGT) + +#define S_OAE 0 +#define M_OAE 0xfU +#define V_OAE(x) ((x) << S_OAE) +#define G_OAE(x) (((x) >> S_OAE) & M_OAE) + +#define A_XGMAC_PORT_HSS_RXA_DDC 0x1974 + +#define S_OLS 11 +#define M_OLS 0x1fU +#define V_OLS(x) ((x) << S_OLS) +#define G_OLS(x) (((x) >> S_OLS) & M_OLS) + +#define S_OES 6 +#define M_OES 0x1fU +#define V_OES(x) ((x) << S_OES) +#define G_OES(x) (((x) >> S_OES) & M_OES) + +#define S_BLKODEC 5 +#define V_BLKODEC(x) ((x) << S_BLKODEC) +#define F_BLKODEC V_BLKODEC(1U) + +#define S_ODEC 0 +#define M_ODEC 0x1fU +#define V_ODEC(x) ((x) << S_ODEC) +#define G_ODEC(x) (((x) >> S_ODEC) & M_ODEC) + +#define A_XGMAC_PORT_HSS_RXA_INTERNAL_STATUS 0x1978 + +#define S_BER6 15 +#define V_BER6(x) ((x) << S_BER6) +#define F_BER6 V_BER6(1U) + +#define S_BER6VAL 14 +#define V_BER6VAL(x) ((x) << S_BER6VAL) +#define F_BER6VAL V_BER6VAL(1U) + +#define S_BER3VAL 13 +#define V_BER3VAL(x) ((x) << S_BER3VAL) +#define F_BER3VAL V_BER3VAL(1U) + +#define S_DPCCMP 9 +#define V_DPCCMP(x) ((x) << S_DPCCMP) +#define F_DPCCMP V_DPCCMP(1U) + +#define S_DACCMP 8 +#define V_DACCMP(x) ((x) << S_DACCMP) +#define F_DACCMP V_DACCMP(1U) + +#define S_DDCCMP 7 +#define V_DDCCMP(x) ((x) << S_DDCCMP) +#define F_DDCCMP V_DDCCMP(1U) + +#define S_AERRFLG 6 +#define V_AERRFLG(x) ((x) << S_AERRFLG) +#define F_AERRFLG V_AERRFLG(1U) + +#define S_WERRFLG 5 +#define V_WERRFLG(x) ((x) << S_WERRFLG) +#define F_WERRFLG V_WERRFLG(1U) + +#define S_TRCMP 4 +#define V_TRCMP(x) ((x) << S_TRCMP) +#define F_TRCMP V_TRCMP(1U) + +#define S_VLCKF 3 +#define V_VLCKF(x) ((x) << S_VLCKF) +#define F_VLCKF V_VLCKF(1U) + +#define S_ROCADJ 2 +#define V_ROCADJ(x) ((x) << S_ROCADJ) +#define F_ROCADJ V_ROCADJ(1U) + +#define S_ROCCMP 1 +#define V_ROCCMP(x) ((x) << S_ROCCMP) +#define F_ROCCMP V_ROCCMP(1U) + +#define S_OCCMP 0 +#define V_OCCMP(x) ((x) << S_OCCMP) +#define F_OCCMP V_OCCMP(1U) + +#define A_XGMAC_PORT_HSS_RXA_DFE_FUNC_CTRL 0x197c + +#define S_FDPC 15 +#define V_FDPC(x) ((x) << S_FDPC) +#define F_FDPC V_FDPC(1U) + +#define S_FDAC 14 +#define V_FDAC(x) ((x) << S_FDAC) +#define F_FDAC V_FDAC(1U) + +#define S_FDDC 13 +#define V_FDDC(x) ((x) << S_FDDC) +#define F_FDDC V_FDDC(1U) + +#define S_FNRND 12 +#define V_FNRND(x) ((x) << S_FNRND) +#define F_FNRND V_FNRND(1U) + +#define S_FVGAIN 11 +#define V_FVGAIN(x) ((x) << S_FVGAIN) +#define F_FVGAIN V_FVGAIN(1U) + +#define S_FVOFF 10 +#define V_FVOFF(x) ((x) << S_FVOFF) +#define F_FVOFF V_FVOFF(1U) + +#define S_FSDET 9 +#define V_FSDET(x) ((x) << S_FSDET) +#define F_FSDET V_FSDET(1U) + +#define S_FBER6 8 +#define V_FBER6(x) ((x) << S_FBER6) +#define F_FBER6 V_FBER6(1U) + +#define S_FROTO 7 +#define V_FROTO(x) ((x) << S_FROTO) +#define F_FROTO V_FROTO(1U) + +#define S_FH4H5 6 +#define V_FH4H5(x) ((x) << S_FH4H5) +#define F_FH4H5 V_FH4H5(1U) + +#define S_FH2H3 5 +#define V_FH2H3(x) ((x) << S_FH2H3) +#define F_FH2H3 V_FH2H3(1U) + +#define S_FH1 4 +#define V_FH1(x) ((x) << S_FH1) +#define F_FH1 V_FH1(1U) + +#define S_FH1SN 3 +#define V_FH1SN(x) ((x) << S_FH1SN) +#define F_FH1SN V_FH1SN(1U) + +#define S_FNRDF 2 +#define V_FNRDF(x) ((x) << S_FNRDF) +#define F_FNRDF V_FNRDF(1U) + +#define S_FADAC 0 +#define V_FADAC(x) ((x) << S_FADAC) +#define F_FADAC V_FADAC(1U) + +#define A_XGMAC_PORT_HSS_RXB_CFG_MODE 0x1980 +#define A_XGMAC_PORT_HSS_RXB_TEST_CTRL 0x1984 +#define A_XGMAC_PORT_HSS_RXB_PH_ROTATOR_CTRL 0x1988 +#define A_XGMAC_PORT_HSS_RXB_PH_ROTATOR_OFFSET_CTRL 0x198c +#define A_XGMAC_PORT_HSS_RXB_PH_ROTATOR_POSITION1 0x1990 +#define A_XGMAC_PORT_HSS_RXB_PH_ROTATOR_POSITION2 0x1994 +#define A_XGMAC_PORT_HSS_RXB_PH_ROTATOR_STATIC_PH_OFFSET 0x1998 +#define A_XGMAC_PORT_HSS_RXB_SIGDET_CTRL 0x199c +#define A_XGMAC_PORT_HSS_RXB_DFE_CTRL 0x19a0 +#define A_XGMAC_PORT_HSS_RXB_DFE_DATA_EDGE_SAMPLE 0x19a4 +#define A_XGMAC_PORT_HSS_RXB_DFE_AMP_SAMPLE 0x19a8 +#define A_XGMAC_PORT_HSS_RXB_VGA_CTRL1 0x19ac +#define A_XGMAC_PORT_HSS_RXB_VGA_CTRL2 0x19b0 +#define A_XGMAC_PORT_HSS_RXB_VGA_CTRL3 0x19b4 +#define A_XGMAC_PORT_HSS_RXB_DFE_D00_D01_OFFSET 0x19b8 +#define A_XGMAC_PORT_HSS_RXB_DFE_D10_D11_OFFSET 0x19bc +#define A_XGMAC_PORT_HSS_RXB_DFE_E0_E1_OFFSET 0x19c0 +#define A_XGMAC_PORT_HSS_RXB_DACA_OFFSET 0x19c4 +#define A_XGMAC_PORT_HSS_RXB_DACAP_DAC_AN_OFFSET 0x19c8 +#define A_XGMAC_PORT_HSS_RXB_DACA_MIN 0x19cc +#define A_XGMAC_PORT_HSS_RXB_ADAC_CTRL 0x19d0 +#define A_XGMAC_PORT_HSS_RXB_DIGITAL_EYE_CTRL 0x19d4 +#define A_XGMAC_PORT_HSS_RXB_DIGITAL_EYE_METRICS 0x19d8 +#define A_XGMAC_PORT_HSS_RXB_DFE_H1 0x19dc +#define A_XGMAC_PORT_HSS_RXB_DFE_H2 0x19e0 +#define A_XGMAC_PORT_HSS_RXB_DFE_H3 0x19e4 +#define A_XGMAC_PORT_HSS_RXB_DFE_H4 0x19e8 +#define A_XGMAC_PORT_HSS_RXB_DFE_H5 0x19ec +#define A_XGMAC_PORT_HSS_RXB_DAC_DPC 0x19f0 +#define A_XGMAC_PORT_HSS_RXB_DDC 0x19f4 +#define A_XGMAC_PORT_HSS_RXB_INTERNAL_STATUS 0x19f8 +#define A_XGMAC_PORT_HSS_RXB_DFE_FUNC_CTRL 0x19fc +#define A_XGMAC_PORT_HSS_TXC_MODE_CFG 0x1a00 +#define A_XGMAC_PORT_HSS_TXC_TEST_CTRL 0x1a04 +#define A_XGMAC_PORT_HSS_TXC_COEFF_CTRL 0x1a08 +#define A_XGMAC_PORT_HSS_TXC_DRIVER_MODE 0x1a0c +#define A_XGMAC_PORT_HSS_TXC_DRIVER_OVR_CTRL 0x1a10 +#define A_XGMAC_PORT_HSS_TXC_TDM_BIASGEN_STANDBY_TIMER 0x1a14 +#define A_XGMAC_PORT_HSS_TXC_TDM_BIASGEN_PWRON_TIMER 0x1a18 +#define A_XGMAC_PORT_HSS_TXC_TAP0_COEFF 0x1a20 +#define A_XGMAC_PORT_HSS_TXC_TAP1_COEFF 0x1a24 +#define A_XGMAC_PORT_HSS_TXC_TAP2_COEFF 0x1a28 +#define A_XGMAC_PORT_HSS_TXC_PWR 0x1a30 +#define A_XGMAC_PORT_HSS_TXC_POLARITY 0x1a34 +#define A_XGMAC_PORT_HSS_TXC_8023AP_AE_CMD 0x1a38 +#define A_XGMAC_PORT_HSS_TXC_8023AP_AE_STATUS 0x1a3c +#define A_XGMAC_PORT_HSS_TXC_TAP0_IDAC_OVR 0x1a40 +#define A_XGMAC_PORT_HSS_TXC_TAP1_IDAC_OVR 0x1a44 +#define A_XGMAC_PORT_HSS_TXC_TAP2_IDAC_OVR 0x1a48 +#define A_XGMAC_PORT_HSS_TXC_PWR_DAC_OVR 0x1a50 +#define A_XGMAC_PORT_HSS_TXC_PWR_DAC 0x1a54 +#define A_XGMAC_PORT_HSS_TXC_TAP0_IDAC_APP 0x1a60 +#define A_XGMAC_PORT_HSS_TXC_TAP1_IDAC_APP 0x1a64 +#define A_XGMAC_PORT_HSS_TXC_TAP2_IDAC_APP 0x1a68 +#define A_XGMAC_PORT_HSS_TXC_SEG_DIS_APP 0x1a70 +#define A_XGMAC_PORT_HSS_TXC_EXT_ADDR_DATA 0x1a78 +#define A_XGMAC_PORT_HSS_TXC_EXT_ADDR 0x1a7c +#define A_XGMAC_PORT_HSS_TXD_MODE_CFG 0x1a80 +#define A_XGMAC_PORT_HSS_TXD_TEST_CTRL 0x1a84 +#define A_XGMAC_PORT_HSS_TXD_COEFF_CTRL 0x1a88 +#define A_XGMAC_PORT_HSS_TXD_DRIVER_MODE 0x1a8c +#define A_XGMAC_PORT_HSS_TXD_DRIVER_OVR_CTRL 0x1a90 +#define A_XGMAC_PORT_HSS_TXD_TDM_BIASGEN_STANDBY_TIMER 0x1a94 +#define A_XGMAC_PORT_HSS_TXD_TDM_BIASGEN_PWRON_TIMER 0x1a98 +#define A_XGMAC_PORT_HSS_TXD_TAP0_COEFF 0x1aa0 +#define A_XGMAC_PORT_HSS_TXD_TAP1_COEFF 0x1aa4 +#define A_XGMAC_PORT_HSS_TXD_TAP2_COEFF 0x1aa8 +#define A_XGMAC_PORT_HSS_TXD_PWR 0x1ab0 +#define A_XGMAC_PORT_HSS_TXD_POLARITY 0x1ab4 +#define A_XGMAC_PORT_HSS_TXD_8023AP_AE_CMD 0x1ab8 +#define A_XGMAC_PORT_HSS_TXD_8023AP_AE_STATUS 0x1abc +#define A_XGMAC_PORT_HSS_TXD_TAP0_IDAC_OVR 0x1ac0 +#define A_XGMAC_PORT_HSS_TXD_TAP1_IDAC_OVR 0x1ac4 +#define A_XGMAC_PORT_HSS_TXD_TAP2_IDAC_OVR 0x1ac8 +#define A_XGMAC_PORT_HSS_TXD_PWR_DAC_OVR 0x1ad0 +#define A_XGMAC_PORT_HSS_TXD_PWR_DAC 0x1ad4 +#define A_XGMAC_PORT_HSS_TXD_TAP0_IDAC_APP 0x1ae0 +#define A_XGMAC_PORT_HSS_TXD_TAP1_IDAC_APP 0x1ae4 +#define A_XGMAC_PORT_HSS_TXD_TAP2_IDAC_APP 0x1ae8 +#define A_XGMAC_PORT_HSS_TXD_SEG_DIS_APP 0x1af0 +#define A_XGMAC_PORT_HSS_TXD_EXT_ADDR_DATA 0x1af8 +#define A_XGMAC_PORT_HSS_TXD_EXT_ADDR 0x1afc +#define A_XGMAC_PORT_HSS_RXC_CFG_MODE 0x1b00 +#define A_XGMAC_PORT_HSS_RXC_TEST_CTRL 0x1b04 +#define A_XGMAC_PORT_HSS_RXC_PH_ROTATOR_CTRL 0x1b08 +#define A_XGMAC_PORT_HSS_RXC_PH_ROTATOR_OFFSET_CTRL 0x1b0c +#define A_XGMAC_PORT_HSS_RXC_PH_ROTATOR_POSITION1 0x1b10 +#define A_XGMAC_PORT_HSS_RXC_PH_ROTATOR_POSITION2 0x1b14 +#define A_XGMAC_PORT_HSS_RXC_PH_ROTATOR_STATIC_PH_OFFSET 0x1b18 +#define A_XGMAC_PORT_HSS_RXC_SIGDET_CTRL 0x1b1c +#define A_XGMAC_PORT_HSS_RXC_DFE_CTRL 0x1b20 +#define A_XGMAC_PORT_HSS_RXC_DFE_DATA_EDGE_SAMPLE 0x1b24 +#define A_XGMAC_PORT_HSS_RXC_DFE_AMP_SAMPLE 0x1b28 +#define A_XGMAC_PORT_HSS_RXC_VGA_CTRL1 0x1b2c +#define A_XGMAC_PORT_HSS_RXC_VGA_CTRL2 0x1b30 +#define A_XGMAC_PORT_HSS_RXC_VGA_CTRL3 0x1b34 +#define A_XGMAC_PORT_HSS_RXC_DFE_D00_D01_OFFSET 0x1b38 +#define A_XGMAC_PORT_HSS_RXC_DFE_D10_D11_OFFSET 0x1b3c +#define A_XGMAC_PORT_HSS_RXC_DFE_E0_E1_OFFSET 0x1b40 +#define A_XGMAC_PORT_HSS_RXC_DACA_OFFSET 0x1b44 +#define A_XGMAC_PORT_HSS_RXC_DACAP_DAC_AN_OFFSET 0x1b48 +#define A_XGMAC_PORT_HSS_RXC_DACA_MIN 0x1b4c +#define A_XGMAC_PORT_HSS_RXC_ADAC_CTRL 0x1b50 +#define A_XGMAC_PORT_HSS_RXC_DIGITAL_EYE_CTRL 0x1b54 +#define A_XGMAC_PORT_HSS_RXC_DIGITAL_EYE_METRICS 0x1b58 +#define A_XGMAC_PORT_HSS_RXC_DFE_H1 0x1b5c +#define A_XGMAC_PORT_HSS_RXC_DFE_H2 0x1b60 +#define A_XGMAC_PORT_HSS_RXC_DFE_H3 0x1b64 +#define A_XGMAC_PORT_HSS_RXC_DFE_H4 0x1b68 +#define A_XGMAC_PORT_HSS_RXC_DFE_H5 0x1b6c +#define A_XGMAC_PORT_HSS_RXC_DAC_DPC 0x1b70 +#define A_XGMAC_PORT_HSS_RXC_DDC 0x1b74 +#define A_XGMAC_PORT_HSS_RXC_INTERNAL_STATUS 0x1b78 +#define A_XGMAC_PORT_HSS_RXC_DFE_FUNC_CTRL 0x1b7c +#define A_XGMAC_PORT_HSS_RXD_CFG_MODE 0x1b80 +#define A_XGMAC_PORT_HSS_RXD_TEST_CTRL 0x1b84 +#define A_XGMAC_PORT_HSS_RXD_PH_ROTATOR_CTRL 0x1b88 +#define A_XGMAC_PORT_HSS_RXD_PH_ROTATOR_OFFSET_CTRL 0x1b8c +#define A_XGMAC_PORT_HSS_RXD_PH_ROTATOR_POSITION1 0x1b90 +#define A_XGMAC_PORT_HSS_RXD_PH_ROTATOR_POSITION2 0x1b94 +#define A_XGMAC_PORT_HSS_RXD_PH_ROTATOR_STATIC_PH_OFFSET 0x1b98 +#define A_XGMAC_PORT_HSS_RXD_SIGDET_CTRL 0x1b9c +#define A_XGMAC_PORT_HSS_RXD_DFE_CTRL 0x1ba0 +#define A_XGMAC_PORT_HSS_RXD_DFE_DATA_EDGE_SAMPLE 0x1ba4 +#define A_XGMAC_PORT_HSS_RXD_DFE_AMP_SAMPLE 0x1ba8 +#define A_XGMAC_PORT_HSS_RXD_VGA_CTRL1 0x1bac +#define A_XGMAC_PORT_HSS_RXD_VGA_CTRL2 0x1bb0 +#define A_XGMAC_PORT_HSS_RXD_VGA_CTRL3 0x1bb4 +#define A_XGMAC_PORT_HSS_RXD_DFE_D00_D01_OFFSET 0x1bb8 +#define A_XGMAC_PORT_HSS_RXD_DFE_D10_D11_OFFSET 0x1bbc +#define A_XGMAC_PORT_HSS_RXD_DFE_E0_E1_OFFSET 0x1bc0 +#define A_XGMAC_PORT_HSS_RXD_DACA_OFFSET 0x1bc4 +#define A_XGMAC_PORT_HSS_RXD_DACAP_DAC_AN_OFFSET 0x1bc8 +#define A_XGMAC_PORT_HSS_RXD_DACA_MIN 0x1bcc +#define A_XGMAC_PORT_HSS_RXD_ADAC_CTRL 0x1bd0 +#define A_XGMAC_PORT_HSS_RXD_DIGITAL_EYE_CTRL 0x1bd4 +#define A_XGMAC_PORT_HSS_RXD_DIGITAL_EYE_METRICS 0x1bd8 +#define A_XGMAC_PORT_HSS_RXD_DFE_H1 0x1bdc +#define A_XGMAC_PORT_HSS_RXD_DFE_H2 0x1be0 +#define A_XGMAC_PORT_HSS_RXD_DFE_H3 0x1be4 +#define A_XGMAC_PORT_HSS_RXD_DFE_H4 0x1be8 +#define A_XGMAC_PORT_HSS_RXD_DFE_H5 0x1bec +#define A_XGMAC_PORT_HSS_RXD_DAC_DPC 0x1bf0 +#define A_XGMAC_PORT_HSS_RXD_DDC 0x1bf4 +#define A_XGMAC_PORT_HSS_RXD_INTERNAL_STATUS 0x1bf8 +#define A_XGMAC_PORT_HSS_RXD_DFE_FUNC_CTRL 0x1bfc +#define A_XGMAC_PORT_HSS_VCO_COARSE_CALIBRATION_0 0x1c00 + +#define S_BSELO 0 +#define M_BSELO 0xfU +#define V_BSELO(x) ((x) << S_BSELO) +#define G_BSELO(x) (((x) >> S_BSELO) & M_BSELO) + +#define A_XGMAC_PORT_HSS_VCO_COARSE_CALIBRATION_1 0x1c04 + +#define S_LDET 4 +#define V_LDET(x) ((x) << S_LDET) +#define F_LDET V_LDET(1U) + +#define S_CCERR 3 +#define V_CCERR(x) ((x) << S_CCERR) +#define F_CCERR V_CCERR(1U) + +#define S_CCCMP 2 +#define V_CCCMP(x) ((x) << S_CCCMP) +#define F_CCCMP V_CCCMP(1U) + +#define A_XGMAC_PORT_HSS_VCO_COARSE_CALIBRATION_2 0x1c08 + +#define S_BSELI 0 +#define M_BSELI 0xfU +#define V_BSELI(x) ((x) << S_BSELI) +#define G_BSELI(x) (((x) >> S_BSELI) & M_BSELI) + +#define A_XGMAC_PORT_HSS_VCO_COARSE_CALIBRATION_3 0x1c0c + +#define S_VISEL 4 +#define V_VISEL(x) ((x) << S_VISEL) +#define F_VISEL V_VISEL(1U) + +#define S_FMIN 3 +#define V_FMIN(x) ((x) << S_FMIN) +#define F_FMIN V_FMIN(1U) + +#define S_FMAX 2 +#define V_FMAX(x) ((x) << S_FMAX) +#define F_FMAX V_FMAX(1U) + +#define S_CVHOLD 1 +#define V_CVHOLD(x) ((x) << S_CVHOLD) +#define F_CVHOLD V_CVHOLD(1U) + +#define S_TCDIS 0 +#define V_TCDIS(x) ((x) << S_TCDIS) +#define F_TCDIS V_TCDIS(1U) + +#define A_XGMAC_PORT_HSS_VCO_COARSE_CALIBRATION_4 0x1c10 + +#define S_CMETH 2 +#define V_CMETH(x) ((x) << S_CMETH) +#define F_CMETH V_CMETH(1U) + +#define S_RECAL 1 +#define V_RECAL(x) ((x) << S_RECAL) +#define F_RECAL V_RECAL(1U) + +#define S_CCLD 0 +#define V_CCLD(x) ((x) << S_CCLD) +#define F_CCLD V_CCLD(1U) + +#define A_XGMAC_PORT_HSS_ANALOG_TEST_MUX 0x1c14 + +#define S_ATST 0 +#define M_ATST 0x1fU +#define V_ATST(x) ((x) << S_ATST) +#define G_ATST(x) (((x) >> S_ATST) & M_ATST) + +#define A_XGMAC_PORT_HSS_PORT_EN_0 0x1c18 + +#define S_RXDEN 7 +#define V_RXDEN(x) ((x) << S_RXDEN) +#define F_RXDEN V_RXDEN(1U) + +#define S_RXCEN 6 +#define V_RXCEN(x) ((x) << S_RXCEN) +#define F_RXCEN V_RXCEN(1U) + +#define S_TXDEN 5 +#define V_TXDEN(x) ((x) << S_TXDEN) +#define F_TXDEN V_TXDEN(1U) + +#define S_TXCEN 4 +#define V_TXCEN(x) ((x) << S_TXCEN) +#define F_TXCEN V_TXCEN(1U) + +#define S_RXBEN 3 +#define V_RXBEN(x) ((x) << S_RXBEN) +#define F_RXBEN V_RXBEN(1U) + +#define S_RXAEN 2 +#define V_RXAEN(x) ((x) << S_RXAEN) +#define F_RXAEN V_RXAEN(1U) + +#define S_TXBEN 1 +#define V_TXBEN(x) ((x) << S_TXBEN) +#define F_TXBEN V_TXBEN(1U) + +#define S_TXAEN 0 +#define V_TXAEN(x) ((x) << S_TXAEN) +#define F_TXAEN V_TXAEN(1U) + +#define A_XGMAC_PORT_HSS_PORT_RESET_0 0x1c20 + +#define S_RXDRST 7 +#define V_RXDRST(x) ((x) << S_RXDRST) +#define F_RXDRST V_RXDRST(1U) + +#define S_RXCRST 6 +#define V_RXCRST(x) ((x) << S_RXCRST) +#define F_RXCRST V_RXCRST(1U) + +#define S_TXDRST 5 +#define V_TXDRST(x) ((x) << S_TXDRST) +#define F_TXDRST V_TXDRST(1U) + +#define S_TXCRST 4 +#define V_TXCRST(x) ((x) << S_TXCRST) +#define F_TXCRST V_TXCRST(1U) + +#define S_RXBRST 3 +#define V_RXBRST(x) ((x) << S_RXBRST) +#define F_RXBRST V_RXBRST(1U) + +#define S_RXARST 2 +#define V_RXARST(x) ((x) << S_RXARST) +#define F_RXARST V_RXARST(1U) + +#define S_TXBRST 1 +#define V_TXBRST(x) ((x) << S_TXBRST) +#define F_TXBRST V_TXBRST(1U) + +#define S_TXARST 0 +#define V_TXARST(x) ((x) << S_TXARST) +#define F_TXARST V_TXARST(1U) + +#define A_XGMAC_PORT_HSS_CHARGE_PUMP_CTRL 0x1c28 + +#define S_ENCPIS 2 +#define V_ENCPIS(x) ((x) << S_ENCPIS) +#define F_ENCPIS V_ENCPIS(1U) + +#define S_CPISEL 0 +#define M_CPISEL 0x3U +#define V_CPISEL(x) ((x) << S_CPISEL) +#define G_CPISEL(x) (((x) >> S_CPISEL) & M_CPISEL) + +#define A_XGMAC_PORT_HSS_BAND_GAP_CTRL 0x1c2c + +#define S_BGCTL 0 +#define M_BGCTL 0x1fU +#define V_BGCTL(x) ((x) << S_BGCTL) +#define G_BGCTL(x) (((x) >> S_BGCTL) & M_BGCTL) + +#define A_XGMAC_PORT_HSS_LOFREQ_OVR 0x1c30 + +#define S_LFREQ2 3 +#define V_LFREQ2(x) ((x) << S_LFREQ2) +#define F_LFREQ2 V_LFREQ2(1U) + +#define S_LFREQ1 2 +#define V_LFREQ1(x) ((x) << S_LFREQ1) +#define F_LFREQ1 V_LFREQ1(1U) + +#define S_LFREQO 1 +#define V_LFREQO(x) ((x) << S_LFREQO) +#define F_LFREQO V_LFREQO(1U) + +#define S_LFSEL 0 +#define V_LFSEL(x) ((x) << S_LFSEL) +#define F_LFSEL V_LFSEL(1U) + +#define A_XGMAC_PORT_HSS_VOLTAGE_BOOST_CTRL 0x1c38 + +#define S_PFVAL 2 +#define V_PFVAL(x) ((x) << S_PFVAL) +#define F_PFVAL V_PFVAL(1U) + +#define S_PFEN 1 +#define V_PFEN(x) ((x) << S_PFEN) +#define F_PFEN V_PFEN(1U) + +#define S_VBADJ 0 +#define V_VBADJ(x) ((x) << S_VBADJ) +#define F_VBADJ V_VBADJ(1U) + +#define A_XGMAC_PORT_HSS_TX_MODE_CFG 0x1c80 +#define A_XGMAC_PORT_HSS_TXTEST_CTRL 0x1c84 +#define A_XGMAC_PORT_HSS_TX_COEFF_CTRL 0x1c88 +#define A_XGMAC_PORT_HSS_TX_DRIVER_MODE 0x1c8c +#define A_XGMAC_PORT_HSS_TX_DRIVER_OVR_CTRL 0x1c90 +#define A_XGMAC_PORT_HSS_TX_TDM_BIASGEN_STANDBY_TIMER 0x1c94 +#define A_XGMAC_PORT_HSS_TX_TDM_BIASGEN_PWRON_TIMER 0x1c98 +#define A_XGMAC_PORT_HSS_TX_TAP0_COEFF 0x1ca0 +#define A_XGMAC_PORT_HSS_TX_TAP1_COEFF 0x1ca4 +#define A_XGMAC_PORT_HSS_TX_TAP2_COEFF 0x1ca8 +#define A_XGMAC_PORT_HSS_TX_PWR 0x1cb0 +#define A_XGMAC_PORT_HSS_TX_POLARITY 0x1cb4 +#define A_XGMAC_PORT_HSS_TX_8023AP_AE_CMD 0x1cb8 +#define A_XGMAC_PORT_HSS_TX_8023AP_AE_STATUS 0x1cbc +#define A_XGMAC_PORT_HSS_TX_TAP0_IDAC_OVR 0x1cc0 +#define A_XGMAC_PORT_HSS_TX_TAP1_IDAC_OVR 0x1cc4 +#define A_XGMAC_PORT_HSS_TX_TAP2_IDAC_OVR 0x1cc8 +#define A_XGMAC_PORT_HSS_TX_PWR_DAC_OVR 0x1cd0 +#define A_XGMAC_PORT_HSS_TX_PWR_DAC 0x1cd4 +#define A_XGMAC_PORT_HSS_TX_TAP0_IDAC_APP 0x1ce0 +#define A_XGMAC_PORT_HSS_TX_TAP1_IDAC_APP 0x1ce4 +#define A_XGMAC_PORT_HSS_TX_TAP2_IDAC_APP 0x1ce8 +#define A_XGMAC_PORT_HSS_TX_SEG_DIS_APP 0x1cf0 +#define A_XGMAC_PORT_HSS_TX_EXT_ADDR_DATA 0x1cf8 +#define A_XGMAC_PORT_HSS_TX_EXT_ADDR 0x1cfc +#define A_XGMAC_PORT_HSS_RX_CFG_MODE 0x1d00 +#define A_XGMAC_PORT_HSS_RXTEST_CTRL 0x1d04 +#define A_XGMAC_PORT_HSS_RX_PH_ROTATOR_CTRL 0x1d08 +#define A_XGMAC_PORT_HSS_RX_PH_ROTATOR_OFFSET_CTRL 0x1d0c +#define A_XGMAC_PORT_HSS_RX_PH_ROTATOR_POSITION1 0x1d10 +#define A_XGMAC_PORT_HSS_RX_PH_ROTATOR_POSITION2 0x1d14 +#define A_XGMAC_PORT_HSS_RX_PH_ROTATOR_STATIC_PH_OFFSET 0x1d18 +#define A_XGMAC_PORT_HSS_RX_SIGDET_CTRL 0x1d1c +#define A_XGMAC_PORT_HSS_RX_DFE_CTRL 0x1d20 +#define A_XGMAC_PORT_HSS_RX_DFE_DATA_EDGE_SAMPLE 0x1d24 +#define A_XGMAC_PORT_HSS_RX_DFE_AMP_SAMPLE 0x1d28 +#define A_XGMAC_PORT_HSS_RX_VGA_CTRL1 0x1d2c +#define A_XGMAC_PORT_HSS_RX_VGA_CTRL2 0x1d30 +#define A_XGMAC_PORT_HSS_RX_VGA_CTRL3 0x1d34 +#define A_XGMAC_PORT_HSS_RX_DFE_D00_D01_OFFSET 0x1d38 +#define A_XGMAC_PORT_HSS_RX_DFE_D10_D11_OFFSET 0x1d3c +#define A_XGMAC_PORT_HSS_RX_DFE_E0_E1_OFFSET 0x1d40 +#define A_XGMAC_PORT_HSS_RX_DACA_OFFSET 0x1d44 +#define A_XGMAC_PORT_HSS_RX_DACAP_DAC_AN_OFFSET 0x1d48 +#define A_XGMAC_PORT_HSS_RX_DACA_MIN 0x1d4c +#define A_XGMAC_PORT_HSS_RX_ADAC_CTRL 0x1d50 +#define A_XGMAC_PORT_HSS_RX_DIGITAL_EYE_CTRL 0x1d54 +#define A_XGMAC_PORT_HSS_RX_DIGITAL_EYE_METRICS 0x1d58 +#define A_XGMAC_PORT_HSS_RX_DFE_H1 0x1d5c +#define A_XGMAC_PORT_HSS_RX_DFE_H2 0x1d60 +#define A_XGMAC_PORT_HSS_RX_DFE_H3 0x1d64 +#define A_XGMAC_PORT_HSS_RX_DFE_H4 0x1d68 +#define A_XGMAC_PORT_HSS_RX_DFE_H5 0x1d6c +#define A_XGMAC_PORT_HSS_RX_DAC_DPC 0x1d70 +#define A_XGMAC_PORT_HSS_RX_DDC 0x1d74 +#define A_XGMAC_PORT_HSS_RX_INTERNAL_STATUS 0x1d78 +#define A_XGMAC_PORT_HSS_RX_DFE_FUNC_CTRL 0x1d7c +#define A_XGMAC_PORT_HSS_TXRX_CFG_MODE 0x1e00 +#define A_XGMAC_PORT_HSS_TXRXTEST_CTRL 0x1e04 + +/* registers for module UP */ +#define UP_BASE_ADDR 0x0 + +#define A_UP_IBQ_CONFIG 0x0 + +#define S_IBQGEN2 2 +#define M_IBQGEN2 0x3fffffffU +#define V_IBQGEN2(x) ((x) << S_IBQGEN2) +#define G_IBQGEN2(x) (((x) >> S_IBQGEN2) & M_IBQGEN2) + +#define S_IBQBUSY 1 +#define V_IBQBUSY(x) ((x) << S_IBQBUSY) +#define F_IBQBUSY V_IBQBUSY(1U) + +#define S_IBQEN 0 +#define V_IBQEN(x) ((x) << S_IBQEN) +#define F_IBQEN V_IBQEN(1U) + +#define A_UP_OBQ_CONFIG 0x4 + +#define S_OBQGEN2 2 +#define M_OBQGEN2 0x3fffffffU +#define V_OBQGEN2(x) ((x) << S_OBQGEN2) +#define G_OBQGEN2(x) (((x) >> S_OBQGEN2) & M_OBQGEN2) + +#define S_OBQBUSY 1 +#define V_OBQBUSY(x) ((x) << S_OBQBUSY) +#define F_OBQBUSY V_OBQBUSY(1U) + +#define S_OBQEN 0 +#define V_OBQEN(x) ((x) << S_OBQEN) +#define F_OBQEN V_OBQEN(1U) + +#define A_UP_IBQ_GEN 0x8 + +#define S_IBQGEN0 22 +#define M_IBQGEN0 0x3ffU +#define V_IBQGEN0(x) ((x) << S_IBQGEN0) +#define G_IBQGEN0(x) (((x) >> S_IBQGEN0) & M_IBQGEN0) + +#define S_IBQTSCHCHNLRDY 18 +#define M_IBQTSCHCHNLRDY 0xfU +#define V_IBQTSCHCHNLRDY(x) ((x) << S_IBQTSCHCHNLRDY) +#define G_IBQTSCHCHNLRDY(x) (((x) >> S_IBQTSCHCHNLRDY) & M_IBQTSCHCHNLRDY) + +#define S_IBQMBVFSTATUS 17 +#define V_IBQMBVFSTATUS(x) ((x) << S_IBQMBVFSTATUS) +#define F_IBQMBVFSTATUS V_IBQMBVFSTATUS(1U) + +#define S_IBQMBSTATUS 16 +#define V_IBQMBSTATUS(x) ((x) << S_IBQMBSTATUS) +#define F_IBQMBSTATUS V_IBQMBSTATUS(1U) + +#define S_IBQGEN1 6 +#define M_IBQGEN1 0x3ffU +#define V_IBQGEN1(x) ((x) << S_IBQGEN1) +#define G_IBQGEN1(x) (((x) >> S_IBQGEN1) & M_IBQGEN1) + +#define S_IBQEMPTY 0 +#define M_IBQEMPTY 0x3fU +#define V_IBQEMPTY(x) ((x) << S_IBQEMPTY) +#define G_IBQEMPTY(x) (((x) >> S_IBQEMPTY) & M_IBQEMPTY) + +#define A_UP_OBQ_GEN 0xc + +#define S_OBQGEN 6 +#define M_OBQGEN 0x3ffffffU +#define V_OBQGEN(x) ((x) << S_OBQGEN) +#define G_OBQGEN(x) (((x) >> S_OBQGEN) & M_OBQGEN) + +#define S_OBQFULL 0 +#define M_OBQFULL 0x3fU +#define V_OBQFULL(x) ((x) << S_OBQFULL) +#define G_OBQFULL(x) (((x) >> S_OBQFULL) & M_OBQFULL) + +#define S_T5_OBQGEN 8 +#define M_T5_OBQGEN 0xffffffU +#define V_T5_OBQGEN(x) ((x) << S_T5_OBQGEN) +#define G_T5_OBQGEN(x) (((x) >> S_T5_OBQGEN) & M_T5_OBQGEN) + +#define S_T5_OBQFULL 0 +#define M_T5_OBQFULL 0xffU +#define V_T5_OBQFULL(x) ((x) << S_T5_OBQFULL) +#define G_T5_OBQFULL(x) (((x) >> S_T5_OBQFULL) & M_T5_OBQFULL) + +#define A_UP_IBQ_0_RDADDR 0x10 + +#define S_QUEID 13 +#define M_QUEID 0x7ffffU +#define V_QUEID(x) ((x) << S_QUEID) +#define G_QUEID(x) (((x) >> S_QUEID) & M_QUEID) + +#define S_IBQRDADDR 0 +#define M_IBQRDADDR 0x1fffU +#define V_IBQRDADDR(x) ((x) << S_IBQRDADDR) +#define G_IBQRDADDR(x) (((x) >> S_IBQRDADDR) & M_IBQRDADDR) + +#define A_UP_IBQ_0_WRADDR 0x14 + +#define S_IBQWRADDR 0 +#define M_IBQWRADDR 0x1fffU +#define V_IBQWRADDR(x) ((x) << S_IBQWRADDR) +#define G_IBQWRADDR(x) (((x) >> S_IBQWRADDR) & M_IBQWRADDR) + +#define A_UP_IBQ_0_STATUS 0x18 + +#define S_QUEERRFRAME 31 +#define V_QUEERRFRAME(x) ((x) << S_QUEERRFRAME) +#define F_QUEERRFRAME V_QUEERRFRAME(1U) + +#define S_QUEREMFLITS 0 +#define M_QUEREMFLITS 0x7ffU +#define V_QUEREMFLITS(x) ((x) << S_QUEREMFLITS) +#define G_QUEREMFLITS(x) (((x) >> S_QUEREMFLITS) & M_QUEREMFLITS) + +#define A_UP_IBQ_0_PKTCNT 0x1c + +#define S_QUEEOPCNT 16 +#define M_QUEEOPCNT 0xfffU +#define V_QUEEOPCNT(x) ((x) << S_QUEEOPCNT) +#define G_QUEEOPCNT(x) (((x) >> S_QUEEOPCNT) & M_QUEEOPCNT) + +#define S_QUESOPCNT 0 +#define M_QUESOPCNT 0xfffU +#define V_QUESOPCNT(x) ((x) << S_QUESOPCNT) +#define G_QUESOPCNT(x) (((x) >> S_QUESOPCNT) & M_QUESOPCNT) + +#define A_UP_IBQ_1_RDADDR 0x20 +#define A_UP_IBQ_1_WRADDR 0x24 +#define A_UP_IBQ_1_STATUS 0x28 +#define A_UP_IBQ_1_PKTCNT 0x2c +#define A_UP_IBQ_2_RDADDR 0x30 +#define A_UP_IBQ_2_WRADDR 0x34 +#define A_UP_IBQ_2_STATUS 0x38 +#define A_UP_IBQ_2_PKTCNT 0x3c +#define A_UP_IBQ_3_RDADDR 0x40 +#define A_UP_IBQ_3_WRADDR 0x44 +#define A_UP_IBQ_3_STATUS 0x48 +#define A_UP_IBQ_3_PKTCNT 0x4c +#define A_UP_IBQ_4_RDADDR 0x50 +#define A_UP_IBQ_4_WRADDR 0x54 +#define A_UP_IBQ_4_STATUS 0x58 +#define A_UP_IBQ_4_PKTCNT 0x5c +#define A_UP_IBQ_5_RDADDR 0x60 +#define A_UP_IBQ_5_WRADDR 0x64 +#define A_UP_IBQ_5_STATUS 0x68 +#define A_UP_IBQ_5_PKTCNT 0x6c +#define A_UP_OBQ_0_RDADDR 0x70 + +#define S_OBQID 15 +#define M_OBQID 0x1ffffU +#define V_OBQID(x) ((x) << S_OBQID) +#define G_OBQID(x) (((x) >> S_OBQID) & M_OBQID) + +#define S_QUERDADDR 0 +#define M_QUERDADDR 0x7fffU +#define V_QUERDADDR(x) ((x) << S_QUERDADDR) +#define G_QUERDADDR(x) (((x) >> S_QUERDADDR) & M_QUERDADDR) + +#define A_UP_OBQ_0_WRADDR 0x74 + +#define S_QUEWRADDR 0 +#define M_QUEWRADDR 0x7fffU +#define V_QUEWRADDR(x) ((x) << S_QUEWRADDR) +#define G_QUEWRADDR(x) (((x) >> S_QUEWRADDR) & M_QUEWRADDR) + +#define A_UP_OBQ_0_STATUS 0x78 +#define A_UP_OBQ_0_PKTCNT 0x7c +#define A_UP_OBQ_1_RDADDR 0x80 +#define A_UP_OBQ_1_WRADDR 0x84 +#define A_UP_OBQ_1_STATUS 0x88 +#define A_UP_OBQ_1_PKTCNT 0x8c +#define A_UP_OBQ_2_RDADDR 0x90 +#define A_UP_OBQ_2_WRADDR 0x94 +#define A_UP_OBQ_2_STATUS 0x98 +#define A_UP_OBQ_2_PKTCNT 0x9c +#define A_UP_OBQ_3_RDADDR 0xa0 +#define A_UP_OBQ_3_WRADDR 0xa4 +#define A_UP_OBQ_3_STATUS 0xa8 +#define A_UP_OBQ_3_PKTCNT 0xac +#define A_UP_OBQ_4_RDADDR 0xb0 +#define A_UP_OBQ_4_WRADDR 0xb4 +#define A_UP_OBQ_4_STATUS 0xb8 +#define A_UP_OBQ_4_PKTCNT 0xbc +#define A_UP_OBQ_5_RDADDR 0xc0 +#define A_UP_OBQ_5_WRADDR 0xc4 +#define A_UP_OBQ_5_STATUS 0xc8 +#define A_UP_OBQ_5_PKTCNT 0xcc +#define A_UP_IBQ_0_CONFIG 0xd0 + +#define S_QUESIZE 26 +#define M_QUESIZE 0x3fU +#define V_QUESIZE(x) ((x) << S_QUESIZE) +#define G_QUESIZE(x) (((x) >> S_QUESIZE) & M_QUESIZE) + +#define S_QUEBASE 8 +#define M_QUEBASE 0x3fU +#define V_QUEBASE(x) ((x) << S_QUEBASE) +#define G_QUEBASE(x) (((x) >> S_QUEBASE) & M_QUEBASE) + +#define S_QUEDBG8BEN 7 +#define V_QUEDBG8BEN(x) ((x) << S_QUEDBG8BEN) +#define F_QUEDBG8BEN V_QUEDBG8BEN(1U) + +#define S_QUEBAREADDR 0 +#define V_QUEBAREADDR(x) ((x) << S_QUEBAREADDR) +#define F_QUEBAREADDR V_QUEBAREADDR(1U) + +#define A_UP_IBQ_0_REALADDR 0xd4 + +#define S_QUERDADDRWRAP 31 +#define V_QUERDADDRWRAP(x) ((x) << S_QUERDADDRWRAP) +#define F_QUERDADDRWRAP V_QUERDADDRWRAP(1U) + +#define S_QUEWRADDRWRAP 30 +#define V_QUEWRADDRWRAP(x) ((x) << S_QUEWRADDRWRAP) +#define F_QUEWRADDRWRAP V_QUEWRADDRWRAP(1U) + +#define S_QUEMEMADDR 3 +#define M_QUEMEMADDR 0x7ffU +#define V_QUEMEMADDR(x) ((x) << S_QUEMEMADDR) +#define G_QUEMEMADDR(x) (((x) >> S_QUEMEMADDR) & M_QUEMEMADDR) + +#define A_UP_IBQ_1_CONFIG 0xd8 +#define A_UP_IBQ_1_REALADDR 0xdc +#define A_UP_IBQ_2_CONFIG 0xe0 +#define A_UP_IBQ_2_REALADDR 0xe4 +#define A_UP_IBQ_3_CONFIG 0xe8 +#define A_UP_IBQ_3_REALADDR 0xec +#define A_UP_IBQ_4_CONFIG 0xf0 +#define A_UP_IBQ_4_REALADDR 0xf4 +#define A_UP_IBQ_5_CONFIG 0xf8 +#define A_UP_IBQ_5_REALADDR 0xfc +#define A_UP_OBQ_0_CONFIG 0x100 +#define A_UP_OBQ_0_REALADDR 0x104 +#define A_UP_OBQ_1_CONFIG 0x108 +#define A_UP_OBQ_1_REALADDR 0x10c +#define A_UP_OBQ_2_CONFIG 0x110 +#define A_UP_OBQ_2_REALADDR 0x114 +#define A_UP_OBQ_3_CONFIG 0x118 +#define A_UP_OBQ_3_REALADDR 0x11c +#define A_UP_OBQ_4_CONFIG 0x120 +#define A_UP_OBQ_4_REALADDR 0x124 +#define A_UP_OBQ_5_CONFIG 0x128 +#define A_UP_OBQ_5_REALADDR 0x12c +#define A_UP_MAILBOX_STATUS 0x130 + +#define S_MBGEN0 20 +#define M_MBGEN0 0xfffU +#define V_MBGEN0(x) ((x) << S_MBGEN0) +#define G_MBGEN0(x) (((x) >> S_MBGEN0) & M_MBGEN0) + +#define S_GENTIMERTRIGGER 16 +#define M_GENTIMERTRIGGER 0xfU +#define V_GENTIMERTRIGGER(x) ((x) << S_GENTIMERTRIGGER) +#define G_GENTIMERTRIGGER(x) (((x) >> S_GENTIMERTRIGGER) & M_GENTIMERTRIGGER) + +#define S_MBGEN1 8 +#define M_MBGEN1 0xffU +#define V_MBGEN1(x) ((x) << S_MBGEN1) +#define G_MBGEN1(x) (((x) >> S_MBGEN1) & M_MBGEN1) + +#define S_MBPFINT 0 +#define M_MBPFINT 0xffU +#define V_MBPFINT(x) ((x) << S_MBPFINT) +#define G_MBPFINT(x) (((x) >> S_MBPFINT) & M_MBPFINT) + +#define A_UP_UP_DBG_LA_CFG 0x140 + +#define S_UPDBGLACAPTBUB 31 +#define V_UPDBGLACAPTBUB(x) ((x) << S_UPDBGLACAPTBUB) +#define F_UPDBGLACAPTBUB V_UPDBGLACAPTBUB(1U) + +#define S_UPDBGLACAPTPCONLY 30 +#define V_UPDBGLACAPTPCONLY(x) ((x) << S_UPDBGLACAPTPCONLY) +#define F_UPDBGLACAPTPCONLY V_UPDBGLACAPTPCONLY(1U) + +#define S_UPDBGLAMASKSTOP 29 +#define V_UPDBGLAMASKSTOP(x) ((x) << S_UPDBGLAMASKSTOP) +#define F_UPDBGLAMASKSTOP V_UPDBGLAMASKSTOP(1U) + +#define S_UPDBGLAMASKTRIG 28 +#define V_UPDBGLAMASKTRIG(x) ((x) << S_UPDBGLAMASKTRIG) +#define F_UPDBGLAMASKTRIG V_UPDBGLAMASKTRIG(1U) + +#define S_UPDBGLAWRPTR 16 +#define M_UPDBGLAWRPTR 0xfffU +#define V_UPDBGLAWRPTR(x) ((x) << S_UPDBGLAWRPTR) +#define G_UPDBGLAWRPTR(x) (((x) >> S_UPDBGLAWRPTR) & M_UPDBGLAWRPTR) + +#define S_UPDBGLARDPTR 2 +#define M_UPDBGLARDPTR 0xfffU +#define V_UPDBGLARDPTR(x) ((x) << S_UPDBGLARDPTR) +#define G_UPDBGLARDPTR(x) (((x) >> S_UPDBGLARDPTR) & M_UPDBGLARDPTR) + +#define S_UPDBGLARDEN 1 +#define V_UPDBGLARDEN(x) ((x) << S_UPDBGLARDEN) +#define F_UPDBGLARDEN V_UPDBGLARDEN(1U) + +#define S_UPDBGLAEN 0 +#define V_UPDBGLAEN(x) ((x) << S_UPDBGLAEN) +#define F_UPDBGLAEN V_UPDBGLAEN(1U) + +#define S_UPDBGLABUSY 14 +#define V_UPDBGLABUSY(x) ((x) << S_UPDBGLABUSY) +#define F_UPDBGLABUSY V_UPDBGLABUSY(1U) + +#define A_UP_UP_DBG_LA_DATA 0x144 +#define A_UP_PIO_MST_CONFIG 0x148 + +#define S_FLSRC 24 +#define M_FLSRC 0x7U +#define V_FLSRC(x) ((x) << S_FLSRC) +#define G_FLSRC(x) (((x) >> S_FLSRC) & M_FLSRC) + +#define S_SEPROT 23 +#define V_SEPROT(x) ((x) << S_SEPROT) +#define F_SEPROT V_SEPROT(1U) + +#define S_SESRC 20 +#define M_SESRC 0x7U +#define V_SESRC(x) ((x) << S_SESRC) +#define G_SESRC(x) (((x) >> S_SESRC) & M_SESRC) + +#define S_UPRGN 19 +#define V_UPRGN(x) ((x) << S_UPRGN) +#define F_UPRGN V_UPRGN(1U) + +#define S_UPPF 16 +#define M_UPPF 0x7U +#define V_UPPF(x) ((x) << S_UPPF) +#define G_UPPF(x) (((x) >> S_UPPF) & M_UPPF) + +#define S_UPRID 0 +#define M_UPRID 0xffffU +#define V_UPRID(x) ((x) << S_UPRID) +#define G_UPRID(x) (((x) >> S_UPRID) & M_UPRID) + +#define S_REQVFVLD 27 +#define V_REQVFVLD(x) ((x) << S_REQVFVLD) +#define F_REQVFVLD V_REQVFVLD(1U) + +#define S_T5_UPRID 0 +#define M_T5_UPRID 0xffU +#define V_T5_UPRID(x) ((x) << S_T5_UPRID) +#define G_T5_UPRID(x) (((x) >> S_T5_UPRID) & M_T5_UPRID) + +#define A_UP_UP_SELF_CONTROL 0x14c + +#define S_UPSELFRESET 0 +#define V_UPSELFRESET(x) ((x) << S_UPSELFRESET) +#define F_UPSELFRESET V_UPSELFRESET(1U) + +#define A_UP_MAILBOX_PF0_CTL 0x180 +#define A_UP_MAILBOX_PF1_CTL 0x190 +#define A_UP_MAILBOX_PF2_CTL 0x1a0 +#define A_UP_MAILBOX_PF3_CTL 0x1b0 +#define A_UP_MAILBOX_PF4_CTL 0x1c0 +#define A_UP_MAILBOX_PF5_CTL 0x1d0 +#define A_UP_MAILBOX_PF6_CTL 0x1e0 +#define A_UP_MAILBOX_PF7_CTL 0x1f0 +#define A_UP_TSCH_CHNLN_CLASS_RDY 0x200 + +#define S_ECO_15444_SGE_DB_BUSY 31 +#define V_ECO_15444_SGE_DB_BUSY(x) ((x) << S_ECO_15444_SGE_DB_BUSY) +#define F_ECO_15444_SGE_DB_BUSY V_ECO_15444_SGE_DB_BUSY(1U) + +#define S_ECO_15444_PL_INTF_BUSY 30 +#define V_ECO_15444_PL_INTF_BUSY(x) ((x) << S_ECO_15444_PL_INTF_BUSY) +#define F_ECO_15444_PL_INTF_BUSY V_ECO_15444_PL_INTF_BUSY(1U) + +#define S_TSCHCHNLCRDY 0 +#define M_TSCHCHNLCRDY 0x3fffffffU +#define V_TSCHCHNLCRDY(x) ((x) << S_TSCHCHNLCRDY) +#define G_TSCHCHNLCRDY(x) (((x) >> S_TSCHCHNLCRDY) & M_TSCHCHNLCRDY) + +#define A_UP_TSCH_CHNLN_CLASS_WATCH_RDY 0x204 + +#define S_TSCHWRRLIMIT 16 +#define M_TSCHWRRLIMIT 0xffffU +#define V_TSCHWRRLIMIT(x) ((x) << S_TSCHWRRLIMIT) +#define G_TSCHWRRLIMIT(x) (((x) >> S_TSCHWRRLIMIT) & M_TSCHWRRLIMIT) + +#define S_TSCHCHNLCWRDY 0 +#define M_TSCHCHNLCWRDY 0xffffU +#define V_TSCHCHNLCWRDY(x) ((x) << S_TSCHCHNLCWRDY) +#define G_TSCHCHNLCWRDY(x) (((x) >> S_TSCHCHNLCWRDY) & M_TSCHCHNLCWRDY) + +#define A_UP_TSCH_CHNLN_CLASS_WATCH_LIST 0x208 + +#define S_TSCHWRRRELOAD 16 +#define M_TSCHWRRRELOAD 0xffffU +#define V_TSCHWRRRELOAD(x) ((x) << S_TSCHWRRRELOAD) +#define G_TSCHWRRRELOAD(x) (((x) >> S_TSCHWRRRELOAD) & M_TSCHWRRRELOAD) + +#define S_TSCHCHNLCWATCH 0 +#define M_TSCHCHNLCWATCH 0xffffU +#define V_TSCHCHNLCWATCH(x) ((x) << S_TSCHCHNLCWATCH) +#define G_TSCHCHNLCWATCH(x) (((x) >> S_TSCHCHNLCWATCH) & M_TSCHCHNLCWATCH) + +#define A_UP_TSCH_CHNLN_CLASS_TAKE 0x20c + +#define S_TSCHCHNLCNUM 24 +#define M_TSCHCHNLCNUM 0x1fU +#define V_TSCHCHNLCNUM(x) ((x) << S_TSCHCHNLCNUM) +#define G_TSCHCHNLCNUM(x) (((x) >> S_TSCHCHNLCNUM) & M_TSCHCHNLCNUM) + +#define S_TSCHCHNLCCNT 0 +#define M_TSCHCHNLCCNT 0xffffffU +#define V_TSCHCHNLCCNT(x) ((x) << S_TSCHCHNLCCNT) +#define G_TSCHCHNLCCNT(x) (((x) >> S_TSCHCHNLCCNT) & M_TSCHCHNLCCNT) + +#define A_UP_UPLADBGPCCHKDATA_0 0x240 +#define A_UP_UPLADBGPCCHKMASK_0 0x244 +#define A_UP_UPLADBGPCCHKDATA_1 0x250 +#define A_UP_UPLADBGPCCHKMASK_1 0x254 +#define A_UP_UPLADBGPCCHKDATA_2 0x260 +#define A_UP_UPLADBGPCCHKMASK_2 0x264 +#define A_UP_UPLADBGPCCHKDATA_3 0x270 +#define A_UP_UPLADBGPCCHKMASK_3 0x274 +#define A_UP_IBQ_0_SHADOW_RDADDR 0x280 +#define A_UP_IBQ_0_SHADOW_WRADDR 0x284 +#define A_UP_IBQ_0_SHADOW_STATUS 0x288 +#define A_UP_IBQ_0_SHADOW_PKTCNT 0x28c +#define A_UP_IBQ_1_SHADOW_RDADDR 0x290 +#define A_UP_IBQ_1_SHADOW_WRADDR 0x294 +#define A_UP_IBQ_1_SHADOW_STATUS 0x298 +#define A_UP_IBQ_1_SHADOW_PKTCNT 0x29c +#define A_UP_IBQ_2_SHADOW_RDADDR 0x2a0 +#define A_UP_IBQ_2_SHADOW_WRADDR 0x2a4 +#define A_UP_IBQ_2_SHADOW_STATUS 0x2a8 +#define A_UP_IBQ_2_SHADOW_PKTCNT 0x2ac +#define A_UP_IBQ_3_SHADOW_RDADDR 0x2b0 +#define A_UP_IBQ_3_SHADOW_WRADDR 0x2b4 +#define A_UP_IBQ_3_SHADOW_STATUS 0x2b8 +#define A_UP_IBQ_3_SHADOW_PKTCNT 0x2bc +#define A_UP_IBQ_4_SHADOW_RDADDR 0x2c0 +#define A_UP_IBQ_4_SHADOW_WRADDR 0x2c4 +#define A_UP_IBQ_4_SHADOW_STATUS 0x2c8 +#define A_UP_IBQ_4_SHADOW_PKTCNT 0x2cc +#define A_UP_IBQ_5_SHADOW_RDADDR 0x2d0 +#define A_UP_IBQ_5_SHADOW_WRADDR 0x2d4 +#define A_UP_IBQ_5_SHADOW_STATUS 0x2d8 +#define A_UP_IBQ_5_SHADOW_PKTCNT 0x2dc +#define A_UP_OBQ_0_SHADOW_RDADDR 0x2e0 +#define A_UP_OBQ_0_SHADOW_WRADDR 0x2e4 +#define A_UP_OBQ_0_SHADOW_STATUS 0x2e8 +#define A_UP_OBQ_0_SHADOW_PKTCNT 0x2ec +#define A_UP_OBQ_1_SHADOW_RDADDR 0x2f0 +#define A_UP_OBQ_1_SHADOW_WRADDR 0x2f4 +#define A_UP_OBQ_1_SHADOW_STATUS 0x2f8 +#define A_UP_OBQ_1_SHADOW_PKTCNT 0x2fc +#define A_UP_OBQ_2_SHADOW_RDADDR 0x300 +#define A_UP_OBQ_2_SHADOW_WRADDR 0x304 +#define A_UP_OBQ_2_SHADOW_STATUS 0x308 +#define A_UP_OBQ_2_SHADOW_PKTCNT 0x30c +#define A_UP_OBQ_3_SHADOW_RDADDR 0x310 +#define A_UP_OBQ_3_SHADOW_WRADDR 0x314 +#define A_UP_OBQ_3_SHADOW_STATUS 0x318 +#define A_UP_OBQ_3_SHADOW_PKTCNT 0x31c +#define A_UP_OBQ_4_SHADOW_RDADDR 0x320 +#define A_UP_OBQ_4_SHADOW_WRADDR 0x324 +#define A_UP_OBQ_4_SHADOW_STATUS 0x328 +#define A_UP_OBQ_4_SHADOW_PKTCNT 0x32c +#define A_UP_OBQ_5_SHADOW_RDADDR 0x330 +#define A_UP_OBQ_5_SHADOW_WRADDR 0x334 +#define A_UP_OBQ_5_SHADOW_STATUS 0x338 +#define A_UP_OBQ_5_SHADOW_PKTCNT 0x33c +#define A_UP_OBQ_6_SHADOW_RDADDR 0x340 +#define A_UP_OBQ_6_SHADOW_WRADDR 0x344 +#define A_UP_OBQ_6_SHADOW_STATUS 0x348 +#define A_UP_OBQ_6_SHADOW_PKTCNT 0x34c +#define A_UP_OBQ_7_SHADOW_RDADDR 0x350 +#define A_UP_OBQ_7_SHADOW_WRADDR 0x354 +#define A_UP_OBQ_7_SHADOW_STATUS 0x358 +#define A_UP_OBQ_7_SHADOW_PKTCNT 0x35c +#define A_UP_IBQ_0_SHADOW_CONFIG 0x360 +#define A_UP_IBQ_0_SHADOW_REALADDR 0x364 +#define A_UP_IBQ_1_SHADOW_CONFIG 0x368 +#define A_UP_IBQ_1_SHADOW_REALADDR 0x36c +#define A_UP_IBQ_2_SHADOW_CONFIG 0x370 +#define A_UP_IBQ_2_SHADOW_REALADDR 0x374 +#define A_UP_IBQ_3_SHADOW_CONFIG 0x378 +#define A_UP_IBQ_3_SHADOW_REALADDR 0x37c +#define A_UP_IBQ_4_SHADOW_CONFIG 0x380 +#define A_UP_IBQ_4_SHADOW_REALADDR 0x384 +#define A_UP_IBQ_5_SHADOW_CONFIG 0x388 +#define A_UP_IBQ_5_SHADOW_REALADDR 0x38c +#define A_UP_OBQ_0_SHADOW_CONFIG 0x390 +#define A_UP_OBQ_0_SHADOW_REALADDR 0x394 +#define A_UP_OBQ_1_SHADOW_CONFIG 0x398 +#define A_UP_OBQ_1_SHADOW_REALADDR 0x39c +#define A_UP_OBQ_2_SHADOW_CONFIG 0x3a0 +#define A_UP_OBQ_2_SHADOW_REALADDR 0x3a4 +#define A_UP_OBQ_3_SHADOW_CONFIG 0x3a8 +#define A_UP_OBQ_3_SHADOW_REALADDR 0x3ac +#define A_UP_OBQ_4_SHADOW_CONFIG 0x3b0 +#define A_UP_OBQ_4_SHADOW_REALADDR 0x3b4 +#define A_UP_OBQ_5_SHADOW_CONFIG 0x3b8 +#define A_UP_OBQ_5_SHADOW_REALADDR 0x3bc +#define A_UP_OBQ_6_SHADOW_CONFIG 0x3c0 +#define A_UP_OBQ_6_SHADOW_REALADDR 0x3c4 +#define A_UP_OBQ_7_SHADOW_CONFIG 0x3c8 +#define A_UP_OBQ_7_SHADOW_REALADDR 0x3cc + +/* registers for module CIM_CTL */ +#define CIM_CTL_BASE_ADDR 0x0 + +#define A_CIM_CTL_CONFIG 0x0 + +#define S_AUTOPREFLOC 17 +#define M_AUTOPREFLOC 0x1fU +#define V_AUTOPREFLOC(x) ((x) << S_AUTOPREFLOC) +#define G_AUTOPREFLOC(x) (((x) >> S_AUTOPREFLOC) & M_AUTOPREFLOC) + +#define S_AUTOPREFEN 16 +#define V_AUTOPREFEN(x) ((x) << S_AUTOPREFEN) +#define F_AUTOPREFEN V_AUTOPREFEN(1U) + +#define S_DISMATIMEOUT 15 +#define V_DISMATIMEOUT(x) ((x) << S_DISMATIMEOUT) +#define F_DISMATIMEOUT V_DISMATIMEOUT(1U) + +#define S_PIFMULTICMD 8 +#define V_PIFMULTICMD(x) ((x) << S_PIFMULTICMD) +#define F_PIFMULTICMD V_PIFMULTICMD(1U) + +#define S_UPSELFRESETTOUT 7 +#define V_UPSELFRESETTOUT(x) ((x) << S_UPSELFRESETTOUT) +#define F_UPSELFRESETTOUT V_UPSELFRESETTOUT(1U) + +#define S_PLSWAPDISWR 6 +#define V_PLSWAPDISWR(x) ((x) << S_PLSWAPDISWR) +#define F_PLSWAPDISWR V_PLSWAPDISWR(1U) + +#define S_PLSWAPDISRD 5 +#define V_PLSWAPDISRD(x) ((x) << S_PLSWAPDISRD) +#define F_PLSWAPDISRD V_PLSWAPDISRD(1U) + +#define S_PREFEN 0 +#define V_PREFEN(x) ((x) << S_PREFEN) +#define F_PREFEN V_PREFEN(1U) + +#define A_CIM_CTL_PREFADDR 0x4 +#define A_CIM_CTL_ALLOCADDR 0x8 +#define A_CIM_CTL_INVLDTADDR 0xc +#define A_CIM_CTL_STATIC_PREFADDR0 0x10 +#define A_CIM_CTL_STATIC_PREFADDR1 0x14 +#define A_CIM_CTL_STATIC_PREFADDR2 0x18 +#define A_CIM_CTL_STATIC_PREFADDR3 0x1c +#define A_CIM_CTL_STATIC_PREFADDR4 0x20 +#define A_CIM_CTL_STATIC_PREFADDR5 0x24 +#define A_CIM_CTL_STATIC_PREFADDR6 0x28 +#define A_CIM_CTL_STATIC_PREFADDR7 0x2c +#define A_CIM_CTL_STATIC_PREFADDR8 0x30 +#define A_CIM_CTL_STATIC_PREFADDR9 0x34 +#define A_CIM_CTL_STATIC_PREFADDR10 0x38 +#define A_CIM_CTL_STATIC_PREFADDR11 0x3c +#define A_CIM_CTL_STATIC_PREFADDR12 0x40 +#define A_CIM_CTL_STATIC_PREFADDR13 0x44 +#define A_CIM_CTL_STATIC_PREFADDR14 0x48 +#define A_CIM_CTL_STATIC_PREFADDR15 0x4c +#define A_CIM_CTL_STATIC_ALLOCADDR0 0x50 +#define A_CIM_CTL_STATIC_ALLOCADDR1 0x54 +#define A_CIM_CTL_STATIC_ALLOCADDR2 0x58 +#define A_CIM_CTL_STATIC_ALLOCADDR3 0x5c +#define A_CIM_CTL_STATIC_ALLOCADDR4 0x60 +#define A_CIM_CTL_STATIC_ALLOCADDR5 0x64 +#define A_CIM_CTL_STATIC_ALLOCADDR6 0x68 +#define A_CIM_CTL_STATIC_ALLOCADDR7 0x6c +#define A_CIM_CTL_STATIC_ALLOCADDR8 0x70 +#define A_CIM_CTL_STATIC_ALLOCADDR9 0x74 +#define A_CIM_CTL_STATIC_ALLOCADDR10 0x78 +#define A_CIM_CTL_STATIC_ALLOCADDR11 0x7c +#define A_CIM_CTL_STATIC_ALLOCADDR12 0x80 +#define A_CIM_CTL_STATIC_ALLOCADDR13 0x84 +#define A_CIM_CTL_STATIC_ALLOCADDR14 0x88 +#define A_CIM_CTL_STATIC_ALLOCADDR15 0x8c +#define A_CIM_CTL_FIFO_CNT 0x90 + +#define S_CTLFIFOCNT 0 +#define M_CTLFIFOCNT 0xfU +#define V_CTLFIFOCNT(x) ((x) << S_CTLFIFOCNT) +#define G_CTLFIFOCNT(x) (((x) >> S_CTLFIFOCNT) & M_CTLFIFOCNT) + +#define A_CIM_CTL_GLB_TIMER 0x94 +#define A_CIM_CTL_TIMER0 0x98 +#define A_CIM_CTL_TIMER1 0x9c +#define A_CIM_CTL_GEN0 0xa0 +#define A_CIM_CTL_GEN1 0xa4 +#define A_CIM_CTL_GEN2 0xa8 +#define A_CIM_CTL_GEN3 0xac +#define A_CIM_CTL_GLB_TIMER_TICK 0xb0 +#define A_CIM_CTL_GEN_TIMER0_CTL 0xb4 + +#define S_GENTIMERRUN 7 +#define V_GENTIMERRUN(x) ((x) << S_GENTIMERRUN) +#define F_GENTIMERRUN V_GENTIMERRUN(1U) + +#define S_GENTIMERTRIG 6 +#define V_GENTIMERTRIG(x) ((x) << S_GENTIMERTRIG) +#define F_GENTIMERTRIG V_GENTIMERTRIG(1U) + +#define S_GENTIMERACT 4 +#define M_GENTIMERACT 0x3U +#define V_GENTIMERACT(x) ((x) << S_GENTIMERACT) +#define G_GENTIMERACT(x) (((x) >> S_GENTIMERACT) & M_GENTIMERACT) + +#define S_GENTIMERCFG 2 +#define M_GENTIMERCFG 0x3U +#define V_GENTIMERCFG(x) ((x) << S_GENTIMERCFG) +#define G_GENTIMERCFG(x) (((x) >> S_GENTIMERCFG) & M_GENTIMERCFG) + +#define S_GENTIMERSTOP 1 +#define V_GENTIMERSTOP(x) ((x) << S_GENTIMERSTOP) +#define F_GENTIMERSTOP V_GENTIMERSTOP(1U) + +#define S_GENTIMERSTRT 0 +#define V_GENTIMERSTRT(x) ((x) << S_GENTIMERSTRT) +#define F_GENTIMERSTRT V_GENTIMERSTRT(1U) + +#define A_CIM_CTL_GEN_TIMER0 0xb8 +#define A_CIM_CTL_GEN_TIMER1_CTL 0xbc +#define A_CIM_CTL_GEN_TIMER1 0xc0 +#define A_CIM_CTL_GEN_TIMER2_CTL 0xc4 +#define A_CIM_CTL_GEN_TIMER2 0xc8 +#define A_CIM_CTL_GEN_TIMER3_CTL 0xcc +#define A_CIM_CTL_GEN_TIMER3 0xd0 +#define A_CIM_CTL_MAILBOX_VF_STATUS 0xe0 +#define A_CIM_CTL_MAILBOX_VFN_CTL 0x100 +#define A_CIM_CTL_TSCH_CHNLN_CTL 0x900 + +#define S_TSCHNLEN 31 +#define V_TSCHNLEN(x) ((x) << S_TSCHNLEN) +#define F_TSCHNLEN V_TSCHNLEN(1U) + +#define S_TSCHNRESET 30 +#define V_TSCHNRESET(x) ((x) << S_TSCHNRESET) +#define F_TSCHNRESET V_TSCHNRESET(1U) + +#define A_CIM_CTL_TSCH_CHNLN_TICK 0x904 + +#define S_TSCHNLTICK 0 +#define M_TSCHNLTICK 0xffffU +#define V_TSCHNLTICK(x) ((x) << S_TSCHNLTICK) +#define G_TSCHNLTICK(x) (((x) >> S_TSCHNLTICK) & M_TSCHNLTICK) + +#define A_CIM_CTL_TSCH_CHNLN_CLASS_ENABLE_A 0x908 + +#define S_TSC15WRREN 31 +#define V_TSC15WRREN(x) ((x) << S_TSC15WRREN) +#define F_TSC15WRREN V_TSC15WRREN(1U) + +#define S_TSC15RATEEN 30 +#define V_TSC15RATEEN(x) ((x) << S_TSC15RATEEN) +#define F_TSC15RATEEN V_TSC15RATEEN(1U) + +#define S_TSC14WRREN 29 +#define V_TSC14WRREN(x) ((x) << S_TSC14WRREN) +#define F_TSC14WRREN V_TSC14WRREN(1U) + +#define S_TSC14RATEEN 28 +#define V_TSC14RATEEN(x) ((x) << S_TSC14RATEEN) +#define F_TSC14RATEEN V_TSC14RATEEN(1U) + +#define S_TSC13WRREN 27 +#define V_TSC13WRREN(x) ((x) << S_TSC13WRREN) +#define F_TSC13WRREN V_TSC13WRREN(1U) + +#define S_TSC13RATEEN 26 +#define V_TSC13RATEEN(x) ((x) << S_TSC13RATEEN) +#define F_TSC13RATEEN V_TSC13RATEEN(1U) + +#define S_TSC12WRREN 25 +#define V_TSC12WRREN(x) ((x) << S_TSC12WRREN) +#define F_TSC12WRREN V_TSC12WRREN(1U) + +#define S_TSC12RATEEN 24 +#define V_TSC12RATEEN(x) ((x) << S_TSC12RATEEN) +#define F_TSC12RATEEN V_TSC12RATEEN(1U) + +#define S_TSC11WRREN 23 +#define V_TSC11WRREN(x) ((x) << S_TSC11WRREN) +#define F_TSC11WRREN V_TSC11WRREN(1U) + +#define S_TSC11RATEEN 22 +#define V_TSC11RATEEN(x) ((x) << S_TSC11RATEEN) +#define F_TSC11RATEEN V_TSC11RATEEN(1U) + +#define S_TSC10WRREN 21 +#define V_TSC10WRREN(x) ((x) << S_TSC10WRREN) +#define F_TSC10WRREN V_TSC10WRREN(1U) + +#define S_TSC10RATEEN 20 +#define V_TSC10RATEEN(x) ((x) << S_TSC10RATEEN) +#define F_TSC10RATEEN V_TSC10RATEEN(1U) + +#define S_TSC9WRREN 19 +#define V_TSC9WRREN(x) ((x) << S_TSC9WRREN) +#define F_TSC9WRREN V_TSC9WRREN(1U) + +#define S_TSC9RATEEN 18 +#define V_TSC9RATEEN(x) ((x) << S_TSC9RATEEN) +#define F_TSC9RATEEN V_TSC9RATEEN(1U) + +#define S_TSC8WRREN 17 +#define V_TSC8WRREN(x) ((x) << S_TSC8WRREN) +#define F_TSC8WRREN V_TSC8WRREN(1U) + +#define S_TSC8RATEEN 16 +#define V_TSC8RATEEN(x) ((x) << S_TSC8RATEEN) +#define F_TSC8RATEEN V_TSC8RATEEN(1U) + +#define S_TSC7WRREN 15 +#define V_TSC7WRREN(x) ((x) << S_TSC7WRREN) +#define F_TSC7WRREN V_TSC7WRREN(1U) + +#define S_TSC7RATEEN 14 +#define V_TSC7RATEEN(x) ((x) << S_TSC7RATEEN) +#define F_TSC7RATEEN V_TSC7RATEEN(1U) + +#define S_TSC6WRREN 13 +#define V_TSC6WRREN(x) ((x) << S_TSC6WRREN) +#define F_TSC6WRREN V_TSC6WRREN(1U) + +#define S_TSC6RATEEN 12 +#define V_TSC6RATEEN(x) ((x) << S_TSC6RATEEN) +#define F_TSC6RATEEN V_TSC6RATEEN(1U) + +#define S_TSC5WRREN 11 +#define V_TSC5WRREN(x) ((x) << S_TSC5WRREN) +#define F_TSC5WRREN V_TSC5WRREN(1U) + +#define S_TSC5RATEEN 10 +#define V_TSC5RATEEN(x) ((x) << S_TSC5RATEEN) +#define F_TSC5RATEEN V_TSC5RATEEN(1U) + +#define S_TSC4WRREN 9 +#define V_TSC4WRREN(x) ((x) << S_TSC4WRREN) +#define F_TSC4WRREN V_TSC4WRREN(1U) + +#define S_TSC4RATEEN 8 +#define V_TSC4RATEEN(x) ((x) << S_TSC4RATEEN) +#define F_TSC4RATEEN V_TSC4RATEEN(1U) + +#define S_TSC3WRREN 7 +#define V_TSC3WRREN(x) ((x) << S_TSC3WRREN) +#define F_TSC3WRREN V_TSC3WRREN(1U) + +#define S_TSC3RATEEN 6 +#define V_TSC3RATEEN(x) ((x) << S_TSC3RATEEN) +#define F_TSC3RATEEN V_TSC3RATEEN(1U) + +#define S_TSC2WRREN 5 +#define V_TSC2WRREN(x) ((x) << S_TSC2WRREN) +#define F_TSC2WRREN V_TSC2WRREN(1U) + +#define S_TSC2RATEEN 4 +#define V_TSC2RATEEN(x) ((x) << S_TSC2RATEEN) +#define F_TSC2RATEEN V_TSC2RATEEN(1U) + +#define S_TSC1WRREN 3 +#define V_TSC1WRREN(x) ((x) << S_TSC1WRREN) +#define F_TSC1WRREN V_TSC1WRREN(1U) + +#define S_TSC1RATEEN 2 +#define V_TSC1RATEEN(x) ((x) << S_TSC1RATEEN) +#define F_TSC1RATEEN V_TSC1RATEEN(1U) + +#define S_TSC0WRREN 1 +#define V_TSC0WRREN(x) ((x) << S_TSC0WRREN) +#define F_TSC0WRREN V_TSC0WRREN(1U) + +#define S_TSC0RATEEN 0 +#define V_TSC0RATEEN(x) ((x) << S_TSC0RATEEN) +#define F_TSC0RATEEN V_TSC0RATEEN(1U) + +#define A_CIM_CTL_TSCH_MIN_MAX_EN 0x90c + +#define S_MIN_MAX_EN 0 +#define V_MIN_MAX_EN(x) ((x) << S_MIN_MAX_EN) +#define F_MIN_MAX_EN V_MIN_MAX_EN(1U) + +#define A_CIM_CTL_TSCH_CHNLN_RATE_LIMITER 0x910 + +#define S_TSCHNLRATENEG 31 +#define V_TSCHNLRATENEG(x) ((x) << S_TSCHNLRATENEG) +#define F_TSCHNLRATENEG V_TSCHNLRATENEG(1U) + +#define S_TSCHNLRATEL 0 +#define M_TSCHNLRATEL 0x7fffffffU +#define V_TSCHNLRATEL(x) ((x) << S_TSCHNLRATEL) +#define G_TSCHNLRATEL(x) (((x) >> S_TSCHNLRATEL) & M_TSCHNLRATEL) + +#define A_CIM_CTL_TSCH_CHNLN_RATE_PROPERTIES 0x914 + +#define S_TSCHNLRMAX 16 +#define M_TSCHNLRMAX 0xffffU +#define V_TSCHNLRMAX(x) ((x) << S_TSCHNLRMAX) +#define G_TSCHNLRMAX(x) (((x) >> S_TSCHNLRMAX) & M_TSCHNLRMAX) + +#define S_TSCHNLRINCR 0 +#define M_TSCHNLRINCR 0xffffU +#define V_TSCHNLRINCR(x) ((x) << S_TSCHNLRINCR) +#define G_TSCHNLRINCR(x) (((x) >> S_TSCHNLRINCR) & M_TSCHNLRINCR) + +#define A_CIM_CTL_TSCH_CHNLN_WRR 0x918 +#define A_CIM_CTL_TSCH_CHNLN_WEIGHT 0x91c + +#define S_TSCHNLWEIGHT 0 +#define M_TSCHNLWEIGHT 0x3fffffU +#define V_TSCHNLWEIGHT(x) ((x) << S_TSCHNLWEIGHT) +#define G_TSCHNLWEIGHT(x) (((x) >> S_TSCHNLWEIGHT) & M_TSCHNLWEIGHT) + +#define A_CIM_CTL_TSCH_CHNLN_CLASSM_RATE_LIMITER 0x920 + +#define S_TSCCLRATENEG 31 +#define V_TSCCLRATENEG(x) ((x) << S_TSCCLRATENEG) +#define F_TSCCLRATENEG V_TSCCLRATENEG(1U) + +#define S_TSCCLRATEL 0 +#define M_TSCCLRATEL 0xffffffU +#define V_TSCCLRATEL(x) ((x) << S_TSCCLRATEL) +#define G_TSCCLRATEL(x) (((x) >> S_TSCCLRATEL) & M_TSCCLRATEL) + +#define A_CIM_CTL_TSCH_CHNLN_CLASSM_RATE_PROPERTIES 0x924 + +#define S_TSCCLRMAX 16 +#define M_TSCCLRMAX 0xffffU +#define V_TSCCLRMAX(x) ((x) << S_TSCCLRMAX) +#define G_TSCCLRMAX(x) (((x) >> S_TSCCLRMAX) & M_TSCCLRMAX) + +#define S_TSCCLRINCR 0 +#define M_TSCCLRINCR 0xffffU +#define V_TSCCLRINCR(x) ((x) << S_TSCCLRINCR) +#define G_TSCCLRINCR(x) (((x) >> S_TSCCLRINCR) & M_TSCCLRINCR) + +#define A_CIM_CTL_TSCH_CHNLN_CLASSM_WRR 0x928 + +#define S_TSCCLWRRNEG 31 +#define V_TSCCLWRRNEG(x) ((x) << S_TSCCLWRRNEG) +#define F_TSCCLWRRNEG V_TSCCLWRRNEG(1U) + +#define S_TSCCLWRR 0 +#define M_TSCCLWRR 0x3ffffffU +#define V_TSCCLWRR(x) ((x) << S_TSCCLWRR) +#define G_TSCCLWRR(x) (((x) >> S_TSCCLWRR) & M_TSCCLWRR) + +#define A_CIM_CTL_TSCH_CHNLN_CLASSM_WEIGHT 0x92c + +#define S_TSCCLWEIGHT 0 +#define M_TSCCLWEIGHT 0xffffU +#define V_TSCCLWEIGHT(x) ((x) << S_TSCCLWEIGHT) +#define G_TSCCLWEIGHT(x) (((x) >> S_TSCCLWEIGHT) & M_TSCCLWEIGHT) + +#define A_CIM_CTL_MAILBOX_PF0_CTL 0xd84 +#define A_CIM_CTL_MAILBOX_PF1_CTL 0xd88 +#define A_CIM_CTL_MAILBOX_PF2_CTL 0xd8c +#define A_CIM_CTL_MAILBOX_PF3_CTL 0xd90 +#define A_CIM_CTL_MAILBOX_PF4_CTL 0xd94 +#define A_CIM_CTL_MAILBOX_PF5_CTL 0xd98 +#define A_CIM_CTL_MAILBOX_PF6_CTL 0xd9c +#define A_CIM_CTL_MAILBOX_PF7_CTL 0xda0 +#define A_CIM_CTL_MAILBOX_CTL_OWNER_COPY 0xda4 + +#define S_PF7_OWNER_PL 15 +#define V_PF7_OWNER_PL(x) ((x) << S_PF7_OWNER_PL) +#define F_PF7_OWNER_PL V_PF7_OWNER_PL(1U) + +#define S_PF6_OWNER_PL 14 +#define V_PF6_OWNER_PL(x) ((x) << S_PF6_OWNER_PL) +#define F_PF6_OWNER_PL V_PF6_OWNER_PL(1U) + +#define S_PF5_OWNER_PL 13 +#define V_PF5_OWNER_PL(x) ((x) << S_PF5_OWNER_PL) +#define F_PF5_OWNER_PL V_PF5_OWNER_PL(1U) + +#define S_PF4_OWNER_PL 12 +#define V_PF4_OWNER_PL(x) ((x) << S_PF4_OWNER_PL) +#define F_PF4_OWNER_PL V_PF4_OWNER_PL(1U) + +#define S_PF3_OWNER_PL 11 +#define V_PF3_OWNER_PL(x) ((x) << S_PF3_OWNER_PL) +#define F_PF3_OWNER_PL V_PF3_OWNER_PL(1U) + +#define S_PF2_OWNER_PL 10 +#define V_PF2_OWNER_PL(x) ((x) << S_PF2_OWNER_PL) +#define F_PF2_OWNER_PL V_PF2_OWNER_PL(1U) + +#define S_PF1_OWNER_PL 9 +#define V_PF1_OWNER_PL(x) ((x) << S_PF1_OWNER_PL) +#define F_PF1_OWNER_PL V_PF1_OWNER_PL(1U) + +#define S_PF0_OWNER_PL 8 +#define V_PF0_OWNER_PL(x) ((x) << S_PF0_OWNER_PL) +#define F_PF0_OWNER_PL V_PF0_OWNER_PL(1U) + +#define S_PF7_OWNER_UP 7 +#define V_PF7_OWNER_UP(x) ((x) << S_PF7_OWNER_UP) +#define F_PF7_OWNER_UP V_PF7_OWNER_UP(1U) + +#define S_PF6_OWNER_UP 6 +#define V_PF6_OWNER_UP(x) ((x) << S_PF6_OWNER_UP) +#define F_PF6_OWNER_UP V_PF6_OWNER_UP(1U) + +#define S_PF5_OWNER_UP 5 +#define V_PF5_OWNER_UP(x) ((x) << S_PF5_OWNER_UP) +#define F_PF5_OWNER_UP V_PF5_OWNER_UP(1U) + +#define S_PF4_OWNER_UP 4 +#define V_PF4_OWNER_UP(x) ((x) << S_PF4_OWNER_UP) +#define F_PF4_OWNER_UP V_PF4_OWNER_UP(1U) + +#define S_PF3_OWNER_UP 3 +#define V_PF3_OWNER_UP(x) ((x) << S_PF3_OWNER_UP) +#define F_PF3_OWNER_UP V_PF3_OWNER_UP(1U) + +#define S_PF2_OWNER_UP 2 +#define V_PF2_OWNER_UP(x) ((x) << S_PF2_OWNER_UP) +#define F_PF2_OWNER_UP V_PF2_OWNER_UP(1U) + +#define S_PF1_OWNER_UP 1 +#define V_PF1_OWNER_UP(x) ((x) << S_PF1_OWNER_UP) +#define F_PF1_OWNER_UP V_PF1_OWNER_UP(1U) + +#define S_PF0_OWNER_UP 0 +#define V_PF0_OWNER_UP(x) ((x) << S_PF0_OWNER_UP) +#define F_PF0_OWNER_UP V_PF0_OWNER_UP(1U) + +#define A_CIM_CTL_PIO_MST_CONFIG 0xda8 + +#define S_T5_CTLRID 0 +#define M_T5_CTLRID 0xffU +#define V_T5_CTLRID(x) ((x) << S_T5_CTLRID) +#define G_T5_CTLRID(x) (((x) >> S_T5_CTLRID) & M_T5_CTLRID) + +/* registers for module MAC */ +#define MAC_BASE_ADDR 0x0 + +#define A_MAC_PORT_CFG 0x800 + +#define S_MAC_CLK_SEL 29 +#define M_MAC_CLK_SEL 0x7U +#define V_MAC_CLK_SEL(x) ((x) << S_MAC_CLK_SEL) +#define G_MAC_CLK_SEL(x) (((x) >> S_MAC_CLK_SEL) & M_MAC_CLK_SEL) + +#define S_SMUXTXSEL 9 +#define V_SMUXTXSEL(x) ((x) << S_SMUXTXSEL) +#define F_SMUXTXSEL V_SMUXTXSEL(1U) + +#define S_SMUXRXSEL 8 +#define V_SMUXRXSEL(x) ((x) << S_SMUXRXSEL) +#define F_SMUXRXSEL V_SMUXRXSEL(1U) + +#define S_PORTSPEED 4 +#define M_PORTSPEED 0x3U +#define V_PORTSPEED(x) ((x) << S_PORTSPEED) +#define G_PORTSPEED(x) (((x) >> S_PORTSPEED) & M_PORTSPEED) + +#define A_MAC_PORT_RESET_CTRL 0x804 + +#define S_TWGDSK_HSSC16B 31 +#define V_TWGDSK_HSSC16B(x) ((x) << S_TWGDSK_HSSC16B) +#define F_TWGDSK_HSSC16B V_TWGDSK_HSSC16B(1U) + +#define S_EEE_RESET 30 +#define V_EEE_RESET(x) ((x) << S_EEE_RESET) +#define F_EEE_RESET V_EEE_RESET(1U) + +#define S_PTP_TIMER 29 +#define V_PTP_TIMER(x) ((x) << S_PTP_TIMER) +#define F_PTP_TIMER V_PTP_TIMER(1U) + +#define S_MTIPREFRESET 28 +#define V_MTIPREFRESET(x) ((x) << S_MTIPREFRESET) +#define F_MTIPREFRESET V_MTIPREFRESET(1U) + +#define S_MTIPTXFFRESET 27 +#define V_MTIPTXFFRESET(x) ((x) << S_MTIPTXFFRESET) +#define F_MTIPTXFFRESET V_MTIPTXFFRESET(1U) + +#define S_MTIPRXFFRESET 26 +#define V_MTIPRXFFRESET(x) ((x) << S_MTIPRXFFRESET) +#define F_MTIPRXFFRESET V_MTIPRXFFRESET(1U) + +#define S_MTIPREGRESET 25 +#define V_MTIPREGRESET(x) ((x) << S_MTIPREGRESET) +#define F_MTIPREGRESET V_MTIPREGRESET(1U) + +#define S_AEC3RESET 23 +#define V_AEC3RESET(x) ((x) << S_AEC3RESET) +#define F_AEC3RESET V_AEC3RESET(1U) + +#define S_AEC2RESET 22 +#define V_AEC2RESET(x) ((x) << S_AEC2RESET) +#define F_AEC2RESET V_AEC2RESET(1U) + +#define S_AEC1RESET 21 +#define V_AEC1RESET(x) ((x) << S_AEC1RESET) +#define F_AEC1RESET V_AEC1RESET(1U) + +#define S_AEC0RESET 20 +#define V_AEC0RESET(x) ((x) << S_AEC0RESET) +#define F_AEC0RESET V_AEC0RESET(1U) + +#define S_AET3RESET 19 +#define V_AET3RESET(x) ((x) << S_AET3RESET) +#define F_AET3RESET V_AET3RESET(1U) + +#define S_AET2RESET 18 +#define V_AET2RESET(x) ((x) << S_AET2RESET) +#define F_AET2RESET V_AET2RESET(1U) + +#define S_AET1RESET 17 +#define V_AET1RESET(x) ((x) << S_AET1RESET) +#define F_AET1RESET V_AET1RESET(1U) + +#define S_AET0RESET 16 +#define V_AET0RESET(x) ((x) << S_AET0RESET) +#define F_AET0RESET V_AET0RESET(1U) + +#define S_TXIF_RESET 12 +#define V_TXIF_RESET(x) ((x) << S_TXIF_RESET) +#define F_TXIF_RESET V_TXIF_RESET(1U) + +#define S_RXIF_RESET 11 +#define V_RXIF_RESET(x) ((x) << S_RXIF_RESET) +#define F_RXIF_RESET V_RXIF_RESET(1U) + +#define S_MTIPSD3TXRST 9 +#define V_MTIPSD3TXRST(x) ((x) << S_MTIPSD3TXRST) +#define F_MTIPSD3TXRST V_MTIPSD3TXRST(1U) + +#define S_MTIPSD2TXRST 8 +#define V_MTIPSD2TXRST(x) ((x) << S_MTIPSD2TXRST) +#define F_MTIPSD2TXRST V_MTIPSD2TXRST(1U) + +#define S_MTIPSD1TXRST 7 +#define V_MTIPSD1TXRST(x) ((x) << S_MTIPSD1TXRST) +#define F_MTIPSD1TXRST V_MTIPSD1TXRST(1U) + +#define S_MTIPSD0TXRST 6 +#define V_MTIPSD0TXRST(x) ((x) << S_MTIPSD0TXRST) +#define F_MTIPSD0TXRST V_MTIPSD0TXRST(1U) + +#define S_MTIPSD3RXRST 5 +#define V_MTIPSD3RXRST(x) ((x) << S_MTIPSD3RXRST) +#define F_MTIPSD3RXRST V_MTIPSD3RXRST(1U) + +#define S_MTIPSD2RXRST 4 +#define V_MTIPSD2RXRST(x) ((x) << S_MTIPSD2RXRST) +#define F_MTIPSD2RXRST V_MTIPSD2RXRST(1U) + +#define S_MTIPSD1RXRST 3 +#define V_MTIPSD1RXRST(x) ((x) << S_MTIPSD1RXRST) +#define F_MTIPSD1RXRST V_MTIPSD1RXRST(1U) + +#define S_MTIPSD0RXRST 1 +#define V_MTIPSD0RXRST(x) ((x) << S_MTIPSD0RXRST) +#define F_MTIPSD0RXRST V_MTIPSD0RXRST(1U) + +#define A_MAC_PORT_LED_CFG 0x808 +#define A_MAC_PORT_LED_COUNTHI 0x80c +#define A_MAC_PORT_LED_COUNTLO 0x810 +#define A_MAC_PORT_CFG3 0x814 + +#define S_FCSDISCTRL 25 +#define V_FCSDISCTRL(x) ((x) << S_FCSDISCTRL) +#define F_FCSDISCTRL V_FCSDISCTRL(1U) + +#define S_SIGDETCTRL 24 +#define V_SIGDETCTRL(x) ((x) << S_SIGDETCTRL) +#define F_SIGDETCTRL V_SIGDETCTRL(1U) + +#define S_TX_LANE 23 +#define V_TX_LANE(x) ((x) << S_TX_LANE) +#define F_TX_LANE V_TX_LANE(1U) + +#define S_RX_LANE 22 +#define V_RX_LANE(x) ((x) << S_RX_LANE) +#define F_RX_LANE V_RX_LANE(1U) + +#define S_SE_CLR 21 +#define V_SE_CLR(x) ((x) << S_SE_CLR) +#define F_SE_CLR V_SE_CLR(1U) + +#define S_AN_ENA 17 +#define M_AN_ENA 0xfU +#define V_AN_ENA(x) ((x) << S_AN_ENA) +#define G_AN_ENA(x) (((x) >> S_AN_ENA) & M_AN_ENA) + +#define S_SD_RX_CLK_ENA 13 +#define M_SD_RX_CLK_ENA 0xfU +#define V_SD_RX_CLK_ENA(x) ((x) << S_SD_RX_CLK_ENA) +#define G_SD_RX_CLK_ENA(x) (((x) >> S_SD_RX_CLK_ENA) & M_SD_RX_CLK_ENA) + +#define S_SD_TX_CLK_ENA 9 +#define M_SD_TX_CLK_ENA 0xfU +#define V_SD_TX_CLK_ENA(x) ((x) << S_SD_TX_CLK_ENA) +#define G_SD_TX_CLK_ENA(x) (((x) >> S_SD_TX_CLK_ENA) & M_SD_TX_CLK_ENA) + +#define S_SGMIISEL 8 +#define V_SGMIISEL(x) ((x) << S_SGMIISEL) +#define F_SGMIISEL V_SGMIISEL(1U) + +#define S_HSSPLLSEL 4 +#define M_HSSPLLSEL 0xfU +#define V_HSSPLLSEL(x) ((x) << S_HSSPLLSEL) +#define G_HSSPLLSEL(x) (((x) >> S_HSSPLLSEL) & M_HSSPLLSEL) + +#define S_HSSC16C20SEL 0 +#define M_HSSC16C20SEL 0xfU +#define V_HSSC16C20SEL(x) ((x) << S_HSSC16C20SEL) +#define G_HSSC16C20SEL(x) (((x) >> S_HSSC16C20SEL) & M_HSSC16C20SEL) + +#define A_MAC_PORT_CFG2 0x818 + +#define S_T5_AEC_PMA_TX_READY 4 +#define M_T5_AEC_PMA_TX_READY 0xfU +#define V_T5_AEC_PMA_TX_READY(x) ((x) << S_T5_AEC_PMA_TX_READY) +#define G_T5_AEC_PMA_TX_READY(x) (((x) >> S_T5_AEC_PMA_TX_READY) & M_T5_AEC_PMA_TX_READY) + +#define S_T5_AEC_PMA_RX_READY 0 +#define M_T5_AEC_PMA_RX_READY 0xfU +#define V_T5_AEC_PMA_RX_READY(x) ((x) << S_T5_AEC_PMA_RX_READY) +#define G_T5_AEC_PMA_RX_READY(x) (((x) >> S_T5_AEC_PMA_RX_READY) & M_T5_AEC_PMA_RX_READY) + +#define A_MAC_PORT_PKT_COUNT 0x81c +#define A_MAC_PORT_CFG4 0x820 + +#define S_AEC3_RX_WIDTH 14 +#define M_AEC3_RX_WIDTH 0x3U +#define V_AEC3_RX_WIDTH(x) ((x) << S_AEC3_RX_WIDTH) +#define G_AEC3_RX_WIDTH(x) (((x) >> S_AEC3_RX_WIDTH) & M_AEC3_RX_WIDTH) + +#define S_AEC2_RX_WIDTH 12 +#define M_AEC2_RX_WIDTH 0x3U +#define V_AEC2_RX_WIDTH(x) ((x) << S_AEC2_RX_WIDTH) +#define G_AEC2_RX_WIDTH(x) (((x) >> S_AEC2_RX_WIDTH) & M_AEC2_RX_WIDTH) + +#define S_AEC1_RX_WIDTH 10 +#define M_AEC1_RX_WIDTH 0x3U +#define V_AEC1_RX_WIDTH(x) ((x) << S_AEC1_RX_WIDTH) +#define G_AEC1_RX_WIDTH(x) (((x) >> S_AEC1_RX_WIDTH) & M_AEC1_RX_WIDTH) + +#define S_AEC0_RX_WIDTH 8 +#define M_AEC0_RX_WIDTH 0x3U +#define V_AEC0_RX_WIDTH(x) ((x) << S_AEC0_RX_WIDTH) +#define G_AEC0_RX_WIDTH(x) (((x) >> S_AEC0_RX_WIDTH) & M_AEC0_RX_WIDTH) + +#define S_AEC3_TX_WIDTH 6 +#define M_AEC3_TX_WIDTH 0x3U +#define V_AEC3_TX_WIDTH(x) ((x) << S_AEC3_TX_WIDTH) +#define G_AEC3_TX_WIDTH(x) (((x) >> S_AEC3_TX_WIDTH) & M_AEC3_TX_WIDTH) + +#define S_AEC2_TX_WIDTH 4 +#define M_AEC2_TX_WIDTH 0x3U +#define V_AEC2_TX_WIDTH(x) ((x) << S_AEC2_TX_WIDTH) +#define G_AEC2_TX_WIDTH(x) (((x) >> S_AEC2_TX_WIDTH) & M_AEC2_TX_WIDTH) + +#define S_AEC1_TX_WIDTH 2 +#define M_AEC1_TX_WIDTH 0x3U +#define V_AEC1_TX_WIDTH(x) ((x) << S_AEC1_TX_WIDTH) +#define G_AEC1_TX_WIDTH(x) (((x) >> S_AEC1_TX_WIDTH) & M_AEC1_TX_WIDTH) + +#define S_AEC0_TX_WIDTH 0 +#define M_AEC0_TX_WIDTH 0x3U +#define V_AEC0_TX_WIDTH(x) ((x) << S_AEC0_TX_WIDTH) +#define G_AEC0_TX_WIDTH(x) (((x) >> S_AEC0_TX_WIDTH) & M_AEC0_TX_WIDTH) + +#define A_MAC_PORT_MAGIC_MACID_LO 0x824 +#define A_MAC_PORT_MAGIC_MACID_HI 0x828 +#define A_MAC_PORT_LINK_STATUS 0x834 + +#define S_AN_DONE 6 +#define V_AN_DONE(x) ((x) << S_AN_DONE) +#define F_AN_DONE V_AN_DONE(1U) + +#define S_ALIGN_DONE 5 +#define V_ALIGN_DONE(x) ((x) << S_ALIGN_DONE) +#define F_ALIGN_DONE V_ALIGN_DONE(1U) + +#define S_BLOCK_LOCK 4 +#define V_BLOCK_LOCK(x) ((x) << S_BLOCK_LOCK) +#define F_BLOCK_LOCK V_BLOCK_LOCK(1U) + +#define A_MAC_PORT_EPIO_DATA0 0x8c0 +#define A_MAC_PORT_EPIO_DATA1 0x8c4 +#define A_MAC_PORT_EPIO_DATA2 0x8c8 +#define A_MAC_PORT_EPIO_DATA3 0x8cc +#define A_MAC_PORT_EPIO_OP 0x8d0 +#define A_MAC_PORT_WOL_STATUS 0x8d4 +#define A_MAC_PORT_INT_EN 0x8d8 + +#define S_TX_TS_AVAIL 29 +#define V_TX_TS_AVAIL(x) ((x) << S_TX_TS_AVAIL) +#define F_TX_TS_AVAIL V_TX_TS_AVAIL(1U) + +#define S_AN_PAGE_RCVD 2 +#define V_AN_PAGE_RCVD(x) ((x) << S_AN_PAGE_RCVD) +#define F_AN_PAGE_RCVD V_AN_PAGE_RCVD(1U) + +#define A_MAC_PORT_INT_CAUSE 0x8dc +#define A_MAC_PORT_PERR_INT_EN 0x8e0 + +#define S_PERR_PKT_RAM 24 +#define V_PERR_PKT_RAM(x) ((x) << S_PERR_PKT_RAM) +#define F_PERR_PKT_RAM V_PERR_PKT_RAM(1U) + +#define S_PERR_MASK_RAM 23 +#define V_PERR_MASK_RAM(x) ((x) << S_PERR_MASK_RAM) +#define F_PERR_MASK_RAM V_PERR_MASK_RAM(1U) + +#define S_PERR_CRC_RAM 22 +#define V_PERR_CRC_RAM(x) ((x) << S_PERR_CRC_RAM) +#define F_PERR_CRC_RAM V_PERR_CRC_RAM(1U) + +#define S_RX_DFF_SEG0 21 +#define V_RX_DFF_SEG0(x) ((x) << S_RX_DFF_SEG0) +#define F_RX_DFF_SEG0 V_RX_DFF_SEG0(1U) + +#define S_RX_SFF_SEG0 20 +#define V_RX_SFF_SEG0(x) ((x) << S_RX_SFF_SEG0) +#define F_RX_SFF_SEG0 V_RX_SFF_SEG0(1U) + +#define S_RX_DFF_MAC10 19 +#define V_RX_DFF_MAC10(x) ((x) << S_RX_DFF_MAC10) +#define F_RX_DFF_MAC10 V_RX_DFF_MAC10(1U) + +#define S_RX_SFF_MAC10 18 +#define V_RX_SFF_MAC10(x) ((x) << S_RX_SFF_MAC10) +#define F_RX_SFF_MAC10 V_RX_SFF_MAC10(1U) + +#define S_TX_DFF_SEG0 17 +#define V_TX_DFF_SEG0(x) ((x) << S_TX_DFF_SEG0) +#define F_TX_DFF_SEG0 V_TX_DFF_SEG0(1U) + +#define S_TX_SFF_SEG0 16 +#define V_TX_SFF_SEG0(x) ((x) << S_TX_SFF_SEG0) +#define F_TX_SFF_SEG0 V_TX_SFF_SEG0(1U) + +#define S_TX_DFF_MAC10 15 +#define V_TX_DFF_MAC10(x) ((x) << S_TX_DFF_MAC10) +#define F_TX_DFF_MAC10 V_TX_DFF_MAC10(1U) + +#define S_TX_SFF_MAC10 14 +#define V_TX_SFF_MAC10(x) ((x) << S_TX_SFF_MAC10) +#define F_TX_SFF_MAC10 V_TX_SFF_MAC10(1U) + +#define S_RX_STATS 13 +#define V_RX_STATS(x) ((x) << S_RX_STATS) +#define F_RX_STATS V_RX_STATS(1U) + +#define S_TX_STATS 12 +#define V_TX_STATS(x) ((x) << S_TX_STATS) +#define F_TX_STATS V_TX_STATS(1U) + +#define S_PERR3_RX_MIX 11 +#define V_PERR3_RX_MIX(x) ((x) << S_PERR3_RX_MIX) +#define F_PERR3_RX_MIX V_PERR3_RX_MIX(1U) + +#define S_PERR3_RX_SD 10 +#define V_PERR3_RX_SD(x) ((x) << S_PERR3_RX_SD) +#define F_PERR3_RX_SD V_PERR3_RX_SD(1U) + +#define S_PERR3_TX 9 +#define V_PERR3_TX(x) ((x) << S_PERR3_TX) +#define F_PERR3_TX V_PERR3_TX(1U) + +#define S_PERR2_RX_MIX 8 +#define V_PERR2_RX_MIX(x) ((x) << S_PERR2_RX_MIX) +#define F_PERR2_RX_MIX V_PERR2_RX_MIX(1U) + +#define S_PERR2_RX_SD 7 +#define V_PERR2_RX_SD(x) ((x) << S_PERR2_RX_SD) +#define F_PERR2_RX_SD V_PERR2_RX_SD(1U) + +#define S_PERR2_TX 6 +#define V_PERR2_TX(x) ((x) << S_PERR2_TX) +#define F_PERR2_TX V_PERR2_TX(1U) + +#define S_PERR1_RX_MIX 5 +#define V_PERR1_RX_MIX(x) ((x) << S_PERR1_RX_MIX) +#define F_PERR1_RX_MIX V_PERR1_RX_MIX(1U) + +#define S_PERR1_RX_SD 4 +#define V_PERR1_RX_SD(x) ((x) << S_PERR1_RX_SD) +#define F_PERR1_RX_SD V_PERR1_RX_SD(1U) + +#define S_PERR1_TX 3 +#define V_PERR1_TX(x) ((x) << S_PERR1_TX) +#define F_PERR1_TX V_PERR1_TX(1U) + +#define S_PERR0_RX_MIX 2 +#define V_PERR0_RX_MIX(x) ((x) << S_PERR0_RX_MIX) +#define F_PERR0_RX_MIX V_PERR0_RX_MIX(1U) + +#define S_PERR0_RX_SD 1 +#define V_PERR0_RX_SD(x) ((x) << S_PERR0_RX_SD) +#define F_PERR0_RX_SD V_PERR0_RX_SD(1U) + +#define S_PERR0_TX 0 +#define V_PERR0_TX(x) ((x) << S_PERR0_TX) +#define F_PERR0_TX V_PERR0_TX(1U) + +#define A_MAC_PORT_PERR_INT_CAUSE 0x8e4 +#define A_MAC_PORT_PERR_ENABLE 0x8e8 +#define A_MAC_PORT_PERR_INJECT 0x8ec +#define A_MAC_PORT_HSS_CFG0 0x8f0 + +#define S_HSSREFCLKVALIDA 20 +#define V_HSSREFCLKVALIDA(x) ((x) << S_HSSREFCLKVALIDA) +#define F_HSSREFCLKVALIDA V_HSSREFCLKVALIDA(1U) + +#define S_HSSREFCLKVALIDB 19 +#define V_HSSREFCLKVALIDB(x) ((x) << S_HSSREFCLKVALIDB) +#define F_HSSREFCLKVALIDB V_HSSREFCLKVALIDB(1U) + +#define S_HSSRESYNCA 18 +#define V_HSSRESYNCA(x) ((x) << S_HSSRESYNCA) +#define F_HSSRESYNCA V_HSSRESYNCA(1U) + +#define S_HSSRESYNCB 16 +#define V_HSSRESYNCB(x) ((x) << S_HSSRESYNCB) +#define F_HSSRESYNCB V_HSSRESYNCB(1U) + +#define S_HSSRECCALA 15 +#define V_HSSRECCALA(x) ((x) << S_HSSRECCALA) +#define F_HSSRECCALA V_HSSRECCALA(1U) + +#define S_HSSRECCALB 13 +#define V_HSSRECCALB(x) ((x) << S_HSSRECCALB) +#define F_HSSRECCALB V_HSSRECCALB(1U) + +#define S_HSSPLLBYPA 12 +#define V_HSSPLLBYPA(x) ((x) << S_HSSPLLBYPA) +#define F_HSSPLLBYPA V_HSSPLLBYPA(1U) + +#define S_HSSPLLBYPB 11 +#define V_HSSPLLBYPB(x) ((x) << S_HSSPLLBYPB) +#define F_HSSPLLBYPB V_HSSPLLBYPB(1U) + +#define S_HSSPDWNPLLA 10 +#define V_HSSPDWNPLLA(x) ((x) << S_HSSPDWNPLLA) +#define F_HSSPDWNPLLA V_HSSPDWNPLLA(1U) + +#define S_HSSPDWNPLLB 9 +#define V_HSSPDWNPLLB(x) ((x) << S_HSSPDWNPLLB) +#define F_HSSPDWNPLLB V_HSSPDWNPLLB(1U) + +#define S_HSSVCOSELA 8 +#define V_HSSVCOSELA(x) ((x) << S_HSSVCOSELA) +#define F_HSSVCOSELA V_HSSVCOSELA(1U) + +#define S_HSSVCOSELB 7 +#define V_HSSVCOSELB(x) ((x) << S_HSSVCOSELB) +#define F_HSSVCOSELB V_HSSVCOSELB(1U) + +#define S_HSSCALCOMP 6 +#define V_HSSCALCOMP(x) ((x) << S_HSSCALCOMP) +#define F_HSSCALCOMP V_HSSCALCOMP(1U) + +#define S_HSSCALENAB 5 +#define V_HSSCALENAB(x) ((x) << S_HSSCALENAB) +#define F_HSSCALENAB V_HSSCALENAB(1U) + +#define A_MAC_PORT_HSS_CFG1 0x8f4 + +#define S_RXACONFIGSEL 30 +#define M_RXACONFIGSEL 0x3U +#define V_RXACONFIGSEL(x) ((x) << S_RXACONFIGSEL) +#define G_RXACONFIGSEL(x) (((x) >> S_RXACONFIGSEL) & M_RXACONFIGSEL) + +#define S_RXAQUIET 29 +#define V_RXAQUIET(x) ((x) << S_RXAQUIET) +#define F_RXAQUIET V_RXAQUIET(1U) + +#define S_RXAREFRESH 28 +#define V_RXAREFRESH(x) ((x) << S_RXAREFRESH) +#define F_RXAREFRESH V_RXAREFRESH(1U) + +#define S_RXBCONFIGSEL 26 +#define M_RXBCONFIGSEL 0x3U +#define V_RXBCONFIGSEL(x) ((x) << S_RXBCONFIGSEL) +#define G_RXBCONFIGSEL(x) (((x) >> S_RXBCONFIGSEL) & M_RXBCONFIGSEL) + +#define S_RXBQUIET 25 +#define V_RXBQUIET(x) ((x) << S_RXBQUIET) +#define F_RXBQUIET V_RXBQUIET(1U) + +#define S_RXBREFRESH 24 +#define V_RXBREFRESH(x) ((x) << S_RXBREFRESH) +#define F_RXBREFRESH V_RXBREFRESH(1U) + +#define S_RXCCONFIGSEL 22 +#define M_RXCCONFIGSEL 0x3U +#define V_RXCCONFIGSEL(x) ((x) << S_RXCCONFIGSEL) +#define G_RXCCONFIGSEL(x) (((x) >> S_RXCCONFIGSEL) & M_RXCCONFIGSEL) + +#define S_RXCQUIET 21 +#define V_RXCQUIET(x) ((x) << S_RXCQUIET) +#define F_RXCQUIET V_RXCQUIET(1U) + +#define S_RXCREFRESH 20 +#define V_RXCREFRESH(x) ((x) << S_RXCREFRESH) +#define F_RXCREFRESH V_RXCREFRESH(1U) + +#define S_RXDCONFIGSEL 18 +#define M_RXDCONFIGSEL 0x3U +#define V_RXDCONFIGSEL(x) ((x) << S_RXDCONFIGSEL) +#define G_RXDCONFIGSEL(x) (((x) >> S_RXDCONFIGSEL) & M_RXDCONFIGSEL) + +#define S_RXDQUIET 17 +#define V_RXDQUIET(x) ((x) << S_RXDQUIET) +#define F_RXDQUIET V_RXDQUIET(1U) + +#define S_RXDREFRESH 16 +#define V_RXDREFRESH(x) ((x) << S_RXDREFRESH) +#define F_RXDREFRESH V_RXDREFRESH(1U) + +#define S_TXACONFIGSEL 14 +#define M_TXACONFIGSEL 0x3U +#define V_TXACONFIGSEL(x) ((x) << S_TXACONFIGSEL) +#define G_TXACONFIGSEL(x) (((x) >> S_TXACONFIGSEL) & M_TXACONFIGSEL) + +#define S_TXAQUIET 13 +#define V_TXAQUIET(x) ((x) << S_TXAQUIET) +#define F_TXAQUIET V_TXAQUIET(1U) + +#define S_TXAREFRESH 12 +#define V_TXAREFRESH(x) ((x) << S_TXAREFRESH) +#define F_TXAREFRESH V_TXAREFRESH(1U) + +#define S_TXBCONFIGSEL 10 +#define M_TXBCONFIGSEL 0x3U +#define V_TXBCONFIGSEL(x) ((x) << S_TXBCONFIGSEL) +#define G_TXBCONFIGSEL(x) (((x) >> S_TXBCONFIGSEL) & M_TXBCONFIGSEL) + +#define S_TXBQUIET 9 +#define V_TXBQUIET(x) ((x) << S_TXBQUIET) +#define F_TXBQUIET V_TXBQUIET(1U) + +#define S_TXBREFRESH 8 +#define V_TXBREFRESH(x) ((x) << S_TXBREFRESH) +#define F_TXBREFRESH V_TXBREFRESH(1U) + +#define S_TXCCONFIGSEL 6 +#define M_TXCCONFIGSEL 0x3U +#define V_TXCCONFIGSEL(x) ((x) << S_TXCCONFIGSEL) +#define G_TXCCONFIGSEL(x) (((x) >> S_TXCCONFIGSEL) & M_TXCCONFIGSEL) + +#define S_TXCQUIET 5 +#define V_TXCQUIET(x) ((x) << S_TXCQUIET) +#define F_TXCQUIET V_TXCQUIET(1U) + +#define S_TXCREFRESH 4 +#define V_TXCREFRESH(x) ((x) << S_TXCREFRESH) +#define F_TXCREFRESH V_TXCREFRESH(1U) + +#define S_TXDCONFIGSEL 2 +#define M_TXDCONFIGSEL 0x3U +#define V_TXDCONFIGSEL(x) ((x) << S_TXDCONFIGSEL) +#define G_TXDCONFIGSEL(x) (((x) >> S_TXDCONFIGSEL) & M_TXDCONFIGSEL) + +#define S_TXDQUIET 1 +#define V_TXDQUIET(x) ((x) << S_TXDQUIET) +#define F_TXDQUIET V_TXDQUIET(1U) + +#define S_TXDREFRESH 0 +#define V_TXDREFRESH(x) ((x) << S_TXDREFRESH) +#define F_TXDREFRESH V_TXDREFRESH(1U) + +#define A_MAC_PORT_HSS_CFG2 0x8f8 + +#define S_RXAASSTCLK 31 +#define V_RXAASSTCLK(x) ((x) << S_RXAASSTCLK) +#define F_RXAASSTCLK V_RXAASSTCLK(1U) + +#define S_T5RXAPRBSRST 30 +#define V_T5RXAPRBSRST(x) ((x) << S_T5RXAPRBSRST) +#define F_T5RXAPRBSRST V_T5RXAPRBSRST(1U) + +#define S_RXBASSTCLK 29 +#define V_RXBASSTCLK(x) ((x) << S_RXBASSTCLK) +#define F_RXBASSTCLK V_RXBASSTCLK(1U) + +#define S_T5RXBPRBSRST 28 +#define V_T5RXBPRBSRST(x) ((x) << S_T5RXBPRBSRST) +#define F_T5RXBPRBSRST V_T5RXBPRBSRST(1U) + +#define S_RXCASSTCLK 27 +#define V_RXCASSTCLK(x) ((x) << S_RXCASSTCLK) +#define F_RXCASSTCLK V_RXCASSTCLK(1U) + +#define S_T5RXCPRBSRST 26 +#define V_T5RXCPRBSRST(x) ((x) << S_T5RXCPRBSRST) +#define F_T5RXCPRBSRST V_T5RXCPRBSRST(1U) + +#define S_RXDASSTCLK 25 +#define V_RXDASSTCLK(x) ((x) << S_RXDASSTCLK) +#define F_RXDASSTCLK V_RXDASSTCLK(1U) + +#define S_T5RXDPRBSRST 24 +#define V_T5RXDPRBSRST(x) ((x) << S_T5RXDPRBSRST) +#define F_T5RXDPRBSRST V_T5RXDPRBSRST(1U) + +#define A_MAC_PORT_HSS_CFG3 0x8fc + +#define S_HSSCALSSTN 25 +#define M_HSSCALSSTN 0x7U +#define V_HSSCALSSTN(x) ((x) << S_HSSCALSSTN) +#define G_HSSCALSSTN(x) (((x) >> S_HSSCALSSTN) & M_HSSCALSSTN) + +#define S_HSSCALSSTP 22 +#define M_HSSCALSSTP 0x7U +#define V_HSSCALSSTP(x) ((x) << S_HSSCALSSTP) +#define G_HSSCALSSTP(x) (((x) >> S_HSSCALSSTP) & M_HSSCALSSTP) + +#define S_HSSVBOOSTDIVB 19 +#define M_HSSVBOOSTDIVB 0x7U +#define V_HSSVBOOSTDIVB(x) ((x) << S_HSSVBOOSTDIVB) +#define G_HSSVBOOSTDIVB(x) (((x) >> S_HSSVBOOSTDIVB) & M_HSSVBOOSTDIVB) + +#define S_HSSVBOOSTDIVA 16 +#define M_HSSVBOOSTDIVA 0x7U +#define V_HSSVBOOSTDIVA(x) ((x) << S_HSSVBOOSTDIVA) +#define G_HSSVBOOSTDIVA(x) (((x) >> S_HSSVBOOSTDIVA) & M_HSSVBOOSTDIVA) + +#define S_HSSPLLCONFIGB 8 +#define M_HSSPLLCONFIGB 0xffU +#define V_HSSPLLCONFIGB(x) ((x) << S_HSSPLLCONFIGB) +#define G_HSSPLLCONFIGB(x) (((x) >> S_HSSPLLCONFIGB) & M_HSSPLLCONFIGB) + +#define S_HSSPLLCONFIGA 0 +#define M_HSSPLLCONFIGA 0xffU +#define V_HSSPLLCONFIGA(x) ((x) << S_HSSPLLCONFIGA) +#define G_HSSPLLCONFIGA(x) (((x) >> S_HSSPLLCONFIGA) & M_HSSPLLCONFIGA) + +#define A_MAC_PORT_HSS_CFG4 0x900 + +#define S_HSSDIVSELA 9 +#define M_HSSDIVSELA 0x1ffU +#define V_HSSDIVSELA(x) ((x) << S_HSSDIVSELA) +#define G_HSSDIVSELA(x) (((x) >> S_HSSDIVSELA) & M_HSSDIVSELA) + +#define S_HSSDIVSELB 0 +#define M_HSSDIVSELB 0x1ffU +#define V_HSSDIVSELB(x) ((x) << S_HSSDIVSELB) +#define G_HSSDIVSELB(x) (((x) >> S_HSSDIVSELB) & M_HSSDIVSELB) + +#define A_MAC_PORT_HSS_STATUS 0x904 + +#define S_HSSPLLLOCKB 3 +#define V_HSSPLLLOCKB(x) ((x) << S_HSSPLLLOCKB) +#define F_HSSPLLLOCKB V_HSSPLLLOCKB(1U) + +#define S_HSSPLLLOCKA 2 +#define V_HSSPLLLOCKA(x) ((x) << S_HSSPLLLOCKA) +#define F_HSSPLLLOCKA V_HSSPLLLOCKA(1U) + +#define S_HSSPRTREADYB 1 +#define V_HSSPRTREADYB(x) ((x) << S_HSSPRTREADYB) +#define F_HSSPRTREADYB V_HSSPRTREADYB(1U) + +#define S_HSSPRTREADYA 0 +#define V_HSSPRTREADYA(x) ((x) << S_HSSPRTREADYA) +#define F_HSSPRTREADYA V_HSSPRTREADYA(1U) + +#define A_MAC_PORT_HSS_EEE_STATUS 0x908 + +#define S_RXAQUIET_STATUS 15 +#define V_RXAQUIET_STATUS(x) ((x) << S_RXAQUIET_STATUS) +#define F_RXAQUIET_STATUS V_RXAQUIET_STATUS(1U) + +#define S_RXAREFRESH_STATUS 14 +#define V_RXAREFRESH_STATUS(x) ((x) << S_RXAREFRESH_STATUS) +#define F_RXAREFRESH_STATUS V_RXAREFRESH_STATUS(1U) + +#define S_RXBQUIET_STATUS 13 +#define V_RXBQUIET_STATUS(x) ((x) << S_RXBQUIET_STATUS) +#define F_RXBQUIET_STATUS V_RXBQUIET_STATUS(1U) + +#define S_RXBREFRESH_STATUS 12 +#define V_RXBREFRESH_STATUS(x) ((x) << S_RXBREFRESH_STATUS) +#define F_RXBREFRESH_STATUS V_RXBREFRESH_STATUS(1U) + +#define S_RXCQUIET_STATUS 11 +#define V_RXCQUIET_STATUS(x) ((x) << S_RXCQUIET_STATUS) +#define F_RXCQUIET_STATUS V_RXCQUIET_STATUS(1U) + +#define S_RXCREFRESH_STATUS 10 +#define V_RXCREFRESH_STATUS(x) ((x) << S_RXCREFRESH_STATUS) +#define F_RXCREFRESH_STATUS V_RXCREFRESH_STATUS(1U) + +#define S_RXDQUIET_STATUS 9 +#define V_RXDQUIET_STATUS(x) ((x) << S_RXDQUIET_STATUS) +#define F_RXDQUIET_STATUS V_RXDQUIET_STATUS(1U) + +#define S_RXDREFRESH_STATUS 8 +#define V_RXDREFRESH_STATUS(x) ((x) << S_RXDREFRESH_STATUS) +#define F_RXDREFRESH_STATUS V_RXDREFRESH_STATUS(1U) + +#define S_TXAQUIET_STATUS 7 +#define V_TXAQUIET_STATUS(x) ((x) << S_TXAQUIET_STATUS) +#define F_TXAQUIET_STATUS V_TXAQUIET_STATUS(1U) + +#define S_TXAREFRESH_STATUS 6 +#define V_TXAREFRESH_STATUS(x) ((x) << S_TXAREFRESH_STATUS) +#define F_TXAREFRESH_STATUS V_TXAREFRESH_STATUS(1U) + +#define S_TXBQUIET_STATUS 5 +#define V_TXBQUIET_STATUS(x) ((x) << S_TXBQUIET_STATUS) +#define F_TXBQUIET_STATUS V_TXBQUIET_STATUS(1U) + +#define S_TXBREFRESH_STATUS 4 +#define V_TXBREFRESH_STATUS(x) ((x) << S_TXBREFRESH_STATUS) +#define F_TXBREFRESH_STATUS V_TXBREFRESH_STATUS(1U) + +#define S_TXCQUIET_STATUS 3 +#define V_TXCQUIET_STATUS(x) ((x) << S_TXCQUIET_STATUS) +#define F_TXCQUIET_STATUS V_TXCQUIET_STATUS(1U) + +#define S_TXCREFRESH_STATUS 2 +#define V_TXCREFRESH_STATUS(x) ((x) << S_TXCREFRESH_STATUS) +#define F_TXCREFRESH_STATUS V_TXCREFRESH_STATUS(1U) + +#define S_TXDQUIET_STATUS 1 +#define V_TXDQUIET_STATUS(x) ((x) << S_TXDQUIET_STATUS) +#define F_TXDQUIET_STATUS V_TXDQUIET_STATUS(1U) + +#define S_TXDREFRESH_STATUS 0 +#define V_TXDREFRESH_STATUS(x) ((x) << S_TXDREFRESH_STATUS) +#define F_TXDREFRESH_STATUS V_TXDREFRESH_STATUS(1U) + +#define A_MAC_PORT_HSS_SIGDET_STATUS 0x90c +#define A_MAC_PORT_HSS_PL_CTL 0x910 + +#define S_TOV 16 +#define M_TOV 0xffU +#define V_TOV(x) ((x) << S_TOV) +#define G_TOV(x) (((x) >> S_TOV) & M_TOV) + +#define S_TSU 8 +#define M_TSU 0xffU +#define V_TSU(x) ((x) << S_TSU) +#define G_TSU(x) (((x) >> S_TSU) & M_TSU) + +#define S_IPW 0 +#define M_IPW 0xffU +#define V_IPW(x) ((x) << S_IPW) +#define G_IPW(x) (((x) >> S_IPW) & M_IPW) + +#define A_MAC_PORT_RUNT_FRAME 0x914 + +#define S_RUNTCLEAR 16 +#define V_RUNTCLEAR(x) ((x) << S_RUNTCLEAR) +#define F_RUNTCLEAR V_RUNTCLEAR(1U) + +#define S_RUNT 0 +#define M_RUNT 0xffffU +#define V_RUNT(x) ((x) << S_RUNT) +#define G_RUNT(x) (((x) >> S_RUNT) & M_RUNT) + +#define A_MAC_PORT_EEE_STATUS 0x918 + +#define S_EEE_TX_10G_STATE 10 +#define M_EEE_TX_10G_STATE 0x3U +#define V_EEE_TX_10G_STATE(x) ((x) << S_EEE_TX_10G_STATE) +#define G_EEE_TX_10G_STATE(x) (((x) >> S_EEE_TX_10G_STATE) & M_EEE_TX_10G_STATE) + +#define S_EEE_RX_10G_STATE 8 +#define M_EEE_RX_10G_STATE 0x3U +#define V_EEE_RX_10G_STATE(x) ((x) << S_EEE_RX_10G_STATE) +#define G_EEE_RX_10G_STATE(x) (((x) >> S_EEE_RX_10G_STATE) & M_EEE_RX_10G_STATE) + +#define S_EEE_TX_1G_STATE 6 +#define M_EEE_TX_1G_STATE 0x3U +#define V_EEE_TX_1G_STATE(x) ((x) << S_EEE_TX_1G_STATE) +#define G_EEE_TX_1G_STATE(x) (((x) >> S_EEE_TX_1G_STATE) & M_EEE_TX_1G_STATE) + +#define S_EEE_RX_1G_STATE 4 +#define M_EEE_RX_1G_STATE 0x3U +#define V_EEE_RX_1G_STATE(x) ((x) << S_EEE_RX_1G_STATE) +#define G_EEE_RX_1G_STATE(x) (((x) >> S_EEE_RX_1G_STATE) & M_EEE_RX_1G_STATE) + +#define S_PMA_RX_REFRESH 3 +#define V_PMA_RX_REFRESH(x) ((x) << S_PMA_RX_REFRESH) +#define F_PMA_RX_REFRESH V_PMA_RX_REFRESH(1U) + +#define S_PMA_RX_QUIET 2 +#define V_PMA_RX_QUIET(x) ((x) << S_PMA_RX_QUIET) +#define F_PMA_RX_QUIET V_PMA_RX_QUIET(1U) + +#define S_PMA_TX_REFRESH 1 +#define V_PMA_TX_REFRESH(x) ((x) << S_PMA_TX_REFRESH) +#define F_PMA_TX_REFRESH V_PMA_TX_REFRESH(1U) + +#define S_PMA_TX_QUIET 0 +#define V_PMA_TX_QUIET(x) ((x) << S_PMA_TX_QUIET) +#define F_PMA_TX_QUIET V_PMA_TX_QUIET(1U) + +#define A_MAC_PORT_CGEN 0x91c + +#define S_CGEN 8 +#define V_CGEN(x) ((x) << S_CGEN) +#define F_CGEN V_CGEN(1U) + +#define S_SD7_CGEN 7 +#define V_SD7_CGEN(x) ((x) << S_SD7_CGEN) +#define F_SD7_CGEN V_SD7_CGEN(1U) + +#define S_SD6_CGEN 6 +#define V_SD6_CGEN(x) ((x) << S_SD6_CGEN) +#define F_SD6_CGEN V_SD6_CGEN(1U) + +#define S_SD5_CGEN 5 +#define V_SD5_CGEN(x) ((x) << S_SD5_CGEN) +#define F_SD5_CGEN V_SD5_CGEN(1U) + +#define S_SD4_CGEN 4 +#define V_SD4_CGEN(x) ((x) << S_SD4_CGEN) +#define F_SD4_CGEN V_SD4_CGEN(1U) + +#define S_SD3_CGEN 3 +#define V_SD3_CGEN(x) ((x) << S_SD3_CGEN) +#define F_SD3_CGEN V_SD3_CGEN(1U) + +#define S_SD2_CGEN 2 +#define V_SD2_CGEN(x) ((x) << S_SD2_CGEN) +#define F_SD2_CGEN V_SD2_CGEN(1U) + +#define S_SD1_CGEN 1 +#define V_SD1_CGEN(x) ((x) << S_SD1_CGEN) +#define F_SD1_CGEN V_SD1_CGEN(1U) + +#define S_SD0_CGEN 0 +#define V_SD0_CGEN(x) ((x) << S_SD0_CGEN) +#define F_SD0_CGEN V_SD0_CGEN(1U) + +#define A_MAC_PORT_CGEN_MTIP 0x920 + +#define S_MACSEG5_CGEN 11 +#define V_MACSEG5_CGEN(x) ((x) << S_MACSEG5_CGEN) +#define F_MACSEG5_CGEN V_MACSEG5_CGEN(1U) + +#define S_PCSSEG5_CGEN 10 +#define V_PCSSEG5_CGEN(x) ((x) << S_PCSSEG5_CGEN) +#define F_PCSSEG5_CGEN V_PCSSEG5_CGEN(1U) + +#define S_MACSEG4_CGEN 9 +#define V_MACSEG4_CGEN(x) ((x) << S_MACSEG4_CGEN) +#define F_MACSEG4_CGEN V_MACSEG4_CGEN(1U) + +#define S_PCSSEG4_CGEN 8 +#define V_PCSSEG4_CGEN(x) ((x) << S_PCSSEG4_CGEN) +#define F_PCSSEG4_CGEN V_PCSSEG4_CGEN(1U) + +#define S_MACSEG3_CGEN 7 +#define V_MACSEG3_CGEN(x) ((x) << S_MACSEG3_CGEN) +#define F_MACSEG3_CGEN V_MACSEG3_CGEN(1U) + +#define S_PCSSEG3_CGEN 6 +#define V_PCSSEG3_CGEN(x) ((x) << S_PCSSEG3_CGEN) +#define F_PCSSEG3_CGEN V_PCSSEG3_CGEN(1U) + +#define S_MACSEG2_CGEN 5 +#define V_MACSEG2_CGEN(x) ((x) << S_MACSEG2_CGEN) +#define F_MACSEG2_CGEN V_MACSEG2_CGEN(1U) + +#define S_PCSSEG2_CGEN 4 +#define V_PCSSEG2_CGEN(x) ((x) << S_PCSSEG2_CGEN) +#define F_PCSSEG2_CGEN V_PCSSEG2_CGEN(1U) + +#define S_MACSEG1_CGEN 3 +#define V_MACSEG1_CGEN(x) ((x) << S_MACSEG1_CGEN) +#define F_MACSEG1_CGEN V_MACSEG1_CGEN(1U) + +#define S_PCSSEG1_CGEN 2 +#define V_PCSSEG1_CGEN(x) ((x) << S_PCSSEG1_CGEN) +#define F_PCSSEG1_CGEN V_PCSSEG1_CGEN(1U) + +#define S_MACSEG0_CGEN 1 +#define V_MACSEG0_CGEN(x) ((x) << S_MACSEG0_CGEN) +#define F_MACSEG0_CGEN V_MACSEG0_CGEN(1U) + +#define S_PCSSEG0_CGEN 0 +#define V_PCSSEG0_CGEN(x) ((x) << S_PCSSEG0_CGEN) +#define F_PCSSEG0_CGEN V_PCSSEG0_CGEN(1U) + +#define A_MAC_PORT_TX_TS_ID 0x924 + +#define S_TS_ID 0 +#define M_TS_ID 0x7U +#define V_TS_ID(x) ((x) << S_TS_ID) +#define G_TS_ID(x) (((x) >> S_TS_ID) & M_TS_ID) + +#define A_MAC_PORT_TX_TS_VAL_LO 0x928 +#define A_MAC_PORT_TX_TS_VAL_HI 0x92c +#define A_MAC_PORT_EEE_CTL 0x930 + +#define S_EEE_CTRL 2 +#define M_EEE_CTRL 0x3fffffffU +#define V_EEE_CTRL(x) ((x) << S_EEE_CTRL) +#define G_EEE_CTRL(x) (((x) >> S_EEE_CTRL) & M_EEE_CTRL) + +#define S_TICK_START 1 +#define V_TICK_START(x) ((x) << S_TICK_START) +#define F_TICK_START V_TICK_START(1U) + +#define S_EEE_ENABLE 0 +#define V_EEE_ENABLE(x) ((x) << S_EEE_ENABLE) +#define F_EEE_ENABLE V_EEE_ENABLE(1U) + +#define A_MAC_PORT_EEE_TX_CTL 0x934 + +#define S_WAKE_TIMER 16 +#define M_WAKE_TIMER 0xffffU +#define V_WAKE_TIMER(x) ((x) << S_WAKE_TIMER) +#define G_WAKE_TIMER(x) (((x) >> S_WAKE_TIMER) & M_WAKE_TIMER) + +#define S_HSS_TIMER 5 +#define M_HSS_TIMER 0xfU +#define V_HSS_TIMER(x) ((x) << S_HSS_TIMER) +#define G_HSS_TIMER(x) (((x) >> S_HSS_TIMER) & M_HSS_TIMER) + +#define S_HSS_CTL 4 +#define V_HSS_CTL(x) ((x) << S_HSS_CTL) +#define F_HSS_CTL V_HSS_CTL(1U) + +#define S_LPI_ACTIVE 3 +#define V_LPI_ACTIVE(x) ((x) << S_LPI_ACTIVE) +#define F_LPI_ACTIVE V_LPI_ACTIVE(1U) + +#define S_LPI_TXHOLD 2 +#define V_LPI_TXHOLD(x) ((x) << S_LPI_TXHOLD) +#define F_LPI_TXHOLD V_LPI_TXHOLD(1U) + +#define S_LPI_REQ 1 +#define V_LPI_REQ(x) ((x) << S_LPI_REQ) +#define F_LPI_REQ V_LPI_REQ(1U) + +#define S_EEE_TX_RESET 0 +#define V_EEE_TX_RESET(x) ((x) << S_EEE_TX_RESET) +#define F_EEE_TX_RESET V_EEE_TX_RESET(1U) + +#define A_MAC_PORT_EEE_RX_CTL 0x938 + +#define S_LPI_IND 1 +#define V_LPI_IND(x) ((x) << S_LPI_IND) +#define F_LPI_IND V_LPI_IND(1U) + +#define S_EEE_RX_RESET 0 +#define V_EEE_RX_RESET(x) ((x) << S_EEE_RX_RESET) +#define F_EEE_RX_RESET V_EEE_RX_RESET(1U) + +#define A_MAC_PORT_EEE_TX_10G_SLEEP_TIMER 0x93c +#define A_MAC_PORT_EEE_TX_10G_QUIET_TIMER 0x940 +#define A_MAC_PORT_EEE_TX_10G_WAKE_TIMER 0x944 +#define A_MAC_PORT_EEE_TX_1G_SLEEP_TIMER 0x948 +#define A_MAC_PORT_EEE_TX_1G_QUIET_TIMER 0x94c +#define A_MAC_PORT_EEE_TX_1G_REFRESH_TIMER 0x950 +#define A_MAC_PORT_EEE_RX_10G_QUIET_TIMER 0x954 +#define A_MAC_PORT_EEE_RX_10G_WAKE_TIMER 0x958 +#define A_MAC_PORT_EEE_RX_10G_WF_TIMER 0x95c +#define A_MAC_PORT_EEE_RX_1G_QUIET_TIMER 0x960 +#define A_MAC_PORT_EEE_RX_1G_WAKE_TIMER 0x964 +#define A_MAC_PORT_EEE_WF_COUNT 0x968 + +#define S_WAKE_CNT_CLR 16 +#define V_WAKE_CNT_CLR(x) ((x) << S_WAKE_CNT_CLR) +#define F_WAKE_CNT_CLR V_WAKE_CNT_CLR(1U) + +#define S_WAKE_CNT 0 +#define M_WAKE_CNT 0xffffU +#define V_WAKE_CNT(x) ((x) << S_WAKE_CNT) +#define G_WAKE_CNT(x) (((x) >> S_WAKE_CNT) & M_WAKE_CNT) + +#define A_MAC_PORT_PTP_TIMER_RD0_LO 0x96c +#define A_MAC_PORT_PTP_TIMER_RD0_HI 0x970 +#define A_MAC_PORT_PTP_TIMER_RD1_LO 0x974 +#define A_MAC_PORT_PTP_TIMER_RD1_HI 0x978 +#define A_MAC_PORT_PTP_TIMER_WR_LO 0x97c +#define A_MAC_PORT_PTP_TIMER_WR_HI 0x980 +#define A_MAC_PORT_PTP_TIMER_OFFSET_0 0x984 +#define A_MAC_PORT_PTP_TIMER_OFFSET_1 0x988 +#define A_MAC_PORT_PTP_TIMER_OFFSET_2 0x98c + +#define S_PTP_OFFSET 0 +#define M_PTP_OFFSET 0xffU +#define V_PTP_OFFSET(x) ((x) << S_PTP_OFFSET) +#define G_PTP_OFFSET(x) (((x) >> S_PTP_OFFSET) & M_PTP_OFFSET) + +#define A_MAC_PORT_PTP_SUM_LO 0x990 +#define A_MAC_PORT_PTP_SUM_HI 0x994 +#define A_MAC_PORT_PTP_TIMER_INCR0 0x998 + +#define S_Y 16 +#define M_Y 0xffffU +#define V_Y(x) ((x) << S_Y) +#define G_Y(x) (((x) >> S_Y) & M_Y) + +#define S_X 0 +#define M_X 0xffffU +#define V_X(x) ((x) << S_X) +#define G_X(x) (((x) >> S_X) & M_X) + +#define A_MAC_PORT_PTP_TIMER_INCR1 0x99c + +#define S_Y_TICK 16 +#define M_Y_TICK 0xffffU +#define V_Y_TICK(x) ((x) << S_Y_TICK) +#define G_Y_TICK(x) (((x) >> S_Y_TICK) & M_Y_TICK) + +#define S_X_TICK 0 +#define M_X_TICK 0xffffU +#define V_X_TICK(x) ((x) << S_X_TICK) +#define G_X_TICK(x) (((x) >> S_X_TICK) & M_X_TICK) + +#define A_MAC_PORT_PTP_DRIFT_ADJUST_COUNT 0x9a0 +#define A_MAC_PORT_PTP_OFFSET_ADJUST_FINE 0x9a4 + +#define S_B 16 +#define M_B 0xffffU +#define V_B(x) ((x) << S_B) +#define G_B(x) (((x) >> S_B) & M_B) + +#define S_A 0 +#define M_A 0xffffU +#define V_A(x) ((x) << S_A) +#define G_A(x) (((x) >> S_A) & M_A) + +#define A_MAC_PORT_PTP_OFFSET_ADJUST_TOTAL 0x9a8 +#define A_MAC_PORT_PTP_CFG 0x9ac + +#define S_FRZ 18 +#define V_FRZ(x) ((x) << S_FRZ) +#define F_FRZ V_FRZ(1U) + +#define S_OFFSER_ADJUST_SIGN 17 +#define V_OFFSER_ADJUST_SIGN(x) ((x) << S_OFFSER_ADJUST_SIGN) +#define F_OFFSER_ADJUST_SIGN V_OFFSER_ADJUST_SIGN(1U) + +#define S_ADD_OFFSET 16 +#define V_ADD_OFFSET(x) ((x) << S_ADD_OFFSET) +#define F_ADD_OFFSET V_ADD_OFFSET(1U) + +#define S_CYCLE1 8 +#define M_CYCLE1 0xffU +#define V_CYCLE1(x) ((x) << S_CYCLE1) +#define G_CYCLE1(x) (((x) >> S_CYCLE1) & M_CYCLE1) + +#define S_Q 0 +#define M_Q 0xffU +#define V_Q(x) ((x) << S_Q) +#define G_Q(x) (((x) >> S_Q) & M_Q) + +#define A_MAC_PORT_MTIP_REVISION 0xa00 + +#define S_CUSTREV 16 +#define M_CUSTREV 0xffffU +#define V_CUSTREV(x) ((x) << S_CUSTREV) +#define G_CUSTREV(x) (((x) >> S_CUSTREV) & M_CUSTREV) + +#define S_VER 8 +#define M_VER 0xffU +#define V_VER(x) ((x) << S_VER) +#define G_VER(x) (((x) >> S_VER) & M_VER) + +#define S_MTIP_REV 0 +#define M_MTIP_REV 0xffU +#define V_MTIP_REV(x) ((x) << S_MTIP_REV) +#define G_MTIP_REV(x) (((x) >> S_MTIP_REV) & M_MTIP_REV) + +#define A_MAC_PORT_MTIP_SCRATCH 0xa04 +#define A_MAC_PORT_MTIP_COMMAND_CONFIG 0xa08 + +#define S_TX_FLUSH_ENABLE 22 +#define V_TX_FLUSH_ENABLE(x) ((x) << S_TX_FLUSH_ENABLE) +#define F_TX_FLUSH_ENABLE V_TX_FLUSH_ENABLE(1U) + +#define S_RX_SFD_ANY 21 +#define V_RX_SFD_ANY(x) ((x) << S_RX_SFD_ANY) +#define F_RX_SFD_ANY V_RX_SFD_ANY(1U) + +#define S_PAUSE_PFC_COMP 20 +#define V_PAUSE_PFC_COMP(x) ((x) << S_PAUSE_PFC_COMP) +#define F_PAUSE_PFC_COMP V_PAUSE_PFC_COMP(1U) + +#define S_PFC_MODE 19 +#define V_PFC_MODE(x) ((x) << S_PFC_MODE) +#define F_PFC_MODE V_PFC_MODE(1U) + +#define S_RS_COL_CNT_EXT 18 +#define V_RS_COL_CNT_EXT(x) ((x) << S_RS_COL_CNT_EXT) +#define F_RS_COL_CNT_EXT V_RS_COL_CNT_EXT(1U) + +#define S_NO_LGTH_CHECK 17 +#define V_NO_LGTH_CHECK(x) ((x) << S_NO_LGTH_CHECK) +#define F_NO_LGTH_CHECK V_NO_LGTH_CHECK(1U) + +#define S_SEND_IDLE 16 +#define V_SEND_IDLE(x) ((x) << S_SEND_IDLE) +#define F_SEND_IDLE V_SEND_IDLE(1U) + +#define S_PHY_TXENA 15 +#define V_PHY_TXENA(x) ((x) << S_PHY_TXENA) +#define F_PHY_TXENA V_PHY_TXENA(1U) + +#define S_RX_ERR_DISC 14 +#define V_RX_ERR_DISC(x) ((x) << S_RX_ERR_DISC) +#define F_RX_ERR_DISC V_RX_ERR_DISC(1U) + +#define S_CMD_FRAME_ENA 13 +#define V_CMD_FRAME_ENA(x) ((x) << S_CMD_FRAME_ENA) +#define F_CMD_FRAME_ENA V_CMD_FRAME_ENA(1U) + +#define S_SW_RESET 12 +#define V_SW_RESET(x) ((x) << S_SW_RESET) +#define F_SW_RESET V_SW_RESET(1U) + +#define S_TX_PAD_EN 11 +#define V_TX_PAD_EN(x) ((x) << S_TX_PAD_EN) +#define F_TX_PAD_EN V_TX_PAD_EN(1U) + +#define S_PHY_LOOPBACK_EN 10 +#define V_PHY_LOOPBACK_EN(x) ((x) << S_PHY_LOOPBACK_EN) +#define F_PHY_LOOPBACK_EN V_PHY_LOOPBACK_EN(1U) + +#define S_TX_ADDR_INS 9 +#define V_TX_ADDR_INS(x) ((x) << S_TX_ADDR_INS) +#define F_TX_ADDR_INS V_TX_ADDR_INS(1U) + +#define S_PAUSE_IGNORE 8 +#define V_PAUSE_IGNORE(x) ((x) << S_PAUSE_IGNORE) +#define F_PAUSE_IGNORE V_PAUSE_IGNORE(1U) + +#define S_PAUSE_FWD 7 +#define V_PAUSE_FWD(x) ((x) << S_PAUSE_FWD) +#define F_PAUSE_FWD V_PAUSE_FWD(1U) + +#define S_CRC_FWD 6 +#define V_CRC_FWD(x) ((x) << S_CRC_FWD) +#define F_CRC_FWD V_CRC_FWD(1U) + +#define S_PAD_EN 5 +#define V_PAD_EN(x) ((x) << S_PAD_EN) +#define F_PAD_EN V_PAD_EN(1U) + +#define S_PROMIS_EN 4 +#define V_PROMIS_EN(x) ((x) << S_PROMIS_EN) +#define F_PROMIS_EN V_PROMIS_EN(1U) + +#define S_WAN_MODE 3 +#define V_WAN_MODE(x) ((x) << S_WAN_MODE) +#define F_WAN_MODE V_WAN_MODE(1U) + +#define S_RX_ENA 1 +#define V_RX_ENA(x) ((x) << S_RX_ENA) +#define F_RX_ENA V_RX_ENA(1U) + +#define S_TX_ENA 0 +#define V_TX_ENA(x) ((x) << S_TX_ENA) +#define F_TX_ENA V_TX_ENA(1U) + +#define A_MAC_PORT_MTIP_MAC_ADDR_0 0xa0c +#define A_MAC_PORT_MTIP_MAC_ADDR_1 0xa10 + +#define S_MACADDRHI 0 +#define M_MACADDRHI 0xffffU +#define V_MACADDRHI(x) ((x) << S_MACADDRHI) +#define G_MACADDRHI(x) (((x) >> S_MACADDRHI) & M_MACADDRHI) + +#define A_MAC_PORT_MTIP_FRM_LENGTH 0xa14 + +#define S_LEN 0 +#define M_LEN 0xffffU +#define V_LEN(x) ((x) << S_LEN) +#define G_LEN(x) (((x) >> S_LEN) & M_LEN) + +#define A_MAC_PORT_MTIP_RX_FIFO_SECTIONS 0xa1c + +#define S_AVAIL 16 +#define M_AVAIL 0xffffU +#define V_AVAIL(x) ((x) << S_AVAIL) +#define G_AVAIL(x) (((x) >> S_AVAIL) & M_AVAIL) + +#define S_EMPTY 0 +#define M_EMPTY 0xffffU +#define V_EMPTY(x) ((x) << S_EMPTY) +#define G_EMPTY(x) (((x) >> S_EMPTY) & M_EMPTY) + +#define A_MAC_PORT_MTIP_TX_FIFO_SECTIONS 0xa20 +#define A_MAC_PORT_MTIP_RX_FIFO_ALMOST_F_E 0xa24 + +#define S_ALMSTFULL 16 +#define M_ALMSTFULL 0xffffU +#define V_ALMSTFULL(x) ((x) << S_ALMSTFULL) +#define G_ALMSTFULL(x) (((x) >> S_ALMSTFULL) & M_ALMSTFULL) + +#define S_ALMSTEMPTY 0 +#define M_ALMSTEMPTY 0xffffU +#define V_ALMSTEMPTY(x) ((x) << S_ALMSTEMPTY) +#define G_ALMSTEMPTY(x) (((x) >> S_ALMSTEMPTY) & M_ALMSTEMPTY) + +#define A_MAC_PORT_MTIP_TX_FIFO_ALMOST_F_E 0xa28 +#define A_MAC_PORT_MTIP_HASHTABLE_LOAD 0xa2c + +#define S_ENABLE_MCAST_RX 8 +#define V_ENABLE_MCAST_RX(x) ((x) << S_ENABLE_MCAST_RX) +#define F_ENABLE_MCAST_RX V_ENABLE_MCAST_RX(1U) + +#define S_HASHTABLE_ADDR 0 +#define M_HASHTABLE_ADDR 0x3fU +#define V_HASHTABLE_ADDR(x) ((x) << S_HASHTABLE_ADDR) +#define G_HASHTABLE_ADDR(x) (((x) >> S_HASHTABLE_ADDR) & M_HASHTABLE_ADDR) + +#define A_MAC_PORT_MTIP_MAC_STATUS 0xa40 + +#define S_TS_AVAIL 3 +#define V_TS_AVAIL(x) ((x) << S_TS_AVAIL) +#define F_TS_AVAIL V_TS_AVAIL(1U) + +#define S_PHY_LOS 2 +#define V_PHY_LOS(x) ((x) << S_PHY_LOS) +#define F_PHY_LOS V_PHY_LOS(1U) + +#define S_RX_REM_FAULT 1 +#define V_RX_REM_FAULT(x) ((x) << S_RX_REM_FAULT) +#define F_RX_REM_FAULT V_RX_REM_FAULT(1U) + +#define S_RX_LOC_FAULT 0 +#define V_RX_LOC_FAULT(x) ((x) << S_RX_LOC_FAULT) +#define F_RX_LOC_FAULT V_RX_LOC_FAULT(1U) + +#define A_MAC_PORT_MTIP_TX_IPG_LENGTH 0xa44 + +#define S_IPG 0 +#define M_IPG 0x7fU +#define V_IPG(x) ((x) << S_IPG) +#define G_IPG(x) (((x) >> S_IPG) & M_IPG) + +#define A_MAC_PORT_MTIP_MAC_CREDIT_TRIGGER 0xa48 + +#define S_RXFIFORST 0 +#define V_RXFIFORST(x) ((x) << S_RXFIFORST) +#define F_RXFIFORST V_RXFIFORST(1U) + +#define A_MAC_PORT_MTIP_INIT_CREDIT 0xa4c + +#define S_MACCRDRST 0 +#define M_MACCRDRST 0xffU +#define V_MACCRDRST(x) ((x) << S_MACCRDRST) +#define G_MACCRDRST(x) (((x) >> S_MACCRDRST) & M_MACCRDRST) + +#define A_MAC_PORT_MTIP_CURRENT_CREDIT 0xa50 + +#define S_INITCREDIT 0 +#define M_INITCREDIT 0xffU +#define V_INITCREDIT(x) ((x) << S_INITCREDIT) +#define G_INITCREDIT(x) (((x) >> S_INITCREDIT) & M_INITCREDIT) + +#define A_MAC_PORT_RX_PAUSE_STATUS 0xa74 + +#define S_STATUS 0 +#define M_STATUS 0xffU +#define V_STATUS(x) ((x) << S_STATUS) +#define G_STATUS(x) (((x) >> S_STATUS) & M_STATUS) + +#define A_MAC_PORT_MTIP_TS_TIMESTAMP 0xa7c +#define A_MAC_PORT_AFRAMESTRANSMITTEDOK 0xa80 +#define A_MAC_PORT_AFRAMESTRANSMITTEDOKHI 0xa84 +#define A_MAC_PORT_AFRAMESRECEIVEDOK 0xa88 +#define A_MAC_PORT_AFRAMESRECEIVEDOKHI 0xa8c +#define A_MAC_PORT_AFRAMECHECKSEQUENCEERRORS 0xa90 +#define A_MAC_PORT_AFRAMECHECKSEQUENCEERRORSHI 0xa94 +#define A_MAC_PORT_AALIGNMENTERRORS 0xa98 +#define A_MAC_PORT_AALIGNMENTERRORSHI 0xa9c +#define A_MAC_PORT_APAUSEMACCTRLFRAMESTRANSMITTED 0xaa0 +#define A_MAC_PORT_APAUSEMACCTRLFRAMESTRANSMITTEDHI 0xaa4 +#define A_MAC_PORT_APAUSEMACCTRLFRAMESRECEIVED 0xaa8 +#define A_MAC_PORT_APAUSEMACCTRLFRAMESRECEIVEDHI 0xaac +#define A_MAC_PORT_AFRAMETOOLONGERRORS 0xab0 +#define A_MAC_PORT_AFRAMETOOLONGERRORSHI 0xab4 +#define A_MAC_PORT_AINRANGELENGTHERRORS 0xab8 +#define A_MAC_PORT_AINRANGELENGTHERRORSHI 0xabc +#define A_MAC_PORT_VLANTRANSMITTEDOK 0xac0 +#define A_MAC_PORT_VLANTRANSMITTEDOKHI 0xac4 +#define A_MAC_PORT_VLANRECEIVEDOK 0xac8 +#define A_MAC_PORT_VLANRECEIVEDOKHI 0xacc +#define A_MAC_PORT_AOCTETSTRANSMITTEDOK 0xad0 +#define A_MAC_PORT_AOCTETSTRANSMITTEDOKHI 0xad4 +#define A_MAC_PORT_AOCTETSRECEIVEDOK 0xad8 +#define A_MAC_PORT_AOCTETSRECEIVEDOKHI 0xadc +#define A_MAC_PORT_IFINUCASTPKTS 0xae0 +#define A_MAC_PORT_IFINUCASTPKTSHI 0xae4 +#define A_MAC_PORT_IFINMULTICASTPKTS 0xae8 +#define A_MAC_PORT_IFINMULTICASTPKTSHI 0xaec +#define A_MAC_PORT_IFINBROADCASTPKTS 0xaf0 +#define A_MAC_PORT_IFINBROADCASTPKTSHI 0xaf4 +#define A_MAC_PORT_IFOUTERRORS 0xaf8 +#define A_MAC_PORT_IFOUTERRORSHI 0xafc +#define A_MAC_PORT_IFOUTUCASTPKTS 0xb08 +#define A_MAC_PORT_IFOUTUCASTPKTSHI 0xb0c +#define A_MAC_PORT_IFOUTMULTICASTPKTS 0xb10 +#define A_MAC_PORT_IFOUTMULTICASTPKTSHI 0xb14 +#define A_MAC_PORT_IFOUTBROADCASTPKTS 0xb18 +#define A_MAC_PORT_IFOUTBROADCASTPKTSHI 0xb1c +#define A_MAC_PORT_ETHERSTATSDROPEVENTS 0xb20 +#define A_MAC_PORT_ETHERSTATSDROPEVENTSHI 0xb24 +#define A_MAC_PORT_ETHERSTATSOCTETS 0xb28 +#define A_MAC_PORT_ETHERSTATSOCTETSHI 0xb2c +#define A_MAC_PORT_ETHERSTATSPKTS 0xb30 +#define A_MAC_PORT_ETHERSTATSPKTSHI 0xb34 +#define A_MAC_PORT_ETHERSTATSUNDERSIZEPKTS 0xb38 +#define A_MAC_PORT_ETHERSTATSUNDERSIZEPKTSHI 0xb3c +#define A_MAC_PORT_ETHERSTATSPKTS64OCTETS 0xb40 +#define A_MAC_PORT_ETHERSTATSPKTS64OCTETSHI 0xb44 +#define A_MAC_PORT_ETHERSTATSPKTS65TO127OCTETS 0xb48 +#define A_MAC_PORT_ETHERSTATSPKTS65TO127OCTETSHI 0xb4c +#define A_MAC_PORT_ETHERSTATSPKTS128TO255OCTETS 0xb50 +#define A_MAC_PORT_ETHERSTATSPKTS128TO255OCTETSHI 0xb54 +#define A_MAC_PORT_ETHERSTATSPKTS256TO511OCTETS 0xb58 +#define A_MAC_PORT_ETHERSTATSPKTS256TO511OCTETSHI 0xb5c +#define A_MAC_PORT_ETHERSTATSPKTS512TO1023OCTETS 0xb60 +#define A_MAC_PORT_ETHERSTATSPKTS512TO1023OCTETSHI 0xb64 +#define A_MAC_PORT_ETHERSTATSPKTS1024TO1518OCTETS 0xb68 +#define A_MAC_PORT_ETHERSTATSPKTS1024TO1518OCTETSHI 0xb6c +#define A_MAC_PORT_ETHERSTATSPKTS1519TOMAXOCTETS 0xb70 +#define A_MAC_PORT_ETHERSTATSPKTS1519TOMAXOCTETSHI 0xb74 +#define A_MAC_PORT_ETHERSTATSOVERSIZEPKTS 0xb78 +#define A_MAC_PORT_ETHERSTATSOVERSIZEPKTSHI 0xb7c +#define A_MAC_PORT_ETHERSTATSJABBERS 0xb80 +#define A_MAC_PORT_ETHERSTATSJABBERSHI 0xb84 +#define A_MAC_PORT_ETHERSTATSFRAGMENTS 0xb88 +#define A_MAC_PORT_ETHERSTATSFRAGMENTSHI 0xb8c +#define A_MAC_PORT_IFINERRORS 0xb90 +#define A_MAC_PORT_IFINERRORSHI 0xb94 +#define A_MAC_PORT_ACBFCPAUSEFRAMESTRANSMITTED_0 0xb98 +#define A_MAC_PORT_ACBFCPAUSEFRAMESTRANSMITTED_0HI 0xb9c +#define A_MAC_PORT_ACBFCPAUSEFRAMESTRANSMITTED_1 0xba0 +#define A_MAC_PORT_ACBFCPAUSEFRAMESTRANSMITTED_1HI 0xba4 +#define A_MAC_PORT_ACBFCPAUSEFRAMESTRANSMITTED_2 0xba8 +#define A_MAC_PORT_ACBFCPAUSEFRAMESTRANSMITTED_2HI 0xbac +#define A_MAC_PORT_ACBFCPAUSEFRAMESTRANSMITTED_3 0xbb0 +#define A_MAC_PORT_ACBFCPAUSEFRAMESTRANSMITTED_3HI 0xbb4 +#define A_MAC_PORT_ACBFCPAUSEFRAMESTRANSMITTED_4 0xbb8 +#define A_MAC_PORT_ACBFCPAUSEFRAMESTRANSMITTED_4HI 0xbbc +#define A_MAC_PORT_ACBFCPAUSEFRAMESTRANSMITTED_5 0xbc0 +#define A_MAC_PORT_ACBFCPAUSEFRAMESTRANSMITTED_5HI 0xbc4 +#define A_MAC_PORT_ACBFCPAUSEFRAMESTRANSMITTED_6 0xbc8 +#define A_MAC_PORT_ACBFCPAUSEFRAMESTRANSMITTED_6HI 0xbcc +#define A_MAC_PORT_ACBFCPAUSEFRAMESTRANSMITTED_7 0xbd0 +#define A_MAC_PORT_ACBFCPAUSEFRAMESTRANSMITTED_7HI 0xbd4 +#define A_MAC_PORT_ACBFCPAUSEFRAMESRECEIVED_0 0xbd8 +#define A_MAC_PORT_ACBFCPAUSEFRAMESRECEIVED_0HI 0xbdc +#define A_MAC_PORT_ACBFCPAUSEFRAMESRECEIVED_1 0xbe0 +#define A_MAC_PORT_ACBFCPAUSEFRAMESRECEIVED_1HI 0xbe4 +#define A_MAC_PORT_ACBFCPAUSEFRAMESRECEIVED_2 0xbe8 +#define A_MAC_PORT_ACBFCPAUSEFRAMESRECEIVED_2HI 0xbec +#define A_MAC_PORT_ACBFCPAUSEFRAMESRECEIVED_3 0xbf0 +#define A_MAC_PORT_ACBFCPAUSEFRAMESRECEIVED_3HI 0xbf4 +#define A_MAC_PORT_ACBFCPAUSEFRAMESRECEIVED_4 0xbf8 +#define A_MAC_PORT_ACBFCPAUSEFRAMESRECEIVED_4HI 0xbfc +#define A_MAC_PORT_ACBFCPAUSEFRAMESRECEIVED_5 0xc00 +#define A_MAC_PORT_ACBFCPAUSEFRAMESRECEIVED_5HI 0xc04 +#define A_MAC_PORT_ACBFCPAUSEFRAMESRECEIVED_6 0xc08 +#define A_MAC_PORT_ACBFCPAUSEFRAMESRECEIVED_6HI 0xc0c +#define A_MAC_PORT_ACBFCPAUSEFRAMESRECEIVED_7 0xc10 +#define A_MAC_PORT_ACBFCPAUSEFRAMESRECEIVED_7HI 0xc14 +#define A_MAC_PORT_AMACCONTROLFRAMESTRANSMITTED 0xc18 +#define A_MAC_PORT_AMACCONTROLFRAMESTRANSMITTEDHI 0xc1c +#define A_MAC_PORT_AMACCONTROLFRAMESRECEIVED 0xc20 +#define A_MAC_PORT_AMACCONTROLFRAMESRECEIVEDHI 0xc24 +#define A_MAC_PORT_MTIP_SGMII_CONTROL 0xd00 + +#define S_RESET 15 +#define V_RESET(x) ((x) << S_RESET) +#define F_RESET V_RESET(1U) + +#define S_LOOPBACK 14 +#define V_LOOPBACK(x) ((x) << S_LOOPBACK) +#define F_LOOPBACK V_LOOPBACK(1U) + +#define S_SPPEDSEL1 13 +#define V_SPPEDSEL1(x) ((x) << S_SPPEDSEL1) +#define F_SPPEDSEL1 V_SPPEDSEL1(1U) + +#define S_AN_EN 12 +#define V_AN_EN(x) ((x) << S_AN_EN) +#define F_AN_EN V_AN_EN(1U) + +#define S_PWRDWN 11 +#define V_PWRDWN(x) ((x) << S_PWRDWN) +#define F_PWRDWN V_PWRDWN(1U) + +#define S_ISOLATE 10 +#define V_ISOLATE(x) ((x) << S_ISOLATE) +#define F_ISOLATE V_ISOLATE(1U) + +#define S_AN_RESTART 9 +#define V_AN_RESTART(x) ((x) << S_AN_RESTART) +#define F_AN_RESTART V_AN_RESTART(1U) + +#define S_DPLX 8 +#define V_DPLX(x) ((x) << S_DPLX) +#define F_DPLX V_DPLX(1U) + +#define S_COLLISIONTEST 7 +#define V_COLLISIONTEST(x) ((x) << S_COLLISIONTEST) +#define F_COLLISIONTEST V_COLLISIONTEST(1U) + +#define S_SPEEDSEL0 6 +#define V_SPEEDSEL0(x) ((x) << S_SPEEDSEL0) +#define F_SPEEDSEL0 V_SPEEDSEL0(1U) + +#define A_MAC_PORT_MTIP_SGMII_STATUS 0xd04 + +#define S_100BASET4 15 +#define V_100BASET4(x) ((x) << S_100BASET4) +#define F_100BASET4 V_100BASET4(1U) + +#define S_100BASEXFULLDPLX 14 +#define V_100BASEXFULLDPLX(x) ((x) << S_100BASEXFULLDPLX) +#define F_100BASEXFULLDPLX V_100BASEXFULLDPLX(1U) + +#define S_100BASEXHALFDPLX 13 +#define V_100BASEXHALFDPLX(x) ((x) << S_100BASEXHALFDPLX) +#define F_100BASEXHALFDPLX V_100BASEXHALFDPLX(1U) + +#define S_10MBPSFULLDPLX 12 +#define V_10MBPSFULLDPLX(x) ((x) << S_10MBPSFULLDPLX) +#define F_10MBPSFULLDPLX V_10MBPSFULLDPLX(1U) + +#define S_10MBPSHALFDPLX 11 +#define V_10MBPSHALFDPLX(x) ((x) << S_10MBPSHALFDPLX) +#define F_10MBPSHALFDPLX V_10MBPSHALFDPLX(1U) + +#define S_100BASET2FULLDPLX 10 +#define V_100BASET2FULLDPLX(x) ((x) << S_100BASET2FULLDPLX) +#define F_100BASET2FULLDPLX V_100BASET2FULLDPLX(1U) + +#define S_100BASET2HALFDPLX 9 +#define V_100BASET2HALFDPLX(x) ((x) << S_100BASET2HALFDPLX) +#define F_100BASET2HALFDPLX V_100BASET2HALFDPLX(1U) + +#define S_EXTDSTATUS 8 +#define V_EXTDSTATUS(x) ((x) << S_EXTDSTATUS) +#define F_EXTDSTATUS V_EXTDSTATUS(1U) + +#define S_SGMII_REM_FAULT 4 +#define V_SGMII_REM_FAULT(x) ((x) << S_SGMII_REM_FAULT) +#define F_SGMII_REM_FAULT V_SGMII_REM_FAULT(1U) + +#define S_JABBERDETECT 1 +#define V_JABBERDETECT(x) ((x) << S_JABBERDETECT) +#define F_JABBERDETECT V_JABBERDETECT(1U) + +#define S_EXTDCAPABILITY 0 +#define V_EXTDCAPABILITY(x) ((x) << S_EXTDCAPABILITY) +#define F_EXTDCAPABILITY V_EXTDCAPABILITY(1U) + +#define A_MAC_PORT_MTIP_SGMII_PHY_IDENTIFIER_0 0xd08 +#define A_MAC_PORT_MTIP_SGMII_PHY_IDENTIFIER_1 0xd0c +#define A_MAC_PORT_MTIP_SGMII_DEV_ABILITY 0xd10 + +#define S_RF2 13 +#define V_RF2(x) ((x) << S_RF2) +#define F_RF2 V_RF2(1U) + +#define S_RF1 12 +#define V_RF1(x) ((x) << S_RF1) +#define F_RF1 V_RF1(1U) + +#define S_PS2 8 +#define V_PS2(x) ((x) << S_PS2) +#define F_PS2 V_PS2(1U) + +#define S_PS1 7 +#define V_PS1(x) ((x) << S_PS1) +#define F_PS1 V_PS1(1U) + +#define S_HD 6 +#define V_HD(x) ((x) << S_HD) +#define F_HD V_HD(1U) + +#define S_FD 5 +#define V_FD(x) ((x) << S_FD) +#define F_FD V_FD(1U) + +#define A_MAC_PORT_MTIP_SGMII_PARTNER_ABILITY 0xd14 + +#define S_CULINKSTATUS 15 +#define V_CULINKSTATUS(x) ((x) << S_CULINKSTATUS) +#define F_CULINKSTATUS V_CULINKSTATUS(1U) + +#define S_CUDPLXSTATUS 12 +#define V_CUDPLXSTATUS(x) ((x) << S_CUDPLXSTATUS) +#define F_CUDPLXSTATUS V_CUDPLXSTATUS(1U) + +#define S_CUSPEED 10 +#define M_CUSPEED 0x3U +#define V_CUSPEED(x) ((x) << S_CUSPEED) +#define G_CUSPEED(x) (((x) >> S_CUSPEED) & M_CUSPEED) + +#define A_MAC_PORT_MTIP_SGMII_AN_EXPANSION 0xd18 + +#define S_PGRCVD 1 +#define V_PGRCVD(x) ((x) << S_PGRCVD) +#define F_PGRCVD V_PGRCVD(1U) + +#define S_REALTIMEPGRCVD 0 +#define V_REALTIMEPGRCVD(x) ((x) << S_REALTIMEPGRCVD) +#define F_REALTIMEPGRCVD V_REALTIMEPGRCVD(1U) + +#define A_MAC_PORT_MTIP_SGMII_DEVICE_NP 0xd1c +#define A_MAC_PORT_MTIP_SGMII_PARTNER_NP 0xd20 +#define A_MAC_PORT_MTIP_SGMII_EXTENDED_STATUS 0xd3c +#define A_MAC_PORT_MTIP_SGMII_LINK_TIMER_LO 0xd48 + +#define S_COUNT_LO 0 +#define M_COUNT_LO 0xffffU +#define V_COUNT_LO(x) ((x) << S_COUNT_LO) +#define G_COUNT_LO(x) (((x) >> S_COUNT_LO) & M_COUNT_LO) + +#define A_MAC_PORT_MTIP_SGMII_LINK_TIMER_HI 0xd4c + +#define S_COUNT_HI 0 +#define M_COUNT_HI 0x1fU +#define V_COUNT_HI(x) ((x) << S_COUNT_HI) +#define G_COUNT_HI(x) (((x) >> S_COUNT_HI) & M_COUNT_HI) + +#define A_MAC_PORT_MTIP_SGMII_IF_MODE 0xd50 + +#define S_SGMII_PCS_ENABLE 5 +#define V_SGMII_PCS_ENABLE(x) ((x) << S_SGMII_PCS_ENABLE) +#define F_SGMII_PCS_ENABLE V_SGMII_PCS_ENABLE(1U) + +#define S_SGMII_HDUPLEX 4 +#define V_SGMII_HDUPLEX(x) ((x) << S_SGMII_HDUPLEX) +#define F_SGMII_HDUPLEX V_SGMII_HDUPLEX(1U) + +#define S_SGMII_SPEED 2 +#define M_SGMII_SPEED 0x3U +#define V_SGMII_SPEED(x) ((x) << S_SGMII_SPEED) +#define G_SGMII_SPEED(x) (((x) >> S_SGMII_SPEED) & M_SGMII_SPEED) + +#define S_USE_SGMII_AN 1 +#define V_USE_SGMII_AN(x) ((x) << S_USE_SGMII_AN) +#define F_USE_SGMII_AN V_USE_SGMII_AN(1U) + +#define S_SGMII_ENA 0 +#define V_SGMII_ENA(x) ((x) << S_SGMII_ENA) +#define F_SGMII_ENA V_SGMII_ENA(1U) + +#define A_MAC_PORT_MTIP_ACT_CTL_SEG 0x1200 + +#define S_ACTIVE 0 +#define M_ACTIVE 0x3fU +#define V_ACTIVE(x) ((x) << S_ACTIVE) +#define G_ACTIVE(x) (((x) >> S_ACTIVE) & M_ACTIVE) + +#define A_MAC_PORT_MTIP_MODE_CTL_SEG 0x1204 + +#define S_MODE_CTL 0 +#define M_MODE_CTL 0x3U +#define V_MODE_CTL(x) ((x) << S_MODE_CTL) +#define G_MODE_CTL(x) (((x) >> S_MODE_CTL) & M_MODE_CTL) + +#define A_MAC_PORT_MTIP_TXCLK_CTL_SEG 0x1208 + +#define S_TXCLK_CTL 0 +#define M_TXCLK_CTL 0xffffU +#define V_TXCLK_CTL(x) ((x) << S_TXCLK_CTL) +#define G_TXCLK_CTL(x) (((x) >> S_TXCLK_CTL) & M_TXCLK_CTL) + +#define A_MAC_PORT_MTIP_TX_PRMBL_CTL_SEG 0x120c +#define A_MAC_PORT_MTIP_WAN_RS_COL_CNT 0x1220 + +#define S_COL_CNT 0 +#define M_COL_CNT 0xffffU +#define V_COL_CNT(x) ((x) << S_COL_CNT) +#define G_COL_CNT(x) (((x) >> S_COL_CNT) & M_COL_CNT) + +#define A_MAC_PORT_MTIP_VL_INTVL 0x1240 + +#define S_VL_INTVL 1 +#define V_VL_INTVL(x) ((x) << S_VL_INTVL) +#define F_VL_INTVL V_VL_INTVL(1U) + +#define A_MAC_PORT_MTIP_MDIO_CFG_STATUS 0x1600 + +#define S_CLK_DIV 7 +#define M_CLK_DIV 0x1ffU +#define V_CLK_DIV(x) ((x) << S_CLK_DIV) +#define G_CLK_DIV(x) (((x) >> S_CLK_DIV) & M_CLK_DIV) + +#define S_CL45_EN 6 +#define V_CL45_EN(x) ((x) << S_CL45_EN) +#define F_CL45_EN V_CL45_EN(1U) + +#define S_DISABLE_PREAMBLE 5 +#define V_DISABLE_PREAMBLE(x) ((x) << S_DISABLE_PREAMBLE) +#define F_DISABLE_PREAMBLE V_DISABLE_PREAMBLE(1U) + +#define S_MDIO_HOLD_TIME 2 +#define M_MDIO_HOLD_TIME 0x7U +#define V_MDIO_HOLD_TIME(x) ((x) << S_MDIO_HOLD_TIME) +#define G_MDIO_HOLD_TIME(x) (((x) >> S_MDIO_HOLD_TIME) & M_MDIO_HOLD_TIME) + +#define S_MDIO_READ_ERR 1 +#define V_MDIO_READ_ERR(x) ((x) << S_MDIO_READ_ERR) +#define F_MDIO_READ_ERR V_MDIO_READ_ERR(1U) + +#define S_MDIO_BUSY 0 +#define V_MDIO_BUSY(x) ((x) << S_MDIO_BUSY) +#define F_MDIO_BUSY V_MDIO_BUSY(1U) + +#define A_MAC_PORT_MTIP_MDIO_COMMAND 0x1604 + +#define S_MDIO_CMD_READ 15 +#define V_MDIO_CMD_READ(x) ((x) << S_MDIO_CMD_READ) +#define F_MDIO_CMD_READ V_MDIO_CMD_READ(1U) + +#define S_READ_INCR 14 +#define V_READ_INCR(x) ((x) << S_READ_INCR) +#define F_READ_INCR V_READ_INCR(1U) + +#define S_PORT_ADDR 5 +#define M_PORT_ADDR 0x1fU +#define V_PORT_ADDR(x) ((x) << S_PORT_ADDR) +#define G_PORT_ADDR(x) (((x) >> S_PORT_ADDR) & M_PORT_ADDR) + +#define S_DEV_ADDR 0 +#define M_DEV_ADDR 0x1fU +#define V_DEV_ADDR(x) ((x) << S_DEV_ADDR) +#define G_DEV_ADDR(x) (((x) >> S_DEV_ADDR) & M_DEV_ADDR) + +#define A_MAC_PORT_MTIP_MDIO_DATA 0x1608 + +#define S_READBUSY 31 +#define V_READBUSY(x) ((x) << S_READBUSY) +#define F_READBUSY V_READBUSY(1U) + +#define S_DATA_WORD 0 +#define M_DATA_WORD 0xffffU +#define V_DATA_WORD(x) ((x) << S_DATA_WORD) +#define G_DATA_WORD(x) (((x) >> S_DATA_WORD) & M_DATA_WORD) + +#define A_MAC_PORT_MTIP_MDIO_REGADDR 0x160c + +#define S_MDIO_ADDR 0 +#define M_MDIO_ADDR 0xffffU +#define V_MDIO_ADDR(x) ((x) << S_MDIO_ADDR) +#define G_MDIO_ADDR(x) (((x) >> S_MDIO_ADDR) & M_MDIO_ADDR) + +#define A_MAC_PORT_MTIP_VLAN_TPID_0 0x1a00 + +#define S_VLANTAG 0 +#define M_VLANTAG 0xffffU +#define V_VLANTAG(x) ((x) << S_VLANTAG) +#define G_VLANTAG(x) (((x) >> S_VLANTAG) & M_VLANTAG) + +#define A_MAC_PORT_MTIP_VLAN_TPID_1 0x1a04 +#define A_MAC_PORT_MTIP_VLAN_TPID_2 0x1a08 +#define A_MAC_PORT_MTIP_VLAN_TPID_3 0x1a0c +#define A_MAC_PORT_MTIP_VLAN_TPID_4 0x1a10 +#define A_MAC_PORT_MTIP_VLAN_TPID_5 0x1a14 +#define A_MAC_PORT_MTIP_VLAN_TPID_6 0x1a18 +#define A_MAC_PORT_MTIP_VLAN_TPID_7 0x1a1c +#define A_MAC_PORT_MTIP_PCS_CTL 0x1e00 + +#define S_PCS_LPBK 14 +#define V_PCS_LPBK(x) ((x) << S_PCS_LPBK) +#define F_PCS_LPBK V_PCS_LPBK(1U) + +#define S_SPEED_SEL1 13 +#define V_SPEED_SEL1(x) ((x) << S_SPEED_SEL1) +#define F_SPEED_SEL1 V_SPEED_SEL1(1U) + +#define S_LP_MODE 11 +#define V_LP_MODE(x) ((x) << S_LP_MODE) +#define F_LP_MODE V_LP_MODE(1U) + +#define S_SPEED_SEL0 6 +#define V_SPEED_SEL0(x) ((x) << S_SPEED_SEL0) +#define F_SPEED_SEL0 V_SPEED_SEL0(1U) + +#define S_PCS_SPEED 2 +#define M_PCS_SPEED 0xfU +#define V_PCS_SPEED(x) ((x) << S_PCS_SPEED) +#define G_PCS_SPEED(x) (((x) >> S_PCS_SPEED) & M_PCS_SPEED) + +#define A_MAC_PORT_MTIP_PCS_STATUS1 0x1e04 + +#define S_FAULTDET 7 +#define V_FAULTDET(x) ((x) << S_FAULTDET) +#define F_FAULTDET V_FAULTDET(1U) + +#define S_RX_LINK_STATUS 2 +#define V_RX_LINK_STATUS(x) ((x) << S_RX_LINK_STATUS) +#define F_RX_LINK_STATUS V_RX_LINK_STATUS(1U) + +#define S_LOPWRABL 1 +#define V_LOPWRABL(x) ((x) << S_LOPWRABL) +#define F_LOPWRABL V_LOPWRABL(1U) + +#define A_MAC_PORT_MTIP_PCS_DEVICE_ID0 0x1e08 + +#define S_DEVICE_ID0 0 +#define M_DEVICE_ID0 0xffffU +#define V_DEVICE_ID0(x) ((x) << S_DEVICE_ID0) +#define G_DEVICE_ID0(x) (((x) >> S_DEVICE_ID0) & M_DEVICE_ID0) + +#define A_MAC_PORT_MTIP_PCS_DEVICE_ID1 0x1e0c + +#define S_DEVICE_ID1 0 +#define M_DEVICE_ID1 0xffffU +#define V_DEVICE_ID1(x) ((x) << S_DEVICE_ID1) +#define G_DEVICE_ID1(x) (((x) >> S_DEVICE_ID1) & M_DEVICE_ID1) + +#define A_MAC_PORT_MTIP_PCS_SPEED_ABILITY 0x1e10 + +#define S_100G 8 +#define V_100G(x) ((x) << S_100G) +#define F_100G V_100G(1U) + +#define S_40G 7 +#define V_40G(x) ((x) << S_40G) +#define F_40G V_40G(1U) + +#define S_10BASE_TL 1 +#define V_10BASE_TL(x) ((x) << S_10BASE_TL) +#define F_10BASE_TL V_10BASE_TL(1U) + +#define S_10G 0 +#define V_10G(x) ((x) << S_10G) +#define F_10G V_10G(1U) + +#define A_MAC_PORT_MTIP_PCS_DEVICE_PKG1 0x1e14 + +#define S_TC_PRESENT 6 +#define V_TC_PRESENT(x) ((x) << S_TC_PRESENT) +#define F_TC_PRESENT V_TC_PRESENT(1U) + +#define S_DTEXS 5 +#define V_DTEXS(x) ((x) << S_DTEXS) +#define F_DTEXS V_DTEXS(1U) + +#define S_PHYXS 4 +#define V_PHYXS(x) ((x) << S_PHYXS) +#define F_PHYXS V_PHYXS(1U) + +#define S_PCS 3 +#define V_PCS(x) ((x) << S_PCS) +#define F_PCS V_PCS(1U) + +#define S_WIS 2 +#define V_WIS(x) ((x) << S_WIS) +#define F_WIS V_WIS(1U) + +#define S_PMD_PMA 1 +#define V_PMD_PMA(x) ((x) << S_PMD_PMA) +#define F_PMD_PMA V_PMD_PMA(1U) + +#define S_CL22 0 +#define V_CL22(x) ((x) << S_CL22) +#define F_CL22 V_CL22(1U) + +#define A_MAC_PORT_MTIP_PCS_DEVICE_PKG2 0x1e18 + +#define S_VENDDEV2 15 +#define V_VENDDEV2(x) ((x) << S_VENDDEV2) +#define F_VENDDEV2 V_VENDDEV2(1U) + +#define S_VENDDEV1 14 +#define V_VENDDEV1(x) ((x) << S_VENDDEV1) +#define F_VENDDEV1 V_VENDDEV1(1U) + +#define S_CL22EXT 13 +#define V_CL22EXT(x) ((x) << S_CL22EXT) +#define F_CL22EXT V_CL22EXT(1U) + +#define A_MAC_PORT_MTIP_PCS_CTL2 0x1e1c + +#define S_PCSTYPE 0 +#define M_PCSTYPE 0x7U +#define V_PCSTYPE(x) ((x) << S_PCSTYPE) +#define G_PCSTYPE(x) (((x) >> S_PCSTYPE) & M_PCSTYPE) + +#define A_MAC_PORT_MTIP_PCS_STATUS2 0x1e20 + +#define S_PCS_STAT2_DEVICE 15 +#define V_PCS_STAT2_DEVICE(x) ((x) << S_PCS_STAT2_DEVICE) +#define F_PCS_STAT2_DEVICE V_PCS_STAT2_DEVICE(1U) + +#define S_TXFAULT 7 +#define V_TXFAULT(x) ((x) << S_TXFAULT) +#define F_TXFAULT V_TXFAULT(1U) + +#define S_RXFAULT 6 +#define V_RXFAULT(x) ((x) << S_RXFAULT) +#define F_RXFAULT V_RXFAULT(1U) + +#define S_100BASE_R 5 +#define V_100BASE_R(x) ((x) << S_100BASE_R) +#define F_100BASE_R V_100BASE_R(1U) + +#define S_40GBASE_R 4 +#define V_40GBASE_R(x) ((x) << S_40GBASE_R) +#define F_40GBASE_R V_40GBASE_R(1U) + +#define S_10GBASE_T 3 +#define V_10GBASE_T(x) ((x) << S_10GBASE_T) +#define F_10GBASE_T V_10GBASE_T(1U) + +#define S_10GBASE_W 2 +#define V_10GBASE_W(x) ((x) << S_10GBASE_W) +#define F_10GBASE_W V_10GBASE_W(1U) + +#define S_10GBASE_X 1 +#define V_10GBASE_X(x) ((x) << S_10GBASE_X) +#define F_10GBASE_X V_10GBASE_X(1U) + +#define S_10GBASE_R 0 +#define V_10GBASE_R(x) ((x) << S_10GBASE_R) +#define F_10GBASE_R V_10GBASE_R(1U) + +#define A_MAC_PORT_MTIP_PCS_PKG_ID0 0x1e38 + +#define S_PKG_ID0 0 +#define M_PKG_ID0 0xffffU +#define V_PKG_ID0(x) ((x) << S_PKG_ID0) +#define G_PKG_ID0(x) (((x) >> S_PKG_ID0) & M_PKG_ID0) + +#define A_MAC_PORT_MTIP_PCS_PKG_ID1 0x1e3c + +#define S_PKG_ID1 0 +#define M_PKG_ID1 0xffffU +#define V_PKG_ID1(x) ((x) << S_PKG_ID1) +#define G_PKG_ID1(x) (((x) >> S_PKG_ID1) & M_PKG_ID1) + +#define A_MAC_PORT_MTIP_PCS_BASER_STATUS1 0x1e80 + +#define S_RXLINKSTATUS 12 +#define V_RXLINKSTATUS(x) ((x) << S_RXLINKSTATUS) +#define F_RXLINKSTATUS V_RXLINKSTATUS(1U) + +#define S_RESEREVED 4 +#define M_RESEREVED 0xffU +#define V_RESEREVED(x) ((x) << S_RESEREVED) +#define G_RESEREVED(x) (((x) >> S_RESEREVED) & M_RESEREVED) + +#define S_10GPRBS9 3 +#define V_10GPRBS9(x) ((x) << S_10GPRBS9) +#define F_10GPRBS9 V_10GPRBS9(1U) + +#define S_10GPRBS31 2 +#define V_10GPRBS31(x) ((x) << S_10GPRBS31) +#define F_10GPRBS31 V_10GPRBS31(1U) + +#define S_HIBER 1 +#define V_HIBER(x) ((x) << S_HIBER) +#define F_HIBER V_HIBER(1U) + +#define S_BLOCKLOCK 0 +#define V_BLOCKLOCK(x) ((x) << S_BLOCKLOCK) +#define F_BLOCKLOCK V_BLOCKLOCK(1U) + +#define A_MAC_PORT_MTIP_PCS_BASER_STATUS2 0x1e84 + +#define S_BLOCKLOCKLL 15 +#define V_BLOCKLOCKLL(x) ((x) << S_BLOCKLOCKLL) +#define F_BLOCKLOCKLL V_BLOCKLOCKLL(1U) + +#define S_HIBERLH 14 +#define V_HIBERLH(x) ((x) << S_HIBERLH) +#define F_HIBERLH V_HIBERLH(1U) + +#define S_HIBERCOUNT 8 +#define M_HIBERCOUNT 0x3fU +#define V_HIBERCOUNT(x) ((x) << S_HIBERCOUNT) +#define G_HIBERCOUNT(x) (((x) >> S_HIBERCOUNT) & M_HIBERCOUNT) + +#define S_ERRBLKCNT 0 +#define M_ERRBLKCNT 0xffU +#define V_ERRBLKCNT(x) ((x) << S_ERRBLKCNT) +#define G_ERRBLKCNT(x) (((x) >> S_ERRBLKCNT) & M_ERRBLKCNT) + +#define A_MAC_PORT_MTIP_10GBASER_SEED_A 0x1e88 + +#define S_SEEDA 0 +#define M_SEEDA 0xffffU +#define V_SEEDA(x) ((x) << S_SEEDA) +#define G_SEEDA(x) (((x) >> S_SEEDA) & M_SEEDA) + +#define A_MAC_PORT_MTIP_10GBASER_SEED_A1 0x1e8c + +#define S_SEEDA1 0 +#define M_SEEDA1 0xffffU +#define V_SEEDA1(x) ((x) << S_SEEDA1) +#define G_SEEDA1(x) (((x) >> S_SEEDA1) & M_SEEDA1) + +#define A_MAC_PORT_MTIP_10GBASER_SEED_A2 0x1e90 + +#define S_SEEDA2 0 +#define M_SEEDA2 0xffffU +#define V_SEEDA2(x) ((x) << S_SEEDA2) +#define G_SEEDA2(x) (((x) >> S_SEEDA2) & M_SEEDA2) + +#define A_MAC_PORT_MTIP_10GBASER_SEED_A3 0x1e94 + +#define S_SEEDA3 0 +#define M_SEEDA3 0x3ffU +#define V_SEEDA3(x) ((x) << S_SEEDA3) +#define G_SEEDA3(x) (((x) >> S_SEEDA3) & M_SEEDA3) + +#define A_MAC_PORT_MTIP_10GBASER_SEED_B 0x1e98 + +#define S_SEEDB 0 +#define M_SEEDB 0xffffU +#define V_SEEDB(x) ((x) << S_SEEDB) +#define G_SEEDB(x) (((x) >> S_SEEDB) & M_SEEDB) + +#define A_MAC_PORT_MTIP_10GBASER_SEED_B1 0x1e9c + +#define S_SEEDB1 0 +#define M_SEEDB1 0xffffU +#define V_SEEDB1(x) ((x) << S_SEEDB1) +#define G_SEEDB1(x) (((x) >> S_SEEDB1) & M_SEEDB1) + +#define A_MAC_PORT_MTIP_10GBASER_SEED_B2 0x1ea0 + +#define S_SEEDB2 0 +#define M_SEEDB2 0xffffU +#define V_SEEDB2(x) ((x) << S_SEEDB2) +#define G_SEEDB2(x) (((x) >> S_SEEDB2) & M_SEEDB2) + +#define A_MAC_PORT_MTIP_10GBASER_SEED_B3 0x1ea4 + +#define S_SEEDB3 0 +#define M_SEEDB3 0x3ffU +#define V_SEEDB3(x) ((x) << S_SEEDB3) +#define G_SEEDB3(x) (((x) >> S_SEEDB3) & M_SEEDB3) + +#define A_MAC_PORT_MTIP_BASER_TEST_CTRL 0x1ea8 + +#define S_TXPRBS9 6 +#define V_TXPRBS9(x) ((x) << S_TXPRBS9) +#define F_TXPRBS9 V_TXPRBS9(1U) + +#define S_RXPRBS31 5 +#define V_RXPRBS31(x) ((x) << S_RXPRBS31) +#define F_RXPRBS31 V_RXPRBS31(1U) + +#define S_TXPRBS31 4 +#define V_TXPRBS31(x) ((x) << S_TXPRBS31) +#define F_TXPRBS31 V_TXPRBS31(1U) + +#define S_TXTESTPATEN 3 +#define V_TXTESTPATEN(x) ((x) << S_TXTESTPATEN) +#define F_TXTESTPATEN V_TXTESTPATEN(1U) + +#define S_RXTESTPATEN 2 +#define V_RXTESTPATEN(x) ((x) << S_RXTESTPATEN) +#define F_RXTESTPATEN V_RXTESTPATEN(1U) + +#define S_TESTPATSEL 1 +#define V_TESTPATSEL(x) ((x) << S_TESTPATSEL) +#define F_TESTPATSEL V_TESTPATSEL(1U) + +#define S_DATAPATSEL 0 +#define V_DATAPATSEL(x) ((x) << S_DATAPATSEL) +#define F_DATAPATSEL V_DATAPATSEL(1U) + +#define A_MAC_PORT_MTIP_BASER_TEST_ERR_CNT 0x1eac + +#define S_TEST_ERR_CNT 0 +#define M_TEST_ERR_CNT 0xffffU +#define V_TEST_ERR_CNT(x) ((x) << S_TEST_ERR_CNT) +#define G_TEST_ERR_CNT(x) (((x) >> S_TEST_ERR_CNT) & M_TEST_ERR_CNT) + +#define A_MAC_PORT_MTIP_BER_HIGH_ORDER_CNT 0x1eb0 + +#define S_BER_CNT_HI 0 +#define M_BER_CNT_HI 0xffffU +#define V_BER_CNT_HI(x) ((x) << S_BER_CNT_HI) +#define G_BER_CNT_HI(x) (((x) >> S_BER_CNT_HI) & M_BER_CNT_HI) + +#define A_MAC_PORT_MTIP_BLK_HIGH_ORDER_CNT 0x1eb4 + +#define S_HICOUNTPRSNT 15 +#define V_HICOUNTPRSNT(x) ((x) << S_HICOUNTPRSNT) +#define F_HICOUNTPRSNT V_HICOUNTPRSNT(1U) + +#define S_BLOCK_CNT_HI 0 +#define M_BLOCK_CNT_HI 0x3fffU +#define V_BLOCK_CNT_HI(x) ((x) << S_BLOCK_CNT_HI) +#define G_BLOCK_CNT_HI(x) (((x) >> S_BLOCK_CNT_HI) & M_BLOCK_CNT_HI) + +#define A_MAC_PORT_MTIP_PCS_MULTI_LANE_ALIGN_STATUS1 0x1ec8 + +#define S_ALIGNSTATUS 12 +#define V_ALIGNSTATUS(x) ((x) << S_ALIGNSTATUS) +#define F_ALIGNSTATUS V_ALIGNSTATUS(1U) + +#define S_LANE7 7 +#define V_LANE7(x) ((x) << S_LANE7) +#define F_LANE7 V_LANE7(1U) + +#define S_LANE6 6 +#define V_LANE6(x) ((x) << S_LANE6) +#define F_LANE6 V_LANE6(1U) + +#define S_LANE5 5 +#define V_LANE5(x) ((x) << S_LANE5) +#define F_LANE5 V_LANE5(1U) + +#define S_LANE4 4 +#define V_LANE4(x) ((x) << S_LANE4) +#define F_LANE4 V_LANE4(1U) + +#define S_LANE3 3 +#define V_LANE3(x) ((x) << S_LANE3) +#define F_LANE3 V_LANE3(1U) + +#define S_LANE2 2 +#define V_LANE2(x) ((x) << S_LANE2) +#define F_LANE2 V_LANE2(1U) + +#define S_LANE1 1 +#define V_LANE1(x) ((x) << S_LANE1) +#define F_LANE1 V_LANE1(1U) + +#define S_LANE0 0 +#define V_LANE0(x) ((x) << S_LANE0) +#define F_LANE0 V_LANE0(1U) + +#define A_MAC_PORT_MTIP_PCS_MULTI_LANE_ALIGN_STATUS2 0x1ecc + +#define S_LANE19 11 +#define V_LANE19(x) ((x) << S_LANE19) +#define F_LANE19 V_LANE19(1U) + +#define S_LANE18 10 +#define V_LANE18(x) ((x) << S_LANE18) +#define F_LANE18 V_LANE18(1U) + +#define S_LANE17 9 +#define V_LANE17(x) ((x) << S_LANE17) +#define F_LANE17 V_LANE17(1U) + +#define S_LANE16 8 +#define V_LANE16(x) ((x) << S_LANE16) +#define F_LANE16 V_LANE16(1U) + +#define S_LANE15 7 +#define V_LANE15(x) ((x) << S_LANE15) +#define F_LANE15 V_LANE15(1U) + +#define S_LANE14 6 +#define V_LANE14(x) ((x) << S_LANE14) +#define F_LANE14 V_LANE14(1U) + +#define S_LANE13 5 +#define V_LANE13(x) ((x) << S_LANE13) +#define F_LANE13 V_LANE13(1U) + +#define S_LANE12 4 +#define V_LANE12(x) ((x) << S_LANE12) +#define F_LANE12 V_LANE12(1U) + +#define S_LANE11 3 +#define V_LANE11(x) ((x) << S_LANE11) +#define F_LANE11 V_LANE11(1U) + +#define S_LANE10 2 +#define V_LANE10(x) ((x) << S_LANE10) +#define F_LANE10 V_LANE10(1U) + +#define S_LANE9 1 +#define V_LANE9(x) ((x) << S_LANE9) +#define F_LANE9 V_LANE9(1U) + +#define S_LANE8 0 +#define V_LANE8(x) ((x) << S_LANE8) +#define F_LANE8 V_LANE8(1U) + +#define A_MAC_PORT_MTIP_PCS_MULTI_LANE_ALIGN_STATUS3 0x1ed0 + +#define S_AMLOCK7 7 +#define V_AMLOCK7(x) ((x) << S_AMLOCK7) +#define F_AMLOCK7 V_AMLOCK7(1U) + +#define S_AMLOCK6 6 +#define V_AMLOCK6(x) ((x) << S_AMLOCK6) +#define F_AMLOCK6 V_AMLOCK6(1U) + +#define S_AMLOCK5 5 +#define V_AMLOCK5(x) ((x) << S_AMLOCK5) +#define F_AMLOCK5 V_AMLOCK5(1U) + +#define S_AMLOCK4 4 +#define V_AMLOCK4(x) ((x) << S_AMLOCK4) +#define F_AMLOCK4 V_AMLOCK4(1U) + +#define S_AMLOCK3 3 +#define V_AMLOCK3(x) ((x) << S_AMLOCK3) +#define F_AMLOCK3 V_AMLOCK3(1U) + +#define S_AMLOCK2 2 +#define V_AMLOCK2(x) ((x) << S_AMLOCK2) +#define F_AMLOCK2 V_AMLOCK2(1U) + +#define S_AMLOCK1 1 +#define V_AMLOCK1(x) ((x) << S_AMLOCK1) +#define F_AMLOCK1 V_AMLOCK1(1U) + +#define S_AMLOCK0 0 +#define V_AMLOCK0(x) ((x) << S_AMLOCK0) +#define F_AMLOCK0 V_AMLOCK0(1U) + +#define A_MAC_PORT_MTIP_PCS_MULTI_LANE_ALIGN_STATUS4 0x1ed4 + +#define S_AMLOCK19 11 +#define V_AMLOCK19(x) ((x) << S_AMLOCK19) +#define F_AMLOCK19 V_AMLOCK19(1U) + +#define S_AMLOCK18 10 +#define V_AMLOCK18(x) ((x) << S_AMLOCK18) +#define F_AMLOCK18 V_AMLOCK18(1U) + +#define S_AMLOCK17 9 +#define V_AMLOCK17(x) ((x) << S_AMLOCK17) +#define F_AMLOCK17 V_AMLOCK17(1U) + +#define S_AMLOCK16 8 +#define V_AMLOCK16(x) ((x) << S_AMLOCK16) +#define F_AMLOCK16 V_AMLOCK16(1U) + +#define S_AMLOCK15 7 +#define V_AMLOCK15(x) ((x) << S_AMLOCK15) +#define F_AMLOCK15 V_AMLOCK15(1U) + +#define S_AMLOCK14 6 +#define V_AMLOCK14(x) ((x) << S_AMLOCK14) +#define F_AMLOCK14 V_AMLOCK14(1U) + +#define S_AMLOCK13 5 +#define V_AMLOCK13(x) ((x) << S_AMLOCK13) +#define F_AMLOCK13 V_AMLOCK13(1U) + +#define S_AMLOCK12 4 +#define V_AMLOCK12(x) ((x) << S_AMLOCK12) +#define F_AMLOCK12 V_AMLOCK12(1U) + +#define S_AMLOCK11 3 +#define V_AMLOCK11(x) ((x) << S_AMLOCK11) +#define F_AMLOCK11 V_AMLOCK11(1U) + +#define S_AMLOCK10 2 +#define V_AMLOCK10(x) ((x) << S_AMLOCK10) +#define F_AMLOCK10 V_AMLOCK10(1U) + +#define S_AMLOCK9 1 +#define V_AMLOCK9(x) ((x) << S_AMLOCK9) +#define F_AMLOCK9 V_AMLOCK9(1U) + +#define S_AMLOCK8 0 +#define V_AMLOCK8(x) ((x) << S_AMLOCK8) +#define F_AMLOCK8 V_AMLOCK8(1U) + +#define A_MAC_PORT_MTIP_PCS_BIP_ERR_CNT_0 0x1f68 + +#define S_BIPERR_CNT 0 +#define M_BIPERR_CNT 0xffffU +#define V_BIPERR_CNT(x) ((x) << S_BIPERR_CNT) +#define G_BIPERR_CNT(x) (((x) >> S_BIPERR_CNT) & M_BIPERR_CNT) + +#define A_MAC_PORT_MTIP_PCS_BIP_ERR_CNT_1 0x1f6c +#define A_MAC_PORT_MTIP_PCS_BIP_ERR_CNT_2 0x1f70 +#define A_MAC_PORT_MTIP_PCS_BIP_ERR_CNT_3 0x1f74 +#define A_MAC_PORT_MTIP_PCS_BIP_ERR_CNT_4 0x1f78 +#define A_MAC_PORT_MTIP_PCS_BIP_ERR_CNT_5 0x1f7c +#define A_MAC_PORT_MTIP_PCS_BIP_ERR_CNT_6 0x1f80 +#define A_MAC_PORT_MTIP_PCS_BIP_ERR_CNT_7 0x1f84 +#define A_MAC_PORT_MTIP_PCS_BIP_ERR_CNT_8 0x1f88 +#define A_MAC_PORT_MTIP_PCS_BIP_ERR_CNT_9 0x1f8c +#define A_MAC_PORT_MTIP_PCS_BIP_ERR_CNT_10 0x1f90 +#define A_MAC_PORT_MTIP_PCS_BIP_ERR_CNT_11 0x1f94 +#define A_MAC_PORT_MTIP_PCS_BIP_ERR_CNT_12 0x1f98 +#define A_MAC_PORT_MTIP_PCS_BIP_ERR_CNT_13 0x1f9c +#define A_MAC_PORT_MTIP_PCS_BIP_ERR_CNT_14 0x1fa0 +#define A_MAC_PORT_MTIP_PCS_BIP_ERR_CNT_15 0x1fa4 +#define A_MAC_PORT_MTIP_PCS_BIP_ERR_CNT_16 0x1fa8 +#define A_MAC_PORT_MTIP_PCS_BIP_ERR_CNT_17 0x1fac +#define A_MAC_PORT_MTIP_PCS_BIP_ERR_CNT_18 0x1fb0 +#define A_MAC_PORT_MTIP_PCS_BIP_ERR_CNT_19 0x1fb4 +#define A_MAC_PORT_MTIP_PCS_LANE_MAP_0 0x1fb8 + +#define S_MAP 0 +#define M_MAP 0x1fU +#define V_MAP(x) ((x) << S_MAP) +#define G_MAP(x) (((x) >> S_MAP) & M_MAP) + +#define A_MAC_PORT_MTIP_PCS_LANE_MAP_1 0x1fbc +#define A_MAC_PORT_MTIP_PCS_LANE_MAP_2 0x1fc0 +#define A_MAC_PORT_MTIP_PCS_LANE_MAP_3 0x1fc4 +#define A_MAC_PORT_MTIP_PCS_LANE_MAP_4 0x1fc8 +#define A_MAC_PORT_MTIP_PCS_LANE_MAP_5 0x1fcc +#define A_MAC_PORT_MTIP_PCS_LANE_MAP_6 0x1fd0 +#define A_MAC_PORT_MTIP_PCS_LANE_MAP_7 0x1fd4 +#define A_MAC_PORT_MTIP_PCS_LANE_MAP_8 0x1fd8 +#define A_MAC_PORT_MTIP_PCS_LANE_MAP_9 0x1fdc +#define A_MAC_PORT_MTIP_PCS_LANE_MAP_10 0x1fe0 +#define A_MAC_PORT_MTIP_PCS_LANE_MAP_11 0x1fe4 +#define A_MAC_PORT_MTIP_PCS_LANE_MAP_12 0x1fe8 +#define A_MAC_PORT_MTIP_PCS_LANE_MAP_13 0x1fec +#define A_MAC_PORT_MTIP_PCS_LANE_MAP_14 0x1ff0 +#define A_MAC_PORT_MTIP_PCS_LANE_MAP_15 0x1ff4 +#define A_MAC_PORT_MTIP_PCS_LANE_MAP_16 0x1ff8 +#define A_MAC_PORT_MTIP_PCS_LANE_MAP_17 0x1ffc +#define A_MAC_PORT_MTIP_PCS_LANE_MAP_18 0x2000 +#define A_MAC_PORT_MTIP_PCS_LANE_MAP_19 0x2004 +#define A_MAC_PORT_BEAN_CTL 0x2200 + +#define S_AN_RESET 15 +#define V_AN_RESET(x) ((x) << S_AN_RESET) +#define F_AN_RESET V_AN_RESET(1U) + +#define S_EXT_NXP_CTRL 13 +#define V_EXT_NXP_CTRL(x) ((x) << S_EXT_NXP_CTRL) +#define F_EXT_NXP_CTRL V_EXT_NXP_CTRL(1U) + +#define S_BEAN_EN 12 +#define V_BEAN_EN(x) ((x) << S_BEAN_EN) +#define F_BEAN_EN V_BEAN_EN(1U) + +#define S_RESTART_BEAN 9 +#define V_RESTART_BEAN(x) ((x) << S_RESTART_BEAN) +#define F_RESTART_BEAN V_RESTART_BEAN(1U) + +#define A_MAC_PORT_BEAN_STATUS 0x2204 + +#define S_PDF 9 +#define V_PDF(x) ((x) << S_PDF) +#define F_PDF V_PDF(1U) + +#define S_EXT_NXP_STATUS 7 +#define V_EXT_NXP_STATUS(x) ((x) << S_EXT_NXP_STATUS) +#define F_EXT_NXP_STATUS V_EXT_NXP_STATUS(1U) + +#define S_PAGE_RCVD 6 +#define V_PAGE_RCVD(x) ((x) << S_PAGE_RCVD) +#define F_PAGE_RCVD V_PAGE_RCVD(1U) + +#define S_BEAN_COMPLETE 5 +#define V_BEAN_COMPLETE(x) ((x) << S_BEAN_COMPLETE) +#define F_BEAN_COMPLETE V_BEAN_COMPLETE(1U) + +#define S_REM_FAULT_STATUS 4 +#define V_REM_FAULT_STATUS(x) ((x) << S_REM_FAULT_STATUS) +#define F_REM_FAULT_STATUS V_REM_FAULT_STATUS(1U) + +#define S_BEAN_ABILITY 3 +#define V_BEAN_ABILITY(x) ((x) << S_BEAN_ABILITY) +#define F_BEAN_ABILITY V_BEAN_ABILITY(1U) + +#define S_LP_BEAN_ABILITY 0 +#define V_LP_BEAN_ABILITY(x) ((x) << S_LP_BEAN_ABILITY) +#define F_LP_BEAN_ABILITY V_LP_BEAN_ABILITY(1U) + +#define A_MAC_PORT_BEAN_ABILITY_0 0x2208 + +#define S_NXP 15 +#define V_NXP(x) ((x) << S_NXP) +#define F_NXP V_NXP(1U) + +#define S_REM_FAULT 13 +#define V_REM_FAULT(x) ((x) << S_REM_FAULT) +#define F_REM_FAULT V_REM_FAULT(1U) + +#define S_PAUSE_ABILITY 10 +#define M_PAUSE_ABILITY 0x7U +#define V_PAUSE_ABILITY(x) ((x) << S_PAUSE_ABILITY) +#define G_PAUSE_ABILITY(x) (((x) >> S_PAUSE_ABILITY) & M_PAUSE_ABILITY) + +#define S_ECHO_NONCE 5 +#define M_ECHO_NONCE 0x1fU +#define V_ECHO_NONCE(x) ((x) << S_ECHO_NONCE) +#define G_ECHO_NONCE(x) (((x) >> S_ECHO_NONCE) & M_ECHO_NONCE) + +#define S_SELECTOR 0 +#define M_SELECTOR 0x1fU +#define V_SELECTOR(x) ((x) << S_SELECTOR) +#define G_SELECTOR(x) (((x) >> S_SELECTOR) & M_SELECTOR) + +#define A_MAC_PORT_BEAN_ABILITY_1 0x220c + +#define S_TECH_ABILITY_1 5 +#define M_TECH_ABILITY_1 0x7ffU +#define V_TECH_ABILITY_1(x) ((x) << S_TECH_ABILITY_1) +#define G_TECH_ABILITY_1(x) (((x) >> S_TECH_ABILITY_1) & M_TECH_ABILITY_1) + +#define S_TX_NONCE 0 +#define M_TX_NONCE 0x1fU +#define V_TX_NONCE(x) ((x) << S_TX_NONCE) +#define G_TX_NONCE(x) (((x) >> S_TX_NONCE) & M_TX_NONCE) + +#define A_MAC_PORT_BEAN_ABILITY_2 0x2210 + +#define S_T5_FEC_ABILITY 14 +#define M_T5_FEC_ABILITY 0x3U +#define V_T5_FEC_ABILITY(x) ((x) << S_T5_FEC_ABILITY) +#define G_T5_FEC_ABILITY(x) (((x) >> S_T5_FEC_ABILITY) & M_T5_FEC_ABILITY) + +#define S_TECH_ABILITY_2 0 +#define M_TECH_ABILITY_2 0x3fffU +#define V_TECH_ABILITY_2(x) ((x) << S_TECH_ABILITY_2) +#define G_TECH_ABILITY_2(x) (((x) >> S_TECH_ABILITY_2) & M_TECH_ABILITY_2) + +#define A_MAC_PORT_BEAN_REM_ABILITY_0 0x2214 +#define A_MAC_PORT_BEAN_REM_ABILITY_1 0x2218 +#define A_MAC_PORT_BEAN_REM_ABILITY_2 0x221c +#define A_MAC_PORT_BEAN_MS_COUNT 0x2220 + +#define S_MS_COUNT 0 +#define M_MS_COUNT 0xffffU +#define V_MS_COUNT(x) ((x) << S_MS_COUNT) +#define G_MS_COUNT(x) (((x) >> S_MS_COUNT) & M_MS_COUNT) + +#define A_MAC_PORT_BEAN_XNP_0 0x2224 + +#define S_XNP 15 +#define V_XNP(x) ((x) << S_XNP) +#define F_XNP V_XNP(1U) + +#define S_ACKNOWLEDGE 14 +#define V_ACKNOWLEDGE(x) ((x) << S_ACKNOWLEDGE) +#define F_ACKNOWLEDGE V_ACKNOWLEDGE(1U) + +#define S_MP 13 +#define V_MP(x) ((x) << S_MP) +#define F_MP V_MP(1U) + +#define S_ACK2 12 +#define V_ACK2(x) ((x) << S_ACK2) +#define F_ACK2 V_ACK2(1U) + +#define S_MU 0 +#define M_MU 0x7ffU +#define V_MU(x) ((x) << S_MU) +#define G_MU(x) (((x) >> S_MU) & M_MU) + +#define A_MAC_PORT_BEAN_XNP_1 0x2228 + +#define S_UNFORMATED 0 +#define M_UNFORMATED 0xffffU +#define V_UNFORMATED(x) ((x) << S_UNFORMATED) +#define G_UNFORMATED(x) (((x) >> S_UNFORMATED) & M_UNFORMATED) + +#define A_MAC_PORT_BEAN_XNP_2 0x222c +#define A_MAC_PORT_LP_BEAN_XNP_0 0x2230 +#define A_MAC_PORT_LP_BEAN_XNP_1 0x2234 +#define A_MAC_PORT_LP_BEAN_XNP_2 0x2238 +#define A_MAC_PORT_BEAN_ETH_STATUS 0x223c + +#define S_100GCR10 8 +#define V_100GCR10(x) ((x) << S_100GCR10) +#define F_100GCR10 V_100GCR10(1U) + +#define S_40GCR4 6 +#define V_40GCR4(x) ((x) << S_40GCR4) +#define F_40GCR4 V_40GCR4(1U) + +#define S_40GKR4 5 +#define V_40GKR4(x) ((x) << S_40GKR4) +#define F_40GKR4 V_40GKR4(1U) + +#define S_FEC 4 +#define V_FEC(x) ((x) << S_FEC) +#define F_FEC V_FEC(1U) + +#define S_10GKR 3 +#define V_10GKR(x) ((x) << S_10GKR) +#define F_10GKR V_10GKR(1U) + +#define S_10GKX4 2 +#define V_10GKX4(x) ((x) << S_10GKX4) +#define F_10GKX4 V_10GKX4(1U) + +#define S_1GKX 1 +#define V_1GKX(x) ((x) << S_1GKX) +#define F_1GKX V_1GKX(1U) + +#define A_MAC_PORT_BEAN_CTL_LANE1 0x2240 +#define A_MAC_PORT_BEAN_STATUS_LANE1 0x2244 +#define A_MAC_PORT_BEAN_ABILITY_0_LANE1 0x2248 +#define A_MAC_PORT_BEAN_ABILITY_1_LANE1 0x224c +#define A_MAC_PORT_BEAN_ABILITY_2_LANE1 0x2250 +#define A_MAC_PORT_BEAN_REM_ABILITY_0_LANE1 0x2254 +#define A_MAC_PORT_BEAN_REM_ABILITY_1_LANE1 0x2258 +#define A_MAC_PORT_BEAN_REM_ABILITY_2_LANE1 0x225c +#define A_MAC_PORT_BEAN_MS_COUNT_LANE1 0x2260 +#define A_MAC_PORT_BEAN_XNP_0_LANE1 0x2264 +#define A_MAC_PORT_BEAN_XNP_1_LANE1 0x2268 +#define A_MAC_PORT_BEAN_XNP_2_LANE1 0x226c +#define A_MAC_PORT_LP_BEAN_XNP_0_LANE1 0x2270 +#define A_MAC_PORT_LP_BEAN_XNP_1_LANE1 0x2274 +#define A_MAC_PORT_LP_BEAN_XNP_2_LANE1 0x2278 +#define A_MAC_PORT_BEAN_ETH_STATUS_LANE1 0x227c +#define A_MAC_PORT_BEAN_CTL_LANE2 0x2280 +#define A_MAC_PORT_BEAN_STATUS_LANE2 0x2284 +#define A_MAC_PORT_BEAN_ABILITY_0_LANE2 0x2288 +#define A_MAC_PORT_BEAN_ABILITY_1_LANE2 0x228c +#define A_MAC_PORT_BEAN_ABILITY_2_LANE2 0x2290 +#define A_MAC_PORT_BEAN_REM_ABILITY_0_LANE2 0x2294 +#define A_MAC_PORT_BEAN_REM_ABILITY_1_LANE2 0x2298 +#define A_MAC_PORT_BEAN_REM_ABILITY_2_LANE2 0x229c +#define A_MAC_PORT_BEAN_MS_COUNT_LANE2 0x22a0 +#define A_MAC_PORT_BEAN_XNP_0_LANE2 0x22a4 +#define A_MAC_PORT_BEAN_XNP_1_LANE2 0x22a8 +#define A_MAC_PORT_BEAN_XNP_2_LANE2 0x22ac +#define A_MAC_PORT_LP_BEAN_XNP_0_LANE2 0x22b0 +#define A_MAC_PORT_LP_BEAN_XNP_1_LANE2 0x22b4 +#define A_MAC_PORT_LP_BEAN_XNP_2_LANE2 0x22b8 +#define A_MAC_PORT_BEAN_ETH_STATUS_LANE2 0x22bc +#define A_MAC_PORT_BEAN_CTL_LANE3 0x22c0 +#define A_MAC_PORT_BEAN_STATUS_LANE3 0x22c4 +#define A_MAC_PORT_BEAN_ABILITY_0_LANE3 0x22c8 +#define A_MAC_PORT_BEAN_ABILITY_1_LANE3 0x22cc +#define A_MAC_PORT_BEAN_ABILITY_2_LANE3 0x22d0 +#define A_MAC_PORT_BEAN_REM_ABILITY_0_LANE3 0x22d4 +#define A_MAC_PORT_BEAN_REM_ABILITY_1_LANE3 0x22d8 +#define A_MAC_PORT_BEAN_REM_ABILITY_2_LANE3 0x22dc +#define A_MAC_PORT_BEAN_MS_COUNT_LANE3 0x22e0 +#define A_MAC_PORT_BEAN_XNP_0_LANE3 0x22e4 +#define A_MAC_PORT_BEAN_XNP_1_LANE3 0x22e8 +#define A_MAC_PORT_BEAN_XNP_2_LANE3 0x22ec +#define A_MAC_PORT_LP_BEAN_XNP_0_LANE3 0x22f0 +#define A_MAC_PORT_LP_BEAN_XNP_1_LANE3 0x22f4 +#define A_MAC_PORT_LP_BEAN_XNP_2_LANE3 0x22f8 +#define A_MAC_PORT_BEAN_ETH_STATUS_LANE3 0x22fc +#define A_MAC_PORT_FEC_KR_CONTROL 0x2600 + +#define S_ENABLE_TR 1 +#define V_ENABLE_TR(x) ((x) << S_ENABLE_TR) +#define F_ENABLE_TR V_ENABLE_TR(1U) + +#define S_RESTART_TR 0 +#define V_RESTART_TR(x) ((x) << S_RESTART_TR) +#define F_RESTART_TR V_RESTART_TR(1U) + +#define A_MAC_PORT_FEC_KR_STATUS 0x2604 + +#define S_FECKRSIGDET 15 +#define V_FECKRSIGDET(x) ((x) << S_FECKRSIGDET) +#define F_FECKRSIGDET V_FECKRSIGDET(1U) + +#define S_TRAIN_FAIL 3 +#define V_TRAIN_FAIL(x) ((x) << S_TRAIN_FAIL) +#define F_TRAIN_FAIL V_TRAIN_FAIL(1U) + +#define S_STARTUP_STATUS 2 +#define V_STARTUP_STATUS(x) ((x) << S_STARTUP_STATUS) +#define F_STARTUP_STATUS V_STARTUP_STATUS(1U) + +#define S_RX_STATUS 0 +#define V_RX_STATUS(x) ((x) << S_RX_STATUS) +#define F_RX_STATUS V_RX_STATUS(1U) + +#define A_MAC_PORT_FEC_KR_LP_COEFF 0x2608 + +#define S_PRESET 13 +#define V_PRESET(x) ((x) << S_PRESET) +#define F_PRESET V_PRESET(1U) + +#define S_INITIALIZE 12 +#define V_INITIALIZE(x) ((x) << S_INITIALIZE) +#define F_INITIALIZE V_INITIALIZE(1U) + +#define S_CP1_UPD 4 +#define M_CP1_UPD 0x3U +#define V_CP1_UPD(x) ((x) << S_CP1_UPD) +#define G_CP1_UPD(x) (((x) >> S_CP1_UPD) & M_CP1_UPD) + +#define S_C0_UPD 2 +#define M_C0_UPD 0x3U +#define V_C0_UPD(x) ((x) << S_C0_UPD) +#define G_C0_UPD(x) (((x) >> S_C0_UPD) & M_C0_UPD) + +#define S_CN1_UPD 0 +#define M_CN1_UPD 0x3U +#define V_CN1_UPD(x) ((x) << S_CN1_UPD) +#define G_CN1_UPD(x) (((x) >> S_CN1_UPD) & M_CN1_UPD) + +#define A_MAC_PORT_FEC_KR_LP_STAT 0x260c + +#define S_RX_READY 15 +#define V_RX_READY(x) ((x) << S_RX_READY) +#define F_RX_READY V_RX_READY(1U) + +#define S_CP1_STAT 4 +#define M_CP1_STAT 0x3U +#define V_CP1_STAT(x) ((x) << S_CP1_STAT) +#define G_CP1_STAT(x) (((x) >> S_CP1_STAT) & M_CP1_STAT) + +#define S_C0_STAT 2 +#define M_C0_STAT 0x3U +#define V_C0_STAT(x) ((x) << S_C0_STAT) +#define G_C0_STAT(x) (((x) >> S_C0_STAT) & M_C0_STAT) + +#define S_CN1_STAT 0 +#define M_CN1_STAT 0x3U +#define V_CN1_STAT(x) ((x) << S_CN1_STAT) +#define G_CN1_STAT(x) (((x) >> S_CN1_STAT) & M_CN1_STAT) + +#define A_MAC_PORT_FEC_KR_LD_COEFF 0x2610 +#define A_MAC_PORT_FEC_KR_LD_STAT 0x2614 +#define A_MAC_PORT_FEC_ABILITY 0x2618 + +#define S_FEC_IND_ABILITY 1 +#define V_FEC_IND_ABILITY(x) ((x) << S_FEC_IND_ABILITY) +#define F_FEC_IND_ABILITY V_FEC_IND_ABILITY(1U) + +#define S_ABILITY 0 +#define V_ABILITY(x) ((x) << S_ABILITY) +#define F_ABILITY V_ABILITY(1U) + +#define A_MAC_PORT_FEC_CONTROL 0x261c + +#define S_FEC_EN_ERR_IND 1 +#define V_FEC_EN_ERR_IND(x) ((x) << S_FEC_EN_ERR_IND) +#define F_FEC_EN_ERR_IND V_FEC_EN_ERR_IND(1U) + +#define S_FEC_EN 0 +#define V_FEC_EN(x) ((x) << S_FEC_EN) +#define F_FEC_EN V_FEC_EN(1U) + +#define A_MAC_PORT_FEC_STATUS 0x2620 + +#define S_FEC_LOCKED_100 1 +#define V_FEC_LOCKED_100(x) ((x) << S_FEC_LOCKED_100) +#define F_FEC_LOCKED_100 V_FEC_LOCKED_100(1U) + +#define S_FEC_LOCKED 0 +#define V_FEC_LOCKED(x) ((x) << S_FEC_LOCKED) +#define F_FEC_LOCKED V_FEC_LOCKED(1U) + +#define A_MAC_PORT_FEC_CERR_CNT_0 0x2624 + +#define S_FEC_CERR_CNT_0 0 +#define M_FEC_CERR_CNT_0 0xffffU +#define V_FEC_CERR_CNT_0(x) ((x) << S_FEC_CERR_CNT_0) +#define G_FEC_CERR_CNT_0(x) (((x) >> S_FEC_CERR_CNT_0) & M_FEC_CERR_CNT_0) + +#define A_MAC_PORT_FEC_CERR_CNT_1 0x2628 + +#define S_FEC_CERR_CNT_1 0 +#define M_FEC_CERR_CNT_1 0xffffU +#define V_FEC_CERR_CNT_1(x) ((x) << S_FEC_CERR_CNT_1) +#define G_FEC_CERR_CNT_1(x) (((x) >> S_FEC_CERR_CNT_1) & M_FEC_CERR_CNT_1) + +#define A_MAC_PORT_FEC_NCERR_CNT_0 0x262c + +#define S_FEC_NCERR_CNT_0 0 +#define M_FEC_NCERR_CNT_0 0xffffU +#define V_FEC_NCERR_CNT_0(x) ((x) << S_FEC_NCERR_CNT_0) +#define G_FEC_NCERR_CNT_0(x) (((x) >> S_FEC_NCERR_CNT_0) & M_FEC_NCERR_CNT_0) + +#define A_MAC_PORT_FEC_NCERR_CNT_1 0x2630 + +#define S_FEC_NCERR_CNT_1 0 +#define M_FEC_NCERR_CNT_1 0xffffU +#define V_FEC_NCERR_CNT_1(x) ((x) << S_FEC_NCERR_CNT_1) +#define G_FEC_NCERR_CNT_1(x) (((x) >> S_FEC_NCERR_CNT_1) & M_FEC_NCERR_CNT_1) + +#define A_MAC_PORT_AE_RX_COEF_REQ 0x2a00 + +#define S_T5_RXREQ_C2 4 +#define M_T5_RXREQ_C2 0x3U +#define V_T5_RXREQ_C2(x) ((x) << S_T5_RXREQ_C2) +#define G_T5_RXREQ_C2(x) (((x) >> S_T5_RXREQ_C2) & M_T5_RXREQ_C2) + +#define S_T5_RXREQ_C1 2 +#define M_T5_RXREQ_C1 0x3U +#define V_T5_RXREQ_C1(x) ((x) << S_T5_RXREQ_C1) +#define G_T5_RXREQ_C1(x) (((x) >> S_T5_RXREQ_C1) & M_T5_RXREQ_C1) + +#define S_T5_RXREQ_C0 0 +#define M_T5_RXREQ_C0 0x3U +#define V_T5_RXREQ_C0(x) ((x) << S_T5_RXREQ_C0) +#define G_T5_RXREQ_C0(x) (((x) >> S_T5_RXREQ_C0) & M_T5_RXREQ_C0) + +#define A_MAC_PORT_AE_RX_COEF_STAT 0x2a04 + +#define S_T5_AE0_RXSTAT_RDY 15 +#define V_T5_AE0_RXSTAT_RDY(x) ((x) << S_T5_AE0_RXSTAT_RDY) +#define F_T5_AE0_RXSTAT_RDY V_T5_AE0_RXSTAT_RDY(1U) + +#define S_T5_AE0_RXSTAT_C2 4 +#define M_T5_AE0_RXSTAT_C2 0x3U +#define V_T5_AE0_RXSTAT_C2(x) ((x) << S_T5_AE0_RXSTAT_C2) +#define G_T5_AE0_RXSTAT_C2(x) (((x) >> S_T5_AE0_RXSTAT_C2) & M_T5_AE0_RXSTAT_C2) + +#define S_T5_AE0_RXSTAT_C1 2 +#define M_T5_AE0_RXSTAT_C1 0x3U +#define V_T5_AE0_RXSTAT_C1(x) ((x) << S_T5_AE0_RXSTAT_C1) +#define G_T5_AE0_RXSTAT_C1(x) (((x) >> S_T5_AE0_RXSTAT_C1) & M_T5_AE0_RXSTAT_C1) + +#define S_T5_AE0_RXSTAT_C0 0 +#define M_T5_AE0_RXSTAT_C0 0x3U +#define V_T5_AE0_RXSTAT_C0(x) ((x) << S_T5_AE0_RXSTAT_C0) +#define G_T5_AE0_RXSTAT_C0(x) (((x) >> S_T5_AE0_RXSTAT_C0) & M_T5_AE0_RXSTAT_C0) + +#define A_MAC_PORT_AE_TX_COEF_REQ 0x2a08 + +#define S_T5_TXREQ_C2 4 +#define M_T5_TXREQ_C2 0x3U +#define V_T5_TXREQ_C2(x) ((x) << S_T5_TXREQ_C2) +#define G_T5_TXREQ_C2(x) (((x) >> S_T5_TXREQ_C2) & M_T5_TXREQ_C2) + +#define S_T5_TXREQ_C1 2 +#define M_T5_TXREQ_C1 0x3U +#define V_T5_TXREQ_C1(x) ((x) << S_T5_TXREQ_C1) +#define G_T5_TXREQ_C1(x) (((x) >> S_T5_TXREQ_C1) & M_T5_TXREQ_C1) + +#define S_T5_TXREQ_C0 0 +#define M_T5_TXREQ_C0 0x3U +#define V_T5_TXREQ_C0(x) ((x) << S_T5_TXREQ_C0) +#define G_T5_TXREQ_C0(x) (((x) >> S_T5_TXREQ_C0) & M_T5_TXREQ_C0) + +#define A_MAC_PORT_AE_TX_COEF_STAT 0x2a0c + +#define S_T5_TXSTAT_C2 4 +#define M_T5_TXSTAT_C2 0x3U +#define V_T5_TXSTAT_C2(x) ((x) << S_T5_TXSTAT_C2) +#define G_T5_TXSTAT_C2(x) (((x) >> S_T5_TXSTAT_C2) & M_T5_TXSTAT_C2) + +#define S_T5_TXSTAT_C1 2 +#define M_T5_TXSTAT_C1 0x3U +#define V_T5_TXSTAT_C1(x) ((x) << S_T5_TXSTAT_C1) +#define G_T5_TXSTAT_C1(x) (((x) >> S_T5_TXSTAT_C1) & M_T5_TXSTAT_C1) + +#define S_T5_TXSTAT_C0 0 +#define M_T5_TXSTAT_C0 0x3U +#define V_T5_TXSTAT_C0(x) ((x) << S_T5_TXSTAT_C0) +#define G_T5_TXSTAT_C0(x) (((x) >> S_T5_TXSTAT_C0) & M_T5_TXSTAT_C0) + +#define A_MAC_PORT_AE_REG_MODE 0x2a10 + +#define S_AET_RSVD 7 +#define V_AET_RSVD(x) ((x) << S_AET_RSVD) +#define F_AET_RSVD V_AET_RSVD(1U) + +#define S_AET_ENABLE 6 +#define V_AET_ENABLE(x) ((x) << S_AET_ENABLE) +#define F_AET_ENABLE V_AET_ENABLE(1U) + +#define A_MAC_PORT_AE_PRBS_CTL 0x2a14 +#define A_MAC_PORT_AE_FSM_CTL 0x2a18 + +#define S_CIN_ENABLE 15 +#define V_CIN_ENABLE(x) ((x) << S_CIN_ENABLE) +#define F_CIN_ENABLE V_CIN_ENABLE(1U) + +#define A_MAC_PORT_AE_FSM_STATE 0x2a1c +#define A_MAC_PORT_AE_RX_COEF_REQ_1 0x2a20 +#define A_MAC_PORT_AE_RX_COEF_STAT_1 0x2a24 + +#define S_T5_AE1_RXSTAT_RDY 15 +#define V_T5_AE1_RXSTAT_RDY(x) ((x) << S_T5_AE1_RXSTAT_RDY) +#define F_T5_AE1_RXSTAT_RDY V_T5_AE1_RXSTAT_RDY(1U) + +#define S_T5_AE1_RXSTAT_C2 4 +#define M_T5_AE1_RXSTAT_C2 0x3U +#define V_T5_AE1_RXSTAT_C2(x) ((x) << S_T5_AE1_RXSTAT_C2) +#define G_T5_AE1_RXSTAT_C2(x) (((x) >> S_T5_AE1_RXSTAT_C2) & M_T5_AE1_RXSTAT_C2) + +#define S_T5_AE1_RXSTAT_C1 2 +#define M_T5_AE1_RXSTAT_C1 0x3U +#define V_T5_AE1_RXSTAT_C1(x) ((x) << S_T5_AE1_RXSTAT_C1) +#define G_T5_AE1_RXSTAT_C1(x) (((x) >> S_T5_AE1_RXSTAT_C1) & M_T5_AE1_RXSTAT_C1) + +#define S_T5_AE1_RXSTAT_C0 0 +#define M_T5_AE1_RXSTAT_C0 0x3U +#define V_T5_AE1_RXSTAT_C0(x) ((x) << S_T5_AE1_RXSTAT_C0) +#define G_T5_AE1_RXSTAT_C0(x) (((x) >> S_T5_AE1_RXSTAT_C0) & M_T5_AE1_RXSTAT_C0) + +#define A_MAC_PORT_AE_TX_COEF_REQ_1 0x2a28 +#define A_MAC_PORT_AE_TX_COEF_STAT_1 0x2a2c +#define A_MAC_PORT_AE_REG_MODE_1 0x2a30 +#define A_MAC_PORT_AE_PRBS_CTL_1 0x2a34 +#define A_MAC_PORT_AE_FSM_CTL_1 0x2a38 +#define A_MAC_PORT_AE_FSM_STATE_1 0x2a3c +#define A_MAC_PORT_AE_RX_COEF_REQ_2 0x2a40 +#define A_MAC_PORT_AE_RX_COEF_STAT_2 0x2a44 + +#define S_T5_AE2_RXSTAT_RDY 15 +#define V_T5_AE2_RXSTAT_RDY(x) ((x) << S_T5_AE2_RXSTAT_RDY) +#define F_T5_AE2_RXSTAT_RDY V_T5_AE2_RXSTAT_RDY(1U) + +#define S_T5_AE2_RXSTAT_C2 4 +#define M_T5_AE2_RXSTAT_C2 0x3U +#define V_T5_AE2_RXSTAT_C2(x) ((x) << S_T5_AE2_RXSTAT_C2) +#define G_T5_AE2_RXSTAT_C2(x) (((x) >> S_T5_AE2_RXSTAT_C2) & M_T5_AE2_RXSTAT_C2) + +#define S_T5_AE2_RXSTAT_C1 2 +#define M_T5_AE2_RXSTAT_C1 0x3U +#define V_T5_AE2_RXSTAT_C1(x) ((x) << S_T5_AE2_RXSTAT_C1) +#define G_T5_AE2_RXSTAT_C1(x) (((x) >> S_T5_AE2_RXSTAT_C1) & M_T5_AE2_RXSTAT_C1) + +#define S_T5_AE2_RXSTAT_C0 0 +#define M_T5_AE2_RXSTAT_C0 0x3U +#define V_T5_AE2_RXSTAT_C0(x) ((x) << S_T5_AE2_RXSTAT_C0) +#define G_T5_AE2_RXSTAT_C0(x) (((x) >> S_T5_AE2_RXSTAT_C0) & M_T5_AE2_RXSTAT_C0) + +#define A_MAC_PORT_AE_TX_COEF_REQ_2 0x2a48 +#define A_MAC_PORT_AE_TX_COEF_STAT_2 0x2a4c +#define A_MAC_PORT_AE_REG_MODE_2 0x2a50 +#define A_MAC_PORT_AE_PRBS_CTL_2 0x2a54 +#define A_MAC_PORT_AE_FSM_CTL_2 0x2a58 +#define A_MAC_PORT_AE_FSM_STATE_2 0x2a5c +#define A_MAC_PORT_AE_RX_COEF_REQ_3 0x2a60 +#define A_MAC_PORT_AE_RX_COEF_STAT_3 0x2a64 + +#define S_T5_AE3_RXSTAT_RDY 15 +#define V_T5_AE3_RXSTAT_RDY(x) ((x) << S_T5_AE3_RXSTAT_RDY) +#define F_T5_AE3_RXSTAT_RDY V_T5_AE3_RXSTAT_RDY(1U) + +#define S_T5_AE3_RXSTAT_C2 4 +#define M_T5_AE3_RXSTAT_C2 0x3U +#define V_T5_AE3_RXSTAT_C2(x) ((x) << S_T5_AE3_RXSTAT_C2) +#define G_T5_AE3_RXSTAT_C2(x) (((x) >> S_T5_AE3_RXSTAT_C2) & M_T5_AE3_RXSTAT_C2) + +#define S_T5_AE3_RXSTAT_C1 2 +#define M_T5_AE3_RXSTAT_C1 0x3U +#define V_T5_AE3_RXSTAT_C1(x) ((x) << S_T5_AE3_RXSTAT_C1) +#define G_T5_AE3_RXSTAT_C1(x) (((x) >> S_T5_AE3_RXSTAT_C1) & M_T5_AE3_RXSTAT_C1) + +#define S_T5_AE3_RXSTAT_C0 0 +#define M_T5_AE3_RXSTAT_C0 0x3U +#define V_T5_AE3_RXSTAT_C0(x) ((x) << S_T5_AE3_RXSTAT_C0) +#define G_T5_AE3_RXSTAT_C0(x) (((x) >> S_T5_AE3_RXSTAT_C0) & M_T5_AE3_RXSTAT_C0) + +#define A_MAC_PORT_AE_TX_COEF_REQ_3 0x2a68 +#define A_MAC_PORT_AE_TX_COEF_STAT_3 0x2a6c +#define A_MAC_PORT_AE_REG_MODE_3 0x2a70 +#define A_MAC_PORT_AE_PRBS_CTL_3 0x2a74 +#define A_MAC_PORT_AE_FSM_CTL_3 0x2a78 +#define A_MAC_PORT_AE_FSM_STATE_3 0x2a7c +#define A_MAC_PORT_AE_TX_DIS 0x2a80 +#define A_MAC_PORT_AE_KR_CTRL 0x2a84 +#define A_MAC_PORT_AE_RX_SIGDET 0x2a88 +#define A_MAC_PORT_AE_KR_STATUS 0x2a8c +#define A_MAC_PORT_AE_TX_DIS_1 0x2a90 +#define A_MAC_PORT_AE_KR_CTRL_1 0x2a94 +#define A_MAC_PORT_AE_RX_SIGDET_1 0x2a98 +#define A_MAC_PORT_AE_KR_STATUS_1 0x2a9c +#define A_MAC_PORT_AE_TX_DIS_2 0x2aa0 +#define A_MAC_PORT_AE_KR_CTRL_2 0x2aa4 +#define A_MAC_PORT_AE_RX_SIGDET_2 0x2aa8 +#define A_MAC_PORT_AE_KR_STATUS_2 0x2aac +#define A_MAC_PORT_AE_TX_DIS_3 0x2ab0 +#define A_MAC_PORT_AE_KR_CTRL_3 0x2ab4 +#define A_MAC_PORT_AE_RX_SIGDET_3 0x2ab8 +#define A_MAC_PORT_AE_KR_STATUS_3 0x2abc +#define A_MAC_PORT_AET_STAGE_CONFIGURATION_0 0x2b00 + +#define S_EN_HOLD_FAIL 14 +#define V_EN_HOLD_FAIL(x) ((x) << S_EN_HOLD_FAIL) +#define F_EN_HOLD_FAIL V_EN_HOLD_FAIL(1U) + +#define S_INIT_METH 12 +#define M_INIT_METH 0x3U +#define V_INIT_METH(x) ((x) << S_INIT_METH) +#define G_INIT_METH(x) (((x) >> S_INIT_METH) & M_INIT_METH) + +#define S_CE_DECS 8 +#define M_CE_DECS 0xfU +#define V_CE_DECS(x) ((x) << S_CE_DECS) +#define G_CE_DECS(x) (((x) >> S_CE_DECS) & M_CE_DECS) + +#define S_EN_ZFE 7 +#define V_EN_ZFE(x) ((x) << S_EN_ZFE) +#define F_EN_ZFE V_EN_ZFE(1U) + +#define S_EN_GAIN_TOG 6 +#define V_EN_GAIN_TOG(x) ((x) << S_EN_GAIN_TOG) +#define F_EN_GAIN_TOG V_EN_GAIN_TOG(1U) + +#define S_EN_AI_C1 5 +#define V_EN_AI_C1(x) ((x) << S_EN_AI_C1) +#define F_EN_AI_C1 V_EN_AI_C1(1U) + +#define S_EN_MAX_ST 4 +#define V_EN_MAX_ST(x) ((x) << S_EN_MAX_ST) +#define F_EN_MAX_ST V_EN_MAX_ST(1U) + +#define S_EN_H1T_EQ 3 +#define V_EN_H1T_EQ(x) ((x) << S_EN_H1T_EQ) +#define F_EN_H1T_EQ V_EN_H1T_EQ(1U) + +#define S_H1TEQ_GOAL 0 +#define M_H1TEQ_GOAL 0x7U +#define V_H1TEQ_GOAL(x) ((x) << S_H1TEQ_GOAL) +#define G_H1TEQ_GOAL(x) (((x) >> S_H1TEQ_GOAL) & M_H1TEQ_GOAL) + +#define A_MAC_PORT_AET_SIGNAL_LOSS_DETECTION_0 0x2b04 + +#define S_GAIN_TH 6 +#define M_GAIN_TH 0x1fU +#define V_GAIN_TH(x) ((x) << S_GAIN_TH) +#define G_GAIN_TH(x) (((x) >> S_GAIN_TH) & M_GAIN_TH) + +#define S_EN_SD_TH 5 +#define V_EN_SD_TH(x) ((x) << S_EN_SD_TH) +#define F_EN_SD_TH V_EN_SD_TH(1U) + +#define S_EN_AMIN_TH 4 +#define V_EN_AMIN_TH(x) ((x) << S_EN_AMIN_TH) +#define F_EN_AMIN_TH V_EN_AMIN_TH(1U) + +#define S_AMIN_TH 0 +#define M_AMIN_TH 0xfU +#define V_AMIN_TH(x) ((x) << S_AMIN_TH) +#define G_AMIN_TH(x) (((x) >> S_AMIN_TH) & M_AMIN_TH) + +#define A_MAC_PORT_AET_ZFE_LIMITS_0 0x2b08 + +#define S_ACC_LIM 8 +#define M_ACC_LIM 0xfU +#define V_ACC_LIM(x) ((x) << S_ACC_LIM) +#define G_ACC_LIM(x) (((x) >> S_ACC_LIM) & M_ACC_LIM) + +#define S_CNV_LIM 4 +#define M_CNV_LIM 0xfU +#define V_CNV_LIM(x) ((x) << S_CNV_LIM) +#define G_CNV_LIM(x) (((x) >> S_CNV_LIM) & M_CNV_LIM) + +#define S_TOG_LIM 0 +#define M_TOG_LIM 0xfU +#define V_TOG_LIM(x) ((x) << S_TOG_LIM) +#define G_TOG_LIM(x) (((x) >> S_TOG_LIM) & M_TOG_LIM) + +#define A_MAC_PORT_AET_BOOTSTRAP_LOOKUP_TABLE_0 0x2b0c + +#define S_BOOT_LUT7 12 +#define M_BOOT_LUT7 0xfU +#define V_BOOT_LUT7(x) ((x) << S_BOOT_LUT7) +#define G_BOOT_LUT7(x) (((x) >> S_BOOT_LUT7) & M_BOOT_LUT7) + +#define S_BOOT_LUT6 8 +#define M_BOOT_LUT6 0xfU +#define V_BOOT_LUT6(x) ((x) << S_BOOT_LUT6) +#define G_BOOT_LUT6(x) (((x) >> S_BOOT_LUT6) & M_BOOT_LUT6) + +#define S_BOOT_LUT45 4 +#define M_BOOT_LUT45 0xfU +#define V_BOOT_LUT45(x) ((x) << S_BOOT_LUT45) +#define G_BOOT_LUT45(x) (((x) >> S_BOOT_LUT45) & M_BOOT_LUT45) + +#define S_BOOT_LUT0123 2 +#define M_BOOT_LUT0123 0x3U +#define V_BOOT_LUT0123(x) ((x) << S_BOOT_LUT0123) +#define G_BOOT_LUT0123(x) (((x) >> S_BOOT_LUT0123) & M_BOOT_LUT0123) + +#define S_BOOT_DEC_C0 1 +#define V_BOOT_DEC_C0(x) ((x) << S_BOOT_DEC_C0) +#define F_BOOT_DEC_C0 V_BOOT_DEC_C0(1U) + +#define A_MAC_PORT_AET_STATUS_0 0x2b10 + +#define S_AET_STAT 9 +#define M_AET_STAT 0xfU +#define V_AET_STAT(x) ((x) << S_AET_STAT) +#define G_AET_STAT(x) (((x) >> S_AET_STAT) & M_AET_STAT) + +#define S_NEU_STATE 5 +#define M_NEU_STATE 0xfU +#define V_NEU_STATE(x) ((x) << S_NEU_STATE) +#define G_NEU_STATE(x) (((x) >> S_NEU_STATE) & M_NEU_STATE) + +#define S_CTRL_STATE 0 +#define M_CTRL_STATE 0x1fU +#define V_CTRL_STATE(x) ((x) << S_CTRL_STATE) +#define G_CTRL_STATE(x) (((x) >> S_CTRL_STATE) & M_CTRL_STATE) + +#define A_MAC_PORT_AET_STAGE_CONFIGURATION_1 0x2b20 +#define A_MAC_PORT_AET_SIGNAL_LOSS_DETECTION_1 0x2b24 +#define A_MAC_PORT_AET_ZFE_LIMITS_1 0x2b28 +#define A_MAC_PORT_AET_BOOTSTRAP_LOOKUP_TABLE_1 0x2b2c +#define A_MAC_PORT_AET_STATUS_1 0x2b30 +#define A_MAC_PORT_AET_STAGE_CONFIGURATION_2 0x2b40 +#define A_MAC_PORT_AET_SIGNAL_LOSS_DETECTION_2 0x2b44 +#define A_MAC_PORT_AET_ZFE_LIMITS_2 0x2b48 +#define A_MAC_PORT_AET_BOOTSTRAP_LOOKUP_TABLE_2 0x2b4c +#define A_MAC_PORT_AET_STATUS_2 0x2b50 +#define A_MAC_PORT_AET_STAGE_CONFIGURATION_3 0x2b60 +#define A_MAC_PORT_AET_SIGNAL_LOSS_DETECTION_3 0x2b64 +#define A_MAC_PORT_AET_ZFE_LIMITS_3 0x2b68 +#define A_MAC_PORT_AET_BOOTSTRAP_LOOKUP_TABLE_3 0x2b6c +#define A_MAC_PORT_AET_STATUS_3 0x2b70 +#define A_MAC_PORT_TX_LINKA_TRANSMIT_CONFIGURATION_MODE 0x3000 + +#define S_T5_TX_LINKEN 15 +#define V_T5_TX_LINKEN(x) ((x) << S_T5_TX_LINKEN) +#define F_T5_TX_LINKEN V_T5_TX_LINKEN(1U) + +#define S_T5_TX_LINKRST 14 +#define V_T5_TX_LINKRST(x) ((x) << S_T5_TX_LINKRST) +#define F_T5_TX_LINKRST V_T5_TX_LINKRST(1U) + +#define S_T5_TX_CFGWRT 13 +#define V_T5_TX_CFGWRT(x) ((x) << S_T5_TX_CFGWRT) +#define F_T5_TX_CFGWRT V_T5_TX_CFGWRT(1U) + +#define S_T5_TX_CFGPTR 11 +#define M_T5_TX_CFGPTR 0x3U +#define V_T5_TX_CFGPTR(x) ((x) << S_T5_TX_CFGPTR) +#define G_T5_TX_CFGPTR(x) (((x) >> S_T5_TX_CFGPTR) & M_T5_TX_CFGPTR) + +#define S_T5_TX_CFGEXT 10 +#define V_T5_TX_CFGEXT(x) ((x) << S_T5_TX_CFGEXT) +#define F_T5_TX_CFGEXT V_T5_TX_CFGEXT(1U) + +#define S_T5_TX_CFGACT 9 +#define V_T5_TX_CFGACT(x) ((x) << S_T5_TX_CFGACT) +#define F_T5_TX_CFGACT V_T5_TX_CFGACT(1U) + +#define S_T5_TX_RSYNCC 8 +#define V_T5_TX_RSYNCC(x) ((x) << S_T5_TX_RSYNCC) +#define F_T5_TX_RSYNCC V_T5_TX_RSYNCC(1U) + +#define S_T5_TX_PLLSEL 6 +#define M_T5_TX_PLLSEL 0x3U +#define V_T5_TX_PLLSEL(x) ((x) << S_T5_TX_PLLSEL) +#define G_T5_TX_PLLSEL(x) (((x) >> S_T5_TX_PLLSEL) & M_T5_TX_PLLSEL) + +#define S_T5_TX_EXTC16 5 +#define V_T5_TX_EXTC16(x) ((x) << S_T5_TX_EXTC16) +#define F_T5_TX_EXTC16 V_T5_TX_EXTC16(1U) + +#define S_T5_TX_DCKSEL 4 +#define V_T5_TX_DCKSEL(x) ((x) << S_T5_TX_DCKSEL) +#define F_T5_TX_DCKSEL V_T5_TX_DCKSEL(1U) + +#define S_T5_TX_RXLOOP 3 +#define V_T5_TX_RXLOOP(x) ((x) << S_T5_TX_RXLOOP) +#define F_T5_TX_RXLOOP V_T5_TX_RXLOOP(1U) + +#define S_T5_TX_BWSEL 2 +#define V_T5_TX_BWSEL(x) ((x) << S_T5_TX_BWSEL) +#define F_T5_TX_BWSEL V_T5_TX_BWSEL(1U) + +#define S_T5_TX_RTSEL 0 +#define M_T5_TX_RTSEL 0x3U +#define V_T5_TX_RTSEL(x) ((x) << S_T5_TX_RTSEL) +#define G_T5_TX_RTSEL(x) (((x) >> S_T5_TX_RTSEL) & M_T5_TX_RTSEL) + +#define A_MAC_PORT_TX_LINKA_TRANSMIT_TEST_CONTROL 0x3004 + +#define S_SPSEL 11 +#define M_SPSEL 0x7U +#define V_SPSEL(x) ((x) << S_SPSEL) +#define G_SPSEL(x) (((x) >> S_SPSEL) & M_SPSEL) + +#define S_AFDWEN 7 +#define V_AFDWEN(x) ((x) << S_AFDWEN) +#define F_AFDWEN V_AFDWEN(1U) + +#define S_TPGMD 3 +#define V_TPGMD(x) ((x) << S_TPGMD) +#define F_TPGMD V_TPGMD(1U) + +#define A_MAC_PORT_TX_LINKA_TRANSMIT_COEFFICIENT_CONTROL 0x3008 + +#define S_ZCALOVRD 8 +#define V_ZCALOVRD(x) ((x) << S_ZCALOVRD) +#define F_ZCALOVRD V_ZCALOVRD(1U) + +#define S_AMMODE 7 +#define V_AMMODE(x) ((x) << S_AMMODE) +#define F_AMMODE V_AMMODE(1U) + +#define S_AEPOL 6 +#define V_AEPOL(x) ((x) << S_AEPOL) +#define F_AEPOL V_AEPOL(1U) + +#define S_AESRC 5 +#define V_AESRC(x) ((x) << S_AESRC) +#define F_AESRC V_AESRC(1U) + +#define A_MAC_PORT_TX_LINKA_TRANSMIT_DRIVER_MODE_CONTROL 0x300c + +#define S_T5DRVHIZ 5 +#define V_T5DRVHIZ(x) ((x) << S_T5DRVHIZ) +#define F_T5DRVHIZ V_T5DRVHIZ(1U) + +#define S_T5SASIMP 4 +#define V_T5SASIMP(x) ((x) << S_T5SASIMP) +#define F_T5SASIMP V_T5SASIMP(1U) + +#define S_T5SLEW 2 +#define M_T5SLEW 0x3U +#define V_T5SLEW(x) ((x) << S_T5SLEW) +#define G_T5SLEW(x) (((x) >> S_T5SLEW) & M_T5SLEW) + +#define A_MAC_PORT_TX_LINKA_TRANSMIT_DRIVER_OVERRIDE_CONTROL 0x3010 + +#define S_T5C2BUFDCEN 5 +#define V_T5C2BUFDCEN(x) ((x) << S_T5C2BUFDCEN) +#define F_T5C2BUFDCEN V_T5C2BUFDCEN(1U) + +#define S_T5DCCEN 4 +#define V_T5DCCEN(x) ((x) << S_T5DCCEN) +#define F_T5DCCEN V_T5DCCEN(1U) + +#define S_T5REGBYP 3 +#define V_T5REGBYP(x) ((x) << S_T5REGBYP) +#define F_T5REGBYP V_T5REGBYP(1U) + +#define S_T5REGAEN 2 +#define V_T5REGAEN(x) ((x) << S_T5REGAEN) +#define F_T5REGAEN V_T5REGAEN(1U) + +#define S_T5REGAMP 0 +#define M_T5REGAMP 0x3U +#define V_T5REGAMP(x) ((x) << S_T5REGAMP) +#define G_T5REGAMP(x) (((x) >> S_T5REGAMP) & M_T5REGAMP) + +#define A_MAC_PORT_TX_LINKA_TRANSMIT_DCLK_ROTATOR_OVERRIDE 0x3014 + +#define S_RSTEP 15 +#define V_RSTEP(x) ((x) << S_RSTEP) +#define F_RSTEP V_RSTEP(1U) + +#define S_RLOCK 14 +#define V_RLOCK(x) ((x) << S_RLOCK) +#define F_RLOCK V_RLOCK(1U) + +#define S_RPOS 8 +#define M_RPOS 0x3fU +#define V_RPOS(x) ((x) << S_RPOS) +#define G_RPOS(x) (((x) >> S_RPOS) & M_RPOS) + +#define S_DCLKSAM 7 +#define V_DCLKSAM(x) ((x) << S_DCLKSAM) +#define F_DCLKSAM V_DCLKSAM(1U) + +#define A_MAC_PORT_TX_LINKA_TRANSMIT_IMPEDANCE_CALIBRATION_OVERRIDE 0x3018 + +#define S_CALSSTN 3 +#define M_CALSSTN 0x7U +#define V_CALSSTN(x) ((x) << S_CALSSTN) +#define G_CALSSTN(x) (((x) >> S_CALSSTN) & M_CALSSTN) + +#define S_CALSSTP 0 +#define M_CALSSTP 0x7U +#define V_CALSSTP(x) ((x) << S_CALSSTP) +#define G_CALSSTP(x) (((x) >> S_CALSSTP) & M_CALSSTP) + +#define A_MAC_PORT_TX_LINKA_TRANSMIT_DCLK_DRIFT_TOLERANCE 0x301c + +#define S_DRTOL 0 +#define M_DRTOL 0x1fU +#define V_DRTOL(x) ((x) << S_DRTOL) +#define G_DRTOL(x) (((x) >> S_DRTOL) & M_DRTOL) + +#define A_MAC_PORT_TX_LINKA_TRANSMIT_TAP_0_COEFFICIENT 0x3020 + +#define S_T5NXTT0 0 +#define M_T5NXTT0 0x1fU +#define V_T5NXTT0(x) ((x) << S_T5NXTT0) +#define G_T5NXTT0(x) (((x) >> S_T5NXTT0) & M_T5NXTT0) + +#define A_MAC_PORT_TX_LINKA_TRANSMIT_TAP_1_COEFFICIENT 0x3024 + +#define S_T5NXTT1 0 +#define M_T5NXTT1 0x3fU +#define V_T5NXTT1(x) ((x) << S_T5NXTT1) +#define G_T5NXTT1(x) (((x) >> S_T5NXTT1) & M_T5NXTT1) + +#define A_MAC_PORT_TX_LINKA_TRANSMIT_TAP_2_COEFFICIENT 0x3028 + +#define S_T5NXTT2 0 +#define M_T5NXTT2 0x3fU +#define V_T5NXTT2(x) ((x) << S_T5NXTT2) +#define G_T5NXTT2(x) (((x) >> S_T5NXTT2) & M_T5NXTT2) + +#define A_MAC_PORT_TX_LINKA_TRANSMIT_AMPLITUDE 0x3030 + +#define S_T5TXPWR 0 +#define M_T5TXPWR 0x3fU +#define V_T5TXPWR(x) ((x) << S_T5TXPWR) +#define G_T5TXPWR(x) (((x) >> S_T5TXPWR) & M_T5TXPWR) + +#define A_MAC_PORT_TX_LINKA_TRANSMIT_POLARITY 0x3034 + +#define S_NXTPOL 0 +#define M_NXTPOL 0x7U +#define V_NXTPOL(x) ((x) << S_NXTPOL) +#define G_NXTPOL(x) (((x) >> S_NXTPOL) & M_NXTPOL) + +#define A_MAC_PORT_TX_LINKA_TRANSMIT_802_3AP_ADAPTIVE_EQUALIZATION_COMMAND 0x3038 + +#define S_CPREST 13 +#define V_CPREST(x) ((x) << S_CPREST) +#define F_CPREST V_CPREST(1U) + +#define S_CINIT 12 +#define V_CINIT(x) ((x) << S_CINIT) +#define F_CINIT V_CINIT(1U) + +#define A_MAC_PORT_TX_LINKA_TRANSMIT_802_3AP_ADAPTIVE_EQUALIZATION_STATUS 0x303c +#define A_MAC_PORT_TX_LINKA_TRANSMIT_TAP_0_COEFFICIENT_OVERRIDE 0x3040 +#define A_MAC_PORT_TX_LINKA_TRANSMIT_TAP_1_COEFFICIENT_OVERRIDE 0x3044 + +#define S_T5NIDAC1 0 +#define M_T5NIDAC1 0x3fU +#define V_T5NIDAC1(x) ((x) << S_T5NIDAC1) +#define G_T5NIDAC1(x) (((x) >> S_T5NIDAC1) & M_T5NIDAC1) + +#define A_MAC_PORT_TX_LINKA_TRANSMIT_TAP_2_COEFFICIENT_OVERRIDE 0x3048 + +#define S_T5NIDAC2 0 +#define M_T5NIDAC2 0x3fU +#define V_T5NIDAC2(x) ((x) << S_T5NIDAC2) +#define G_T5NIDAC2(x) (((x) >> S_T5NIDAC2) & M_T5NIDAC2) + +#define A_MAC_PORT_TX_LINKA_TRANSMIT_TAP_0_COEFFICIENT_APPLIED 0x3060 +#define A_MAC_PORT_TX_LINKA_TRANSMIT_TAP_1_COEFFICIENT_APPLIED 0x3064 + +#define S_T5AIDAC1 0 +#define M_T5AIDAC1 0x3fU +#define V_T5AIDAC1(x) ((x) << S_T5AIDAC1) +#define G_T5AIDAC1(x) (((x) >> S_T5AIDAC1) & M_T5AIDAC1) + +#define A_MAC_PORT_TX_LINKA_TRANSMIT_TAP_2_COEFFICIENT_APPLIED 0x3068 +#define A_MAC_PORT_TX_LINKA_TRANSMIT_SEGMENT_DISABLE_APPLIED_1 0x3070 + +#define S_MAINSC 6 +#define M_MAINSC 0x3fU +#define V_MAINSC(x) ((x) << S_MAINSC) +#define G_MAINSC(x) (((x) >> S_MAINSC) & M_MAINSC) + +#define S_POSTSC 0 +#define M_POSTSC 0x3fU +#define V_POSTSC(x) ((x) << S_POSTSC) +#define G_POSTSC(x) (((x) >> S_POSTSC) & M_POSTSC) + +#define A_MAC_PORT_TX_LINKA_TRANSMIT_SEGMENT_DISABLE_APPLIED_2 0x3074 + +#define S_PRESC 0 +#define M_PRESC 0x1fU +#define V_PRESC(x) ((x) << S_PRESC) +#define G_PRESC(x) (((x) >> S_PRESC) & M_PRESC) + +#define A_MAC_PORT_TX_LINKA_TRANSMIT_EXTENDED_ADDRESS_DATA 0x3078 +#define A_MAC_PORT_TX_LINKA_TRANSMIT_EXTENDED_ADDRESS_ADDR 0x307c + +#define S_T5XADDR 1 +#define M_T5XADDR 0x1fU +#define V_T5XADDR(x) ((x) << S_T5XADDR) +#define G_T5XADDR(x) (((x) >> S_T5XADDR) & M_T5XADDR) + +#define S_T5XWR 0 +#define V_T5XWR(x) ((x) << S_T5XWR) +#define F_T5XWR V_T5XWR(1U) + +#define A_MAC_PORT_TX_LINKA_TRANSMIT_PATTERN_BUFFER_BYTES_1_0 0x3080 + +#define S_XDAT10 0 +#define M_XDAT10 0xffffU +#define V_XDAT10(x) ((x) << S_XDAT10) +#define G_XDAT10(x) (((x) >> S_XDAT10) & M_XDAT10) + +#define A_MAC_PORT_TX_LINKA_TRANSMIT_PATTERN_BUFFER_BYTES_3_2 0x3084 + +#define S_XDAT32 0 +#define M_XDAT32 0xffffU +#define V_XDAT32(x) ((x) << S_XDAT32) +#define G_XDAT32(x) (((x) >> S_XDAT32) & M_XDAT32) + +#define A_MAC_PORT_TX_LINKA_TRANSMIT_PATTERN_BUFFER_BYTE_4 0x3088 + +#define S_XDAT4 0 +#define M_XDAT4 0xffU +#define V_XDAT4(x) ((x) << S_XDAT4) +#define G_XDAT4(x) (((x) >> S_XDAT4) & M_XDAT4) + +#define A_MAC_PORT_TX_LINKA_TRANSMIT_DCC_CONTROL 0x308c + +#define S_DCCTIMEDOUT 15 +#define V_DCCTIMEDOUT(x) ((x) << S_DCCTIMEDOUT) +#define F_DCCTIMEDOUT V_DCCTIMEDOUT(1U) + +#define S_DCCTIMEEN 14 +#define V_DCCTIMEEN(x) ((x) << S_DCCTIMEEN) +#define F_DCCTIMEEN V_DCCTIMEEN(1U) + +#define S_DCCLOCK 13 +#define V_DCCLOCK(x) ((x) << S_DCCLOCK) +#define F_DCCLOCK V_DCCLOCK(1U) + +#define S_DCCOFFSET 8 +#define M_DCCOFFSET 0x1fU +#define V_DCCOFFSET(x) ((x) << S_DCCOFFSET) +#define G_DCCOFFSET(x) (((x) >> S_DCCOFFSET) & M_DCCOFFSET) + +#define S_DCCSTEP 6 +#define M_DCCSTEP 0x3U +#define V_DCCSTEP(x) ((x) << S_DCCSTEP) +#define G_DCCSTEP(x) (((x) >> S_DCCSTEP) & M_DCCSTEP) + +#define S_DCCASTEP 1 +#define M_DCCASTEP 0x1fU +#define V_DCCASTEP(x) ((x) << S_DCCASTEP) +#define G_DCCASTEP(x) (((x) >> S_DCCASTEP) & M_DCCASTEP) + +#define S_DCCAEN 0 +#define V_DCCAEN(x) ((x) << S_DCCAEN) +#define F_DCCAEN V_DCCAEN(1U) + +#define A_MAC_PORT_TX_LINKA_TRANSMIT_DCC_OVERRIDE 0x3090 + +#define S_DCCOUT 12 +#define V_DCCOUT(x) ((x) << S_DCCOUT) +#define F_DCCOUT V_DCCOUT(1U) + +#define S_DCCCLK 11 +#define V_DCCCLK(x) ((x) << S_DCCCLK) +#define F_DCCCLK V_DCCCLK(1U) + +#define S_DCCHOLD 10 +#define V_DCCHOLD(x) ((x) << S_DCCHOLD) +#define F_DCCHOLD V_DCCHOLD(1U) + +#define S_DCCSIGN 8 +#define M_DCCSIGN 0x3U +#define V_DCCSIGN(x) ((x) << S_DCCSIGN) +#define G_DCCSIGN(x) (((x) >> S_DCCSIGN) & M_DCCSIGN) + +#define S_DCCAMP 1 +#define M_DCCAMP 0x7fU +#define V_DCCAMP(x) ((x) << S_DCCAMP) +#define G_DCCAMP(x) (((x) >> S_DCCAMP) & M_DCCAMP) + +#define S_DCCOEN 0 +#define V_DCCOEN(x) ((x) << S_DCCOEN) +#define F_DCCOEN V_DCCOEN(1U) + +#define A_MAC_PORT_TX_LINKA_TRANSMIT_DCC_APPLIED 0x3094 + +#define S_DCCASIGN 7 +#define M_DCCASIGN 0x3U +#define V_DCCASIGN(x) ((x) << S_DCCASIGN) +#define G_DCCASIGN(x) (((x) >> S_DCCASIGN) & M_DCCASIGN) + +#define S_DCCAAMP 0 +#define M_DCCAAMP 0x7fU +#define V_DCCAAMP(x) ((x) << S_DCCAAMP) +#define G_DCCAAMP(x) (((x) >> S_DCCAAMP) & M_DCCAAMP) + +#define A_MAC_PORT_TX_LINKA_TRANSMIT_DCC_TIME_OUT 0x3098 + +#define S_DCCTIMEOUTVAL 0 +#define M_DCCTIMEOUTVAL 0xffffU +#define V_DCCTIMEOUTVAL(x) ((x) << S_DCCTIMEOUTVAL) +#define G_DCCTIMEOUTVAL(x) (((x) >> S_DCCTIMEOUTVAL) & M_DCCTIMEOUTVAL) + +#define A_MAC_PORT_TX_LINKA_TRANSMIT_802_3AZ_CONTROL 0x309c + +#define S_LPIDCLK 4 +#define V_LPIDCLK(x) ((x) << S_LPIDCLK) +#define F_LPIDCLK V_LPIDCLK(1U) + +#define S_LPITERM 2 +#define M_LPITERM 0x3U +#define V_LPITERM(x) ((x) << S_LPITERM) +#define G_LPITERM(x) (((x) >> S_LPITERM) & M_LPITERM) + +#define S_LPIPRCD 0 +#define M_LPIPRCD 0x3U +#define V_LPIPRCD(x) ((x) << S_LPIPRCD) +#define G_LPIPRCD(x) (((x) >> S_LPIPRCD) & M_LPIPRCD) + +#define A_MAC_PORT_TX_LINKA_TRANSMIT_MACRO_TEST_CONTROL_4 0x30f0 + +#define S_SDOVRDEN 8 +#define V_SDOVRDEN(x) ((x) << S_SDOVRDEN) +#define F_SDOVRDEN V_SDOVRDEN(1U) + +#define S_SDOVRD 0 +#define M_SDOVRD 0xffU +#define V_SDOVRD(x) ((x) << S_SDOVRD) +#define G_SDOVRD(x) (((x) >> S_SDOVRD) & M_SDOVRD) + +#define A_MAC_PORT_TX_LINKA_TRANSMIT_MACRO_TEST_CONTROL_3 0x30f4 + +#define S_SLEWCODE 1 +#define M_SLEWCODE 0x3U +#define V_SLEWCODE(x) ((x) << S_SLEWCODE) +#define G_SLEWCODE(x) (((x) >> S_SLEWCODE) & M_SLEWCODE) + +#define S_ASEGEN 0 +#define V_ASEGEN(x) ((x) << S_ASEGEN) +#define F_ASEGEN V_ASEGEN(1U) + +#define A_MAC_PORT_TX_LINKA_TRANSMIT_MACRO_TEST_CONTROL_2 0x30f8 + +#define S_AECMDVAL 14 +#define V_AECMDVAL(x) ((x) << S_AECMDVAL) +#define F_AECMDVAL V_AECMDVAL(1U) + +#define S_AECMD1312 12 +#define M_AECMD1312 0x3U +#define V_AECMD1312(x) ((x) << S_AECMD1312) +#define G_AECMD1312(x) (((x) >> S_AECMD1312) & M_AECMD1312) + +#define S_AECMD70 0 +#define M_AECMD70 0xffU +#define V_AECMD70(x) ((x) << S_AECMD70) +#define G_AECMD70(x) (((x) >> S_AECMD70) & M_AECMD70) + +#define A_MAC_PORT_TX_LINKA_TRANSMIT_MACRO_TEST_CONTROL_1 0x30fc + +#define S_C48DIVCTL 12 +#define M_C48DIVCTL 0x7U +#define V_C48DIVCTL(x) ((x) << S_C48DIVCTL) +#define G_C48DIVCTL(x) (((x) >> S_C48DIVCTL) & M_C48DIVCTL) + +#define S_RATEDIVCTL 9 +#define M_RATEDIVCTL 0x7U +#define V_RATEDIVCTL(x) ((x) << S_RATEDIVCTL) +#define G_RATEDIVCTL(x) (((x) >> S_RATEDIVCTL) & M_RATEDIVCTL) + +#define S_ANLGFLSH 8 +#define V_ANLGFLSH(x) ((x) << S_ANLGFLSH) +#define F_ANLGFLSH V_ANLGFLSH(1U) + +#define S_DCCTSTOUT 7 +#define V_DCCTSTOUT(x) ((x) << S_DCCTSTOUT) +#define F_DCCTSTOUT V_DCCTSTOUT(1U) + +#define S_BSOUT 6 +#define V_BSOUT(x) ((x) << S_BSOUT) +#define F_BSOUT V_BSOUT(1U) + +#define S_BSIN 5 +#define V_BSIN(x) ((x) << S_BSIN) +#define F_BSIN V_BSIN(1U) + +#define S_JTAGAMPL 3 +#define M_JTAGAMPL 0x3U +#define V_JTAGAMPL(x) ((x) << S_JTAGAMPL) +#define G_JTAGAMPL(x) (((x) >> S_JTAGAMPL) & M_JTAGAMPL) + +#define S_JTAGTS 2 +#define V_JTAGTS(x) ((x) << S_JTAGTS) +#define F_JTAGTS V_JTAGTS(1U) + +#define S_TS 1 +#define V_TS(x) ((x) << S_TS) +#define F_TS V_TS(1U) + +#define S_OBS 0 +#define V_OBS(x) ((x) << S_OBS) +#define F_OBS V_OBS(1U) + +#define A_MAC_PORT_TX_LINKB_TRANSMIT_CONFIGURATION_MODE 0x3100 +#define A_MAC_PORT_TX_LINKB_TRANSMIT_TEST_CONTROL 0x3104 +#define A_MAC_PORT_TX_LINKB_TRANSMIT_COEFFICIENT_CONTROL 0x3108 +#define A_MAC_PORT_TX_LINKB_TRANSMIT_DRIVER_MODE_CONTROL 0x310c +#define A_MAC_PORT_TX_LINKB_TRANSMIT_DRIVER_OVERRIDE_CONTROL 0x3110 +#define A_MAC_PORT_TX_LINKB_TRANSMIT_DCLK_ROTATOR_OVERRIDE 0x3114 +#define A_MAC_PORT_TX_LINKB_TRANSMIT_IMPEDANCE_CALIBRATION_OVERRIDE 0x3118 +#define A_MAC_PORT_TX_LINKB_TRANSMIT_DCLK_DRIFT_TOLERANCE 0x311c +#define A_MAC_PORT_TX_LINKB_TRANSMIT_TAP_0_COEFFICIENT 0x3120 +#define A_MAC_PORT_TX_LINKB_TRANSMIT_TAP_1_COEFFICIENT 0x3124 +#define A_MAC_PORT_TX_LINKB_TRANSMIT_TAP_2_COEFFICIENT 0x3128 +#define A_MAC_PORT_TX_LINKB_TRANSMIT_AMPLITUDE 0x3130 +#define A_MAC_PORT_TX_LINKB_TRANSMIT_POLARITY 0x3134 +#define A_MAC_PORT_TX_LINKB_TRANSMIT_802_3AP_ADAPTIVE_EQUALIZATION_COMMAND 0x3138 +#define A_MAC_PORT_TX_LINKB_TRANSMIT_802_3AP_ADAPTIVE_EQUALIZATION_STATUS 0x313c +#define A_MAC_PORT_TX_LINKB_TRANSMIT_TAP_0_COEFFICIENT_OVERRIDE 0x3140 +#define A_MAC_PORT_TX_LINKB_TRANSMIT_TAP_1_COEFFICIENT_OVERRIDE 0x3144 +#define A_MAC_PORT_TX_LINKB_TRANSMIT_TAP_2_COEFFICIENT_OVERRIDE 0x3148 +#define A_MAC_PORT_TX_LINKB_TRANSMIT_TAP_0_COEFFICIENT_APPLIED 0x3160 +#define A_MAC_PORT_TX_LINKB_TRANSMIT_TAP_1_COEFFICIENT_APPLIED 0x3164 +#define A_MAC_PORT_TX_LINKB_TRANSMIT_TAP_2_COEFFICIENT_APPLIED 0x3168 +#define A_MAC_PORT_TX_LINKB_TRANSMIT_SEGMENT_DISABLE_APPLIED_1 0x3170 +#define A_MAC_PORT_TX_LINKB_TRANSMIT_SEGMENT_DISABLE_APPLIED_2 0x3174 +#define A_MAC_PORT_TX_LINKB_TRANSMIT_EXTENDED_ADDRESS_DATA 0x3178 +#define A_MAC_PORT_TX_LINKB_TRANSMIT_EXTENDED_ADDRESS_ADDR 0x317c +#define A_MAC_PORT_TX_LINKB_TRANSMIT_PATTERN_BUFFER_BYTES_1_0 0x3180 +#define A_MAC_PORT_TX_LINKB_TRANSMIT_PATTERN_BUFFER_BYTES_3_2 0x3184 +#define A_MAC_PORT_TX_LINKB_TRANSMIT_PATTERN_BUFFER_BYTE_4 0x3188 +#define A_MAC_PORT_TX_LINKB_TRANSMIT_DCC_CONTROL 0x318c +#define A_MAC_PORT_TX_LINKB_TRANSMIT_DCC_OVERRIDE 0x3190 +#define A_MAC_PORT_TX_LINKB_TRANSMIT_DCC_APPLIED 0x3194 +#define A_MAC_PORT_TX_LINKB_TRANSMIT_DCC_TIME_OUT 0x3198 +#define A_MAC_PORT_TX_LINKB_TRANSMIT_802_3AZ_CONTROL 0x319c +#define A_MAC_PORT_TX_LINKB_TRANSMIT_MACRO_TEST_CONTROL_4 0x31f0 +#define A_MAC_PORT_TX_LINKB_TRANSMIT_MACRO_TEST_CONTROL_3 0x31f4 +#define A_MAC_PORT_TX_LINKB_TRANSMIT_MACRO_TEST_CONTROL_2 0x31f8 +#define A_MAC_PORT_TX_LINKB_TRANSMIT_MACRO_TEST_CONTROL_1 0x31fc +#define A_MAC_PORT_RX_LINKA_RECEIVER_CONFIGURATION_MODE 0x3200 + +#define S_T5_RX_LINKEN 15 +#define V_T5_RX_LINKEN(x) ((x) << S_T5_RX_LINKEN) +#define F_T5_RX_LINKEN V_T5_RX_LINKEN(1U) + +#define S_T5_RX_LINKRST 14 +#define V_T5_RX_LINKRST(x) ((x) << S_T5_RX_LINKRST) +#define F_T5_RX_LINKRST V_T5_RX_LINKRST(1U) + +#define S_T5_RX_CFGWRT 13 +#define V_T5_RX_CFGWRT(x) ((x) << S_T5_RX_CFGWRT) +#define F_T5_RX_CFGWRT V_T5_RX_CFGWRT(1U) + +#define S_T5_RX_CFGPTR 11 +#define M_T5_RX_CFGPTR 0x3U +#define V_T5_RX_CFGPTR(x) ((x) << S_T5_RX_CFGPTR) +#define G_T5_RX_CFGPTR(x) (((x) >> S_T5_RX_CFGPTR) & M_T5_RX_CFGPTR) + +#define S_T5_RX_CFGEXT 10 +#define V_T5_RX_CFGEXT(x) ((x) << S_T5_RX_CFGEXT) +#define F_T5_RX_CFGEXT V_T5_RX_CFGEXT(1U) + +#define S_T5_RX_CFGACT 9 +#define V_T5_RX_CFGACT(x) ((x) << S_T5_RX_CFGACT) +#define F_T5_RX_CFGACT V_T5_RX_CFGACT(1U) + +#define S_T5_RX_AUXCLK 8 +#define V_T5_RX_AUXCLK(x) ((x) << S_T5_RX_AUXCLK) +#define F_T5_RX_AUXCLK V_T5_RX_AUXCLK(1U) + +#define S_T5_RX_PLLSEL 6 +#define M_T5_RX_PLLSEL 0x3U +#define V_T5_RX_PLLSEL(x) ((x) << S_T5_RX_PLLSEL) +#define G_T5_RX_PLLSEL(x) (((x) >> S_T5_RX_PLLSEL) & M_T5_RX_PLLSEL) + +#define S_T5_RX_DMSEL 4 +#define M_T5_RX_DMSEL 0x3U +#define V_T5_RX_DMSEL(x) ((x) << S_T5_RX_DMSEL) +#define G_T5_RX_DMSEL(x) (((x) >> S_T5_RX_DMSEL) & M_T5_RX_DMSEL) + +#define S_T5_RX_BWSEL 2 +#define M_T5_RX_BWSEL 0x3U +#define V_T5_RX_BWSEL(x) ((x) << S_T5_RX_BWSEL) +#define G_T5_RX_BWSEL(x) (((x) >> S_T5_RX_BWSEL) & M_T5_RX_BWSEL) + +#define S_T5_RX_RTSEL 0 +#define M_T5_RX_RTSEL 0x3U +#define V_T5_RX_RTSEL(x) ((x) << S_T5_RX_RTSEL) +#define G_T5_RX_RTSEL(x) (((x) >> S_T5_RX_RTSEL) & M_T5_RX_RTSEL) + +#define A_MAC_PORT_RX_LINKA_RECEIVER_TEST_CONTROL 0x3204 + +#define S_FERRST 10 +#define V_FERRST(x) ((x) << S_FERRST) +#define F_FERRST V_FERRST(1U) + +#define S_ERRST 9 +#define V_ERRST(x) ((x) << S_ERRST) +#define F_ERRST V_ERRST(1U) + +#define S_SYNCST 8 +#define V_SYNCST(x) ((x) << S_SYNCST) +#define F_SYNCST V_SYNCST(1U) + +#define S_WRPSM 7 +#define V_WRPSM(x) ((x) << S_WRPSM) +#define F_WRPSM V_WRPSM(1U) + +#define S_WPLPEN 6 +#define V_WPLPEN(x) ((x) << S_WPLPEN) +#define F_WPLPEN V_WPLPEN(1U) + +#define S_WRPMD 5 +#define V_WRPMD(x) ((x) << S_WRPMD) +#define F_WRPMD V_WRPMD(1U) + +#define S_PATSEL 0 +#define M_PATSEL 0x7U +#define V_PATSEL(x) ((x) << S_PATSEL) +#define G_PATSEL(x) (((x) >> S_PATSEL) & M_PATSEL) + +#define A_MAC_PORT_RX_LINKA_PHASE_ROTATOR_CONTROL 0x3208 + +#define S_RSTUCK 3 +#define V_RSTUCK(x) ((x) << S_RSTUCK) +#define F_RSTUCK V_RSTUCK(1U) + +#define S_FRZFW 2 +#define V_FRZFW(x) ((x) << S_FRZFW) +#define F_FRZFW V_FRZFW(1U) + +#define S_RSTFW 1 +#define V_RSTFW(x) ((x) << S_RSTFW) +#define F_RSTFW V_RSTFW(1U) + +#define S_SSCEN 0 +#define V_SSCEN(x) ((x) << S_SSCEN) +#define F_SSCEN V_SSCEN(1U) + +#define A_MAC_PORT_RX_LINKA_PHASE_ROTATOR_OFFSET_CONTROL 0x320c +#define A_MAC_PORT_RX_LINKA_PHASE_ROTATOR_POSITION_1 0x3210 + +#define S_ROT00 0 +#define M_ROT00 0x3fU +#define V_ROT00(x) ((x) << S_ROT00) +#define G_ROT00(x) (((x) >> S_ROT00) & M_ROT00) + +#define A_MAC_PORT_RX_LINKA_PHASE_ROTATOR_POSITION_2 0x3214 + +#define S_FREQFW 8 +#define M_FREQFW 0xffU +#define V_FREQFW(x) ((x) << S_FREQFW) +#define G_FREQFW(x) (((x) >> S_FREQFW) & M_FREQFW) + +#define S_FWSNAP 7 +#define V_FWSNAP(x) ((x) << S_FWSNAP) +#define F_FWSNAP V_FWSNAP(1U) + +#define A_MAC_PORT_RX_LINKA_PHASE_ROTATOR_STATIC_PHASE_OFFSET_1 0x3218 +#define A_MAC_PORT_RX_LINKA_PHASE_ROTATOR_STATIC_PHASE_OFFSET_2 0x321c + +#define S_RBOOFF 10 +#define M_RBOOFF 0x1fU +#define V_RBOOFF(x) ((x) << S_RBOOFF) +#define G_RBOOFF(x) (((x) >> S_RBOOFF) & M_RBOOFF) + +#define S_RBEOFF 5 +#define M_RBEOFF 0x1fU +#define V_RBEOFF(x) ((x) << S_RBEOFF) +#define G_RBEOFF(x) (((x) >> S_RBEOFF) & M_RBEOFF) + +#define A_MAC_PORT_RX_LINKA_DFE_CONTROL 0x3220 +#define A_MAC_PORT_RX_LINKA_DFE_SAMPLE_SNAPSHOT_1 0x3224 + +#define S_T5BYTE1 8 +#define M_T5BYTE1 0xffU +#define V_T5BYTE1(x) ((x) << S_T5BYTE1) +#define G_T5BYTE1(x) (((x) >> S_T5BYTE1) & M_T5BYTE1) + +#define S_T5BYTE0 0 +#define M_T5BYTE0 0xffU +#define V_T5BYTE0(x) ((x) << S_T5BYTE0) +#define G_T5BYTE0(x) (((x) >> S_T5BYTE0) & M_T5BYTE0) + +#define A_MAC_PORT_RX_LINKA_DFE_SAMPLE_SNAPSHOT_2 0x3228 + +#define S_T5_RX_SMODE 8 +#define M_T5_RX_SMODE 0x7U +#define V_T5_RX_SMODE(x) ((x) << S_T5_RX_SMODE) +#define G_T5_RX_SMODE(x) (((x) >> S_T5_RX_SMODE) & M_T5_RX_SMODE) + +#define S_T5_RX_ADCORR 7 +#define V_T5_RX_ADCORR(x) ((x) << S_T5_RX_ADCORR) +#define F_T5_RX_ADCORR V_T5_RX_ADCORR(1U) + +#define S_T5_RX_TRAINEN 6 +#define V_T5_RX_TRAINEN(x) ((x) << S_T5_RX_TRAINEN) +#define F_T5_RX_TRAINEN V_T5_RX_TRAINEN(1U) + +#define S_T5_RX_ASAMPQ 3 +#define M_T5_RX_ASAMPQ 0x7U +#define V_T5_RX_ASAMPQ(x) ((x) << S_T5_RX_ASAMPQ) +#define G_T5_RX_ASAMPQ(x) (((x) >> S_T5_RX_ASAMPQ) & M_T5_RX_ASAMPQ) + +#define S_T5_RX_ASAMP 0 +#define M_T5_RX_ASAMP 0x7U +#define V_T5_RX_ASAMP(x) ((x) << S_T5_RX_ASAMP) +#define G_T5_RX_ASAMP(x) (((x) >> S_T5_RX_ASAMP) & M_T5_RX_ASAMP) + +#define A_MAC_PORT_RX_LINKA_RECEIVER_VGA_CONTROL_1 0x322c +#define A_MAC_PORT_RX_LINKA_RECEIVER_VGA_CONTROL_2 0x3230 + +#define S_T5SHORTV 10 +#define V_T5SHORTV(x) ((x) << S_T5SHORTV) +#define F_T5SHORTV V_T5SHORTV(1U) + +#define S_T5VGAIN 0 +#define M_T5VGAIN 0x1fU +#define V_T5VGAIN(x) ((x) << S_T5VGAIN) +#define G_T5VGAIN(x) (((x) >> S_T5VGAIN) & M_T5VGAIN) + +#define A_MAC_PORT_RX_LINKA_RECEIVER_VGA_CONTROL_3 0x3234 +#define A_MAC_PORT_RX_LINKA_RECEIVER_DQCC_CONTROL_1 0x3238 + +#define S_IQSEP 10 +#define M_IQSEP 0x1fU +#define V_IQSEP(x) ((x) << S_IQSEP) +#define G_IQSEP(x) (((x) >> S_IQSEP) & M_IQSEP) + +#define S_DUTYQ 5 +#define M_DUTYQ 0x1fU +#define V_DUTYQ(x) ((x) << S_DUTYQ) +#define G_DUTYQ(x) (((x) >> S_DUTYQ) & M_DUTYQ) + +#define S_DUTYI 0 +#define M_DUTYI 0x1fU +#define V_DUTYI(x) ((x) << S_DUTYI) +#define G_DUTYI(x) (((x) >> S_DUTYI) & M_DUTYI) + +#define A_MAC_PORT_RX_LINKA_RECEIVER_DQCC_CONTROL_3 0x3240 + +#define S_DTHR 8 +#define M_DTHR 0x3fU +#define V_DTHR(x) ((x) << S_DTHR) +#define G_DTHR(x) (((x) >> S_DTHR) & M_DTHR) + +#define S_SNUL 0 +#define M_SNUL 0x1fU +#define V_SNUL(x) ((x) << S_SNUL) +#define G_SNUL(x) (((x) >> S_SNUL) & M_SNUL) + +#define A_MAC_PORT_RX_LINKA_RECEIVER_DACAP_AND_DACAN 0x3248 +#define A_MAC_PORT_RX_LINKA_RECEIVER_DACA_MIN_AND_DACAZ 0x324c +#define A_MAC_PORT_RX_LINKA_RECEIVER_ADAC_CONTROL 0x3250 + +#define S_ADSN_READWRITE 8 +#define V_ADSN_READWRITE(x) ((x) << S_ADSN_READWRITE) +#define F_ADSN_READWRITE V_ADSN_READWRITE(1U) + +#define S_ADSN_READONLY 7 +#define V_ADSN_READONLY(x) ((x) << S_ADSN_READONLY) +#define F_ADSN_READONLY V_ADSN_READONLY(1U) + +#define A_MAC_PORT_RX_LINKA_DFE_H1_LOCAL_OFFSET_ODD2_EVN2 0x325c + +#define S_H1O2 8 +#define M_H1O2 0x3fU +#define V_H1O2(x) ((x) << S_H1O2) +#define G_H1O2(x) (((x) >> S_H1O2) & M_H1O2) + +#define S_H1E2 0 +#define M_H1E2 0x3fU +#define V_H1E2(x) ((x) << S_H1E2) +#define G_H1E2(x) (((x) >> S_H1E2) & M_H1E2) + +#define A_MAC_PORT_RX_LINKA_DFE_H1_LOCAL_OFFSET_ODD3_EVN3 0x3260 + +#define S_H1O3 8 +#define M_H1O3 0x3fU +#define V_H1O3(x) ((x) << S_H1O3) +#define G_H1O3(x) (((x) >> S_H1O3) & M_H1O3) + +#define S_H1E3 0 +#define M_H1E3 0x3fU +#define V_H1E3(x) ((x) << S_H1E3) +#define G_H1E3(x) (((x) >> S_H1E3) & M_H1E3) + +#define A_MAC_PORT_RX_LINKA_DFE_H1_LOCAL_OFFSET_ODD4_EVN4 0x3264 + +#define S_H1O4 8 +#define M_H1O4 0x3fU +#define V_H1O4(x) ((x) << S_H1O4) +#define G_H1O4(x) (((x) >> S_H1O4) & M_H1O4) + +#define S_H1E4 0 +#define M_H1E4 0x3fU +#define V_H1E4(x) ((x) << S_H1E4) +#define G_H1E4(x) (((x) >> S_H1E4) & M_H1E4) + +#define A_MAC_PORT_RX_LINKA_DYNAMIC_AMPLITUDE_CENTERING_DAC_AND_DYNAMIC_PEAKING_CONTROL_DPC 0x3270 + +#define S_DPCMD 14 +#define V_DPCMD(x) ((x) << S_DPCMD) +#define F_DPCMD V_DPCMD(1U) + +#define A_MAC_PORT_RX_LINKA_DYNAMIC_DATA_CENTERING_DDC 0x3274 +#define A_MAC_PORT_RX_LINKA_RECEIVER_INTERNAL_STATUS 0x3278 + +#define S_T5BER6VAL 15 +#define V_T5BER6VAL(x) ((x) << S_T5BER6VAL) +#define F_T5BER6VAL V_T5BER6VAL(1U) + +#define S_T5BER6 14 +#define V_T5BER6(x) ((x) << S_T5BER6) +#define F_T5BER6 V_T5BER6(1U) + +#define S_T5BER3VAL 13 +#define V_T5BER3VAL(x) ((x) << S_T5BER3VAL) +#define F_T5BER3VAL V_T5BER3VAL(1U) + +#define S_T5TOOFAST 12 +#define V_T5TOOFAST(x) ((x) << S_T5TOOFAST) +#define F_T5TOOFAST V_T5TOOFAST(1U) + +#define S_T5DPCCMP 9 +#define V_T5DPCCMP(x) ((x) << S_T5DPCCMP) +#define F_T5DPCCMP V_T5DPCCMP(1U) + +#define S_T5DACCMP 8 +#define V_T5DACCMP(x) ((x) << S_T5DACCMP) +#define F_T5DACCMP V_T5DACCMP(1U) + +#define S_T5DDCCMP 7 +#define V_T5DDCCMP(x) ((x) << S_T5DDCCMP) +#define F_T5DDCCMP V_T5DDCCMP(1U) + +#define S_T5AERRFLG 6 +#define V_T5AERRFLG(x) ((x) << S_T5AERRFLG) +#define F_T5AERRFLG V_T5AERRFLG(1U) + +#define S_T5WERRFLG 5 +#define V_T5WERRFLG(x) ((x) << S_T5WERRFLG) +#define F_T5WERRFLG V_T5WERRFLG(1U) + +#define S_T5TRCMP 4 +#define V_T5TRCMP(x) ((x) << S_T5TRCMP) +#define F_T5TRCMP V_T5TRCMP(1U) + +#define S_T5VLCKF 3 +#define V_T5VLCKF(x) ((x) << S_T5VLCKF) +#define F_T5VLCKF V_T5VLCKF(1U) + +#define S_T5ROCCMP 2 +#define V_T5ROCCMP(x) ((x) << S_T5ROCCMP) +#define F_T5ROCCMP V_T5ROCCMP(1U) + +#define S_T5DQCCCMP 1 +#define V_T5DQCCCMP(x) ((x) << S_T5DQCCCMP) +#define F_T5DQCCCMP V_T5DQCCCMP(1U) + +#define S_T5OCCMP 0 +#define V_T5OCCMP(x) ((x) << S_T5OCCMP) +#define F_T5OCCMP V_T5OCCMP(1U) + +#define A_MAC_PORT_RX_LINKA_DFE_FUNCTION_CONTROL_1 0x327c + +#define S_FLOFF 1 +#define V_FLOFF(x) ((x) << S_FLOFF) +#define F_FLOFF V_FLOFF(1U) + +#define A_MAC_PORT_RX_LINKA_DFE_FUNCTION_CONTROL_2 0x3280 + +#define S_H25SPC 15 +#define V_H25SPC(x) ((x) << S_H25SPC) +#define F_H25SPC V_H25SPC(1U) + +#define S_FTOOFAST 8 +#define V_FTOOFAST(x) ((x) << S_FTOOFAST) +#define F_FTOOFAST V_FTOOFAST(1U) + +#define S_FINTTRIM 7 +#define V_FINTTRIM(x) ((x) << S_FINTTRIM) +#define F_FINTTRIM V_FINTTRIM(1U) + +#define S_FDINV 6 +#define V_FDINV(x) ((x) << S_FDINV) +#define F_FDINV V_FDINV(1U) + +#define S_FHGS 5 +#define V_FHGS(x) ((x) << S_FHGS) +#define F_FHGS V_FHGS(1U) + +#define S_FH6H12 4 +#define V_FH6H12(x) ((x) << S_FH6H12) +#define F_FH6H12 V_FH6H12(1U) + +#define S_FH1CAL 3 +#define V_FH1CAL(x) ((x) << S_FH1CAL) +#define F_FH1CAL V_FH1CAL(1U) + +#define S_FINTCAL 2 +#define V_FINTCAL(x) ((x) << S_FINTCAL) +#define F_FINTCAL V_FINTCAL(1U) + +#define S_FDCA 1 +#define V_FDCA(x) ((x) << S_FDCA) +#define F_FDCA V_FDCA(1U) + +#define S_FDQCC 0 +#define V_FDQCC(x) ((x) << S_FDQCC) +#define F_FDQCC V_FDQCC(1U) + +#define A_MAC_PORT_RX_LINKA_DFE_OFFSET_EVN1_EVN2 0x3284 + +#define S_LOFE2S_READWRITE 16 +#define V_LOFE2S_READWRITE(x) ((x) << S_LOFE2S_READWRITE) +#define F_LOFE2S_READWRITE V_LOFE2S_READWRITE(1U) + +#define S_LOFE2S_READONLY 14 +#define M_LOFE2S_READONLY 0x3U +#define V_LOFE2S_READONLY(x) ((x) << S_LOFE2S_READONLY) +#define G_LOFE2S_READONLY(x) (((x) >> S_LOFE2S_READONLY) & M_LOFE2S_READONLY) + +#define S_LOFE2 8 +#define M_LOFE2 0x3fU +#define V_LOFE2(x) ((x) << S_LOFE2) +#define G_LOFE2(x) (((x) >> S_LOFE2) & M_LOFE2) + +#define S_LOFE1S_READWRITE 7 +#define V_LOFE1S_READWRITE(x) ((x) << S_LOFE1S_READWRITE) +#define F_LOFE1S_READWRITE V_LOFE1S_READWRITE(1U) + +#define S_LOFE1S_READONLY 6 +#define V_LOFE1S_READONLY(x) ((x) << S_LOFE1S_READONLY) +#define F_LOFE1S_READONLY V_LOFE1S_READONLY(1U) + +#define S_LOFE1 0 +#define M_LOFE1 0x3fU +#define V_LOFE1(x) ((x) << S_LOFE1) +#define G_LOFE1(x) (((x) >> S_LOFE1) & M_LOFE1) + +#define A_MAC_PORT_RX_LINKA_DFE_OFFSET_ODD1_ODD2 0x3288 + +#define S_LOFO2S_READWRITE 15 +#define V_LOFO2S_READWRITE(x) ((x) << S_LOFO2S_READWRITE) +#define F_LOFO2S_READWRITE V_LOFO2S_READWRITE(1U) + +#define S_LOFO2S_READONLY 14 +#define V_LOFO2S_READONLY(x) ((x) << S_LOFO2S_READONLY) +#define F_LOFO2S_READONLY V_LOFO2S_READONLY(1U) + +#define S_LOFO2 8 +#define M_LOFO2 0x3fU +#define V_LOFO2(x) ((x) << S_LOFO2) +#define G_LOFO2(x) (((x) >> S_LOFO2) & M_LOFO2) + +#define S_LOFO1S_READWRITE 7 +#define V_LOFO1S_READWRITE(x) ((x) << S_LOFO1S_READWRITE) +#define F_LOFO1S_READWRITE V_LOFO1S_READWRITE(1U) + +#define S_LOFO1S_READONLY 6 +#define V_LOFO1S_READONLY(x) ((x) << S_LOFO1S_READONLY) +#define F_LOFO1S_READONLY V_LOFO1S_READONLY(1U) + +#define S_LOFO1 0 +#define M_LOFO1 0x3fU +#define V_LOFO1(x) ((x) << S_LOFO1) +#define G_LOFO1(x) (((x) >> S_LOFO1) & M_LOFO1) + +#define A_MAC_PORT_RX_LINKA_DFE_OFFSET_EVN3_EVN4 0x328c + +#define S_LOFE4S_READWRITE 15 +#define V_LOFE4S_READWRITE(x) ((x) << S_LOFE4S_READWRITE) +#define F_LOFE4S_READWRITE V_LOFE4S_READWRITE(1U) + +#define S_LOFE4S_READONLY 14 +#define V_LOFE4S_READONLY(x) ((x) << S_LOFE4S_READONLY) +#define F_LOFE4S_READONLY V_LOFE4S_READONLY(1U) + +#define S_LOFE 8 +#define M_LOFE 0x3fU +#define V_LOFE(x) ((x) << S_LOFE) +#define G_LOFE(x) (((x) >> S_LOFE) & M_LOFE) + +#define S_LOFE3S_READWRITE 7 +#define V_LOFE3S_READWRITE(x) ((x) << S_LOFE3S_READWRITE) +#define F_LOFE3S_READWRITE V_LOFE3S_READWRITE(1U) + +#define S_LOFE3S_READONLY 6 +#define V_LOFE3S_READONLY(x) ((x) << S_LOFE3S_READONLY) +#define F_LOFE3S_READONLY V_LOFE3S_READONLY(1U) + +#define S_LOFE3 0 +#define M_LOFE3 0x3fU +#define V_LOFE3(x) ((x) << S_LOFE3) +#define G_LOFE3(x) (((x) >> S_LOFE3) & M_LOFE3) + +#define A_MAC_PORT_RX_LINKA_DFE_OFFSET_ODD3_ODD4 0x3290 + +#define S_LOFO4S_READWRITE 15 +#define V_LOFO4S_READWRITE(x) ((x) << S_LOFO4S_READWRITE) +#define F_LOFO4S_READWRITE V_LOFO4S_READWRITE(1U) + +#define S_LOFO4S_READONLY 14 +#define V_LOFO4S_READONLY(x) ((x) << S_LOFO4S_READONLY) +#define F_LOFO4S_READONLY V_LOFO4S_READONLY(1U) + +#define S_LOFO4 8 +#define M_LOFO4 0x3fU +#define V_LOFO4(x) ((x) << S_LOFO4) +#define G_LOFO4(x) (((x) >> S_LOFO4) & M_LOFO4) + +#define S_LOFO3S_READWRITE 7 +#define V_LOFO3S_READWRITE(x) ((x) << S_LOFO3S_READWRITE) +#define F_LOFO3S_READWRITE V_LOFO3S_READWRITE(1U) + +#define S_LOFO3S_READONLY 6 +#define V_LOFO3S_READONLY(x) ((x) << S_LOFO3S_READONLY) +#define F_LOFO3S_READONLY V_LOFO3S_READONLY(1U) + +#define S_LOFO3 0 +#define M_LOFO3 0x3fU +#define V_LOFO3(x) ((x) << S_LOFO3) +#define G_LOFO3(x) (((x) >> S_LOFO3) & M_LOFO3) + +#define A_MAC_PORT_RX_LINKA_DFE_E0_AND_E1_OFFSET 0x3294 + +#define S_T5E1SN_READWRITE 15 +#define V_T5E1SN_READWRITE(x) ((x) << S_T5E1SN_READWRITE) +#define F_T5E1SN_READWRITE V_T5E1SN_READWRITE(1U) + +#define S_T5E1SN_READONLY 14 +#define V_T5E1SN_READONLY(x) ((x) << S_T5E1SN_READONLY) +#define F_T5E1SN_READONLY V_T5E1SN_READONLY(1U) + +#define S_T5E1AMP 8 +#define M_T5E1AMP 0x3fU +#define V_T5E1AMP(x) ((x) << S_T5E1AMP) +#define G_T5E1AMP(x) (((x) >> S_T5E1AMP) & M_T5E1AMP) + +#define S_T5E0SN_READWRITE 7 +#define V_T5E0SN_READWRITE(x) ((x) << S_T5E0SN_READWRITE) +#define F_T5E0SN_READWRITE V_T5E0SN_READWRITE(1U) + +#define S_T5E0SN_READONLY 6 +#define V_T5E0SN_READONLY(x) ((x) << S_T5E0SN_READONLY) +#define F_T5E0SN_READONLY V_T5E0SN_READONLY(1U) + +#define S_T5E0AMP 0 +#define M_T5E0AMP 0x3fU +#define V_T5E0AMP(x) ((x) << S_T5E0AMP) +#define G_T5E0AMP(x) (((x) >> S_T5E0AMP) & M_T5E0AMP) + +#define A_MAC_PORT_RX_LINKA_RECEIVER_LOFF_CONTROL 0x3298 + +#define S_T5LFREG 12 +#define V_T5LFREG(x) ((x) << S_T5LFREG) +#define F_T5LFREG V_T5LFREG(1U) + +#define S_T5LFRC 11 +#define V_T5LFRC(x) ((x) << S_T5LFRC) +#define F_T5LFRC V_T5LFRC(1U) + +#define S_T5LFSEL 8 +#define M_T5LFSEL 0x7U +#define V_T5LFSEL(x) ((x) << S_T5LFSEL) +#define G_T5LFSEL(x) (((x) >> S_T5LFSEL) & M_T5LFSEL) + +#define A_MAC_PORT_RX_LINKA_RECEIVER_SIGDET_CONTROL 0x329c + +#define S_OFFSN_READWRITE 14 +#define V_OFFSN_READWRITE(x) ((x) << S_OFFSN_READWRITE) +#define F_OFFSN_READWRITE V_OFFSN_READWRITE(1U) + +#define S_OFFSN_READONLY 13 +#define V_OFFSN_READONLY(x) ((x) << S_OFFSN_READONLY) +#define F_OFFSN_READONLY V_OFFSN_READONLY(1U) + +#define S_OFFAMP 8 +#define M_OFFAMP 0x1fU +#define V_OFFAMP(x) ((x) << S_OFFAMP) +#define G_OFFAMP(x) (((x) >> S_OFFAMP) & M_OFFAMP) + +#define S_SDACDC 7 +#define V_SDACDC(x) ((x) << S_SDACDC) +#define F_SDACDC V_SDACDC(1U) + +#define A_MAC_PORT_RX_LINKA_RECEIVER_ANALOG_CONTROL_SWITCH 0x32a0 + +#define S_T5_RX_SETHDIS 7 +#define V_T5_RX_SETHDIS(x) ((x) << S_T5_RX_SETHDIS) +#define F_T5_RX_SETHDIS V_T5_RX_SETHDIS(1U) + +#define S_T5_RX_PDTERM 6 +#define V_T5_RX_PDTERM(x) ((x) << S_T5_RX_PDTERM) +#define F_T5_RX_PDTERM V_T5_RX_PDTERM(1U) + +#define S_T5_RX_BYPASS 5 +#define V_T5_RX_BYPASS(x) ((x) << S_T5_RX_BYPASS) +#define F_T5_RX_BYPASS V_T5_RX_BYPASS(1U) + +#define S_T5_RX_LPFEN 4 +#define V_T5_RX_LPFEN(x) ((x) << S_T5_RX_LPFEN) +#define F_T5_RX_LPFEN V_T5_RX_LPFEN(1U) + +#define S_T5_RX_VGABOD 3 +#define V_T5_RX_VGABOD(x) ((x) << S_T5_RX_VGABOD) +#define F_T5_RX_VGABOD V_T5_RX_VGABOD(1U) + +#define S_T5_RX_VTBYP 2 +#define V_T5_RX_VTBYP(x) ((x) << S_T5_RX_VTBYP) +#define F_T5_RX_VTBYP V_T5_RX_VTBYP(1U) + +#define S_T5_RX_VTERM 0 +#define M_T5_RX_VTERM 0x3U +#define V_T5_RX_VTERM(x) ((x) << S_T5_RX_VTERM) +#define G_T5_RX_VTERM(x) (((x) >> S_T5_RX_VTERM) & M_T5_RX_VTERM) + +#define A_MAC_PORT_RX_LINKA_INTEGRATOR_DAC_OFFSET 0x32a4 + +#define S_ISTRIMS 14 +#define M_ISTRIMS 0x3U +#define V_ISTRIMS(x) ((x) << S_ISTRIMS) +#define G_ISTRIMS(x) (((x) >> S_ISTRIMS) & M_ISTRIMS) + +#define S_ISTRIM 8 +#define M_ISTRIM 0x3fU +#define V_ISTRIM(x) ((x) << S_ISTRIM) +#define G_ISTRIM(x) (((x) >> S_ISTRIM) & M_ISTRIM) + +#define S_HALF1 7 +#define V_HALF1(x) ((x) << S_HALF1) +#define F_HALF1 V_HALF1(1U) + +#define S_HALF2 6 +#define V_HALF2(x) ((x) << S_HALF2) +#define F_HALF2 V_HALF2(1U) + +#define S_INTDAC 0 +#define M_INTDAC 0x3fU +#define V_INTDAC(x) ((x) << S_INTDAC) +#define G_INTDAC(x) (((x) >> S_INTDAC) & M_INTDAC) + +#define A_MAC_PORT_RX_LINKA_DIGITAL_EYE_CONTROL 0x32a8 + +#define S_MINWDTH 5 +#define M_MINWDTH 0x1fU +#define V_MINWDTH(x) ((x) << S_MINWDTH) +#define G_MINWDTH(x) (((x) >> S_MINWDTH) & M_MINWDTH) + +#define A_MAC_PORT_RX_LINKA_DIGITAL_EYE_METRICS 0x32ac + +#define S_T5SMQM 13 +#define M_T5SMQM 0x7U +#define V_T5SMQM(x) ((x) << S_T5SMQM) +#define G_T5SMQM(x) (((x) >> S_T5SMQM) & M_T5SMQM) + +#define S_T5SMQ 5 +#define M_T5SMQ 0xffU +#define V_T5SMQ(x) ((x) << S_T5SMQ) +#define G_T5SMQ(x) (((x) >> S_T5SMQ) & M_T5SMQ) + +#define S_T5EMMD 3 +#define M_T5EMMD 0x3U +#define V_T5EMMD(x) ((x) << S_T5EMMD) +#define G_T5EMMD(x) (((x) >> S_T5EMMD) & M_T5EMMD) + +#define S_T5EMBRDY 2 +#define V_T5EMBRDY(x) ((x) << S_T5EMBRDY) +#define F_T5EMBRDY V_T5EMBRDY(1U) + +#define S_T5EMBUMP 1 +#define V_T5EMBUMP(x) ((x) << S_T5EMBUMP) +#define F_T5EMBUMP V_T5EMBUMP(1U) + +#define S_T5EMEN 0 +#define V_T5EMEN(x) ((x) << S_T5EMEN) +#define F_T5EMEN V_T5EMEN(1U) + +#define A_MAC_PORT_RX_LINKA_DIGITAL_EYE_METRICS_ERROR_COUNT 0x32b0 + +#define S_EMF8 15 +#define V_EMF8(x) ((x) << S_EMF8) +#define F_EMF8 V_EMF8(1U) + +#define S_EMCNT 4 +#define M_EMCNT 0xffU +#define V_EMCNT(x) ((x) << S_EMCNT) +#define G_EMCNT(x) (((x) >> S_EMCNT) & M_EMCNT) + +#define S_EMOFLO 2 +#define V_EMOFLO(x) ((x) << S_EMOFLO) +#define F_EMOFLO V_EMOFLO(1U) + +#define S_EMCRST 1 +#define V_EMCRST(x) ((x) << S_EMCRST) +#define F_EMCRST V_EMCRST(1U) + +#define S_EMCEN 0 +#define V_EMCEN(x) ((x) << S_EMCEN) +#define F_EMCEN V_EMCEN(1U) + +#define A_MAC_PORT_RX_LINKA_DIGITAL_EYE_METRICS_PDF_EYE_COUNT 0x32b4 + +#define S_SM2RDY 15 +#define V_SM2RDY(x) ((x) << S_SM2RDY) +#define F_SM2RDY V_SM2RDY(1U) + +#define S_SM2RST 14 +#define V_SM2RST(x) ((x) << S_SM2RST) +#define F_SM2RST V_SM2RST(1U) + +#define S_APDF 0 +#define M_APDF 0xfffU +#define V_APDF(x) ((x) << S_APDF) +#define G_APDF(x) (((x) >> S_APDF) & M_APDF) + +#define A_MAC_PORT_RX_LINKA_DIGITAL_EYE_METRICS_PATTERN_LENGTH 0x32b8 + +#define S_SM0LEN 0 +#define M_SM0LEN 0x7fffU +#define V_SM0LEN(x) ((x) << S_SM0LEN) +#define G_SM0LEN(x) (((x) >> S_SM0LEN) & M_SM0LEN) + +#define A_MAC_PORT_RX_LINKA_DFE_TAP_ENABLE 0x32c0 + +#define S_H_EN 1 +#define M_H_EN 0xfffU +#define V_H_EN(x) ((x) << S_H_EN) +#define G_H_EN(x) (((x) >> S_H_EN) & M_H_EN) + +#define A_MAC_PORT_RX_LINKA_DFE_H1 0x32c4 +#define A_MAC_PORT_RX_LINKA_DFE_H2 0x32c8 + +#define S_H2OSN_READWRITE 14 +#define V_H2OSN_READWRITE(x) ((x) << S_H2OSN_READWRITE) +#define F_H2OSN_READWRITE V_H2OSN_READWRITE(1U) + +#define S_H2OSN_READONLY 13 +#define V_H2OSN_READONLY(x) ((x) << S_H2OSN_READONLY) +#define F_H2OSN_READONLY V_H2OSN_READONLY(1U) + +#define S_H2ESN_READWRITE 6 +#define V_H2ESN_READWRITE(x) ((x) << S_H2ESN_READWRITE) +#define F_H2ESN_READWRITE V_H2ESN_READWRITE(1U) + +#define S_H2ESN_READONLY 5 +#define V_H2ESN_READONLY(x) ((x) << S_H2ESN_READONLY) +#define F_H2ESN_READONLY V_H2ESN_READONLY(1U) + +#define A_MAC_PORT_RX_LINKA_DFE_H3 0x32cc + +#define S_H3OSN_READWRITE 13 +#define V_H3OSN_READWRITE(x) ((x) << S_H3OSN_READWRITE) +#define F_H3OSN_READWRITE V_H3OSN_READWRITE(1U) + +#define S_H3OSN_READONLY 12 +#define V_H3OSN_READONLY(x) ((x) << S_H3OSN_READONLY) +#define F_H3OSN_READONLY V_H3OSN_READONLY(1U) + +#define S_H3ESN_READWRITE 5 +#define V_H3ESN_READWRITE(x) ((x) << S_H3ESN_READWRITE) +#define F_H3ESN_READWRITE V_H3ESN_READWRITE(1U) + +#define S_H3ESN_READONLY 4 +#define V_H3ESN_READONLY(x) ((x) << S_H3ESN_READONLY) +#define F_H3ESN_READONLY V_H3ESN_READONLY(1U) + +#define A_MAC_PORT_RX_LINKA_DFE_H4 0x32d0 + +#define S_H4OGS 14 +#define M_H4OGS 0x3U +#define V_H4OGS(x) ((x) << S_H4OGS) +#define G_H4OGS(x) (((x) >> S_H4OGS) & M_H4OGS) + +#define S_H4OSN_READWRITE 13 +#define V_H4OSN_READWRITE(x) ((x) << S_H4OSN_READWRITE) +#define F_H4OSN_READWRITE V_H4OSN_READWRITE(1U) + +#define S_H4OSN_READONLY 12 +#define V_H4OSN_READONLY(x) ((x) << S_H4OSN_READONLY) +#define F_H4OSN_READONLY V_H4OSN_READONLY(1U) + +#define S_H4EGS 6 +#define M_H4EGS 0x3U +#define V_H4EGS(x) ((x) << S_H4EGS) +#define G_H4EGS(x) (((x) >> S_H4EGS) & M_H4EGS) + +#define S_H4ESN_READWRITE 5 +#define V_H4ESN_READWRITE(x) ((x) << S_H4ESN_READWRITE) +#define F_H4ESN_READWRITE V_H4ESN_READWRITE(1U) + +#define S_H4ESN_READONLY 4 +#define V_H4ESN_READONLY(x) ((x) << S_H4ESN_READONLY) +#define F_H4ESN_READONLY V_H4ESN_READONLY(1U) + +#define A_MAC_PORT_RX_LINKA_DFE_H5 0x32d4 + +#define S_H5OGS 14 +#define M_H5OGS 0x3U +#define V_H5OGS(x) ((x) << S_H5OGS) +#define G_H5OGS(x) (((x) >> S_H5OGS) & M_H5OGS) + +#define S_H5OSN_READWRITE 13 +#define V_H5OSN_READWRITE(x) ((x) << S_H5OSN_READWRITE) +#define F_H5OSN_READWRITE V_H5OSN_READWRITE(1U) + +#define S_H5OSN_READONLY 12 +#define V_H5OSN_READONLY(x) ((x) << S_H5OSN_READONLY) +#define F_H5OSN_READONLY V_H5OSN_READONLY(1U) + +#define S_H5EGS 6 +#define M_H5EGS 0x3U +#define V_H5EGS(x) ((x) << S_H5EGS) +#define G_H5EGS(x) (((x) >> S_H5EGS) & M_H5EGS) + +#define S_H5ESN_READWRITE 5 +#define V_H5ESN_READWRITE(x) ((x) << S_H5ESN_READWRITE) +#define F_H5ESN_READWRITE V_H5ESN_READWRITE(1U) + +#define S_H5ESN_READONLY 4 +#define V_H5ESN_READONLY(x) ((x) << S_H5ESN_READONLY) +#define F_H5ESN_READONLY V_H5ESN_READONLY(1U) + +#define A_MAC_PORT_RX_LINKA_DFE_H6_AND_H7 0x32d8 + +#define S_H7GS 14 +#define M_H7GS 0x3U +#define V_H7GS(x) ((x) << S_H7GS) +#define G_H7GS(x) (((x) >> S_H7GS) & M_H7GS) + +#define S_H7SN_READWRITE 13 +#define V_H7SN_READWRITE(x) ((x) << S_H7SN_READWRITE) +#define F_H7SN_READWRITE V_H7SN_READWRITE(1U) + +#define S_H7SN_READONLY 12 +#define V_H7SN_READONLY(x) ((x) << S_H7SN_READONLY) +#define F_H7SN_READONLY V_H7SN_READONLY(1U) + +#define S_H7MAG 8 +#define M_H7MAG 0xfU +#define V_H7MAG(x) ((x) << S_H7MAG) +#define G_H7MAG(x) (((x) >> S_H7MAG) & M_H7MAG) + +#define S_H6GS 6 +#define M_H6GS 0x3U +#define V_H6GS(x) ((x) << S_H6GS) +#define G_H6GS(x) (((x) >> S_H6GS) & M_H6GS) + +#define S_H6SN_READWRITE 5 +#define V_H6SN_READWRITE(x) ((x) << S_H6SN_READWRITE) +#define F_H6SN_READWRITE V_H6SN_READWRITE(1U) + +#define S_H6SN_READONLY 4 +#define V_H6SN_READONLY(x) ((x) << S_H6SN_READONLY) +#define F_H6SN_READONLY V_H6SN_READONLY(1U) + +#define S_H6MAG 0 +#define M_H6MAG 0xfU +#define V_H6MAG(x) ((x) << S_H6MAG) +#define G_H6MAG(x) (((x) >> S_H6MAG) & M_H6MAG) + +#define A_MAC_PORT_RX_LINKA_DFE_H8_AND_H9 0x32dc + +#define S_H9GS 14 +#define M_H9GS 0x3U +#define V_H9GS(x) ((x) << S_H9GS) +#define G_H9GS(x) (((x) >> S_H9GS) & M_H9GS) + +#define S_H9SN_READWRITE 13 +#define V_H9SN_READWRITE(x) ((x) << S_H9SN_READWRITE) +#define F_H9SN_READWRITE V_H9SN_READWRITE(1U) + +#define S_H9SN_READONLY 12 +#define V_H9SN_READONLY(x) ((x) << S_H9SN_READONLY) +#define F_H9SN_READONLY V_H9SN_READONLY(1U) + +#define S_H9MAG 8 +#define M_H9MAG 0xfU +#define V_H9MAG(x) ((x) << S_H9MAG) +#define G_H9MAG(x) (((x) >> S_H9MAG) & M_H9MAG) + +#define S_H8GS 6 +#define M_H8GS 0x3U +#define V_H8GS(x) ((x) << S_H8GS) +#define G_H8GS(x) (((x) >> S_H8GS) & M_H8GS) + +#define S_H8SN_READWRITE 5 +#define V_H8SN_READWRITE(x) ((x) << S_H8SN_READWRITE) +#define F_H8SN_READWRITE V_H8SN_READWRITE(1U) + +#define S_H8SN_READONLY 4 +#define V_H8SN_READONLY(x) ((x) << S_H8SN_READONLY) +#define F_H8SN_READONLY V_H8SN_READONLY(1U) + +#define S_H8MAG 0 +#define M_H8MAG 0xfU +#define V_H8MAG(x) ((x) << S_H8MAG) +#define G_H8MAG(x) (((x) >> S_H8MAG) & M_H8MAG) + +#define A_MAC_PORT_RX_LINKA_DFE_H10_AND_H11 0x32e0 + +#define S_H11GS 14 +#define M_H11GS 0x3U +#define V_H11GS(x) ((x) << S_H11GS) +#define G_H11GS(x) (((x) >> S_H11GS) & M_H11GS) + +#define S_H11SN_READWRITE 13 +#define V_H11SN_READWRITE(x) ((x) << S_H11SN_READWRITE) +#define F_H11SN_READWRITE V_H11SN_READWRITE(1U) + +#define S_H11SN_READONLY 12 +#define V_H11SN_READONLY(x) ((x) << S_H11SN_READONLY) +#define F_H11SN_READONLY V_H11SN_READONLY(1U) + +#define S_H11MAG 8 +#define M_H11MAG 0xfU +#define V_H11MAG(x) ((x) << S_H11MAG) +#define G_H11MAG(x) (((x) >> S_H11MAG) & M_H11MAG) + +#define S_H10GS 6 +#define M_H10GS 0x3U +#define V_H10GS(x) ((x) << S_H10GS) +#define G_H10GS(x) (((x) >> S_H10GS) & M_H10GS) + +#define S_H10SN_READWRITE 5 +#define V_H10SN_READWRITE(x) ((x) << S_H10SN_READWRITE) +#define F_H10SN_READWRITE V_H10SN_READWRITE(1U) + +#define S_H10SN_READONLY 4 +#define V_H10SN_READONLY(x) ((x) << S_H10SN_READONLY) +#define F_H10SN_READONLY V_H10SN_READONLY(1U) + +#define S_H10MAG 0 +#define M_H10MAG 0xfU +#define V_H10MAG(x) ((x) << S_H10MAG) +#define G_H10MAG(x) (((x) >> S_H10MAG) & M_H10MAG) + +#define A_MAC_PORT_RX_LINKA_DFE_H12 0x32e4 + +#define S_H12GS 6 +#define M_H12GS 0x3U +#define V_H12GS(x) ((x) << S_H12GS) +#define G_H12GS(x) (((x) >> S_H12GS) & M_H12GS) + +#define S_H12SN_READWRITE 5 +#define V_H12SN_READWRITE(x) ((x) << S_H12SN_READWRITE) +#define F_H12SN_READWRITE V_H12SN_READWRITE(1U) + +#define S_H12SN_READONLY 4 +#define V_H12SN_READONLY(x) ((x) << S_H12SN_READONLY) +#define F_H12SN_READONLY V_H12SN_READONLY(1U) + +#define S_H12MAG 0 +#define M_H12MAG 0xfU +#define V_H12MAG(x) ((x) << S_H12MAG) +#define G_H12MAG(x) (((x) >> S_H12MAG) & M_H12MAG) + +#define A_MAC_PORT_RX_LINKA_RECEIVER_MACRO_TEST_CONTROL_2 0x32f8 + +#define S_DFEDACLSSD 6 +#define V_DFEDACLSSD(x) ((x) << S_DFEDACLSSD) +#define F_DFEDACLSSD V_DFEDACLSSD(1U) + +#define S_SDLSSD 5 +#define V_SDLSSD(x) ((x) << S_SDLSSD) +#define F_SDLSSD V_SDLSSD(1U) + +#define S_DFEOBSBIAS 4 +#define V_DFEOBSBIAS(x) ((x) << S_DFEOBSBIAS) +#define F_DFEOBSBIAS V_DFEOBSBIAS(1U) + +#define S_GBOFSTLSSD 3 +#define V_GBOFSTLSSD(x) ((x) << S_GBOFSTLSSD) +#define F_GBOFSTLSSD V_GBOFSTLSSD(1U) + +#define S_RXDOBS 2 +#define V_RXDOBS(x) ((x) << S_RXDOBS) +#define F_RXDOBS V_RXDOBS(1U) + +#define S_ACJZPT 1 +#define V_ACJZPT(x) ((x) << S_ACJZPT) +#define F_ACJZPT V_ACJZPT(1U) + +#define S_ACJZNT 0 +#define V_ACJZNT(x) ((x) << S_ACJZNT) +#define F_ACJZNT V_ACJZNT(1U) + +#define A_MAC_PORT_RX_LINKA_RECEIVER_MACRO_TEST_CONTROL_1 0x32fc + +#define S_PHSLOCK 10 +#define V_PHSLOCK(x) ((x) << S_PHSLOCK) +#define F_PHSLOCK V_PHSLOCK(1U) + +#define S_TESTMODE 9 +#define V_TESTMODE(x) ((x) << S_TESTMODE) +#define F_TESTMODE V_TESTMODE(1U) + +#define S_CALMODE 8 +#define V_CALMODE(x) ((x) << S_CALMODE) +#define F_CALMODE V_CALMODE(1U) + +#define S_AMPSEL 7 +#define V_AMPSEL(x) ((x) << S_AMPSEL) +#define F_AMPSEL V_AMPSEL(1U) + +#define S_WHICHNRZ 6 +#define V_WHICHNRZ(x) ((x) << S_WHICHNRZ) +#define F_WHICHNRZ V_WHICHNRZ(1U) + +#define S_BANKA 5 +#define V_BANKA(x) ((x) << S_BANKA) +#define F_BANKA V_BANKA(1U) + +#define S_BANKB 4 +#define V_BANKB(x) ((x) << S_BANKB) +#define F_BANKB V_BANKB(1U) + +#define S_ACJPDP 3 +#define V_ACJPDP(x) ((x) << S_ACJPDP) +#define F_ACJPDP V_ACJPDP(1U) + +#define S_ACJPDN 2 +#define V_ACJPDN(x) ((x) << S_ACJPDN) +#define F_ACJPDN V_ACJPDN(1U) + +#define S_LSSDT 1 +#define V_LSSDT(x) ((x) << S_LSSDT) +#define F_LSSDT V_LSSDT(1U) + +#define S_MTHOLD 0 +#define V_MTHOLD(x) ((x) << S_MTHOLD) +#define F_MTHOLD V_MTHOLD(1U) + +#define A_MAC_PORT_RX_LINKB_RECEIVER_CONFIGURATION_MODE 0x3300 +#define A_MAC_PORT_RX_LINKB_RECEIVER_TEST_CONTROL 0x3304 +#define A_MAC_PORT_RX_LINKB_PHASE_ROTATOR_CONTROL 0x3308 +#define A_MAC_PORT_RX_LINKB_PHASE_ROTATOR_OFFSET_CONTROL 0x330c +#define A_MAC_PORT_RX_LINKB_PHASE_ROTATOR_POSITION_1 0x3310 +#define A_MAC_PORT_RX_LINKB_PHASE_ROTATOR_POSITION_2 0x3314 +#define A_MAC_PORT_RX_LINKB_PHASE_ROTATOR_STATIC_PHASE_OFFSET_1 0x3318 +#define A_MAC_PORT_RX_LINKB_PHASE_ROTATOR_STATIC_PHASE_OFFSET_2 0x331c +#define A_MAC_PORT_RX_LINKB_DFE_CONTROL 0x3320 +#define A_MAC_PORT_RX_LINKB_DFE_SAMPLE_SNAPSHOT_1 0x3324 +#define A_MAC_PORT_RX_LINKB_DFE_SAMPLE_SNAPSHOT_2 0x3328 +#define A_MAC_PORT_RX_LINKB_RECEIVER_VGA_CONTROL_1 0x332c +#define A_MAC_PORT_RX_LINKB_RECEIVER_VGA_CONTROL_2 0x3330 +#define A_MAC_PORT_RX_LINKB_RECEIVER_VGA_CONTROL_3 0x3334 +#define A_MAC_PORT_RX_LINKB_RECEIVER_DQCC_CONTROL_1 0x3338 +#define A_MAC_PORT_RX_LINKB_RECEIVER_DQCC_CONTROL_3 0x3340 +#define A_MAC_PORT_RX_LINKB_RECEIVER_DACAP_AND_DACAN 0x3348 +#define A_MAC_PORT_RX_LINKB_RECEIVER_DACA_MIN_AND_DACAZ 0x334c +#define A_MAC_PORT_RX_LINKB_RECEIVER_ADAC_CONTROL 0x3350 +#define A_MAC_PORT_RX_LINKB_DFE_H1_LOCAL_OFFSET_ODD2_EVN2 0x335c +#define A_MAC_PORT_RX_LINKB_DFE_H1_LOCAL_OFFSET_ODD3_EVN3 0x3360 +#define A_MAC_PORT_RX_LINKB_DFE_H1_LOCAL_OFFSET_ODD4_EVN4 0x3364 +#define A_MAC_PORT_RX_LINKB_DYNAMIC_AMPLITUDE_CENTERING_DAC_AND_DYNAMIC_PEAKING_CONTROL_DPC 0x3370 +#define A_MAC_PORT_RX_LINKB_DYNAMIC_DATA_CENTERING_DDC 0x3374 +#define A_MAC_PORT_RX_LINKB_RECEIVER_INTERNAL_STATUS 0x3378 +#define A_MAC_PORT_RX_LINKB_DFE_FUNCTION_CONTROL_1 0x337c +#define A_MAC_PORT_RX_LINKB_DFE_FUNCTION_CONTROL_2 0x3380 +#define A_MAC_PORT_RX_LINKB_DFE_OFFSET_EVN1_EVN2 0x3384 +#define A_MAC_PORT_RX_LINKB_DFE_OFFSET_ODD1_ODD2 0x3388 +#define A_MAC_PORT_RX_LINKB_DFE_OFFSET_EVN3_EVN4 0x338c +#define A_MAC_PORT_RX_LINKB_DFE_OFFSET_ODD3_ODD4 0x3390 +#define A_MAC_PORT_RX_LINKB_DFE_E0_AND_E1_OFFSET 0x3394 +#define A_MAC_PORT_RX_LINKB_RECEIVER_LOFF_CONTROL 0x3398 +#define A_MAC_PORT_RX_LINKB_RECEIVER_SIGDET_CONTROL 0x339c +#define A_MAC_PORT_RX_LINKB_RECEIVER_ANALOG_CONTROL_SWITCH 0x33a0 +#define A_MAC_PORT_RX_LINKB_INTEGRATOR_DAC_OFFSET 0x33a4 +#define A_MAC_PORT_RX_LINKB_DIGITAL_EYE_CONTROL 0x33a8 +#define A_MAC_PORT_RX_LINKB_DIGITAL_EYE_METRICS 0x33ac +#define A_MAC_PORT_RX_LINKB_DIGITAL_EYE_METRICS_ERROR_COUNT 0x33b0 +#define A_MAC_PORT_RX_LINKB_DIGITAL_EYE_METRICS_PDF_EYE_COUNT 0x33b4 +#define A_MAC_PORT_RX_LINKB_DIGITAL_EYE_METRICS_PATTERN_LENGTH 0x33b8 +#define A_MAC_PORT_RX_LINKB_DFE_TAP_ENABLE 0x33c0 +#define A_MAC_PORT_RX_LINKB_DFE_H1 0x33c4 +#define A_MAC_PORT_RX_LINKB_DFE_H2 0x33c8 +#define A_MAC_PORT_RX_LINKB_DFE_H3 0x33cc +#define A_MAC_PORT_RX_LINKB_DFE_H4 0x33d0 +#define A_MAC_PORT_RX_LINKB_DFE_H5 0x33d4 +#define A_MAC_PORT_RX_LINKB_DFE_H6_AND_H7 0x33d8 +#define A_MAC_PORT_RX_LINKB_DFE_H8_AND_H9 0x33dc +#define A_MAC_PORT_RX_LINKB_DFE_H10_AND_H11 0x33e0 +#define A_MAC_PORT_RX_LINKB_DFE_H12 0x33e4 +#define A_MAC_PORT_RX_LINKB_RECEIVER_MACRO_TEST_CONTROL_2 0x33f8 +#define A_MAC_PORT_RX_LINKB_RECEIVER_MACRO_TEST_CONTROL_1 0x33fc +#define A_MAC_PORT_TX_LINKC_TRANSMIT_CONFIGURATION_MODE 0x3400 +#define A_MAC_PORT_TX_LINKC_TRANSMIT_TEST_CONTROL 0x3404 +#define A_MAC_PORT_TX_LINKC_TRANSMIT_COEFFICIENT_CONTROL 0x3408 +#define A_MAC_PORT_TX_LINKC_TRANSMIT_DRIVER_MODE_CONTROL 0x340c +#define A_MAC_PORT_TX_LINKC_TRANSMIT_DRIVER_OVERRIDE_CONTROL 0x3410 +#define A_MAC_PORT_TX_LINKC_TRANSMIT_DCLK_ROTATOR_OVERRIDE 0x3414 +#define A_MAC_PORT_TX_LINKC_TRANSMIT_IMPEDANCE_CALIBRATION_OVERRIDE 0x3418 +#define A_MAC_PORT_TX_LINKC_TRANSMIT_DCLK_DRIFT_TOLERANCE 0x341c +#define A_MAC_PORT_TX_LINKC_TRANSMIT_TAP_0_COEFFICIENT 0x3420 +#define A_MAC_PORT_TX_LINKC_TRANSMIT_TAP_1_COEFFICIENT 0x3424 +#define A_MAC_PORT_TX_LINKC_TRANSMIT_TAP_2_COEFFICIENT 0x3428 +#define A_MAC_PORT_TX_LINKC_TRANSMIT_AMPLITUDE 0x3430 +#define A_MAC_PORT_TX_LINKC_TRANSMIT_POLARITY 0x3434 +#define A_MAC_PORT_TX_LINKC_TRANSMIT_802_3AP_ADAPTIVE_EQUALIZATION_COMMAND 0x3438 +#define A_MAC_PORT_TX_LINKC_TRANSMIT_802_3AP_ADAPTIVE_EQUALIZATION_STATUS 0x343c +#define A_MAC_PORT_TX_LINKC_TRANSMIT_TAP_0_COEFFICIENT_OVERRIDE 0x3440 +#define A_MAC_PORT_TX_LINKC_TRANSMIT_TAP_1_COEFFICIENT_OVERRIDE 0x3444 +#define A_MAC_PORT_TX_LINKC_TRANSMIT_TAP_2_COEFFICIENT_OVERRIDE 0x3448 +#define A_MAC_PORT_TX_LINKC_TRANSMIT_TAP_0_COEFFICIENT_APPLIED 0x3460 +#define A_MAC_PORT_TX_LINKC_TRANSMIT_TAP_1_COEFFICIENT_APPLIED 0x3464 +#define A_MAC_PORT_TX_LINKC_TRANSMIT_TAP_2_COEFFICIENT_APPLIED 0x3468 +#define A_MAC_PORT_TX_LINKC_TRANSMIT_SEGMENT_DISABLE_APPLIED_1 0x3470 +#define A_MAC_PORT_TX_LINKC_TRANSMIT_SEGMENT_DISABLE_APPLIED_2 0x3474 +#define A_MAC_PORT_TX_LINKC_TRANSMIT_EXTENDED_ADDRESS_DATA 0x3478 +#define A_MAC_PORT_TX_LINKC_TRANSMIT_EXTENDED_ADDRESS_ADDR 0x347c +#define A_MAC_PORT_TX_LINKC_TRANSMIT_PATTERN_BUFFER_BYTES_1_0 0x3480 +#define A_MAC_PORT_TX_LINKC_TRANSMIT_PATTERN_BUFFER_BYTES_3_2 0x3484 +#define A_MAC_PORT_TX_LINKC_TRANSMIT_PATTERN_BUFFER_BYTE_4 0x3488 +#define A_MAC_PORT_TX_LINKC_TRANSMIT_DCC_CONTROL 0x348c +#define A_MAC_PORT_TX_LINKC_TRANSMIT_DCC_OVERRIDE 0x3490 +#define A_MAC_PORT_TX_LINKC_TRANSMIT_DCC_APPLIED 0x3494 +#define A_MAC_PORT_TX_LINKC_TRANSMIT_DCC_TIME_OUT 0x3498 +#define A_MAC_PORT_TX_LINKC_TRANSMIT_802_3AZ_CONTROL 0x349c +#define A_MAC_PORT_TX_LINKC_TRANSMIT_MACRO_TEST_CONTROL_4 0x34f0 +#define A_MAC_PORT_TX_LINKC_TRANSMIT_MACRO_TEST_CONTROL_3 0x34f4 +#define A_MAC_PORT_TX_LINKC_TRANSMIT_MACRO_TEST_CONTROL_2 0x34f8 +#define A_MAC_PORT_TX_LINKC_TRANSMIT_MACRO_TEST_CONTROL_1 0x34fc +#define A_MAC_PORT_TX_LINKD_TRANSMIT_CONFIGURATION_MODE 0x3500 +#define A_MAC_PORT_TX_LINKD_TRANSMIT_TEST_CONTROL 0x3504 +#define A_MAC_PORT_TX_LINKD_TRANSMIT_COEFFICIENT_CONTROL 0x3508 +#define A_MAC_PORT_TX_LINKD_TRANSMIT_DRIVER_MODE_CONTROL 0x350c +#define A_MAC_PORT_TX_LINKD_TRANSMIT_DRIVER_OVERRIDE_CONTROL 0x3510 +#define A_MAC_PORT_TX_LINKD_TRANSMIT_DCLK_ROTATOR_OVERRIDE 0x3514 +#define A_MAC_PORT_TX_LINKD_TRANSMIT_IMPEDANCE_CALIBRATION_OVERRIDE 0x3518 +#define A_MAC_PORT_TX_LINKD_TRANSMIT_DCLK_DRIFT_TOLERANCE 0x351c +#define A_MAC_PORT_TX_LINKD_TRANSMIT_TAP_0_COEFFICIENT 0x3520 +#define A_MAC_PORT_TX_LINKD_TRANSMIT_TAP_1_COEFFICIENT 0x3524 +#define A_MAC_PORT_TX_LINKD_TRANSMIT_TAP_2_COEFFICIENT 0x3528 +#define A_MAC_PORT_TX_LINKD_TRANSMIT_AMPLITUDE 0x3530 +#define A_MAC_PORT_TX_LINKD_TRANSMIT_POLARITY 0x3534 +#define A_MAC_PORT_TX_LINKD_TRANSMIT_802_3AP_ADAPTIVE_EQUALIZATION_COMMAND 0x3538 +#define A_MAC_PORT_TX_LINKD_TRANSMIT_802_3AP_ADAPTIVE_EQUALIZATION_STATUS 0x353c +#define A_MAC_PORT_TX_LINKD_TRANSMIT_TAP_0_COEFFICIENT_OVERRIDE 0x3540 +#define A_MAC_PORT_TX_LINKD_TRANSMIT_TAP_1_COEFFICIENT_OVERRIDE 0x3544 +#define A_MAC_PORT_TX_LINKD_TRANSMIT_TAP_2_COEFFICIENT_OVERRIDE 0x3548 +#define A_MAC_PORT_TX_LINKD_TRANSMIT_TAP_0_COEFFICIENT_APPLIED 0x3560 +#define A_MAC_PORT_TX_LINKD_TRANSMIT_TAP_1_COEFFICIENT_APPLIED 0x3564 +#define A_MAC_PORT_TX_LINKD_TRANSMIT_TAP_2_COEFFICIENT_APPLIED 0x3568 +#define A_MAC_PORT_TX_LINKD_TRANSMIT_SEGMENT_DISABLE_APPLIED_1 0x3570 +#define A_MAC_PORT_TX_LINKD_TRANSMIT_SEGMENT_DISABLE_APPLIED_2 0x3574 +#define A_MAC_PORT_TX_LINKD_TRANSMIT_EXTENDED_ADDRESS_DATA 0x3578 +#define A_MAC_PORT_TX_LINKD_TRANSMIT_EXTENDED_ADDRESS_ADDR 0x357c +#define A_MAC_PORT_TX_LINKD_TRANSMIT_PATTERN_BUFFER_BYTES_1_0 0x3580 +#define A_MAC_PORT_TX_LINKD_TRANSMIT_PATTERN_BUFFER_BYTES_3_2 0x3584 +#define A_MAC_PORT_TX_LINKD_TRANSMIT_PATTERN_BUFFER_BYTE_4 0x3588 +#define A_MAC_PORT_TX_LINKD_TRANSMIT_DCC_CONTROL 0x358c +#define A_MAC_PORT_TX_LINKD_TRANSMIT_DCC_OVERRIDE 0x3590 +#define A_MAC_PORT_TX_LINKD_TRANSMIT_DCC_APPLIED 0x3594 +#define A_MAC_PORT_TX_LINKD_TRANSMIT_DCC_TIME_OUT 0x3598 +#define A_MAC_PORT_TX_LINKD_TRANSMIT_802_3AZ_CONTROL 0x359c +#define A_MAC_PORT_TX_LINKD_TRANSMIT_MACRO_TEST_CONTROL_4 0x35f0 +#define A_MAC_PORT_TX_LINKD_TRANSMIT_MACRO_TEST_CONTROL_3 0x35f4 +#define A_MAC_PORT_TX_LINKD_TRANSMIT_MACRO_TEST_CONTROL_2 0x35f8 +#define A_MAC_PORT_TX_LINKD_TRANSMIT_MACRO_TEST_CONTROL_1 0x35fc +#define A_MAC_PORT_RX_LINKC_RECEIVER_CONFIGURATION_MODE 0x3600 +#define A_MAC_PORT_RX_LINKC_RECEIVER_TEST_CONTROL 0x3604 +#define A_MAC_PORT_RX_LINKC_PHASE_ROTATOR_CONTROL 0x3608 +#define A_MAC_PORT_RX_LINKC_PHASE_ROTATOR_OFFSET_CONTROL 0x360c +#define A_MAC_PORT_RX_LINKC_PHASE_ROTATOR_POSITION_1 0x3610 +#define A_MAC_PORT_RX_LINKC_PHASE_ROTATOR_POSITION_2 0x3614 +#define A_MAC_PORT_RX_LINKC_PHASE_ROTATOR_STATIC_PHASE_OFFSET_1 0x3618 +#define A_MAC_PORT_RX_LINKC_PHASE_ROTATOR_STATIC_PHASE_OFFSET_2 0x361c +#define A_MAC_PORT_RX_LINKC_DFE_CONTROL 0x3620 +#define A_MAC_PORT_RX_LINKC_DFE_SAMPLE_SNAPSHOT_1 0x3624 +#define A_MAC_PORT_RX_LINKC_DFE_SAMPLE_SNAPSHOT_2 0x3628 +#define A_MAC_PORT_RX_LINKC_RECEIVER_VGA_CONTROL_1 0x362c +#define A_MAC_PORT_RX_LINKC_RECEIVER_VGA_CONTROL_2 0x3630 +#define A_MAC_PORT_RX_LINKC_RECEIVER_VGA_CONTROL_3 0x3634 +#define A_MAC_PORT_RX_LINKC_RECEIVER_DQCC_CONTROL_1 0x3638 +#define A_MAC_PORT_RX_LINKC_RECEIVER_DQCC_CONTROL_3 0x3640 +#define A_MAC_PORT_RX_LINKC_RECEIVER_DACAP_AND_DACAN 0x3648 +#define A_MAC_PORT_RX_LINKC_RECEIVER_DACA_MIN_AND_DACAZ 0x364c +#define A_MAC_PORT_RX_LINKC_RECEIVER_ADAC_CONTROL 0x3650 +#define A_MAC_PORT_RX_LINKC_DFE_H1_LOCAL_OFFSET_ODD2_EVN2 0x365c +#define A_MAC_PORT_RX_LINKC_DFE_H1_LOCAL_OFFSET_ODD3_EVN3 0x3660 +#define A_MAC_PORT_RX_LINKC_DFE_H1_LOCAL_OFFSET_ODD4_EVN4 0x3664 +#define A_MAC_PORT_RX_LINKC_DYNAMIC_AMPLITUDE_CENTERING_DAC_AND_DYNAMIC_PEAKING_CONTROL_DPC 0x3670 +#define A_MAC_PORT_RX_LINKC_DYNAMIC_DATA_CENTERING_DDC 0x3674 +#define A_MAC_PORT_RX_LINKC_RECEIVER_INTERNAL_STATUS 0x3678 +#define A_MAC_PORT_RX_LINKC_DFE_FUNCTION_CONTROL_1 0x367c +#define A_MAC_PORT_RX_LINKC_DFE_FUNCTION_CONTROL_2 0x3680 +#define A_MAC_PORT_RX_LINKC_DFE_OFFSET_EVN1_EVN2 0x3684 +#define A_MAC_PORT_RX_LINKC_DFE_OFFSET_ODD1_ODD2 0x3688 +#define A_MAC_PORT_RX_LINKC_DFE_OFFSET_EVN3_EVN4 0x368c +#define A_MAC_PORT_RX_LINKC_DFE_OFFSET_ODD3_ODD4 0x3690 +#define A_MAC_PORT_RX_LINKC_DFE_E0_AND_E1_OFFSET 0x3694 +#define A_MAC_PORT_RX_LINKC_RECEIVER_LOFF_CONTROL 0x3698 +#define A_MAC_PORT_RX_LINKC_RECEIVER_SIGDET_CONTROL 0x369c +#define A_MAC_PORT_RX_LINKC_RECEIVER_ANALOG_CONTROL_SWITCH 0x36a0 +#define A_MAC_PORT_RX_LINKC_INTEGRATOR_DAC_OFFSET 0x36a4 +#define A_MAC_PORT_RX_LINKC_DIGITAL_EYE_CONTROL 0x36a8 +#define A_MAC_PORT_RX_LINKC_DIGITAL_EYE_METRICS 0x36ac +#define A_MAC_PORT_RX_LINKC_DIGITAL_EYE_METRICS_ERROR_COUNT 0x36b0 +#define A_MAC_PORT_RX_LINKC_DIGITAL_EYE_METRICS_PDF_EYE_COUNT 0x36b4 +#define A_MAC_PORT_RX_LINKC_DIGITAL_EYE_METRICS_PATTERN_LENGTH 0x36b8 +#define A_MAC_PORT_RX_LINKC_DFE_TAP_ENABLE 0x36c0 +#define A_MAC_PORT_RX_LINKC_DFE_H1 0x36c4 +#define A_MAC_PORT_RX_LINKC_DFE_H2 0x36c8 +#define A_MAC_PORT_RX_LINKC_DFE_H3 0x36cc +#define A_MAC_PORT_RX_LINKC_DFE_H4 0x36d0 +#define A_MAC_PORT_RX_LINKC_DFE_H5 0x36d4 +#define A_MAC_PORT_RX_LINKC_DFE_H6_AND_H7 0x36d8 +#define A_MAC_PORT_RX_LINKC_DFE_H8_AND_H9 0x36dc +#define A_MAC_PORT_RX_LINKC_DFE_H10_AND_H11 0x36e0 +#define A_MAC_PORT_RX_LINKC_DFE_H12 0x36e4 +#define A_MAC_PORT_RX_LINKC_RECEIVER_MACRO_TEST_CONTROL_2 0x36f8 +#define A_MAC_PORT_RX_LINKC_RECEIVER_MACRO_TEST_CONTROL_1 0x36fc +#define A_MAC_PORT_RX_LINKD_RECEIVER_CONFIGURATION_MODE 0x3700 +#define A_MAC_PORT_RX_LINKD_RECEIVER_TEST_CONTROL 0x3704 +#define A_MAC_PORT_RX_LINKD_PHASE_ROTATOR_CONTROL 0x3708 +#define A_MAC_PORT_RX_LINKD_PHASE_ROTATOR_OFFSET_CONTROL 0x370c +#define A_MAC_PORT_RX_LINKD_PHASE_ROTATOR_POSITION_1 0x3710 +#define A_MAC_PORT_RX_LINKD_PHASE_ROTATOR_POSITION_2 0x3714 +#define A_MAC_PORT_RX_LINKD_PHASE_ROTATOR_STATIC_PHASE_OFFSET_1 0x3718 +#define A_MAC_PORT_RX_LINKD_PHASE_ROTATOR_STATIC_PHASE_OFFSET_2 0x371c +#define A_MAC_PORT_RX_LINKD_DFE_CONTROL 0x3720 +#define A_MAC_PORT_RX_LINKD_DFE_SAMPLE_SNAPSHOT_1 0x3724 +#define A_MAC_PORT_RX_LINKD_DFE_SAMPLE_SNAPSHOT_2 0x3728 +#define A_MAC_PORT_RX_LINKD_RECEIVER_VGA_CONTROL_1 0x372c +#define A_MAC_PORT_RX_LINKD_RECEIVER_VGA_CONTROL_2 0x3730 +#define A_MAC_PORT_RX_LINKD_RECEIVER_VGA_CONTROL_3 0x3734 +#define A_MAC_PORT_RX_LINKD_RECEIVER_DQCC_CONTROL_1 0x3738 +#define A_MAC_PORT_RX_LINKD_RECEIVER_DQCC_CONTROL_3 0x3740 +#define A_MAC_PORT_RX_LINKD_RECEIVER_DACAP_AND_DACAN 0x3748 +#define A_MAC_PORT_RX_LINKD_RECEIVER_DACA_MIN_AND_DACAZ 0x374c +#define A_MAC_PORT_RX_LINKD_RECEIVER_ADAC_CONTROL 0x3750 +#define A_MAC_PORT_RX_LINKD_DFE_H1_LOCAL_OFFSET_ODD2_EVN2 0x375c +#define A_MAC_PORT_RX_LINKD_DFE_H1_LOCAL_OFFSET_ODD3_EVN3 0x3760 +#define A_MAC_PORT_RX_LINKD_DFE_H1_LOCAL_OFFSET_ODD4_EVN4 0x3764 +#define A_MAC_PORT_RX_LINKD_DYNAMIC_AMPLITUDE_CENTERING_DAC_AND_DYNAMIC_PEAKING_CONTROL_DPC 0x3770 +#define A_MAC_PORT_RX_LINKD_DYNAMIC_DATA_CENTERING_DDC 0x3774 +#define A_MAC_PORT_RX_LINKD_RECEIVER_INTERNAL_STATUS 0x3778 +#define A_MAC_PORT_RX_LINKD_DFE_FUNCTION_CONTROL_1 0x377c +#define A_MAC_PORT_RX_LINKD_DFE_FUNCTION_CONTROL_2 0x3780 +#define A_MAC_PORT_RX_LINKD_DFE_OFFSET_EVN1_EVN2 0x3784 +#define A_MAC_PORT_RX_LINKD_DFE_OFFSET_ODD1_ODD2 0x3788 +#define A_MAC_PORT_RX_LINKD_DFE_OFFSET_EVN3_EVN4 0x378c +#define A_MAC_PORT_RX_LINKD_DFE_OFFSET_ODD3_ODD4 0x3790 +#define A_MAC_PORT_RX_LINKD_DFE_E0_AND_E1_OFFSET 0x3794 +#define A_MAC_PORT_RX_LINKD_RECEIVER_LOFF_CONTROL 0x3798 +#define A_MAC_PORT_RX_LINKD_RECEIVER_SIGDET_CONTROL 0x379c +#define A_MAC_PORT_RX_LINKD_RECEIVER_ANALOG_CONTROL_SWITCH 0x37a0 +#define A_MAC_PORT_RX_LINKD_INTEGRATOR_DAC_OFFSET 0x37a4 +#define A_MAC_PORT_RX_LINKD_DIGITAL_EYE_CONTROL 0x37a8 +#define A_MAC_PORT_RX_LINKD_DIGITAL_EYE_METRICS 0x37ac +#define A_MAC_PORT_RX_LINKD_DIGITAL_EYE_METRICS_ERROR_COUNT 0x37b0 +#define A_MAC_PORT_RX_LINKD_DIGITAL_EYE_METRICS_PDF_EYE_COUNT 0x37b4 +#define A_MAC_PORT_RX_LINKD_DIGITAL_EYE_METRICS_PATTERN_LENGTH 0x37b8 +#define A_MAC_PORT_RX_LINKD_DFE_TAP_ENABLE 0x37c0 +#define A_MAC_PORT_RX_LINKD_DFE_H1 0x37c4 +#define A_MAC_PORT_RX_LINKD_DFE_H2 0x37c8 +#define A_MAC_PORT_RX_LINKD_DFE_H3 0x37cc +#define A_MAC_PORT_RX_LINKD_DFE_H4 0x37d0 +#define A_MAC_PORT_RX_LINKD_DFE_H5 0x37d4 +#define A_MAC_PORT_RX_LINKD_DFE_H6_AND_H7 0x37d8 +#define A_MAC_PORT_RX_LINKD_DFE_H8_AND_H9 0x37dc +#define A_MAC_PORT_RX_LINKD_DFE_H10_AND_H11 0x37e0 +#define A_MAC_PORT_RX_LINKD_DFE_H12 0x37e4 +#define A_MAC_PORT_RX_LINKD_RECEIVER_MACRO_TEST_CONTROL_2 0x37f8 +#define A_MAC_PORT_RX_LINKD_RECEIVER_MACRO_TEST_CONTROL_1 0x37fc +#define A_MAC_PORT_ANALOG_TEST_MUX 0x3814 +#define A_MAC_PORT_BANDGAP_CONTROL 0x382c + +#define S_T5BGCTL 0 +#define M_T5BGCTL 0xfU +#define V_T5BGCTL(x) ((x) << S_T5BGCTL) +#define G_T5BGCTL(x) (((x) >> S_T5BGCTL) & M_T5BGCTL) + +#define A_MAC_PORT_RESISTOR_CALIBRATION_CONTROL 0x3880 + +#define S_RCCTL1 5 +#define V_RCCTL1(x) ((x) << S_RCCTL1) +#define F_RCCTL1 V_RCCTL1(1U) + +#define S_RCCTL0 4 +#define V_RCCTL0(x) ((x) << S_RCCTL0) +#define F_RCCTL0 V_RCCTL0(1U) + +#define S_RCAMP1 3 +#define V_RCAMP1(x) ((x) << S_RCAMP1) +#define F_RCAMP1 V_RCAMP1(1U) + +#define S_RCAMP0 2 +#define V_RCAMP0(x) ((x) << S_RCAMP0) +#define F_RCAMP0 V_RCAMP0(1U) + +#define S_RCAMPEN 1 +#define V_RCAMPEN(x) ((x) << S_RCAMPEN) +#define F_RCAMPEN V_RCAMPEN(1U) + +#define S_RCRST 0 +#define V_RCRST(x) ((x) << S_RCRST) +#define F_RCRST V_RCRST(1U) + +#define A_MAC_PORT_RESISTOR_CALIBRATION_STATUS_1 0x3884 + +#define S_RCERR 1 +#define V_RCERR(x) ((x) << S_RCERR) +#define F_RCERR V_RCERR(1U) + +#define S_RCCOMP 0 +#define V_RCCOMP(x) ((x) << S_RCCOMP) +#define F_RCCOMP V_RCCOMP(1U) + +#define A_MAC_PORT_RESISTOR_CALIBRATION_STATUS_2 0x3888 + +#define S_RESREG2 0 +#define M_RESREG2 0xffU +#define V_RESREG2(x) ((x) << S_RESREG2) +#define G_RESREG2(x) (((x) >> S_RESREG2) & M_RESREG2) + +#define A_MAC_PORT_RESISTOR_CALIBRATION_STATUS_3 0x388c + +#define S_RESREG3 0 +#define M_RESREG3 0xffU +#define V_RESREG3(x) ((x) << S_RESREG3) +#define G_RESREG3(x) (((x) >> S_RESREG3) & M_RESREG3) + +#define A_MAC_PORT_MACRO_TEST_CONTROL_6 0x38e8 + +#define S_LBIST 7 +#define V_LBIST(x) ((x) << S_LBIST) +#define F_LBIST V_LBIST(1U) + +#define S_LOGICTEST 6 +#define V_LOGICTEST(x) ((x) << S_LOGICTEST) +#define F_LOGICTEST V_LOGICTEST(1U) + +#define S_MAVDHI 5 +#define V_MAVDHI(x) ((x) << S_MAVDHI) +#define F_MAVDHI V_MAVDHI(1U) + +#define S_AUXEN 4 +#define V_AUXEN(x) ((x) << S_AUXEN) +#define F_AUXEN V_AUXEN(1U) + +#define S_JTAGMD 3 +#define V_JTAGMD(x) ((x) << S_JTAGMD) +#define F_JTAGMD V_JTAGMD(1U) + +#define S_RXACMODE 2 +#define V_RXACMODE(x) ((x) << S_RXACMODE) +#define F_RXACMODE V_RXACMODE(1U) + +#define S_HSSACJPC 1 +#define V_HSSACJPC(x) ((x) << S_HSSACJPC) +#define F_HSSACJPC V_HSSACJPC(1U) + +#define S_HSSACJAC 0 +#define V_HSSACJAC(x) ((x) << S_HSSACJAC) +#define F_HSSACJAC V_HSSACJAC(1U) + +#define A_MAC_PORT_MACRO_TEST_CONTROL_5 0x38ec + +#define S_REFVALIDD 6 +#define V_REFVALIDD(x) ((x) << S_REFVALIDD) +#define F_REFVALIDD V_REFVALIDD(1U) + +#define S_REFVALIDC 5 +#define V_REFVALIDC(x) ((x) << S_REFVALIDC) +#define F_REFVALIDC V_REFVALIDC(1U) + +#define S_REFVALIDB 4 +#define V_REFVALIDB(x) ((x) << S_REFVALIDB) +#define F_REFVALIDB V_REFVALIDB(1U) + +#define S_REFVALIDA 3 +#define V_REFVALIDA(x) ((x) << S_REFVALIDA) +#define F_REFVALIDA V_REFVALIDA(1U) + +#define S_REFSELRESET 2 +#define V_REFSELRESET(x) ((x) << S_REFSELRESET) +#define F_REFSELRESET V_REFSELRESET(1U) + +#define S_SOFTRESET 1 +#define V_SOFTRESET(x) ((x) << S_SOFTRESET) +#define F_SOFTRESET V_SOFTRESET(1U) + +#define S_MACROTEST 0 +#define V_MACROTEST(x) ((x) << S_MACROTEST) +#define F_MACROTEST V_MACROTEST(1U) + +#define A_MAC_PORT_TX_LINK_BCST_TRANSMIT_CONFIGURATION_MODE 0x3900 +#define A_MAC_PORT_TX_LINK_BCST_TRANSMIT_TEST_CONTROL 0x3904 +#define A_MAC_PORT_TX_LINK_BCST_TRANSMIT_COEFFICIENT_CONTROL 0x3908 +#define A_MAC_PORT_TX_LINK_BCST_TRANSMIT_DRIVER_MODE_CONTROL 0x390c +#define A_MAC_PORT_TX_LINK_BCST_TRANSMIT_DRIVER_OVERRIDE_CONTROL 0x3910 +#define A_MAC_PORT_TX_LINK_BCST_TRANSMIT_DCLK_ROTATOR_OVERRIDE 0x3914 +#define A_MAC_PORT_TX_LINK_BCST_TRANSMIT_IMPEDANCE_CALIBRATION_OVERRIDE 0x3918 +#define A_MAC_PORT_TX_LINK_BCST_TRANSMIT_DCLK_DRIFT_TOLERANCE 0x391c +#define A_MAC_PORT_TX_LINK_BCST_TRANSMIT_TAP_0_COEFFICIENT 0x3920 +#define A_MAC_PORT_TX_LINK_BCST_TRANSMIT_TAP_1_COEFFICIENT 0x3924 +#define A_MAC_PORT_TX_LINK_BCST_TRANSMIT_TAP_2_COEFFICIENT 0x3928 +#define A_MAC_PORT_TX_LINK_BCST_TRANSMIT_AMPLITUDE 0x3930 +#define A_MAC_PORT_TX_LINK_BCST_TRANSMIT_POLARITY 0x3934 +#define A_MAC_PORT_TX_LINK_BCST_TRANSMIT_802_3AP_ADAPTIVE_EQUALIZATION_COMMAND 0x3938 +#define A_MAC_PORT_TX_LINK_BCST_TRANSMIT_802_3AP_ADAPTIVE_EQUALIZATION_STATUS 0x393c +#define A_MAC_PORT_TX_LINK_BCST_TRANSMIT_TAP_0_COEFFICIENT_OVERRIDE 0x3940 +#define A_MAC_PORT_TX_LINK_BCST_TRANSMIT_TAP_1_COEFFICIENT_OVERRIDE 0x3944 +#define A_MAC_PORT_TX_LINK_BCST_TRANSMIT_TAP_2_COEFFICIENT_OVERRIDE 0x3948 +#define A_MAC_PORT_TX_LINK_BCST_TRANSMIT_TAP_0_COEFFICIENT_APPLIED 0x3960 +#define A_MAC_PORT_TX_LINK_BCST_TRANSMIT_TAP_1_COEFFICIENT_APPLIED 0x3964 +#define A_MAC_PORT_TX_LINK_BCST_TRANSMIT_TAP_2_COEFFICIENT_APPLIED 0x3968 +#define A_MAC_PORT_TX_LINK_BCST_TRANSMIT_SEGMENT_DISABLE_APPLIED_1 0x3970 +#define A_MAC_PORT_TX_LINK_BCST_TRANSMIT_SEGMENT_DISABLE_APPLIED_2 0x3974 +#define A_MAC_PORT_TX_LINK_BCST_TRANSMIT_EXTENDED_ADDRESS_DATA 0x3978 +#define A_MAC_PORT_TX_LINK_BCST_TRANSMIT_EXTENDED_ADDRESS_ADDR 0x397c +#define A_MAC_PORT_TX_LINK_BCST_TRANSMIT_PATTERN_BUFFER_BYTES_1_0 0x3980 +#define A_MAC_PORT_TX_LINK_BCST_TRANSMIT_PATTERN_BUFFER_BYTES_3_2 0x3984 +#define A_MAC_PORT_TX_LINK_BCST_TRANSMIT_PATTERN_BUFFER_BYTE_4 0x3988 +#define A_MAC_PORT_TX_LINK_BCST_TRANSMIT_DCC_CONTROL 0x398c +#define A_MAC_PORT_TX_LINK_BCST_TRANSMIT_DCC_OVERRIDE 0x3990 +#define A_MAC_PORT_TX_LINK_BCST_TRANSMIT_DCC_APPLIED 0x3994 +#define A_MAC_PORT_TX_LINK_BCST_TRANSMIT_DCC_TIME_OUT 0x3998 +#define A_MAC_PORT_TX_LINK_BCST_TRANSMIT_802_3AZ_CONTROL 0x399c +#define A_MAC_PORT_TX_LINK_BCST_TRANSMIT_MACRO_TEST_CONTROL_4 0x39f0 +#define A_MAC_PORT_TX_LINK_BCST_TRANSMIT_MACRO_TEST_CONTROL_3 0x39f4 +#define A_MAC_PORT_TX_LINK_BCST_TRANSMIT_MACRO_TEST_CONTROL_2 0x39f8 +#define A_MAC_PORT_TX_LINK_BCST_TRANSMIT_MACRO_TEST_CONTROL_1 0x39fc +#define A_MAC_PORT_RX_LINK_BCST_RECEIVER_CONFIGURATION_MODE 0x3a00 +#define A_MAC_PORT_RX_LINK_BCST_RECEIVER_TEST_CONTROL 0x3a04 +#define A_MAC_PORT_RX_LINK_BCST_PHASE_ROTATOR_CONTROL 0x3a08 +#define A_MAC_PORT_RX_LINK_BCST_PHASE_ROTATOR_OFFSET_CONTROL 0x3a0c +#define A_MAC_PORT_RX_LINK_BCST_PHASE_ROTATOR_POSITION_1 0x3a10 +#define A_MAC_PORT_RX_LINK_BCST_PHASE_ROTATOR_POSITION_2 0x3a14 +#define A_MAC_PORT_RX_LINK_BCST_PHASE_ROTATOR_STATIC_PHASE_OFFSET_1 0x3a18 +#define A_MAC_PORT_RX_LINK_BCST_PHASE_ROTATOR_STATIC_PHASE_OFFSET_2 0x3a1c +#define A_MAC_PORT_RX_LINK_BCST_DFE_CONTROL 0x3a20 +#define A_MAC_PORT_RX_LINK_BCST_DFE_SAMPLE_SNAPSHOT_1 0x3a24 +#define A_MAC_PORT_RX_LINK_BCST_DFE_SAMPLE_SNAPSHOT_2 0x3a28 +#define A_MAC_PORT_RX_LINK_BCST_RECEIVER_VGA_CONTROL_1 0x3a2c +#define A_MAC_PORT_RX_LINK_BCST_RECEIVER_VGA_CONTROL_2 0x3a30 +#define A_MAC_PORT_RX_LINK_BCST_RECEIVER_VGA_CONTROL_3 0x3a34 +#define A_MAC_PORT_RX_LINK_BCST_RECEIVER_DQCC_CONTROL_1 0x3a38 +#define A_MAC_PORT_RX_LINK_BCST_RECEIVER_DQCC_CONTROL_3 0x3a40 +#define A_MAC_PORT_RX_LINK_BCST_RECEIVER_DACAP_AND_DACAN 0x3a48 +#define A_MAC_PORT_RX_LINK_BCST_RECEIVER_DACA_MIN_AND_DACAZ 0x3a4c +#define A_MAC_PORT_RX_LINK_BCST_RECEIVER_ADAC_CONTROL 0x3a50 +#define A_MAC_PORT_RX_LINK_BCST_DFE_H1_LOCAL_OFFSET_ODD2_EVN2 0x3a5c +#define A_MAC_PORT_RX_LINK_BCST_DFE_H1_LOCAL_OFFSET_ODD3_EVN3 0x3a60 +#define A_MAC_PORT_RX_LINK_BCST_DFE_H1_LOCAL_OFFSET_ODD4_EVN4 0x3a64 +#define A_MAC_PORT_RX_LINK_BCST_DYNAMIC_AMPLITUDE_CENTERING_DAC_AND_DYNAMIC_PEAKING_CONTROL_DPC 0x3a70 +#define A_MAC_PORT_RX_LINK_BCST_DYNAMIC_DATA_CENTERING_DDC 0x3a74 +#define A_MAC_PORT_RX_LINK_BCST_RECEIVER_INTERNAL_STATUS 0x3a78 +#define A_MAC_PORT_RX_LINK_BCST_DFE_FUNCTION_CONTROL_1 0x3a7c +#define A_MAC_PORT_RX_LINK_BCST_DFE_FUNCTION_CONTROL_2 0x3a80 +#define A_MAC_PORT_RX_LINK_BCST_DFE_OFFSET_EVN1_EVN2 0x3a84 +#define A_MAC_PORT_RX_LINK_BCST_DFE_OFFSET_ODD1_ODD2 0x3a88 +#define A_MAC_PORT_RX_LINK_BCST_DFE_OFFSET_EVN3_EVN4 0x3a8c +#define A_MAC_PORT_RX_LINK_BCST_DFE_OFFSET_ODD3_ODD4 0x3a90 +#define A_MAC_PORT_RX_LINK_BCST_DFE_E0_AND_E1_OFFSET 0x3a94 +#define A_MAC_PORT_RX_LINK_BCST_RECEIVER_LOFF_CONTROL 0x3a98 +#define A_MAC_PORT_RX_LINK_BCST_RECEIVER_SIGDET_CONTROL 0x3a9c +#define A_MAC_PORT_RX_LINK_BCST_RECEIVER_ANALOG_CONTROL_SWITCH 0x3aa0 +#define A_MAC_PORT_RX_LINK_BCST_INTEGRATOR_DAC_OFFSET 0x3aa4 +#define A_MAC_PORT_RX_LINK_BCST_DIGITAL_EYE_CONTROL 0x3aa8 +#define A_MAC_PORT_RX_LINK_BCST_DIGITAL_EYE_METRICS 0x3aac +#define A_MAC_PORT_RX_LINK_BCST_DIGITAL_EYE_METRICS_ERROR_COUNT 0x3ab0 +#define A_MAC_PORT_RX_LINK_BCST_DIGITAL_EYE_METRICS_PDF_EYE_COUNT 0x3ab4 +#define A_MAC_PORT_RX_LINK_BCST_DIGITAL_EYE_METRICS_PATTERN_LENGTH 0x3ab8 +#define A_MAC_PORT_RX_LINK_BCST_DFE_TAP_ENABLE 0x3ac0 +#define A_MAC_PORT_RX_LINK_BCST_DFE_H1 0x3ac4 +#define A_MAC_PORT_RX_LINK_BCST_DFE_H2 0x3ac8 +#define A_MAC_PORT_RX_LINK_BCST_DFE_H3 0x3acc +#define A_MAC_PORT_RX_LINK_BCST_DFE_H4 0x3ad0 +#define A_MAC_PORT_RX_LINK_BCST_DFE_H5 0x3ad4 +#define A_MAC_PORT_RX_LINK_BCST_DFE_H6_AND_H7 0x3ad8 +#define A_MAC_PORT_RX_LINK_BCST_DFE_H8_AND_H9 0x3adc +#define A_MAC_PORT_RX_LINK_BCST_DFE_H10_AND_H11 0x3ae0 +#define A_MAC_PORT_RX_LINK_BCST_DFE_H12 0x3ae4 +#define A_MAC_PORT_RX_LINK_BCST_RECEIVER_MACRO_TEST_CONTROL_2 0x3af8 +#define A_MAC_PORT_RX_LINK_BCST_RECEIVER_MACRO_TEST_CONTROL_1 0x3afc +#define A_MAC_PORT_PLLA_VCO_COARSE_CALIBRATION_0 0x3b00 +#define A_MAC_PORT_PLLA_VCO_COARSE_CALIBRATION_1 0x3b04 +#define A_MAC_PORT_PLLA_VCO_COARSE_CALIBRATION_2 0x3b08 +#define A_MAC_PORT_PLLA_VCO_COARSE_CALIBRATION_3 0x3b0c +#define A_MAC_PORT_PLLA_VCO_COARSE_CALIBRATION_4 0x3b10 +#define A_MAC_PORT_PLLA_CHARGE_PUMP_CONTROL 0x3b28 + +#define S_T5CPISEL 0 +#define M_T5CPISEL 0x7U +#define V_T5CPISEL(x) ((x) << S_T5CPISEL) +#define G_T5CPISEL(x) (((x) >> S_T5CPISEL) & M_T5CPISEL) + +#define A_MAC_PORT_PLLA_PCLK_CONTROL 0x3b3c + +#define S_SPEDIV 3 +#define M_SPEDIV 0x1fU +#define V_SPEDIV(x) ((x) << S_SPEDIV) +#define G_SPEDIV(x) (((x) >> S_SPEDIV) & M_SPEDIV) + +#define S_PCKSEL 0 +#define M_PCKSEL 0x7U +#define V_PCKSEL(x) ((x) << S_PCKSEL) +#define G_PCKSEL(x) (((x) >> S_PCKSEL) & M_PCKSEL) + +#define A_MAC_PORT_PLLA_EYE_METRICS_INTERVAL_CONTROL 0x3b40 + +#define S_EMIL 2 +#define V_EMIL(x) ((x) << S_EMIL) +#define F_EMIL V_EMIL(1U) + +#define S_EMID 1 +#define V_EMID(x) ((x) << S_EMID) +#define F_EMID V_EMID(1U) + +#define S_EMIS 0 +#define V_EMIS(x) ((x) << S_EMIS) +#define F_EMIS V_EMIS(1U) + +#define A_MAC_PORT_PLLA_EYE_METRICS_INTERVAL_LIMIT_1 0x3b44 + +#define S_EMIL1 0 +#define M_EMIL1 0xffU +#define V_EMIL1(x) ((x) << S_EMIL1) +#define G_EMIL1(x) (((x) >> S_EMIL1) & M_EMIL1) + +#define A_MAC_PORT_PLLA_EYE_METRICS_INTERVAL_LIMIT_2 0x3b48 + +#define S_EMIL2 0 +#define M_EMIL2 0xffU +#define V_EMIL2(x) ((x) << S_EMIL2) +#define G_EMIL2(x) (((x) >> S_EMIL2) & M_EMIL2) + +#define A_MAC_PORT_PLLA_EYE_METRICS_INTERVAL_LIMIT_3 0x3b4c + +#define S_EMIL3 0 +#define M_EMIL3 0xffU +#define V_EMIL3(x) ((x) << S_EMIL3) +#define G_EMIL3(x) (((x) >> S_EMIL3) & M_EMIL3) + +#define A_MAC_PORT_PLLA_EYE_METRICS_INTERVAL_LIMIT_4 0x3b50 + +#define S_EMIL4 0 +#define M_EMIL4 0xffU +#define V_EMIL4(x) ((x) << S_EMIL4) +#define G_EMIL4(x) (((x) >> S_EMIL4) & M_EMIL4) + +#define A_MAC_PORT_PLLA_MACRO_TEST_CONTROL_4 0x3bf0 + +#define S_VBST 1 +#define M_VBST 0x7U +#define V_VBST(x) ((x) << S_VBST) +#define G_VBST(x) (((x) >> S_VBST) & M_VBST) + +#define A_MAC_PORT_PLLA_MACRO_TEST_CONTROL_3 0x3bf4 + +#define S_RESYNC 6 +#define V_RESYNC(x) ((x) << S_RESYNC) +#define F_RESYNC V_RESYNC(1U) + +#define S_RXCLKSEL 5 +#define V_RXCLKSEL(x) ((x) << S_RXCLKSEL) +#define F_RXCLKSEL V_RXCLKSEL(1U) + +#define S_FRCBAND 4 +#define V_FRCBAND(x) ((x) << S_FRCBAND) +#define F_FRCBAND V_FRCBAND(1U) + +#define S_PLLBYP 3 +#define V_PLLBYP(x) ((x) << S_PLLBYP) +#define F_PLLBYP V_PLLBYP(1U) + +#define S_PDWNP 2 +#define V_PDWNP(x) ((x) << S_PDWNP) +#define F_PDWNP V_PDWNP(1U) + +#define S_VCOSEL 1 +#define V_VCOSEL(x) ((x) << S_VCOSEL) +#define F_VCOSEL V_VCOSEL(1U) + +#define S_DIVSEL8 0 +#define V_DIVSEL8(x) ((x) << S_DIVSEL8) +#define F_DIVSEL8 V_DIVSEL8(1U) + +#define A_MAC_PORT_PLLA_MACRO_TEST_CONTROL_2 0x3bf8 + +#define S_DIVSEL 0 +#define M_DIVSEL 0xffU +#define V_DIVSEL(x) ((x) << S_DIVSEL) +#define G_DIVSEL(x) (((x) >> S_DIVSEL) & M_DIVSEL) + +#define A_MAC_PORT_PLLA_MACRO_TEST_CONTROL_1 0x3bfc + +#define S_CONFIG 0 +#define M_CONFIG 0xffU +#define V_CONFIG(x) ((x) << S_CONFIG) +#define G_CONFIG(x) (((x) >> S_CONFIG) & M_CONFIG) + +#define A_MAC_PORT_PLLB_VCO_COARSE_CALIBRATION_0 0x3c00 +#define A_MAC_PORT_PLLB_VCO_COARSE_CALIBRATION_1 0x3c04 +#define A_MAC_PORT_PLLB_VCO_COARSE_CALIBRATION_2 0x3c08 +#define A_MAC_PORT_PLLB_VCO_COARSE_CALIBRATION_3 0x3c0c +#define A_MAC_PORT_PLLB_VCO_COARSE_CALIBRATION_4 0x3c10 +#define A_MAC_PORT_PLLB_CHARGE_PUMP_CONTROL 0x3c28 +#define A_MAC_PORT_PLLB_PCLK_CONTROL 0x3c3c +#define A_MAC_PORT_PLLB_EYE_METRICS_INTERVAL_CONTROL 0x3c40 +#define A_MAC_PORT_PLLB_EYE_METRICS_INTERVAL_LIMIT_1 0x3c44 +#define A_MAC_PORT_PLLB_EYE_METRICS_INTERVAL_LIMIT_2 0x3c48 +#define A_MAC_PORT_PLLB_EYE_METRICS_INTERVAL_LIMIT_3 0x3c4c +#define A_MAC_PORT_PLLB_EYE_METRICS_INTERVAL_LIMIT_4 0x3c50 +#define A_MAC_PORT_PLLB_MACRO_TEST_CONTROL_4 0x3cf0 +#define A_MAC_PORT_PLLB_MACRO_TEST_CONTROL_3 0x3cf4 +#define A_MAC_PORT_PLLB_MACRO_TEST_CONTROL_2 0x3cf8 +#define A_MAC_PORT_PLLB_MACRO_TEST_CONTROL_1 0x3cfc +#define A_MAC_PORT_TX_LINKA_TRANSMIT_802_3AP_STEP_SIZE_EXTENDED 0x0 + +#define S_STEP 0 +#define M_STEP 0x7U +#define V_STEP(x) ((x) << S_STEP) +#define G_STEP(x) (((x) >> S_STEP) & M_STEP) + +#define A_MAC_PORT_TX_LINKA_TRANSMIT_802_3AP_C0_INIT_EXTENDED 0x8 + +#define S_C0INIT 0 +#define M_C0INIT 0x1fU +#define V_C0INIT(x) ((x) << S_C0INIT) +#define G_C0INIT(x) (((x) >> S_C0INIT) & M_C0INIT) + +#define A_MAC_PORT_TX_LINKA_TRANSMIT_802_3AP_C0_LIMIT_EXTENDED 0x10 + +#define S_C0MAX 8 +#define M_C0MAX 0x1fU +#define V_C0MAX(x) ((x) << S_C0MAX) +#define G_C0MAX(x) (((x) >> S_C0MAX) & M_C0MAX) + +#define S_C0MIN 0 +#define M_C0MIN 0x1fU +#define V_C0MIN(x) ((x) << S_C0MIN) +#define G_C0MIN(x) (((x) >> S_C0MIN) & M_C0MIN) + +#define A_MAC_PORT_TX_LINKA_TRANSMIT_802_3AP_C1_INIT_EXTENDED 0x18 + +#define S_C1INIT 0 +#define M_C1INIT 0x7fU +#define V_C1INIT(x) ((x) << S_C1INIT) +#define G_C1INIT(x) (((x) >> S_C1INIT) & M_C1INIT) + +#define A_MAC_PORT_TX_LINKA_TRANSMIT_802_3AP_C1_LIMIT_EXTENDED 0x20 + +#define S_C1MAX 8 +#define M_C1MAX 0x7fU +#define V_C1MAX(x) ((x) << S_C1MAX) +#define G_C1MAX(x) (((x) >> S_C1MAX) & M_C1MAX) + +#define S_C1MIN 0 +#define M_C1MIN 0x7fU +#define V_C1MIN(x) ((x) << S_C1MIN) +#define G_C1MIN(x) (((x) >> S_C1MIN) & M_C1MIN) + +#define A_MAC_PORT_TX_LINKA_TRANSMIT_802_3AP_C2_INIT_EXTENDED 0x28 + +#define S_C2INIT 0 +#define M_C2INIT 0x3fU +#define V_C2INIT(x) ((x) << S_C2INIT) +#define G_C2INIT(x) (((x) >> S_C2INIT) & M_C2INIT) + +#define A_MAC_PORT_TX_LINKA_TRANSMIT_802_3AP_C2_LIMIT_EXTENDED 0x30 + +#define S_C2MAX 8 +#define M_C2MAX 0x3fU +#define V_C2MAX(x) ((x) << S_C2MAX) +#define G_C2MAX(x) (((x) >> S_C2MAX) & M_C2MAX) + +#define S_C2MIN 0 +#define M_C2MIN 0x3fU +#define V_C2MIN(x) ((x) << S_C2MIN) +#define G_C2MIN(x) (((x) >> S_C2MIN) & M_C2MIN) + +#define A_MAC_PORT_TX_LINKA_TRANSMIT_802_3AP_VM_LIMIT_EXTENDED 0x38 + +#define S_VMMAX 0 +#define M_VMMAX 0x7fU +#define V_VMMAX(x) ((x) << S_VMMAX) +#define G_VMMAX(x) (((x) >> S_VMMAX) & M_VMMAX) + +#define A_MAC_PORT_TX_LINKA_TRANSMIT_802_3AP_V2_LIMIT_EXTENDED 0x40 + +#define S_V2MIN 0 +#define M_V2MIN 0x7fU +#define V_V2MIN(x) ((x) << S_V2MIN) +#define G_V2MIN(x) (((x) >> S_V2MIN) & M_V2MIN) + +#define A_MAC_PORT_TX_LINKB_TRANSMIT_802_3AP_STEP_SIZE_EXTENDED 0x0 +#define A_MAC_PORT_TX_LINKB_TRANSMIT_802_3AP_C0_INIT_EXTENDED 0x8 +#define A_MAC_PORT_TX_LINKB_TRANSMIT_802_3AP_C0_LIMIT_EXTENDED 0x10 +#define A_MAC_PORT_TX_LINKB_TRANSMIT_802_3AP_C1_INIT_EXTENDED 0x18 +#define A_MAC_PORT_TX_LINKB_TRANSMIT_802_3AP_C1_LIMIT_EXTENDED 0x20 +#define A_MAC_PORT_TX_LINKB_TRANSMIT_802_3AP_C2_INIT_EXTENDED 0x28 +#define A_MAC_PORT_TX_LINKB_TRANSMIT_802_3AP_C2_LIMIT_EXTENDED 0x30 +#define A_MAC_PORT_TX_LINKB_TRANSMIT_802_3AP_VM_LIMIT_EXTENDED 0x38 +#define A_MAC_PORT_TX_LINKB_TRANSMIT_802_3AP_V2_LIMIT_EXTENDED 0x40 +#define A_MAC_PORT_TX_LINKC_TRANSMIT_802_3AP_STEP_SIZE_EXTENDED 0x0 +#define A_MAC_PORT_TX_LINKC_TRANSMIT_802_3AP_C0_INIT_EXTENDED 0x8 +#define A_MAC_PORT_TX_LINKC_TRANSMIT_802_3AP_C0_LIMIT_EXTENDED 0x10 +#define A_MAC_PORT_TX_LINKC_TRANSMIT_802_3AP_C1_INIT_EXTENDED 0x18 +#define A_MAC_PORT_TX_LINKC_TRANSMIT_802_3AP_C1_LIMIT_EXTENDED 0x20 +#define A_MAC_PORT_TX_LINKC_TRANSMIT_802_3AP_C2_INIT_EXTENDED 0x28 +#define A_MAC_PORT_TX_LINKC_TRANSMIT_802_3AP_C2_LIMIT_EXTENDED 0x30 +#define A_MAC_PORT_TX_LINKC_TRANSMIT_802_3AP_VM_LIMIT_EXTENDED 0x38 +#define A_MAC_PORT_TX_LINKC_TRANSMIT_802_3AP_V2_LIMIT_EXTENDED 0x40 +#define A_MAC_PORT_TX_LINKD_TRANSMIT_802_3AP_STEP_SIZE_EXTENDED 0x0 +#define A_MAC_PORT_TX_LINKD_TRANSMIT_802_3AP_C0_INIT_EXTENDED 0x8 +#define A_MAC_PORT_TX_LINKD_TRANSMIT_802_3AP_C0_LIMIT_EXTENDED 0x10 +#define A_MAC_PORT_TX_LINKD_TRANSMIT_802_3AP_C1_INIT_EXTENDED 0x18 +#define A_MAC_PORT_TX_LINKD_TRANSMIT_802_3AP_C1_LIMIT_EXTENDED 0x20 +#define A_MAC_PORT_TX_LINKD_TRANSMIT_802_3AP_C2_INIT_EXTENDED 0x28 +#define A_MAC_PORT_TX_LINKD_TRANSMIT_802_3AP_C2_LIMIT_EXTENDED 0x30 +#define A_MAC_PORT_TX_LINKD_TRANSMIT_802_3AP_VM_LIMIT_EXTENDED 0x38 +#define A_MAC_PORT_TX_LINKD_TRANSMIT_802_3AP_V2_LIMIT_EXTENDED 0x40 +#define A_MAC_PORT_TX_LINK_BCST_TRANSMIT_802_3AP_STEP_SIZE_EXTENDED 0x0 +#define A_MAC_PORT_TX_LINK_BCST_TRANSMIT_802_3AP_C0_INIT_EXTENDED 0x8 +#define A_MAC_PORT_TX_LINK_BCST_TRANSMIT_802_3AP_C0_LIMIT_EXTENDED 0x10 +#define A_MAC_PORT_TX_LINK_BCST_TRANSMIT_802_3AP_C1_INIT_EXTENDED 0x18 +#define A_MAC_PORT_TX_LINK_BCST_TRANSMIT_802_3AP_C1_LIMIT_EXTENDED 0x20 +#define A_MAC_PORT_TX_LINK_BCST_TRANSMIT_802_3AP_C2_INIT_EXTENDED 0x28 +#define A_MAC_PORT_TX_LINK_BCST_TRANSMIT_802_3AP_C2_LIMIT_EXTENDED 0x30 +#define A_MAC_PORT_TX_LINK_BCST_TRANSMIT_802_3AP_VM_LIMIT_EXTENDED 0x38 +#define A_MAC_PORT_TX_LINK_BCST_TRANSMIT_802_3AP_V2_LIMIT_EXTENDED 0x40 + +/* registers for module MC_0 */ +#define MC_0_BASE_ADDR 0x40000 + +#define A_MC_UPCTL_SCFG 0x40000 + +#define S_BBFLAGS_TIMING 8 +#define M_BBFLAGS_TIMING 0xfU +#define V_BBFLAGS_TIMING(x) ((x) << S_BBFLAGS_TIMING) +#define G_BBFLAGS_TIMING(x) (((x) >> S_BBFLAGS_TIMING) & M_BBFLAGS_TIMING) + +#define S_NFIFO_NIF1_DIS 6 +#define V_NFIFO_NIF1_DIS(x) ((x) << S_NFIFO_NIF1_DIS) +#define F_NFIFO_NIF1_DIS V_NFIFO_NIF1_DIS(1U) + +#define A_MC_UPCTL_SCTL 0x40004 +#define A_MC_UPCTL_STAT 0x40008 + +#define S_LP_TRIG 4 +#define M_LP_TRIG 0x7U +#define V_LP_TRIG(x) ((x) << S_LP_TRIG) +#define G_LP_TRIG(x) (((x) >> S_LP_TRIG) & M_LP_TRIG) + +#define A_MC_UPCTL_INTRSTAT 0x4000c + +#define S_PARITY_INTR 1 +#define V_PARITY_INTR(x) ((x) << S_PARITY_INTR) +#define F_PARITY_INTR V_PARITY_INTR(1U) + +#define S_ECC_INTR 0 +#define V_ECC_INTR(x) ((x) << S_ECC_INTR) +#define F_ECC_INTR V_ECC_INTR(1U) + +#define A_MC_UPCTL_MCMD 0x40040 + +#define S_CMD_OPCODE0 0 +#define M_CMD_OPCODE0 0xfU +#define V_CMD_OPCODE0(x) ((x) << S_CMD_OPCODE0) +#define G_CMD_OPCODE0(x) (((x) >> S_CMD_OPCODE0) & M_CMD_OPCODE0) + +#define A_MC_UPCTL_POWCTL 0x40044 +#define A_MC_UPCTL_POWSTAT 0x40048 +#define A_MC_UPCTL_CMDTSTAT 0x4004c + +#define S_CMD_TSTAT 0 +#define V_CMD_TSTAT(x) ((x) << S_CMD_TSTAT) +#define F_CMD_TSTAT V_CMD_TSTAT(1U) + +#define A_MC_UPCTL_CMDTSTATEN 0x40050 + +#define S_CMD_TSTAT_EN 0 +#define V_CMD_TSTAT_EN(x) ((x) << S_CMD_TSTAT_EN) +#define F_CMD_TSTAT_EN V_CMD_TSTAT_EN(1U) + +#define A_MC_UPCTL_MRRCFG0 0x40060 + +#define S_MRR_BYTE_SEL 0 +#define M_MRR_BYTE_SEL 0xfU +#define V_MRR_BYTE_SEL(x) ((x) << S_MRR_BYTE_SEL) +#define G_MRR_BYTE_SEL(x) (((x) >> S_MRR_BYTE_SEL) & M_MRR_BYTE_SEL) + +#define A_MC_UPCTL_MRRSTAT0 0x40064 + +#define S_MRRSTAT_BEAT3 24 +#define M_MRRSTAT_BEAT3 0xffU +#define V_MRRSTAT_BEAT3(x) ((x) << S_MRRSTAT_BEAT3) +#define G_MRRSTAT_BEAT3(x) (((x) >> S_MRRSTAT_BEAT3) & M_MRRSTAT_BEAT3) + +#define S_MRRSTAT_BEAT2 16 +#define M_MRRSTAT_BEAT2 0xffU +#define V_MRRSTAT_BEAT2(x) ((x) << S_MRRSTAT_BEAT2) +#define G_MRRSTAT_BEAT2(x) (((x) >> S_MRRSTAT_BEAT2) & M_MRRSTAT_BEAT2) + +#define S_MRRSTAT_BEAT1 8 +#define M_MRRSTAT_BEAT1 0xffU +#define V_MRRSTAT_BEAT1(x) ((x) << S_MRRSTAT_BEAT1) +#define G_MRRSTAT_BEAT1(x) (((x) >> S_MRRSTAT_BEAT1) & M_MRRSTAT_BEAT1) + +#define S_MRRSTAT_BEAT0 0 +#define M_MRRSTAT_BEAT0 0xffU +#define V_MRRSTAT_BEAT0(x) ((x) << S_MRRSTAT_BEAT0) +#define G_MRRSTAT_BEAT0(x) (((x) >> S_MRRSTAT_BEAT0) & M_MRRSTAT_BEAT0) + +#define A_MC_UPCTL_MRRSTAT1 0x40068 + +#define S_MRRSTAT_BEAT7 24 +#define M_MRRSTAT_BEAT7 0xffU +#define V_MRRSTAT_BEAT7(x) ((x) << S_MRRSTAT_BEAT7) +#define G_MRRSTAT_BEAT7(x) (((x) >> S_MRRSTAT_BEAT7) & M_MRRSTAT_BEAT7) + +#define S_MRRSTAT_BEAT6 16 +#define M_MRRSTAT_BEAT6 0xffU +#define V_MRRSTAT_BEAT6(x) ((x) << S_MRRSTAT_BEAT6) +#define G_MRRSTAT_BEAT6(x) (((x) >> S_MRRSTAT_BEAT6) & M_MRRSTAT_BEAT6) + +#define S_MRRSTAT_BEAT5 8 +#define M_MRRSTAT_BEAT5 0xffU +#define V_MRRSTAT_BEAT5(x) ((x) << S_MRRSTAT_BEAT5) +#define G_MRRSTAT_BEAT5(x) (((x) >> S_MRRSTAT_BEAT5) & M_MRRSTAT_BEAT5) + +#define S_MRRSTAT_BEAT4 0 +#define M_MRRSTAT_BEAT4 0xffU +#define V_MRRSTAT_BEAT4(x) ((x) << S_MRRSTAT_BEAT4) +#define G_MRRSTAT_BEAT4(x) (((x) >> S_MRRSTAT_BEAT4) & M_MRRSTAT_BEAT4) + +#define A_MC_UPCTL_MCFG1 0x4007c + +#define S_HW_EXIT_IDLE_EN 31 +#define V_HW_EXIT_IDLE_EN(x) ((x) << S_HW_EXIT_IDLE_EN) +#define F_HW_EXIT_IDLE_EN V_HW_EXIT_IDLE_EN(1U) + +#define S_HW_IDLE 16 +#define M_HW_IDLE 0xffU +#define V_HW_IDLE(x) ((x) << S_HW_IDLE) +#define G_HW_IDLE(x) (((x) >> S_HW_IDLE) & M_HW_IDLE) + +#define S_SR_IDLE 0 +#define M_SR_IDLE 0xffU +#define V_SR_IDLE(x) ((x) << S_SR_IDLE) +#define G_SR_IDLE(x) (((x) >> S_SR_IDLE) & M_SR_IDLE) + +#define A_MC_UPCTL_MCFG 0x40080 + +#define S_MDDR_LPDDR2_CLK_STOP_IDLE 24 +#define M_MDDR_LPDDR2_CLK_STOP_IDLE 0xffU +#define V_MDDR_LPDDR2_CLK_STOP_IDLE(x) ((x) << S_MDDR_LPDDR2_CLK_STOP_IDLE) +#define G_MDDR_LPDDR2_CLK_STOP_IDLE(x) (((x) >> S_MDDR_LPDDR2_CLK_STOP_IDLE) & M_MDDR_LPDDR2_CLK_STOP_IDLE) + +#define S_MDDR_LPDDR2_EN 22 +#define M_MDDR_LPDDR2_EN 0x3U +#define V_MDDR_LPDDR2_EN(x) ((x) << S_MDDR_LPDDR2_EN) +#define G_MDDR_LPDDR2_EN(x) (((x) >> S_MDDR_LPDDR2_EN) & M_MDDR_LPDDR2_EN) + +#define S_MDDR_LPDDR2_BL 20 +#define M_MDDR_LPDDR2_BL 0x3U +#define V_MDDR_LPDDR2_BL(x) ((x) << S_MDDR_LPDDR2_BL) +#define G_MDDR_LPDDR2_BL(x) (((x) >> S_MDDR_LPDDR2_BL) & M_MDDR_LPDDR2_BL) + +#define S_LPDDR2_S4 6 +#define V_LPDDR2_S4(x) ((x) << S_LPDDR2_S4) +#define F_LPDDR2_S4 V_LPDDR2_S4(1U) + +#define S_STAGGER_CS 4 +#define V_STAGGER_CS(x) ((x) << S_STAGGER_CS) +#define F_STAGGER_CS V_STAGGER_CS(1U) + +#define S_CKE_OR_EN 1 +#define V_CKE_OR_EN(x) ((x) << S_CKE_OR_EN) +#define F_CKE_OR_EN V_CKE_OR_EN(1U) + +#define A_MC_UPCTL_PPCFG 0x40084 +#define A_MC_UPCTL_MSTAT 0x40088 + +#define S_SELF_REFRESH 2 +#define V_SELF_REFRESH(x) ((x) << S_SELF_REFRESH) +#define F_SELF_REFRESH V_SELF_REFRESH(1U) + +#define S_CLOCK_STOP 1 +#define V_CLOCK_STOP(x) ((x) << S_CLOCK_STOP) +#define F_CLOCK_STOP V_CLOCK_STOP(1U) + +#define A_MC_UPCTL_LPDDR2ZQCFG 0x4008c + +#define S_ZQCL_OP 24 +#define M_ZQCL_OP 0xffU +#define V_ZQCL_OP(x) ((x) << S_ZQCL_OP) +#define G_ZQCL_OP(x) (((x) >> S_ZQCL_OP) & M_ZQCL_OP) + +#define S_ZQCL_MA 16 +#define M_ZQCL_MA 0xffU +#define V_ZQCL_MA(x) ((x) << S_ZQCL_MA) +#define G_ZQCL_MA(x) (((x) >> S_ZQCL_MA) & M_ZQCL_MA) + +#define S_ZQCS_OP 8 +#define M_ZQCS_OP 0xffU +#define V_ZQCS_OP(x) ((x) << S_ZQCS_OP) +#define G_ZQCS_OP(x) (((x) >> S_ZQCS_OP) & M_ZQCS_OP) + +#define S_ZQCS_MA 0 +#define M_ZQCS_MA 0xffU +#define V_ZQCS_MA(x) ((x) << S_ZQCS_MA) +#define G_ZQCS_MA(x) (((x) >> S_ZQCS_MA) & M_ZQCS_MA) + +#define A_MC_UPCTL_DTUPDES 0x40094 + +#define S_DTU_ERR_B7 7 +#define V_DTU_ERR_B7(x) ((x) << S_DTU_ERR_B7) +#define F_DTU_ERR_B7 V_DTU_ERR_B7(1U) + +#define A_MC_UPCTL_DTUNA 0x40098 +#define A_MC_UPCTL_DTUNE 0x4009c +#define A_MC_UPCTL_DTUPRD0 0x400a0 +#define A_MC_UPCTL_DTUPRD1 0x400a4 +#define A_MC_UPCTL_DTUPRD2 0x400a8 +#define A_MC_UPCTL_DTUPRD3 0x400ac +#define A_MC_UPCTL_DTUAWDT 0x400b0 +#define A_MC_UPCTL_TOGCNT1U 0x400c0 +#define A_MC_UPCTL_TINIT 0x400c4 +#define A_MC_UPCTL_TRSTH 0x400c8 +#define A_MC_UPCTL_TOGCNT100N 0x400cc +#define A_MC_UPCTL_TREFI 0x400d0 +#define A_MC_UPCTL_TMRD 0x400d4 +#define A_MC_UPCTL_TRFC 0x400d8 + +#define S_T_RFC0 0 +#define M_T_RFC0 0x1ffU +#define V_T_RFC0(x) ((x) << S_T_RFC0) +#define G_T_RFC0(x) (((x) >> S_T_RFC0) & M_T_RFC0) + +#define A_MC_UPCTL_TRP 0x400dc + +#define S_PREA_EXTRA 16 +#define M_PREA_EXTRA 0x3U +#define V_PREA_EXTRA(x) ((x) << S_PREA_EXTRA) +#define G_PREA_EXTRA(x) (((x) >> S_PREA_EXTRA) & M_PREA_EXTRA) + +#define A_MC_UPCTL_TRTW 0x400e0 + +#define S_T_RTW0 0 +#define M_T_RTW0 0xfU +#define V_T_RTW0(x) ((x) << S_T_RTW0) +#define G_T_RTW0(x) (((x) >> S_T_RTW0) & M_T_RTW0) + +#define A_MC_UPCTL_TAL 0x400e4 +#define A_MC_UPCTL_TCL 0x400e8 +#define A_MC_UPCTL_TCWL 0x400ec +#define A_MC_UPCTL_TRAS 0x400f0 +#define A_MC_UPCTL_TRC 0x400f4 +#define A_MC_UPCTL_TRCD 0x400f8 +#define A_MC_UPCTL_TRRD 0x400fc +#define A_MC_UPCTL_TRTP 0x40100 + +#define S_T_RTP0 0 +#define M_T_RTP0 0xfU +#define V_T_RTP0(x) ((x) << S_T_RTP0) +#define G_T_RTP0(x) (((x) >> S_T_RTP0) & M_T_RTP0) + +#define A_MC_UPCTL_TWR 0x40104 + +#define S_U_T_WR 0 +#define M_U_T_WR 0x1fU +#define V_U_T_WR(x) ((x) << S_U_T_WR) +#define G_U_T_WR(x) (((x) >> S_U_T_WR) & M_U_T_WR) + +#define A_MC_UPCTL_TWTR 0x40108 + +#define S_T_WTR0 0 +#define M_T_WTR0 0xfU +#define V_T_WTR0(x) ((x) << S_T_WTR0) +#define G_T_WTR0(x) (((x) >> S_T_WTR0) & M_T_WTR0) + +#define A_MC_UPCTL_TEXSR 0x4010c +#define A_MC_UPCTL_TXP 0x40110 +#define A_MC_UPCTL_TXPDLL 0x40114 +#define A_MC_UPCTL_TZQCS 0x40118 +#define A_MC_UPCTL_TZQCSI 0x4011c +#define A_MC_UPCTL_TDQS 0x40120 +#define A_MC_UPCTL_TCKSRE 0x40124 + +#define S_T_CKSRE0 0 +#define M_T_CKSRE0 0x1fU +#define V_T_CKSRE0(x) ((x) << S_T_CKSRE0) +#define G_T_CKSRE0(x) (((x) >> S_T_CKSRE0) & M_T_CKSRE0) + +#define A_MC_UPCTL_TCKSRX 0x40128 + +#define S_T_CKSRX0 0 +#define M_T_CKSRX0 0x1fU +#define V_T_CKSRX0(x) ((x) << S_T_CKSRX0) +#define G_T_CKSRX0(x) (((x) >> S_T_CKSRX0) & M_T_CKSRX0) + +#define A_MC_UPCTL_TCKE 0x4012c +#define A_MC_UPCTL_TMOD 0x40130 + +#define S_T_MOD0 0 +#define M_T_MOD0 0x1fU +#define V_T_MOD0(x) ((x) << S_T_MOD0) +#define G_T_MOD0(x) (((x) >> S_T_MOD0) & M_T_MOD0) + +#define A_MC_UPCTL_TRSTL 0x40134 + +#define S_T_RSTL 0 +#define M_T_RSTL 0x7fU +#define V_T_RSTL(x) ((x) << S_T_RSTL) +#define G_T_RSTL(x) (((x) >> S_T_RSTL) & M_T_RSTL) + +#define A_MC_UPCTL_TZQCL 0x40138 +#define A_MC_UPCTL_TMRR 0x4013c + +#define S_T_MRR 0 +#define M_T_MRR 0xffU +#define V_T_MRR(x) ((x) << S_T_MRR) +#define G_T_MRR(x) (((x) >> S_T_MRR) & M_T_MRR) + +#define A_MC_UPCTL_TCKESR 0x40140 + +#define S_T_CKESR 0 +#define M_T_CKESR 0xfU +#define V_T_CKESR(x) ((x) << S_T_CKESR) +#define G_T_CKESR(x) (((x) >> S_T_CKESR) & M_T_CKESR) + +#define A_MC_UPCTL_TDPD 0x40144 + +#define S_T_DPD 0 +#define M_T_DPD 0x3ffU +#define V_T_DPD(x) ((x) << S_T_DPD) +#define G_T_DPD(x) (((x) >> S_T_DPD) & M_T_DPD) + +#define A_MC_UPCTL_ECCCFG 0x40180 +#define A_MC_UPCTL_ECCTST 0x40184 + +#define S_ECC_TEST_MASK0 0 +#define M_ECC_TEST_MASK0 0x7fU +#define V_ECC_TEST_MASK0(x) ((x) << S_ECC_TEST_MASK0) +#define G_ECC_TEST_MASK0(x) (((x) >> S_ECC_TEST_MASK0) & M_ECC_TEST_MASK0) + +#define A_MC_UPCTL_ECCCLR 0x40188 +#define A_MC_UPCTL_ECCLOG 0x4018c +#define A_MC_UPCTL_DTUWACTL 0x40200 + +#define S_DTU_WR_ROW0 13 +#define M_DTU_WR_ROW0 0xffffU +#define V_DTU_WR_ROW0(x) ((x) << S_DTU_WR_ROW0) +#define G_DTU_WR_ROW0(x) (((x) >> S_DTU_WR_ROW0) & M_DTU_WR_ROW0) + +#define A_MC_UPCTL_DTURACTL 0x40204 + +#define S_DTU_RD_ROW0 13 +#define M_DTU_RD_ROW0 0xffffU +#define V_DTU_RD_ROW0(x) ((x) << S_DTU_RD_ROW0) +#define G_DTU_RD_ROW0(x) (((x) >> S_DTU_RD_ROW0) & M_DTU_RD_ROW0) + +#define A_MC_UPCTL_DTUCFG 0x40208 +#define A_MC_UPCTL_DTUECTL 0x4020c +#define A_MC_UPCTL_DTUWD0 0x40210 +#define A_MC_UPCTL_DTUWD1 0x40214 +#define A_MC_UPCTL_DTUWD2 0x40218 +#define A_MC_UPCTL_DTUWD3 0x4021c +#define A_MC_UPCTL_DTUWDM 0x40220 +#define A_MC_UPCTL_DTURD0 0x40224 +#define A_MC_UPCTL_DTURD1 0x40228 +#define A_MC_UPCTL_DTURD2 0x4022c +#define A_MC_UPCTL_DTURD3 0x40230 +#define A_MC_UPCTL_DTULFSRWD 0x40234 +#define A_MC_UPCTL_DTULFSRRD 0x40238 +#define A_MC_UPCTL_DTUEAF 0x4023c + +#define S_EA_ROW0 13 +#define M_EA_ROW0 0xffffU +#define V_EA_ROW0(x) ((x) << S_EA_ROW0) +#define G_EA_ROW0(x) (((x) >> S_EA_ROW0) & M_EA_ROW0) + +#define A_MC_UPCTL_DFITCTRLDELAY 0x40240 + +#define S_TCTRL_DELAY 0 +#define M_TCTRL_DELAY 0xfU +#define V_TCTRL_DELAY(x) ((x) << S_TCTRL_DELAY) +#define G_TCTRL_DELAY(x) (((x) >> S_TCTRL_DELAY) & M_TCTRL_DELAY) + +#define A_MC_UPCTL_DFIODTCFG 0x40244 + +#define S_RANK3_ODT_WRITE_NSEL 26 +#define V_RANK3_ODT_WRITE_NSEL(x) ((x) << S_RANK3_ODT_WRITE_NSEL) +#define F_RANK3_ODT_WRITE_NSEL V_RANK3_ODT_WRITE_NSEL(1U) + +#define A_MC_UPCTL_DFIODTCFG1 0x40248 + +#define S_ODT_LEN_B8_R 24 +#define M_ODT_LEN_B8_R 0x7U +#define V_ODT_LEN_B8_R(x) ((x) << S_ODT_LEN_B8_R) +#define G_ODT_LEN_B8_R(x) (((x) >> S_ODT_LEN_B8_R) & M_ODT_LEN_B8_R) + +#define S_ODT_LEN_BL8_W 16 +#define M_ODT_LEN_BL8_W 0x7U +#define V_ODT_LEN_BL8_W(x) ((x) << S_ODT_LEN_BL8_W) +#define G_ODT_LEN_BL8_W(x) (((x) >> S_ODT_LEN_BL8_W) & M_ODT_LEN_BL8_W) + +#define S_ODT_LAT_R 8 +#define M_ODT_LAT_R 0x1fU +#define V_ODT_LAT_R(x) ((x) << S_ODT_LAT_R) +#define G_ODT_LAT_R(x) (((x) >> S_ODT_LAT_R) & M_ODT_LAT_R) + +#define S_ODT_LAT_W 0 +#define M_ODT_LAT_W 0x1fU +#define V_ODT_LAT_W(x) ((x) << S_ODT_LAT_W) +#define G_ODT_LAT_W(x) (((x) >> S_ODT_LAT_W) & M_ODT_LAT_W) + +#define A_MC_UPCTL_DFIODTRANKMAP 0x4024c + +#define S_ODT_RANK_MAP3 12 +#define M_ODT_RANK_MAP3 0xfU +#define V_ODT_RANK_MAP3(x) ((x) << S_ODT_RANK_MAP3) +#define G_ODT_RANK_MAP3(x) (((x) >> S_ODT_RANK_MAP3) & M_ODT_RANK_MAP3) + +#define S_ODT_RANK_MAP2 8 +#define M_ODT_RANK_MAP2 0xfU +#define V_ODT_RANK_MAP2(x) ((x) << S_ODT_RANK_MAP2) +#define G_ODT_RANK_MAP2(x) (((x) >> S_ODT_RANK_MAP2) & M_ODT_RANK_MAP2) + +#define S_ODT_RANK_MAP1 4 +#define M_ODT_RANK_MAP1 0xfU +#define V_ODT_RANK_MAP1(x) ((x) << S_ODT_RANK_MAP1) +#define G_ODT_RANK_MAP1(x) (((x) >> S_ODT_RANK_MAP1) & M_ODT_RANK_MAP1) + +#define S_ODT_RANK_MAP0 0 +#define M_ODT_RANK_MAP0 0xfU +#define V_ODT_RANK_MAP0(x) ((x) << S_ODT_RANK_MAP0) +#define G_ODT_RANK_MAP0(x) (((x) >> S_ODT_RANK_MAP0) & M_ODT_RANK_MAP0) + +#define A_MC_UPCTL_DFITPHYWRDATA 0x40250 + +#define S_TPHY_WRDATA 0 +#define M_TPHY_WRDATA 0x1fU +#define V_TPHY_WRDATA(x) ((x) << S_TPHY_WRDATA) +#define G_TPHY_WRDATA(x) (((x) >> S_TPHY_WRDATA) & M_TPHY_WRDATA) + +#define A_MC_UPCTL_DFITPHYWRLAT 0x40254 + +#define S_TPHY_WRLAT 0 +#define M_TPHY_WRLAT 0x1fU +#define V_TPHY_WRLAT(x) ((x) << S_TPHY_WRLAT) +#define G_TPHY_WRLAT(x) (((x) >> S_TPHY_WRLAT) & M_TPHY_WRLAT) + +#define A_MC_UPCTL_DFITRDDATAEN 0x40260 + +#define S_TRDDATA_EN 0 +#define M_TRDDATA_EN 0x1fU +#define V_TRDDATA_EN(x) ((x) << S_TRDDATA_EN) +#define G_TRDDATA_EN(x) (((x) >> S_TRDDATA_EN) & M_TRDDATA_EN) + +#define A_MC_UPCTL_DFITPHYRDLAT 0x40264 + +#define S_TPHY_RDLAT 0 +#define M_TPHY_RDLAT 0x3fU +#define V_TPHY_RDLAT(x) ((x) << S_TPHY_RDLAT) +#define G_TPHY_RDLAT(x) (((x) >> S_TPHY_RDLAT) & M_TPHY_RDLAT) + +#define A_MC_UPCTL_DFITPHYUPDTYPE0 0x40270 + +#define S_TPHYUPD_TYPE0 0 +#define M_TPHYUPD_TYPE0 0xfffU +#define V_TPHYUPD_TYPE0(x) ((x) << S_TPHYUPD_TYPE0) +#define G_TPHYUPD_TYPE0(x) (((x) >> S_TPHYUPD_TYPE0) & M_TPHYUPD_TYPE0) + +#define A_MC_UPCTL_DFITPHYUPDTYPE1 0x40274 + +#define S_TPHYUPD_TYPE1 0 +#define M_TPHYUPD_TYPE1 0xfffU +#define V_TPHYUPD_TYPE1(x) ((x) << S_TPHYUPD_TYPE1) +#define G_TPHYUPD_TYPE1(x) (((x) >> S_TPHYUPD_TYPE1) & M_TPHYUPD_TYPE1) + +#define A_MC_UPCTL_DFITPHYUPDTYPE2 0x40278 + +#define S_TPHYUPD_TYPE2 0 +#define M_TPHYUPD_TYPE2 0xfffU +#define V_TPHYUPD_TYPE2(x) ((x) << S_TPHYUPD_TYPE2) +#define G_TPHYUPD_TYPE2(x) (((x) >> S_TPHYUPD_TYPE2) & M_TPHYUPD_TYPE2) + +#define A_MC_UPCTL_DFITPHYUPDTYPE3 0x4027c + +#define S_TPHYUPD_TYPE3 0 +#define M_TPHYUPD_TYPE3 0xfffU +#define V_TPHYUPD_TYPE3(x) ((x) << S_TPHYUPD_TYPE3) +#define G_TPHYUPD_TYPE3(x) (((x) >> S_TPHYUPD_TYPE3) & M_TPHYUPD_TYPE3) + +#define A_MC_UPCTL_DFITCTRLUPDMIN 0x40280 + +#define S_TCTRLUPD_MIN 0 +#define M_TCTRLUPD_MIN 0xffffU +#define V_TCTRLUPD_MIN(x) ((x) << S_TCTRLUPD_MIN) +#define G_TCTRLUPD_MIN(x) (((x) >> S_TCTRLUPD_MIN) & M_TCTRLUPD_MIN) + +#define A_MC_UPCTL_DFITCTRLUPDMAX 0x40284 + +#define S_TCTRLUPD_MAX 0 +#define M_TCTRLUPD_MAX 0xffffU +#define V_TCTRLUPD_MAX(x) ((x) << S_TCTRLUPD_MAX) +#define G_TCTRLUPD_MAX(x) (((x) >> S_TCTRLUPD_MAX) & M_TCTRLUPD_MAX) + +#define A_MC_UPCTL_DFITCTRLUPDDLY 0x40288 + +#define S_TCTRLUPD_DLY 0 +#define M_TCTRLUPD_DLY 0xfU +#define V_TCTRLUPD_DLY(x) ((x) << S_TCTRLUPD_DLY) +#define G_TCTRLUPD_DLY(x) (((x) >> S_TCTRLUPD_DLY) & M_TCTRLUPD_DLY) + +#define A_MC_UPCTL_DFIUPDCFG 0x40290 + +#define S_DFI_PHYUPD_EN 1 +#define V_DFI_PHYUPD_EN(x) ((x) << S_DFI_PHYUPD_EN) +#define F_DFI_PHYUPD_EN V_DFI_PHYUPD_EN(1U) + +#define S_DFI_CTRLUPD_EN 0 +#define V_DFI_CTRLUPD_EN(x) ((x) << S_DFI_CTRLUPD_EN) +#define F_DFI_CTRLUPD_EN V_DFI_CTRLUPD_EN(1U) + +#define A_MC_UPCTL_DFITREFMSKI 0x40294 + +#define S_TREFMSKI 0 +#define M_TREFMSKI 0xffU +#define V_TREFMSKI(x) ((x) << S_TREFMSKI) +#define G_TREFMSKI(x) (((x) >> S_TREFMSKI) & M_TREFMSKI) + +#define A_MC_UPCTL_DFITCTRLUPDI 0x40298 +#define A_MC_UPCTL_DFITRCFG0 0x402ac + +#define S_DFI_WRLVL_RANK_SEL 16 +#define M_DFI_WRLVL_RANK_SEL 0xfU +#define V_DFI_WRLVL_RANK_SEL(x) ((x) << S_DFI_WRLVL_RANK_SEL) +#define G_DFI_WRLVL_RANK_SEL(x) (((x) >> S_DFI_WRLVL_RANK_SEL) & M_DFI_WRLVL_RANK_SEL) + +#define S_DFI_RDLVL_EDGE 4 +#define M_DFI_RDLVL_EDGE 0x1ffU +#define V_DFI_RDLVL_EDGE(x) ((x) << S_DFI_RDLVL_EDGE) +#define G_DFI_RDLVL_EDGE(x) (((x) >> S_DFI_RDLVL_EDGE) & M_DFI_RDLVL_EDGE) + +#define S_DFI_RDLVL_RANK_SEL 0 +#define M_DFI_RDLVL_RANK_SEL 0xfU +#define V_DFI_RDLVL_RANK_SEL(x) ((x) << S_DFI_RDLVL_RANK_SEL) +#define G_DFI_RDLVL_RANK_SEL(x) (((x) >> S_DFI_RDLVL_RANK_SEL) & M_DFI_RDLVL_RANK_SEL) + +#define A_MC_UPCTL_DFITRSTAT0 0x402b0 + +#define S_DFI_WRLVL_MODE 16 +#define M_DFI_WRLVL_MODE 0x3U +#define V_DFI_WRLVL_MODE(x) ((x) << S_DFI_WRLVL_MODE) +#define G_DFI_WRLVL_MODE(x) (((x) >> S_DFI_WRLVL_MODE) & M_DFI_WRLVL_MODE) + +#define S_DFI_RDLVL_GATE_MODE 8 +#define M_DFI_RDLVL_GATE_MODE 0x3U +#define V_DFI_RDLVL_GATE_MODE(x) ((x) << S_DFI_RDLVL_GATE_MODE) +#define G_DFI_RDLVL_GATE_MODE(x) (((x) >> S_DFI_RDLVL_GATE_MODE) & M_DFI_RDLVL_GATE_MODE) + +#define S_DFI_RDLVL_MODE 0 +#define M_DFI_RDLVL_MODE 0x3U +#define V_DFI_RDLVL_MODE(x) ((x) << S_DFI_RDLVL_MODE) +#define G_DFI_RDLVL_MODE(x) (((x) >> S_DFI_RDLVL_MODE) & M_DFI_RDLVL_MODE) + +#define A_MC_UPCTL_DFITRWRLVLEN 0x402b4 + +#define S_DFI_WRLVL_EN 0 +#define M_DFI_WRLVL_EN 0x1ffU +#define V_DFI_WRLVL_EN(x) ((x) << S_DFI_WRLVL_EN) +#define G_DFI_WRLVL_EN(x) (((x) >> S_DFI_WRLVL_EN) & M_DFI_WRLVL_EN) + +#define A_MC_UPCTL_DFITRRDLVLEN 0x402b8 + +#define S_DFI_RDLVL_EN 0 +#define M_DFI_RDLVL_EN 0x1ffU +#define V_DFI_RDLVL_EN(x) ((x) << S_DFI_RDLVL_EN) +#define G_DFI_RDLVL_EN(x) (((x) >> S_DFI_RDLVL_EN) & M_DFI_RDLVL_EN) + +#define A_MC_UPCTL_DFITRRDLVLGATEEN 0x402bc + +#define S_DFI_RDLVL_GATE_EN 0 +#define M_DFI_RDLVL_GATE_EN 0x1ffU +#define V_DFI_RDLVL_GATE_EN(x) ((x) << S_DFI_RDLVL_GATE_EN) +#define G_DFI_RDLVL_GATE_EN(x) (((x) >> S_DFI_RDLVL_GATE_EN) & M_DFI_RDLVL_GATE_EN) + +#define A_MC_UPCTL_DFISTSTAT0 0x402c0 + +#define S_DFI_DATA_BYTE_DISABLE 16 +#define M_DFI_DATA_BYTE_DISABLE 0x1ffU +#define V_DFI_DATA_BYTE_DISABLE(x) ((x) << S_DFI_DATA_BYTE_DISABLE) +#define G_DFI_DATA_BYTE_DISABLE(x) (((x) >> S_DFI_DATA_BYTE_DISABLE) & M_DFI_DATA_BYTE_DISABLE) + +#define S_DFI_FREQ_RATIO 4 +#define M_DFI_FREQ_RATIO 0x3U +#define V_DFI_FREQ_RATIO(x) ((x) << S_DFI_FREQ_RATIO) +#define G_DFI_FREQ_RATIO(x) (((x) >> S_DFI_FREQ_RATIO) & M_DFI_FREQ_RATIO) + +#define S_DFI_INIT_START0 1 +#define V_DFI_INIT_START0(x) ((x) << S_DFI_INIT_START0) +#define F_DFI_INIT_START0 V_DFI_INIT_START0(1U) + +#define S_DFI_INIT_COMPLETE 0 +#define V_DFI_INIT_COMPLETE(x) ((x) << S_DFI_INIT_COMPLETE) +#define F_DFI_INIT_COMPLETE V_DFI_INIT_COMPLETE(1U) + +#define A_MC_UPCTL_DFISTCFG0 0x402c4 + +#define S_DFI_DATA_BYTE_DISABLE_EN 2 +#define V_DFI_DATA_BYTE_DISABLE_EN(x) ((x) << S_DFI_DATA_BYTE_DISABLE_EN) +#define F_DFI_DATA_BYTE_DISABLE_EN V_DFI_DATA_BYTE_DISABLE_EN(1U) + +#define S_DFI_FREQ_RATIO_EN 1 +#define V_DFI_FREQ_RATIO_EN(x) ((x) << S_DFI_FREQ_RATIO_EN) +#define F_DFI_FREQ_RATIO_EN V_DFI_FREQ_RATIO_EN(1U) + +#define S_DFI_INIT_START 0 +#define V_DFI_INIT_START(x) ((x) << S_DFI_INIT_START) +#define F_DFI_INIT_START V_DFI_INIT_START(1U) + +#define A_MC_UPCTL_DFISTCFG1 0x402c8 + +#define S_DFI_DRAM_CLK_DISABLE_EN_DPD 1 +#define V_DFI_DRAM_CLK_DISABLE_EN_DPD(x) ((x) << S_DFI_DRAM_CLK_DISABLE_EN_DPD) +#define F_DFI_DRAM_CLK_DISABLE_EN_DPD V_DFI_DRAM_CLK_DISABLE_EN_DPD(1U) + +#define S_DFI_DRAM_CLK_DISABLE_EN 0 +#define V_DFI_DRAM_CLK_DISABLE_EN(x) ((x) << S_DFI_DRAM_CLK_DISABLE_EN) +#define F_DFI_DRAM_CLK_DISABLE_EN V_DFI_DRAM_CLK_DISABLE_EN(1U) + +#define A_MC_UPCTL_DFITDRAMCLKEN 0x402d0 + +#define S_TDRAM_CLK_ENABLE 0 +#define M_TDRAM_CLK_ENABLE 0xfU +#define V_TDRAM_CLK_ENABLE(x) ((x) << S_TDRAM_CLK_ENABLE) +#define G_TDRAM_CLK_ENABLE(x) (((x) >> S_TDRAM_CLK_ENABLE) & M_TDRAM_CLK_ENABLE) + +#define A_MC_UPCTL_DFITDRAMCLKDIS 0x402d4 + +#define S_TDRAM_CLK_DISABLE 0 +#define M_TDRAM_CLK_DISABLE 0xfU +#define V_TDRAM_CLK_DISABLE(x) ((x) << S_TDRAM_CLK_DISABLE) +#define G_TDRAM_CLK_DISABLE(x) (((x) >> S_TDRAM_CLK_DISABLE) & M_TDRAM_CLK_DISABLE) + +#define A_MC_UPCTL_DFISTCFG2 0x402d8 + +#define S_PARITY_EN 1 +#define V_PARITY_EN(x) ((x) << S_PARITY_EN) +#define F_PARITY_EN V_PARITY_EN(1U) + +#define S_PARITY_INTR_EN 0 +#define V_PARITY_INTR_EN(x) ((x) << S_PARITY_INTR_EN) +#define F_PARITY_INTR_EN V_PARITY_INTR_EN(1U) + +#define A_MC_UPCTL_DFISTPARCLR 0x402dc + +#define S_PARITY_LOG_CLR 1 +#define V_PARITY_LOG_CLR(x) ((x) << S_PARITY_LOG_CLR) +#define F_PARITY_LOG_CLR V_PARITY_LOG_CLR(1U) + +#define S_PARITY_INTR_CLR 0 +#define V_PARITY_INTR_CLR(x) ((x) << S_PARITY_INTR_CLR) +#define F_PARITY_INTR_CLR V_PARITY_INTR_CLR(1U) + +#define A_MC_UPCTL_DFISTPARLOG 0x402e0 +#define A_MC_UPCTL_DFILPCFG0 0x402f0 + +#define S_DFI_LP_WAKEUP_DPD 28 +#define M_DFI_LP_WAKEUP_DPD 0xfU +#define V_DFI_LP_WAKEUP_DPD(x) ((x) << S_DFI_LP_WAKEUP_DPD) +#define G_DFI_LP_WAKEUP_DPD(x) (((x) >> S_DFI_LP_WAKEUP_DPD) & M_DFI_LP_WAKEUP_DPD) + +#define S_DFI_LP_EN_DPD 24 +#define V_DFI_LP_EN_DPD(x) ((x) << S_DFI_LP_EN_DPD) +#define F_DFI_LP_EN_DPD V_DFI_LP_EN_DPD(1U) + +#define S_DFI_TLP_RESP 16 +#define M_DFI_TLP_RESP 0xfU +#define V_DFI_TLP_RESP(x) ((x) << S_DFI_TLP_RESP) +#define G_DFI_TLP_RESP(x) (((x) >> S_DFI_TLP_RESP) & M_DFI_TLP_RESP) + +#define S_DFI_LP_EN_SR 8 +#define V_DFI_LP_EN_SR(x) ((x) << S_DFI_LP_EN_SR) +#define F_DFI_LP_EN_SR V_DFI_LP_EN_SR(1U) + +#define S_DFI_LP_WAKEUP_PD 4 +#define M_DFI_LP_WAKEUP_PD 0xfU +#define V_DFI_LP_WAKEUP_PD(x) ((x) << S_DFI_LP_WAKEUP_PD) +#define G_DFI_LP_WAKEUP_PD(x) (((x) >> S_DFI_LP_WAKEUP_PD) & M_DFI_LP_WAKEUP_PD) + +#define S_DFI_LP_EN_PD 0 +#define V_DFI_LP_EN_PD(x) ((x) << S_DFI_LP_EN_PD) +#define F_DFI_LP_EN_PD V_DFI_LP_EN_PD(1U) + +#define A_MC_UPCTL_DFITRWRLVLRESP0 0x40300 +#define A_MC_UPCTL_DFITRWRLVLRESP1 0x40304 +#define A_MC_UPCTL_DFITRWRLVLRESP2 0x40308 + +#define S_DFI_WRLVL_RESP2 0 +#define M_DFI_WRLVL_RESP2 0xffU +#define V_DFI_WRLVL_RESP2(x) ((x) << S_DFI_WRLVL_RESP2) +#define G_DFI_WRLVL_RESP2(x) (((x) >> S_DFI_WRLVL_RESP2) & M_DFI_WRLVL_RESP2) + +#define A_MC_UPCTL_DFITRRDLVLRESP0 0x4030c +#define A_MC_UPCTL_DFITRRDLVLRESP1 0x40310 +#define A_MC_UPCTL_DFITRRDLVLRESP2 0x40314 + +#define S_DFI_RDLVL_RESP2 0 +#define M_DFI_RDLVL_RESP2 0xffU +#define V_DFI_RDLVL_RESP2(x) ((x) << S_DFI_RDLVL_RESP2) +#define G_DFI_RDLVL_RESP2(x) (((x) >> S_DFI_RDLVL_RESP2) & M_DFI_RDLVL_RESP2) + +#define A_MC_UPCTL_DFITRWRLVLDELAY0 0x40318 +#define A_MC_UPCTL_DFITRWRLVLDELAY1 0x4031c +#define A_MC_UPCTL_DFITRWRLVLDELAY2 0x40320 + +#define S_DFI_WRLVL_DELAY2 0 +#define M_DFI_WRLVL_DELAY2 0xffU +#define V_DFI_WRLVL_DELAY2(x) ((x) << S_DFI_WRLVL_DELAY2) +#define G_DFI_WRLVL_DELAY2(x) (((x) >> S_DFI_WRLVL_DELAY2) & M_DFI_WRLVL_DELAY2) + +#define A_MC_UPCTL_DFITRRDLVLDELAY0 0x40324 +#define A_MC_UPCTL_DFITRRDLVLDELAY1 0x40328 +#define A_MC_UPCTL_DFITRRDLVLDELAY2 0x4032c + +#define S_DFI_RDLVL_DELAY2 0 +#define M_DFI_RDLVL_DELAY2 0xffU +#define V_DFI_RDLVL_DELAY2(x) ((x) << S_DFI_RDLVL_DELAY2) +#define G_DFI_RDLVL_DELAY2(x) (((x) >> S_DFI_RDLVL_DELAY2) & M_DFI_RDLVL_DELAY2) + +#define A_MC_UPCTL_DFITRRDLVLGATEDELAY0 0x40330 +#define A_MC_UPCTL_DFITRRDLVLGATEDELAY1 0x40334 +#define A_MC_UPCTL_DFITRRDLVLGATEDELAY2 0x40338 + +#define S_DFI_RDLVL_GATE_DELAY2 0 +#define M_DFI_RDLVL_GATE_DELAY2 0xffU +#define V_DFI_RDLVL_GATE_DELAY2(x) ((x) << S_DFI_RDLVL_GATE_DELAY2) +#define G_DFI_RDLVL_GATE_DELAY2(x) (((x) >> S_DFI_RDLVL_GATE_DELAY2) & M_DFI_RDLVL_GATE_DELAY2) + +#define A_MC_UPCTL_DFITRCMD 0x4033c + +#define S_DFITRCMD_START 31 +#define V_DFITRCMD_START(x) ((x) << S_DFITRCMD_START) +#define F_DFITRCMD_START V_DFITRCMD_START(1U) + +#define S_DFITRCMD_EN 4 +#define M_DFITRCMD_EN 0x1ffU +#define V_DFITRCMD_EN(x) ((x) << S_DFITRCMD_EN) +#define G_DFITRCMD_EN(x) (((x) >> S_DFITRCMD_EN) & M_DFITRCMD_EN) + +#define S_DFITRCMD_OPCODE 0 +#define M_DFITRCMD_OPCODE 0x3U +#define V_DFITRCMD_OPCODE(x) ((x) << S_DFITRCMD_OPCODE) +#define G_DFITRCMD_OPCODE(x) (((x) >> S_DFITRCMD_OPCODE) & M_DFITRCMD_OPCODE) + +#define A_MC_UPCTL_IPVR 0x403f8 +#define A_MC_UPCTL_IPTR 0x403fc +#define A_MC_P_DDRPHY_RST_CTRL 0x41300 + +#define S_PHY_DRAM_WL 17 +#define M_PHY_DRAM_WL 0x1fU +#define V_PHY_DRAM_WL(x) ((x) << S_PHY_DRAM_WL) +#define G_PHY_DRAM_WL(x) (((x) >> S_PHY_DRAM_WL) & M_PHY_DRAM_WL) + +#define S_PHY_CALIB_DONE 5 +#define V_PHY_CALIB_DONE(x) ((x) << S_PHY_CALIB_DONE) +#define F_PHY_CALIB_DONE V_PHY_CALIB_DONE(1U) + +#define S_CTL_CAL_REQ 4 +#define V_CTL_CAL_REQ(x) ((x) << S_CTL_CAL_REQ) +#define F_CTL_CAL_REQ V_CTL_CAL_REQ(1U) + +#define S_CTL_CKE 3 +#define V_CTL_CKE(x) ((x) << S_CTL_CKE) +#define F_CTL_CKE V_CTL_CKE(1U) + +#define S_CTL_RST_N 2 +#define V_CTL_RST_N(x) ((x) << S_CTL_RST_N) +#define F_CTL_RST_N V_CTL_RST_N(1U) + +#define A_MC_P_PERFORMANCE_CTRL 0x41304 +#define A_MC_P_ECC_CTRL 0x41308 +#define A_MC_P_PAR_ENABLE 0x4130c +#define A_MC_P_PAR_CAUSE 0x41310 +#define A_MC_P_INT_ENABLE 0x41314 +#define A_MC_P_INT_CAUSE 0x41318 +#define A_MC_P_ECC_STATUS 0x4131c +#define A_MC_P_PHY_CTRL 0x41320 +#define A_MC_P_STATIC_CFG_STATUS 0x41324 + +#define S_STATIC_AWEN 23 +#define V_STATIC_AWEN(x) ((x) << S_STATIC_AWEN) +#define F_STATIC_AWEN V_STATIC_AWEN(1U) + +#define S_STATIC_SWLAT 18 +#define M_STATIC_SWLAT 0x1fU +#define V_STATIC_SWLAT(x) ((x) << S_STATIC_SWLAT) +#define G_STATIC_SWLAT(x) (((x) >> S_STATIC_SWLAT) & M_STATIC_SWLAT) + +#define S_STATIC_WLAT 17 +#define V_STATIC_WLAT(x) ((x) << S_STATIC_WLAT) +#define F_STATIC_WLAT V_STATIC_WLAT(1U) + +#define S_STATIC_ALIGN 16 +#define V_STATIC_ALIGN(x) ((x) << S_STATIC_ALIGN) +#define F_STATIC_ALIGN V_STATIC_ALIGN(1U) + +#define S_STATIC_SLAT 11 +#define M_STATIC_SLAT 0x1fU +#define V_STATIC_SLAT(x) ((x) << S_STATIC_SLAT) +#define G_STATIC_SLAT(x) (((x) >> S_STATIC_SLAT) & M_STATIC_SLAT) + +#define S_STATIC_LAT 10 +#define V_STATIC_LAT(x) ((x) << S_STATIC_LAT) +#define F_STATIC_LAT V_STATIC_LAT(1U) + +#define A_MC_P_CORE_PCTL_STAT 0x41328 +#define A_MC_P_DEBUG_CNT 0x4132c +#define A_MC_CE_ERR_DATA_RDATA 0x41330 +#define A_MC_CE_COR_DATA_RDATA 0x41350 +#define A_MC_UE_ERR_DATA_RDATA 0x41370 +#define A_MC_UE_COR_DATA_RDATA 0x41390 +#define A_MC_CE_ADDR 0x413b0 +#define A_MC_UE_ADDR 0x413b4 +#define A_MC_P_DEEP_SLEEP 0x413b8 + +#define S_SLEEPSTATUS 1 +#define V_SLEEPSTATUS(x) ((x) << S_SLEEPSTATUS) +#define F_SLEEPSTATUS V_SLEEPSTATUS(1U) + +#define S_SLEEPREQ 0 +#define V_SLEEPREQ(x) ((x) << S_SLEEPREQ) +#define F_SLEEPREQ V_SLEEPREQ(1U) + +#define A_MC_P_FPGA_BONUS 0x413bc +#define A_MC_P_DEBUG_CFG 0x413c0 +#define A_MC_P_DEBUG_RPT 0x413c4 +#define A_MC_P_BIST_CMD 0x41400 + +#define S_BURST_LEN 16 +#define M_BURST_LEN 0x3U +#define V_BURST_LEN(x) ((x) << S_BURST_LEN) +#define G_BURST_LEN(x) (((x) >> S_BURST_LEN) & M_BURST_LEN) + +#define A_MC_P_BIST_CMD_ADDR 0x41404 +#define A_MC_P_BIST_CMD_LEN 0x41408 +#define A_MC_P_BIST_DATA_PATTERN 0x4140c +#define A_MC_P_BIST_USER_WDATA0 0x41414 +#define A_MC_P_BIST_USER_WDATA1 0x41418 +#define A_MC_P_BIST_USER_WDATA2 0x4141c + +#define S_USER_DATA_MASK 8 +#define M_USER_DATA_MASK 0x1ffU +#define V_USER_DATA_MASK(x) ((x) << S_USER_DATA_MASK) +#define G_USER_DATA_MASK(x) (((x) >> S_USER_DATA_MASK) & M_USER_DATA_MASK) + +#define A_MC_P_BIST_NUM_ERR 0x41480 +#define A_MC_P_BIST_ERR_FIRST_ADDR 0x41484 +#define A_MC_P_BIST_STATUS_RDATA 0x41488 +#define A_MC_P_BIST_CRC_SEED 0x414d0 +#define A_MC_DDRPHY_DP18_DATA_BIT_ENABLE0 0x44000 + +#define S_DATA_BIT_ENABLE_0_15 0 +#define M_DATA_BIT_ENABLE_0_15 0xffffU +#define V_DATA_BIT_ENABLE_0_15(x) ((x) << S_DATA_BIT_ENABLE_0_15) +#define G_DATA_BIT_ENABLE_0_15(x) (((x) >> S_DATA_BIT_ENABLE_0_15) & M_DATA_BIT_ENABLE_0_15) + +#define A_MC_DDRPHY_DP18_DATA_BIT_ENABLE1 0x44004 + +#define S_DATA_BIT_ENABLE_16_23 8 +#define M_DATA_BIT_ENABLE_16_23 0xffU +#define V_DATA_BIT_ENABLE_16_23(x) ((x) << S_DATA_BIT_ENABLE_16_23) +#define G_DATA_BIT_ENABLE_16_23(x) (((x) >> S_DATA_BIT_ENABLE_16_23) & M_DATA_BIT_ENABLE_16_23) + +#define S_DFT_FORCE_OUTPUTS 7 +#define V_DFT_FORCE_OUTPUTS(x) ((x) << S_DFT_FORCE_OUTPUTS) +#define F_DFT_FORCE_OUTPUTS V_DFT_FORCE_OUTPUTS(1U) + +#define S_DFT_PRBS7_GEN_EN 6 +#define V_DFT_PRBS7_GEN_EN(x) ((x) << S_DFT_PRBS7_GEN_EN) +#define F_DFT_PRBS7_GEN_EN V_DFT_PRBS7_GEN_EN(1U) + +#define S_WRAPSEL 5 +#define V_WRAPSEL(x) ((x) << S_WRAPSEL) +#define F_WRAPSEL V_WRAPSEL(1U) + +#define S_MRS_CMD_DATA_N0 3 +#define V_MRS_CMD_DATA_N0(x) ((x) << S_MRS_CMD_DATA_N0) +#define F_MRS_CMD_DATA_N0 V_MRS_CMD_DATA_N0(1U) + +#define S_MRS_CMD_DATA_N1 2 +#define V_MRS_CMD_DATA_N1(x) ((x) << S_MRS_CMD_DATA_N1) +#define F_MRS_CMD_DATA_N1 V_MRS_CMD_DATA_N1(1U) + +#define S_MRS_CMD_DATA_N2 1 +#define V_MRS_CMD_DATA_N2(x) ((x) << S_MRS_CMD_DATA_N2) +#define F_MRS_CMD_DATA_N2 V_MRS_CMD_DATA_N2(1U) + +#define S_MRS_CMD_DATA_N3 0 +#define V_MRS_CMD_DATA_N3(x) ((x) << S_MRS_CMD_DATA_N3) +#define F_MRS_CMD_DATA_N3 V_MRS_CMD_DATA_N3(1U) + +#define A_MC_DDRPHY_DP18_DATA_BIT_DIR0 0x44008 + +#define S_DATA_BIT_DIR_0_15 0 +#define M_DATA_BIT_DIR_0_15 0xffffU +#define V_DATA_BIT_DIR_0_15(x) ((x) << S_DATA_BIT_DIR_0_15) +#define G_DATA_BIT_DIR_0_15(x) (((x) >> S_DATA_BIT_DIR_0_15) & M_DATA_BIT_DIR_0_15) + +#define A_MC_DDRPHY_DP18_DATA_BIT_DIR1 0x4400c + +#define S_DATA_BIT_DIR_16_23 8 +#define M_DATA_BIT_DIR_16_23 0xffU +#define V_DATA_BIT_DIR_16_23(x) ((x) << S_DATA_BIT_DIR_16_23) +#define G_DATA_BIT_DIR_16_23(x) (((x) >> S_DATA_BIT_DIR_16_23) & M_DATA_BIT_DIR_16_23) + +#define S_WL_ADVANCE_DISABLE 7 +#define V_WL_ADVANCE_DISABLE(x) ((x) << S_WL_ADVANCE_DISABLE) +#define F_WL_ADVANCE_DISABLE V_WL_ADVANCE_DISABLE(1U) + +#define S_DISABLE_PING_PONG 6 +#define V_DISABLE_PING_PONG(x) ((x) << S_DISABLE_PING_PONG) +#define F_DISABLE_PING_PONG V_DISABLE_PING_PONG(1U) + +#define S_DELAY_PING_PONG_HALF 5 +#define V_DELAY_PING_PONG_HALF(x) ((x) << S_DELAY_PING_PONG_HALF) +#define F_DELAY_PING_PONG_HALF V_DELAY_PING_PONG_HALF(1U) + +#define S_ADVANCE_PING_PONG 4 +#define V_ADVANCE_PING_PONG(x) ((x) << S_ADVANCE_PING_PONG) +#define F_ADVANCE_PING_PONG V_ADVANCE_PING_PONG(1U) + +#define S_ATEST_MUX_CTL0 3 +#define V_ATEST_MUX_CTL0(x) ((x) << S_ATEST_MUX_CTL0) +#define F_ATEST_MUX_CTL0 V_ATEST_MUX_CTL0(1U) + +#define S_ATEST_MUX_CTL1 2 +#define V_ATEST_MUX_CTL1(x) ((x) << S_ATEST_MUX_CTL1) +#define F_ATEST_MUX_CTL1 V_ATEST_MUX_CTL1(1U) + +#define S_ATEST_MUX_CTL2 1 +#define V_ATEST_MUX_CTL2(x) ((x) << S_ATEST_MUX_CTL2) +#define F_ATEST_MUX_CTL2 V_ATEST_MUX_CTL2(1U) + +#define S_ATEST_MUX_CTL3 0 +#define V_ATEST_MUX_CTL3(x) ((x) << S_ATEST_MUX_CTL3) +#define F_ATEST_MUX_CTL3 V_ATEST_MUX_CTL3(1U) + +#define A_MC_DDRPHY_DP18_READ_CLOCK_RANK_PAIR 0x44010 + +#define S_QUAD0_CLK16_BIT0 15 +#define V_QUAD0_CLK16_BIT0(x) ((x) << S_QUAD0_CLK16_BIT0) +#define F_QUAD0_CLK16_BIT0 V_QUAD0_CLK16_BIT0(1U) + +#define S_QUAD1_CLK16_BIT1 14 +#define V_QUAD1_CLK16_BIT1(x) ((x) << S_QUAD1_CLK16_BIT1) +#define F_QUAD1_CLK16_BIT1 V_QUAD1_CLK16_BIT1(1U) + +#define S_QUAD2_CLK16_BIT2 13 +#define V_QUAD2_CLK16_BIT2(x) ((x) << S_QUAD2_CLK16_BIT2) +#define F_QUAD2_CLK16_BIT2 V_QUAD2_CLK16_BIT2(1U) + +#define S_QUAD3_CLK16_BIT3 12 +#define V_QUAD3_CLK16_BIT3(x) ((x) << S_QUAD3_CLK16_BIT3) +#define F_QUAD3_CLK16_BIT3 V_QUAD3_CLK16_BIT3(1U) + +#define S_QUAD0_CLK18_BIT4 11 +#define V_QUAD0_CLK18_BIT4(x) ((x) << S_QUAD0_CLK18_BIT4) +#define F_QUAD0_CLK18_BIT4 V_QUAD0_CLK18_BIT4(1U) + +#define S_QUAD1_CLK18_BIT5 10 +#define V_QUAD1_CLK18_BIT5(x) ((x) << S_QUAD1_CLK18_BIT5) +#define F_QUAD1_CLK18_BIT5 V_QUAD1_CLK18_BIT5(1U) + +#define S_QUAD2_CLK20_BIT6 9 +#define V_QUAD2_CLK20_BIT6(x) ((x) << S_QUAD2_CLK20_BIT6) +#define F_QUAD2_CLK20_BIT6 V_QUAD2_CLK20_BIT6(1U) + +#define S_QUAD3_CLK20_BIT7 8 +#define V_QUAD3_CLK20_BIT7(x) ((x) << S_QUAD3_CLK20_BIT7) +#define F_QUAD3_CLK20_BIT7 V_QUAD3_CLK20_BIT7(1U) + +#define S_QUAD2_CLK22_BIT8 7 +#define V_QUAD2_CLK22_BIT8(x) ((x) << S_QUAD2_CLK22_BIT8) +#define F_QUAD2_CLK22_BIT8 V_QUAD2_CLK22_BIT8(1U) + +#define S_QUAD3_CLK22_BIT9 6 +#define V_QUAD3_CLK22_BIT9(x) ((x) << S_QUAD3_CLK22_BIT9) +#define F_QUAD3_CLK22_BIT9 V_QUAD3_CLK22_BIT9(1U) + +#define S_CLK16_SINGLE_ENDED_BIT10 5 +#define V_CLK16_SINGLE_ENDED_BIT10(x) ((x) << S_CLK16_SINGLE_ENDED_BIT10) +#define F_CLK16_SINGLE_ENDED_BIT10 V_CLK16_SINGLE_ENDED_BIT10(1U) + +#define S_CLK18_SINGLE_ENDED_BIT11 4 +#define V_CLK18_SINGLE_ENDED_BIT11(x) ((x) << S_CLK18_SINGLE_ENDED_BIT11) +#define F_CLK18_SINGLE_ENDED_BIT11 V_CLK18_SINGLE_ENDED_BIT11(1U) + +#define S_CLK20_SINGLE_ENDED_BIT12 3 +#define V_CLK20_SINGLE_ENDED_BIT12(x) ((x) << S_CLK20_SINGLE_ENDED_BIT12) +#define F_CLK20_SINGLE_ENDED_BIT12 V_CLK20_SINGLE_ENDED_BIT12(1U) + +#define S_CLK22_SINGLE_ENDED_BIT13 2 +#define V_CLK22_SINGLE_ENDED_BIT13(x) ((x) << S_CLK22_SINGLE_ENDED_BIT13) +#define F_CLK22_SINGLE_ENDED_BIT13 V_CLK22_SINGLE_ENDED_BIT13(1U) + +#define A_MC_DDRPHY_DP18_WRCLK_EN_RP 0x44014 + +#define S_QUAD2_CLK18_BIT14 1 +#define V_QUAD2_CLK18_BIT14(x) ((x) << S_QUAD2_CLK18_BIT14) +#define F_QUAD2_CLK18_BIT14 V_QUAD2_CLK18_BIT14(1U) + +#define S_QUAD3_CLK18_BIT15 0 +#define V_QUAD3_CLK18_BIT15(x) ((x) << S_QUAD3_CLK18_BIT15) +#define F_QUAD3_CLK18_BIT15 V_QUAD3_CLK18_BIT15(1U) + +#define A_MC_DDRPHY_DP18_RX_PEAK_AMP 0x44018 + +#define S_PEAK_AMP_CTL_SIDE0 13 +#define M_PEAK_AMP_CTL_SIDE0 0x7U +#define V_PEAK_AMP_CTL_SIDE0(x) ((x) << S_PEAK_AMP_CTL_SIDE0) +#define G_PEAK_AMP_CTL_SIDE0(x) (((x) >> S_PEAK_AMP_CTL_SIDE0) & M_PEAK_AMP_CTL_SIDE0) + +#define S_PEAK_AMP_CTL_SIDE1 9 +#define M_PEAK_AMP_CTL_SIDE1 0x7U +#define V_PEAK_AMP_CTL_SIDE1(x) ((x) << S_PEAK_AMP_CTL_SIDE1) +#define G_PEAK_AMP_CTL_SIDE1(x) (((x) >> S_PEAK_AMP_CTL_SIDE1) & M_PEAK_AMP_CTL_SIDE1) + +#define S_SXMCVREF_0_3 4 +#define M_SXMCVREF_0_3 0xfU +#define V_SXMCVREF_0_3(x) ((x) << S_SXMCVREF_0_3) +#define G_SXMCVREF_0_3(x) (((x) >> S_SXMCVREF_0_3) & M_SXMCVREF_0_3) + +#define S_SXPODVREF 3 +#define V_SXPODVREF(x) ((x) << S_SXPODVREF) +#define F_SXPODVREF V_SXPODVREF(1U) + +#define S_DISABLE_TERMINATION 2 +#define V_DISABLE_TERMINATION(x) ((x) << S_DISABLE_TERMINATION) +#define F_DISABLE_TERMINATION V_DISABLE_TERMINATION(1U) + +#define S_READ_CENTERING_MODE 0 +#define M_READ_CENTERING_MODE 0x3U +#define V_READ_CENTERING_MODE(x) ((x) << S_READ_CENTERING_MODE) +#define G_READ_CENTERING_MODE(x) (((x) >> S_READ_CENTERING_MODE) & M_READ_CENTERING_MODE) + +#define A_MC_DDRPHY_DP18_SYSCLK_PR 0x4401c + +#define S_SYSCLK_PHASE_ALIGN_RESET 6 +#define V_SYSCLK_PHASE_ALIGN_RESET(x) ((x) << S_SYSCLK_PHASE_ALIGN_RESET) +#define F_SYSCLK_PHASE_ALIGN_RESET V_SYSCLK_PHASE_ALIGN_RESET(1U) + +#define A_MC_DDRPHY_DP18_DFT_DIG_EYE 0x44020 + +#define S_DIGITAL_EYE_EN 15 +#define V_DIGITAL_EYE_EN(x) ((x) << S_DIGITAL_EYE_EN) +#define F_DIGITAL_EYE_EN V_DIGITAL_EYE_EN(1U) + +#define S_BUMP 14 +#define V_BUMP(x) ((x) << S_BUMP) +#define F_BUMP V_BUMP(1U) + +#define S_TRIG_PERIOD 13 +#define V_TRIG_PERIOD(x) ((x) << S_TRIG_PERIOD) +#define F_TRIG_PERIOD V_TRIG_PERIOD(1U) + +#define S_CNTL_POL 12 +#define V_CNTL_POL(x) ((x) << S_CNTL_POL) +#define F_CNTL_POL V_CNTL_POL(1U) + +#define S_CNTL_SRC 8 +#define V_CNTL_SRC(x) ((x) << S_CNTL_SRC) +#define F_CNTL_SRC V_CNTL_SRC(1U) + +#define S_DIGITAL_EYE_VALUE 0 +#define M_DIGITAL_EYE_VALUE 0xffU +#define V_DIGITAL_EYE_VALUE(x) ((x) << S_DIGITAL_EYE_VALUE) +#define G_DIGITAL_EYE_VALUE(x) (((x) >> S_DIGITAL_EYE_VALUE) & M_DIGITAL_EYE_VALUE) + +#define A_MC_DDRPHY_DP18_DQS_RD_PHASE_SELECT_RANK_PAIR 0x44024 + +#define S_DQSCLK_SELECT0 14 +#define M_DQSCLK_SELECT0 0x3U +#define V_DQSCLK_SELECT0(x) ((x) << S_DQSCLK_SELECT0) +#define G_DQSCLK_SELECT0(x) (((x) >> S_DQSCLK_SELECT0) & M_DQSCLK_SELECT0) + +#define S_RDCLK_SELECT0 12 +#define M_RDCLK_SELECT0 0x3U +#define V_RDCLK_SELECT0(x) ((x) << S_RDCLK_SELECT0) +#define G_RDCLK_SELECT0(x) (((x) >> S_RDCLK_SELECT0) & M_RDCLK_SELECT0) + +#define S_DQSCLK_SELECT1 10 +#define M_DQSCLK_SELECT1 0x3U +#define V_DQSCLK_SELECT1(x) ((x) << S_DQSCLK_SELECT1) +#define G_DQSCLK_SELECT1(x) (((x) >> S_DQSCLK_SELECT1) & M_DQSCLK_SELECT1) + +#define S_RDCLK_SELECT1 8 +#define M_RDCLK_SELECT1 0x3U +#define V_RDCLK_SELECT1(x) ((x) << S_RDCLK_SELECT1) +#define G_RDCLK_SELECT1(x) (((x) >> S_RDCLK_SELECT1) & M_RDCLK_SELECT1) + +#define S_DQSCLK_SELECT2 6 +#define M_DQSCLK_SELECT2 0x3U +#define V_DQSCLK_SELECT2(x) ((x) << S_DQSCLK_SELECT2) +#define G_DQSCLK_SELECT2(x) (((x) >> S_DQSCLK_SELECT2) & M_DQSCLK_SELECT2) + +#define S_RDCLK_SELECT2 4 +#define M_RDCLK_SELECT2 0x3U +#define V_RDCLK_SELECT2(x) ((x) << S_RDCLK_SELECT2) +#define G_RDCLK_SELECT2(x) (((x) >> S_RDCLK_SELECT2) & M_RDCLK_SELECT2) + +#define S_DQSCLK_SELECT3 2 +#define M_DQSCLK_SELECT3 0x3U +#define V_DQSCLK_SELECT3(x) ((x) << S_DQSCLK_SELECT3) +#define G_DQSCLK_SELECT3(x) (((x) >> S_DQSCLK_SELECT3) & M_DQSCLK_SELECT3) + +#define S_RDCLK_SELECT3 0 +#define M_RDCLK_SELECT3 0x3U +#define V_RDCLK_SELECT3(x) ((x) << S_RDCLK_SELECT3) +#define G_RDCLK_SELECT3(x) (((x) >> S_RDCLK_SELECT3) & M_RDCLK_SELECT3) + +#define A_MC_DDRPHY_DP18_DRIFT_LIMITS 0x44028 + +#define S_MIN_RD_EYE_SIZE 8 +#define M_MIN_RD_EYE_SIZE 0x3fU +#define V_MIN_RD_EYE_SIZE(x) ((x) << S_MIN_RD_EYE_SIZE) +#define G_MIN_RD_EYE_SIZE(x) (((x) >> S_MIN_RD_EYE_SIZE) & M_MIN_RD_EYE_SIZE) + +#define S_MAX_DQS_DRIFT 0 +#define M_MAX_DQS_DRIFT 0x3fU +#define V_MAX_DQS_DRIFT(x) ((x) << S_MAX_DQS_DRIFT) +#define G_MAX_DQS_DRIFT(x) (((x) >> S_MAX_DQS_DRIFT) & M_MAX_DQS_DRIFT) + +#define A_MC_DDRPHY_DP18_DEBUG_SEL 0x4402c + +#define S_HS_PROBE_A_SEL 11 +#define M_HS_PROBE_A_SEL 0x1fU +#define V_HS_PROBE_A_SEL(x) ((x) << S_HS_PROBE_A_SEL) +#define G_HS_PROBE_A_SEL(x) (((x) >> S_HS_PROBE_A_SEL) & M_HS_PROBE_A_SEL) + +#define S_HS_PROBE_B_SEL 6 +#define M_HS_PROBE_B_SEL 0x1fU +#define V_HS_PROBE_B_SEL(x) ((x) << S_HS_PROBE_B_SEL) +#define G_HS_PROBE_B_SEL(x) (((x) >> S_HS_PROBE_B_SEL) & M_HS_PROBE_B_SEL) + +#define S_RD_DEBUG_SEL 3 +#define M_RD_DEBUG_SEL 0x7U +#define V_RD_DEBUG_SEL(x) ((x) << S_RD_DEBUG_SEL) +#define G_RD_DEBUG_SEL(x) (((x) >> S_RD_DEBUG_SEL) & M_RD_DEBUG_SEL) + +#define S_WR_DEBUG_SEL 0 +#define M_WR_DEBUG_SEL 0x7U +#define V_WR_DEBUG_SEL(x) ((x) << S_WR_DEBUG_SEL) +#define G_WR_DEBUG_SEL(x) (((x) >> S_WR_DEBUG_SEL) & M_WR_DEBUG_SEL) + +#define A_MC_DDRPHY_DP18_READ_DELAY_OFFSET0_RANK_PAIR 0x44030 + +#define S_OFFSET_BITS1_7 8 +#define M_OFFSET_BITS1_7 0x7fU +#define V_OFFSET_BITS1_7(x) ((x) << S_OFFSET_BITS1_7) +#define G_OFFSET_BITS1_7(x) (((x) >> S_OFFSET_BITS1_7) & M_OFFSET_BITS1_7) + +#define S_OFFSET_BITS9_15 0 +#define M_OFFSET_BITS9_15 0x7fU +#define V_OFFSET_BITS9_15(x) ((x) << S_OFFSET_BITS9_15) +#define G_OFFSET_BITS9_15(x) (((x) >> S_OFFSET_BITS9_15) & M_OFFSET_BITS9_15) + +#define A_MC_DDRPHY_DP18_READ_DELAY_OFFSET1_RANK_PAIR 0x44034 +#define A_MC_DDRPHY_DP18_RD_LVL_STATUS0 0x44038 + +#define S_LEADING_EDGE_NOT_FOUND_0 0 +#define M_LEADING_EDGE_NOT_FOUND_0 0xffffU +#define V_LEADING_EDGE_NOT_FOUND_0(x) ((x) << S_LEADING_EDGE_NOT_FOUND_0) +#define G_LEADING_EDGE_NOT_FOUND_0(x) (((x) >> S_LEADING_EDGE_NOT_FOUND_0) & M_LEADING_EDGE_NOT_FOUND_0) + +#define A_MC_DDRPHY_DP18_RD_LVL_STATUS1 0x4403c + +#define S_LEADING_EDGE_NOT_FOUND_1 8 +#define M_LEADING_EDGE_NOT_FOUND_1 0xffU +#define V_LEADING_EDGE_NOT_FOUND_1(x) ((x) << S_LEADING_EDGE_NOT_FOUND_1) +#define G_LEADING_EDGE_NOT_FOUND_1(x) (((x) >> S_LEADING_EDGE_NOT_FOUND_1) & M_LEADING_EDGE_NOT_FOUND_1) + +#define A_MC_DDRPHY_DP18_RD_LVL_STATUS2 0x44040 + +#define S_TRAILING_EDGE_NOT_FOUND 0 +#define M_TRAILING_EDGE_NOT_FOUND 0xffffU +#define V_TRAILING_EDGE_NOT_FOUND(x) ((x) << S_TRAILING_EDGE_NOT_FOUND) +#define G_TRAILING_EDGE_NOT_FOUND(x) (((x) >> S_TRAILING_EDGE_NOT_FOUND) & M_TRAILING_EDGE_NOT_FOUND) + +#define A_MC_DDRPHY_DP18_RD_LVL_STATUS3 0x44044 + +#define S_TRAILING_EDGE_NOT_FOUND_16_23 8 +#define M_TRAILING_EDGE_NOT_FOUND_16_23 0xffU +#define V_TRAILING_EDGE_NOT_FOUND_16_23(x) ((x) << S_TRAILING_EDGE_NOT_FOUND_16_23) +#define G_TRAILING_EDGE_NOT_FOUND_16_23(x) (((x) >> S_TRAILING_EDGE_NOT_FOUND_16_23) & M_TRAILING_EDGE_NOT_FOUND_16_23) + +#define A_MC_DDRPHY_DP18_RD_DIA_CONFIG5 0x44048 + +#define S_DYN_POWER_CNTL_EN 15 +#define V_DYN_POWER_CNTL_EN(x) ((x) << S_DYN_POWER_CNTL_EN) +#define F_DYN_POWER_CNTL_EN V_DYN_POWER_CNTL_EN(1U) + +#define S_DYN_MCTERM_CNTL_EN 14 +#define V_DYN_MCTERM_CNTL_EN(x) ((x) << S_DYN_MCTERM_CNTL_EN) +#define F_DYN_MCTERM_CNTL_EN V_DYN_MCTERM_CNTL_EN(1U) + +#define S_DYN_RX_GATE_CNTL_EN 13 +#define V_DYN_RX_GATE_CNTL_EN(x) ((x) << S_DYN_RX_GATE_CNTL_EN) +#define F_DYN_RX_GATE_CNTL_EN V_DYN_RX_GATE_CNTL_EN(1U) + +#define S_CALGATE_ON 12 +#define V_CALGATE_ON(x) ((x) << S_CALGATE_ON) +#define F_CALGATE_ON V_CALGATE_ON(1U) + +#define S_PER_RDCLK_UPDATE_DIS 11 +#define V_PER_RDCLK_UPDATE_DIS(x) ((x) << S_PER_RDCLK_UPDATE_DIS) +#define F_PER_RDCLK_UPDATE_DIS V_PER_RDCLK_UPDATE_DIS(1U) + +#define A_MC_DDRPHY_DP18_DQS_GATE_DELAY_RP 0x4404c + +#define S_DQS_GATE_DELAY_N0 12 +#define M_DQS_GATE_DELAY_N0 0x7U +#define V_DQS_GATE_DELAY_N0(x) ((x) << S_DQS_GATE_DELAY_N0) +#define G_DQS_GATE_DELAY_N0(x) (((x) >> S_DQS_GATE_DELAY_N0) & M_DQS_GATE_DELAY_N0) + +#define S_DQS_GATE_DELAY_N1 8 +#define M_DQS_GATE_DELAY_N1 0x7U +#define V_DQS_GATE_DELAY_N1(x) ((x) << S_DQS_GATE_DELAY_N1) +#define G_DQS_GATE_DELAY_N1(x) (((x) >> S_DQS_GATE_DELAY_N1) & M_DQS_GATE_DELAY_N1) + +#define S_DQS_GATE_DELAY_N2 4 +#define M_DQS_GATE_DELAY_N2 0x7U +#define V_DQS_GATE_DELAY_N2(x) ((x) << S_DQS_GATE_DELAY_N2) +#define G_DQS_GATE_DELAY_N2(x) (((x) >> S_DQS_GATE_DELAY_N2) & M_DQS_GATE_DELAY_N2) + +#define S_DQS_GATE_DELAY_N3 0 +#define M_DQS_GATE_DELAY_N3 0x7U +#define V_DQS_GATE_DELAY_N3(x) ((x) << S_DQS_GATE_DELAY_N3) +#define G_DQS_GATE_DELAY_N3(x) (((x) >> S_DQS_GATE_DELAY_N3) & M_DQS_GATE_DELAY_N3) + +#define A_MC_DDRPHY_DP18_RD_STATUS0 0x44050 + +#define S_NO_EYE_DETECTED 15 +#define V_NO_EYE_DETECTED(x) ((x) << S_NO_EYE_DETECTED) +#define F_NO_EYE_DETECTED V_NO_EYE_DETECTED(1U) + +#define S_LEADING_EDGE_FOUND 14 +#define V_LEADING_EDGE_FOUND(x) ((x) << S_LEADING_EDGE_FOUND) +#define F_LEADING_EDGE_FOUND V_LEADING_EDGE_FOUND(1U) + +#define S_TRAILING_EDGE_FOUND 13 +#define V_TRAILING_EDGE_FOUND(x) ((x) << S_TRAILING_EDGE_FOUND) +#define F_TRAILING_EDGE_FOUND V_TRAILING_EDGE_FOUND(1U) + +#define S_INCOMPLETE_RD_CAL_N0 12 +#define V_INCOMPLETE_RD_CAL_N0(x) ((x) << S_INCOMPLETE_RD_CAL_N0) +#define F_INCOMPLETE_RD_CAL_N0 V_INCOMPLETE_RD_CAL_N0(1U) + +#define S_INCOMPLETE_RD_CAL_N1 11 +#define V_INCOMPLETE_RD_CAL_N1(x) ((x) << S_INCOMPLETE_RD_CAL_N1) +#define F_INCOMPLETE_RD_CAL_N1 V_INCOMPLETE_RD_CAL_N1(1U) + +#define S_INCOMPLETE_RD_CAL_N2 10 +#define V_INCOMPLETE_RD_CAL_N2(x) ((x) << S_INCOMPLETE_RD_CAL_N2) +#define F_INCOMPLETE_RD_CAL_N2 V_INCOMPLETE_RD_CAL_N2(1U) + +#define S_INCOMPLETE_RD_CAL_N3 9 +#define V_INCOMPLETE_RD_CAL_N3(x) ((x) << S_INCOMPLETE_RD_CAL_N3) +#define F_INCOMPLETE_RD_CAL_N3 V_INCOMPLETE_RD_CAL_N3(1U) + +#define S_COARSE_PATTERN_ERR_N0 8 +#define V_COARSE_PATTERN_ERR_N0(x) ((x) << S_COARSE_PATTERN_ERR_N0) +#define F_COARSE_PATTERN_ERR_N0 V_COARSE_PATTERN_ERR_N0(1U) + +#define S_COARSE_PATTERN_ERR_N1 7 +#define V_COARSE_PATTERN_ERR_N1(x) ((x) << S_COARSE_PATTERN_ERR_N1) +#define F_COARSE_PATTERN_ERR_N1 V_COARSE_PATTERN_ERR_N1(1U) + +#define S_COARSE_PATTERN_ERR_N2 6 +#define V_COARSE_PATTERN_ERR_N2(x) ((x) << S_COARSE_PATTERN_ERR_N2) +#define F_COARSE_PATTERN_ERR_N2 V_COARSE_PATTERN_ERR_N2(1U) + +#define S_COARSE_PATTERN_ERR_N3 5 +#define V_COARSE_PATTERN_ERR_N3(x) ((x) << S_COARSE_PATTERN_ERR_N3) +#define F_COARSE_PATTERN_ERR_N3 V_COARSE_PATTERN_ERR_N3(1U) + +#define S_EYE_CLIPPING 4 +#define V_EYE_CLIPPING(x) ((x) << S_EYE_CLIPPING) +#define F_EYE_CLIPPING V_EYE_CLIPPING(1U) + +#define S_NO_DQS 3 +#define V_NO_DQS(x) ((x) << S_NO_DQS) +#define F_NO_DQS V_NO_DQS(1U) + +#define S_NO_LOCK 2 +#define V_NO_LOCK(x) ((x) << S_NO_LOCK) +#define F_NO_LOCK V_NO_LOCK(1U) + +#define S_DRIFT_ERROR 1 +#define V_DRIFT_ERROR(x) ((x) << S_DRIFT_ERROR) +#define F_DRIFT_ERROR V_DRIFT_ERROR(1U) + +#define S_MIN_EYE 0 +#define V_MIN_EYE(x) ((x) << S_MIN_EYE) +#define F_MIN_EYE V_MIN_EYE(1U) + +#define A_MC_DDRPHY_DP18_RD_ERROR_MASK0 0x44054 + +#define S_NO_EYE_DETECTED_MASK 15 +#define V_NO_EYE_DETECTED_MASK(x) ((x) << S_NO_EYE_DETECTED_MASK) +#define F_NO_EYE_DETECTED_MASK V_NO_EYE_DETECTED_MASK(1U) + +#define S_LEADING_EDGE_FOUND_MASK 14 +#define V_LEADING_EDGE_FOUND_MASK(x) ((x) << S_LEADING_EDGE_FOUND_MASK) +#define F_LEADING_EDGE_FOUND_MASK V_LEADING_EDGE_FOUND_MASK(1U) + +#define S_TRAILING_EDGE_FOUND_MASK 13 +#define V_TRAILING_EDGE_FOUND_MASK(x) ((x) << S_TRAILING_EDGE_FOUND_MASK) +#define F_TRAILING_EDGE_FOUND_MASK V_TRAILING_EDGE_FOUND_MASK(1U) + +#define S_INCOMPLETE_RD_CAL_N0_MASK 12 +#define V_INCOMPLETE_RD_CAL_N0_MASK(x) ((x) << S_INCOMPLETE_RD_CAL_N0_MASK) +#define F_INCOMPLETE_RD_CAL_N0_MASK V_INCOMPLETE_RD_CAL_N0_MASK(1U) + +#define S_INCOMPLETE_RD_CAL_N1_MASK 11 +#define V_INCOMPLETE_RD_CAL_N1_MASK(x) ((x) << S_INCOMPLETE_RD_CAL_N1_MASK) +#define F_INCOMPLETE_RD_CAL_N1_MASK V_INCOMPLETE_RD_CAL_N1_MASK(1U) + +#define S_INCOMPLETE_RD_CAL_N2_MASK 10 +#define V_INCOMPLETE_RD_CAL_N2_MASK(x) ((x) << S_INCOMPLETE_RD_CAL_N2_MASK) +#define F_INCOMPLETE_RD_CAL_N2_MASK V_INCOMPLETE_RD_CAL_N2_MASK(1U) + +#define S_INCOMPLETE_RD_CAL_N3_MASK 9 +#define V_INCOMPLETE_RD_CAL_N3_MASK(x) ((x) << S_INCOMPLETE_RD_CAL_N3_MASK) +#define F_INCOMPLETE_RD_CAL_N3_MASK V_INCOMPLETE_RD_CAL_N3_MASK(1U) + +#define S_COARSE_PATTERN_ERR_N0_MASK 8 +#define V_COARSE_PATTERN_ERR_N0_MASK(x) ((x) << S_COARSE_PATTERN_ERR_N0_MASK) +#define F_COARSE_PATTERN_ERR_N0_MASK V_COARSE_PATTERN_ERR_N0_MASK(1U) + +#define S_COARSE_PATTERN_ERR_N1_MASK 7 +#define V_COARSE_PATTERN_ERR_N1_MASK(x) ((x) << S_COARSE_PATTERN_ERR_N1_MASK) +#define F_COARSE_PATTERN_ERR_N1_MASK V_COARSE_PATTERN_ERR_N1_MASK(1U) + +#define S_COARSE_PATTERN_ERR_N2_MASK 6 +#define V_COARSE_PATTERN_ERR_N2_MASK(x) ((x) << S_COARSE_PATTERN_ERR_N2_MASK) +#define F_COARSE_PATTERN_ERR_N2_MASK V_COARSE_PATTERN_ERR_N2_MASK(1U) + +#define S_COARSE_PATTERN_ERR_N3_MASK 5 +#define V_COARSE_PATTERN_ERR_N3_MASK(x) ((x) << S_COARSE_PATTERN_ERR_N3_MASK) +#define F_COARSE_PATTERN_ERR_N3_MASK V_COARSE_PATTERN_ERR_N3_MASK(1U) + +#define S_EYE_CLIPPING_MASK 4 +#define V_EYE_CLIPPING_MASK(x) ((x) << S_EYE_CLIPPING_MASK) +#define F_EYE_CLIPPING_MASK V_EYE_CLIPPING_MASK(1U) + +#define S_NO_DQS_MASK 3 +#define V_NO_DQS_MASK(x) ((x) << S_NO_DQS_MASK) +#define F_NO_DQS_MASK V_NO_DQS_MASK(1U) + +#define S_NO_LOCK_MASK 2 +#define V_NO_LOCK_MASK(x) ((x) << S_NO_LOCK_MASK) +#define F_NO_LOCK_MASK V_NO_LOCK_MASK(1U) + +#define S_DRIFT_ERROR_MASK 1 +#define V_DRIFT_ERROR_MASK(x) ((x) << S_DRIFT_ERROR_MASK) +#define F_DRIFT_ERROR_MASK V_DRIFT_ERROR_MASK(1U) + +#define S_MIN_EYE_MASK 0 +#define V_MIN_EYE_MASK(x) ((x) << S_MIN_EYE_MASK) +#define F_MIN_EYE_MASK V_MIN_EYE_MASK(1U) + +#define A_MC_DDRPHY_DP18_WR_LVL_STATUS0 0x4405c + +#define S_CLK_LEVEL 14 +#define M_CLK_LEVEL 0x3U +#define V_CLK_LEVEL(x) ((x) << S_CLK_LEVEL) +#define G_CLK_LEVEL(x) (((x) >> S_CLK_LEVEL) & M_CLK_LEVEL) + +#define S_FINE_STEPPING 13 +#define V_FINE_STEPPING(x) ((x) << S_FINE_STEPPING) +#define F_FINE_STEPPING V_FINE_STEPPING(1U) + +#define S_DONE 12 +#define V_DONE(x) ((x) << S_DONE) +#define F_DONE V_DONE(1U) + +#define S_WL_ERR_CLK16_ST 11 +#define V_WL_ERR_CLK16_ST(x) ((x) << S_WL_ERR_CLK16_ST) +#define F_WL_ERR_CLK16_ST V_WL_ERR_CLK16_ST(1U) + +#define S_WL_ERR_CLK18_ST 10 +#define V_WL_ERR_CLK18_ST(x) ((x) << S_WL_ERR_CLK18_ST) +#define F_WL_ERR_CLK18_ST V_WL_ERR_CLK18_ST(1U) + +#define S_WL_ERR_CLK20_ST 9 +#define V_WL_ERR_CLK20_ST(x) ((x) << S_WL_ERR_CLK20_ST) +#define F_WL_ERR_CLK20_ST V_WL_ERR_CLK20_ST(1U) + +#define S_WL_ERR_CLK22_ST 8 +#define V_WL_ERR_CLK22_ST(x) ((x) << S_WL_ERR_CLK22_ST) +#define F_WL_ERR_CLK22_ST V_WL_ERR_CLK22_ST(1U) + +#define S_ZERO_DETECTED 7 +#define V_ZERO_DETECTED(x) ((x) << S_ZERO_DETECTED) +#define F_ZERO_DETECTED V_ZERO_DETECTED(1U) + +#define A_MC_DDRPHY_DP18_WR_CNTR_STATUS0 0x44060 + +#define S_BIT_CENTERED 11 +#define M_BIT_CENTERED 0x1fU +#define V_BIT_CENTERED(x) ((x) << S_BIT_CENTERED) +#define G_BIT_CENTERED(x) (((x) >> S_BIT_CENTERED) & M_BIT_CENTERED) + +#define S_SMALL_STEP_LEFT 10 +#define V_SMALL_STEP_LEFT(x) ((x) << S_SMALL_STEP_LEFT) +#define F_SMALL_STEP_LEFT V_SMALL_STEP_LEFT(1U) + +#define S_BIG_STEP_RIGHT 9 +#define V_BIG_STEP_RIGHT(x) ((x) << S_BIG_STEP_RIGHT) +#define F_BIG_STEP_RIGHT V_BIG_STEP_RIGHT(1U) + +#define S_MATCH_STEP_RIGHT 8 +#define V_MATCH_STEP_RIGHT(x) ((x) << S_MATCH_STEP_RIGHT) +#define F_MATCH_STEP_RIGHT V_MATCH_STEP_RIGHT(1U) + +#define S_JUMP_BACK_RIGHT 7 +#define V_JUMP_BACK_RIGHT(x) ((x) << S_JUMP_BACK_RIGHT) +#define F_JUMP_BACK_RIGHT V_JUMP_BACK_RIGHT(1U) + +#define S_SMALL_STEP_RIGHT 6 +#define V_SMALL_STEP_RIGHT(x) ((x) << S_SMALL_STEP_RIGHT) +#define F_SMALL_STEP_RIGHT V_SMALL_STEP_RIGHT(1U) + +#define S_DDONE 5 +#define V_DDONE(x) ((x) << S_DDONE) +#define F_DDONE V_DDONE(1U) + +#define A_MC_DDRPHY_DP18_WR_CNTR_STATUS1 0x44064 + +#define S_FW_LEFT_SIDE 5 +#define M_FW_LEFT_SIDE 0x7ffU +#define V_FW_LEFT_SIDE(x) ((x) << S_FW_LEFT_SIDE) +#define G_FW_LEFT_SIDE(x) (((x) >> S_FW_LEFT_SIDE) & M_FW_LEFT_SIDE) + +#define A_MC_DDRPHY_DP18_WR_CNTR_STATUS2 0x44068 + +#define S_FW_RIGHT_SIDE 5 +#define M_FW_RIGHT_SIDE 0x7ffU +#define V_FW_RIGHT_SIDE(x) ((x) << S_FW_RIGHT_SIDE) +#define G_FW_RIGHT_SIDE(x) (((x) >> S_FW_RIGHT_SIDE) & M_FW_RIGHT_SIDE) + +#define A_MC_DDRPHY_DP18_WR_ERROR0 0x4406c + +#define S_WL_ERR_CLK16 15 +#define V_WL_ERR_CLK16(x) ((x) << S_WL_ERR_CLK16) +#define F_WL_ERR_CLK16 V_WL_ERR_CLK16(1U) + +#define S_WL_ERR_CLK18 14 +#define V_WL_ERR_CLK18(x) ((x) << S_WL_ERR_CLK18) +#define F_WL_ERR_CLK18 V_WL_ERR_CLK18(1U) + +#define S_WL_ERR_CLK20 13 +#define V_WL_ERR_CLK20(x) ((x) << S_WL_ERR_CLK20) +#define F_WL_ERR_CLK20 V_WL_ERR_CLK20(1U) + +#define S_WL_ERR_CLK22 12 +#define V_WL_ERR_CLK22(x) ((x) << S_WL_ERR_CLK22) +#define F_WL_ERR_CLK22 V_WL_ERR_CLK22(1U) + +#define S_VALID_NS_BIG_L 7 +#define V_VALID_NS_BIG_L(x) ((x) << S_VALID_NS_BIG_L) +#define F_VALID_NS_BIG_L V_VALID_NS_BIG_L(1U) + +#define S_INVALID_NS_SMALL_L 6 +#define V_INVALID_NS_SMALL_L(x) ((x) << S_INVALID_NS_SMALL_L) +#define F_INVALID_NS_SMALL_L V_INVALID_NS_SMALL_L(1U) + +#define S_VALID_NS_BIG_R 5 +#define V_VALID_NS_BIG_R(x) ((x) << S_VALID_NS_BIG_R) +#define F_VALID_NS_BIG_R V_VALID_NS_BIG_R(1U) + +#define S_INVALID_NS_BIG_R 4 +#define V_INVALID_NS_BIG_R(x) ((x) << S_INVALID_NS_BIG_R) +#define F_INVALID_NS_BIG_R V_INVALID_NS_BIG_R(1U) + +#define S_VALID_NS_JUMP_BACK 3 +#define V_VALID_NS_JUMP_BACK(x) ((x) << S_VALID_NS_JUMP_BACK) +#define F_VALID_NS_JUMP_BACK V_VALID_NS_JUMP_BACK(1U) + +#define S_INVALID_NS_SMALL_R 2 +#define V_INVALID_NS_SMALL_R(x) ((x) << S_INVALID_NS_SMALL_R) +#define F_INVALID_NS_SMALL_R V_INVALID_NS_SMALL_R(1U) + +#define S_OFFSET_ERR 1 +#define V_OFFSET_ERR(x) ((x) << S_OFFSET_ERR) +#define F_OFFSET_ERR V_OFFSET_ERR(1U) + +#define A_MC_DDRPHY_DP18_WR_ERROR_MASK0 0x44070 + +#define S_WL_ERR_CLK16_MASK 15 +#define V_WL_ERR_CLK16_MASK(x) ((x) << S_WL_ERR_CLK16_MASK) +#define F_WL_ERR_CLK16_MASK V_WL_ERR_CLK16_MASK(1U) + +#define S_WL_ERR_CLK18_MASK 14 +#define V_WL_ERR_CLK18_MASK(x) ((x) << S_WL_ERR_CLK18_MASK) +#define F_WL_ERR_CLK18_MASK V_WL_ERR_CLK18_MASK(1U) + +#define S_WL_ERR_CLK20_MASK 13 +#define V_WL_ERR_CLK20_MASK(x) ((x) << S_WL_ERR_CLK20_MASK) +#define F_WL_ERR_CLK20_MASK V_WL_ERR_CLK20_MASK(1U) + +#define S_WR_ERR_CLK22_MASK 12 +#define V_WR_ERR_CLK22_MASK(x) ((x) << S_WR_ERR_CLK22_MASK) +#define F_WR_ERR_CLK22_MASK V_WR_ERR_CLK22_MASK(1U) + +#define S_VALID_NS_BIG_L_MASK 7 +#define V_VALID_NS_BIG_L_MASK(x) ((x) << S_VALID_NS_BIG_L_MASK) +#define F_VALID_NS_BIG_L_MASK V_VALID_NS_BIG_L_MASK(1U) + +#define S_INVALID_NS_SMALL_L_MASK 6 +#define V_INVALID_NS_SMALL_L_MASK(x) ((x) << S_INVALID_NS_SMALL_L_MASK) +#define F_INVALID_NS_SMALL_L_MASK V_INVALID_NS_SMALL_L_MASK(1U) + +#define S_VALID_NS_BIG_R_MASK 5 +#define V_VALID_NS_BIG_R_MASK(x) ((x) << S_VALID_NS_BIG_R_MASK) +#define F_VALID_NS_BIG_R_MASK V_VALID_NS_BIG_R_MASK(1U) + +#define S_INVALID_NS_BIG_R_MASK 4 +#define V_INVALID_NS_BIG_R_MASK(x) ((x) << S_INVALID_NS_BIG_R_MASK) +#define F_INVALID_NS_BIG_R_MASK V_INVALID_NS_BIG_R_MASK(1U) + +#define S_VALID_NS_JUMP_BACK_MASK 3 +#define V_VALID_NS_JUMP_BACK_MASK(x) ((x) << S_VALID_NS_JUMP_BACK_MASK) +#define F_VALID_NS_JUMP_BACK_MASK V_VALID_NS_JUMP_BACK_MASK(1U) + +#define S_INVALID_NS_SMALL_R_MASK 2 +#define V_INVALID_NS_SMALL_R_MASK(x) ((x) << S_INVALID_NS_SMALL_R_MASK) +#define F_INVALID_NS_SMALL_R_MASK V_INVALID_NS_SMALL_R_MASK(1U) + +#define S_OFFSET_ERR_MASK 1 +#define V_OFFSET_ERR_MASK(x) ((x) << S_OFFSET_ERR_MASK) +#define F_OFFSET_ERR_MASK V_OFFSET_ERR_MASK(1U) + +#define A_MC_DDRPHY_DP18_DFT_WRAP_STATUS 0x44074 + +#define S_CHECKER_RESET 14 +#define V_CHECKER_RESET(x) ((x) << S_CHECKER_RESET) +#define F_CHECKER_RESET V_CHECKER_RESET(1U) + +#define S_DP18_DFT_SYNC 6 +#define M_DP18_DFT_SYNC 0x3fU +#define V_DP18_DFT_SYNC(x) ((x) << S_DP18_DFT_SYNC) +#define G_DP18_DFT_SYNC(x) (((x) >> S_DP18_DFT_SYNC) & M_DP18_DFT_SYNC) + +#define S_ERROR 0 +#define M_ERROR 0x3fU +#define V_ERROR(x) ((x) << S_ERROR) +#define G_ERROR(x) (((x) >> S_ERROR) & M_ERROR) + +#define A_MC_DDRPHY_DP18_RD_DIA_CONFIG0 0x44078 +#define A_MC_DDRPHY_DP18_DQSCLK_PR0_RANK_PAIR 0x440c0 + +#define S_DQSCLK_ROT_CLK_N0_N2 8 +#define M_DQSCLK_ROT_CLK_N0_N2 0x7fU +#define V_DQSCLK_ROT_CLK_N0_N2(x) ((x) << S_DQSCLK_ROT_CLK_N0_N2) +#define G_DQSCLK_ROT_CLK_N0_N2(x) (((x) >> S_DQSCLK_ROT_CLK_N0_N2) & M_DQSCLK_ROT_CLK_N0_N2) + +#define S_DQSCLK_ROT_CLK_N1_N3 0 +#define M_DQSCLK_ROT_CLK_N1_N3 0x7fU +#define V_DQSCLK_ROT_CLK_N1_N3(x) ((x) << S_DQSCLK_ROT_CLK_N1_N3) +#define G_DQSCLK_ROT_CLK_N1_N3(x) (((x) >> S_DQSCLK_ROT_CLK_N1_N3) & M_DQSCLK_ROT_CLK_N1_N3) + +#define A_MC_DDRPHY_DP18_DQSCLK_PR1_RANK_PAIR 0x440c4 +#define A_MC_DDRPHY_DP18_PATTERN_POS_0 0x440c8 + +#define S_MEMINTD00_POS 14 +#define M_MEMINTD00_POS 0x3U +#define V_MEMINTD00_POS(x) ((x) << S_MEMINTD00_POS) +#define G_MEMINTD00_POS(x) (((x) >> S_MEMINTD00_POS) & M_MEMINTD00_POS) + +#define S_MEMINTD01_PO 12 +#define M_MEMINTD01_PO 0x3U +#define V_MEMINTD01_PO(x) ((x) << S_MEMINTD01_PO) +#define G_MEMINTD01_PO(x) (((x) >> S_MEMINTD01_PO) & M_MEMINTD01_PO) + +#define S_MEMINTD02_POS 10 +#define M_MEMINTD02_POS 0x3U +#define V_MEMINTD02_POS(x) ((x) << S_MEMINTD02_POS) +#define G_MEMINTD02_POS(x) (((x) >> S_MEMINTD02_POS) & M_MEMINTD02_POS) + +#define S_MEMINTD03_POS 8 +#define M_MEMINTD03_POS 0x3U +#define V_MEMINTD03_POS(x) ((x) << S_MEMINTD03_POS) +#define G_MEMINTD03_POS(x) (((x) >> S_MEMINTD03_POS) & M_MEMINTD03_POS) + +#define S_MEMINTD04_POS 6 +#define M_MEMINTD04_POS 0x3U +#define V_MEMINTD04_POS(x) ((x) << S_MEMINTD04_POS) +#define G_MEMINTD04_POS(x) (((x) >> S_MEMINTD04_POS) & M_MEMINTD04_POS) + +#define S_MEMINTD05_POS 4 +#define M_MEMINTD05_POS 0x3U +#define V_MEMINTD05_POS(x) ((x) << S_MEMINTD05_POS) +#define G_MEMINTD05_POS(x) (((x) >> S_MEMINTD05_POS) & M_MEMINTD05_POS) + +#define S_MEMINTD06_POS 2 +#define M_MEMINTD06_POS 0x3U +#define V_MEMINTD06_POS(x) ((x) << S_MEMINTD06_POS) +#define G_MEMINTD06_POS(x) (((x) >> S_MEMINTD06_POS) & M_MEMINTD06_POS) + +#define S_MEMINTD07_POS 0 +#define M_MEMINTD07_POS 0x3U +#define V_MEMINTD07_POS(x) ((x) << S_MEMINTD07_POS) +#define G_MEMINTD07_POS(x) (((x) >> S_MEMINTD07_POS) & M_MEMINTD07_POS) + +#define A_MC_DDRPHY_DP18_PATTERN_POS_1 0x440cc + +#define S_MEMINTD08_POS 14 +#define M_MEMINTD08_POS 0x3U +#define V_MEMINTD08_POS(x) ((x) << S_MEMINTD08_POS) +#define G_MEMINTD08_POS(x) (((x) >> S_MEMINTD08_POS) & M_MEMINTD08_POS) + +#define S_MEMINTD09_POS 12 +#define M_MEMINTD09_POS 0x3U +#define V_MEMINTD09_POS(x) ((x) << S_MEMINTD09_POS) +#define G_MEMINTD09_POS(x) (((x) >> S_MEMINTD09_POS) & M_MEMINTD09_POS) + +#define S_MEMINTD10_POS 10 +#define M_MEMINTD10_POS 0x3U +#define V_MEMINTD10_POS(x) ((x) << S_MEMINTD10_POS) +#define G_MEMINTD10_POS(x) (((x) >> S_MEMINTD10_POS) & M_MEMINTD10_POS) + +#define S_MEMINTD11_POS 8 +#define M_MEMINTD11_POS 0x3U +#define V_MEMINTD11_POS(x) ((x) << S_MEMINTD11_POS) +#define G_MEMINTD11_POS(x) (((x) >> S_MEMINTD11_POS) & M_MEMINTD11_POS) + +#define S_MEMINTD12_POS 6 +#define M_MEMINTD12_POS 0x3U +#define V_MEMINTD12_POS(x) ((x) << S_MEMINTD12_POS) +#define G_MEMINTD12_POS(x) (((x) >> S_MEMINTD12_POS) & M_MEMINTD12_POS) + +#define S_MEMINTD13_POS 4 +#define M_MEMINTD13_POS 0x3U +#define V_MEMINTD13_POS(x) ((x) << S_MEMINTD13_POS) +#define G_MEMINTD13_POS(x) (((x) >> S_MEMINTD13_POS) & M_MEMINTD13_POS) + +#define S_MEMINTD14_POS 2 +#define M_MEMINTD14_POS 0x3U +#define V_MEMINTD14_POS(x) ((x) << S_MEMINTD14_POS) +#define G_MEMINTD14_POS(x) (((x) >> S_MEMINTD14_POS) & M_MEMINTD14_POS) + +#define S_MEMINTD15_POS 0 +#define M_MEMINTD15_POS 0x3U +#define V_MEMINTD15_POS(x) ((x) << S_MEMINTD15_POS) +#define G_MEMINTD15_POS(x) (((x) >> S_MEMINTD15_POS) & M_MEMINTD15_POS) + +#define A_MC_DDRPHY_DP18_PATTERN_POS_2 0x440d0 + +#define S_MEMINTD16_POS 14 +#define M_MEMINTD16_POS 0x3U +#define V_MEMINTD16_POS(x) ((x) << S_MEMINTD16_POS) +#define G_MEMINTD16_POS(x) (((x) >> S_MEMINTD16_POS) & M_MEMINTD16_POS) + +#define S_MEMINTD17_POS 12 +#define M_MEMINTD17_POS 0x3U +#define V_MEMINTD17_POS(x) ((x) << S_MEMINTD17_POS) +#define G_MEMINTD17_POS(x) (((x) >> S_MEMINTD17_POS) & M_MEMINTD17_POS) + +#define S_MEMINTD18_POS 10 +#define M_MEMINTD18_POS 0x3U +#define V_MEMINTD18_POS(x) ((x) << S_MEMINTD18_POS) +#define G_MEMINTD18_POS(x) (((x) >> S_MEMINTD18_POS) & M_MEMINTD18_POS) + +#define S_MEMINTD19_POS 8 +#define M_MEMINTD19_POS 0x3U +#define V_MEMINTD19_POS(x) ((x) << S_MEMINTD19_POS) +#define G_MEMINTD19_POS(x) (((x) >> S_MEMINTD19_POS) & M_MEMINTD19_POS) + +#define S_MEMINTD20_POS 6 +#define M_MEMINTD20_POS 0x3U +#define V_MEMINTD20_POS(x) ((x) << S_MEMINTD20_POS) +#define G_MEMINTD20_POS(x) (((x) >> S_MEMINTD20_POS) & M_MEMINTD20_POS) + +#define S_MEMINTD21_POS 4 +#define M_MEMINTD21_POS 0x3U +#define V_MEMINTD21_POS(x) ((x) << S_MEMINTD21_POS) +#define G_MEMINTD21_POS(x) (((x) >> S_MEMINTD21_POS) & M_MEMINTD21_POS) + +#define S_MEMINTD22_POS 2 +#define M_MEMINTD22_POS 0x3U +#define V_MEMINTD22_POS(x) ((x) << S_MEMINTD22_POS) +#define G_MEMINTD22_POS(x) (((x) >> S_MEMINTD22_POS) & M_MEMINTD22_POS) + +#define S_MEMINTD23_POS 0 +#define M_MEMINTD23_POS 0x3U +#define V_MEMINTD23_POS(x) ((x) << S_MEMINTD23_POS) +#define G_MEMINTD23_POS(x) (((x) >> S_MEMINTD23_POS) & M_MEMINTD23_POS) + +#define A_MC_DDRPHY_DP18_RD_DIA_CONFIG1 0x440d4 +#define A_MC_DDRPHY_DP18_RD_DIA_CONFIG2 0x440d8 +#define A_MC_DDRPHY_DP18_DQSCLK_OFFSET 0x440dc + +#define S_DQS_OFFSET 8 +#define M_DQS_OFFSET 0x7fU +#define V_DQS_OFFSET(x) ((x) << S_DQS_OFFSET) +#define G_DQS_OFFSET(x) (((x) >> S_DQS_OFFSET) & M_DQS_OFFSET) + +#define A_MC_DDRPHY_DP18_WR_DELAY_VALUE_0_RP 0x440e0 + +#define S_WR_DELAY 6 +#define M_WR_DELAY 0x3ffU +#define V_WR_DELAY(x) ((x) << S_WR_DELAY) +#define G_WR_DELAY(x) (((x) >> S_WR_DELAY) & M_WR_DELAY) + +#define A_MC_DDRPHY_DP18_WR_DELAY_VALUE_1_RP 0x440e4 +#define A_MC_DDRPHY_DP18_WR_DELAY_VALUE_2_RP 0x440e8 +#define A_MC_DDRPHY_DP18_WR_DELAY_VALUE_3_RP 0x440ec +#define A_MC_DDRPHY_DP18_WR_DELAY_VALUE_4_RP 0x440f0 +#define A_MC_DDRPHY_DP18_WR_DELAY_VALUE_5_RP 0x440f4 +#define A_MC_DDRPHY_DP18_WR_DELAY_VALUE_6_RP 0x440f8 +#define A_MC_DDRPHY_DP18_WR_DELAY_VALUE_7_RP 0x440fc +#define A_MC_DDRPHY_DP18_WR_DELAY_VALUE_8_RP 0x44100 +#define A_MC_DDRPHY_DP18_WR_DELAY_VALUE_9_RP 0x44104 +#define A_MC_DDRPHY_DP18_WR_DELAY_VALUE_10_RP 0x44108 +#define A_MC_DDRPHY_DP18_WR_DELAY_VALUE_11_RP 0x4410c +#define A_MC_DDRPHY_DP18_WR_DELAY_VALUE_12_RP 0x44110 +#define A_MC_DDRPHY_DP18_WR_DELAY_VALUE_13_RP 0x44114 +#define A_MC_DDRPHY_DP18_WR_DELAY_VALUE_14_RP 0x44118 +#define A_MC_DDRPHY_DP18_WR_DELAY_VALUE_15_RP 0x4411c +#define A_MC_DDRPHY_DP18_WR_DELAY_VALUE_16_RP 0x44120 +#define A_MC_DDRPHY_DP18_WR_DELAY_VALUE_17_RP 0x44124 +#define A_MC_DDRPHY_DP18_WR_DELAY_VALUE_18_RP 0x44128 +#define A_MC_DDRPHY_DP18_WR_DELAY_VALUE_19_RP 0x4412c +#define A_MC_DDRPHY_DP18_WR_DELAY_VALUE_20_RP 0x44130 +#define A_MC_DDRPHY_DP18_WR_DELAY_VALUE_21_RP 0x44134 +#define A_MC_DDRPHY_DP18_WR_DELAY_VALUE_22_RP 0x44138 +#define A_MC_DDRPHY_DP18_WR_DELAY_VALUE_23_RP 0x4413c +#define A_MC_DDRPHY_DP18_READ_DELAY0_RANK_PAIR 0x44140 + +#define S_RD_DELAY_BITS0_6 9 +#define M_RD_DELAY_BITS0_6 0x7fU +#define V_RD_DELAY_BITS0_6(x) ((x) << S_RD_DELAY_BITS0_6) +#define G_RD_DELAY_BITS0_6(x) (((x) >> S_RD_DELAY_BITS0_6) & M_RD_DELAY_BITS0_6) + +#define S_RD_DELAY_BITS8_14 1 +#define M_RD_DELAY_BITS8_14 0x7fU +#define V_RD_DELAY_BITS8_14(x) ((x) << S_RD_DELAY_BITS8_14) +#define G_RD_DELAY_BITS8_14(x) (((x) >> S_RD_DELAY_BITS8_14) & M_RD_DELAY_BITS8_14) + +#define A_MC_DDRPHY_DP18_READ_DELAY1_RANK_PAIR 0x44144 +#define A_MC_DDRPHY_DP18_READ_DELAY2_RANK_PAIR 0x44148 +#define A_MC_DDRPHY_DP18_READ_DELAY3_RANK_PAIR 0x4414c +#define A_MC_DDRPHY_DP18_READ_DELAY4_RANK_PAIR 0x44150 +#define A_MC_DDRPHY_DP18_READ_DELAY5_RANK_PAIR 0x44154 +#define A_MC_DDRPHY_DP18_READ_DELAY6_RANK_PAIR 0x44158 +#define A_MC_DDRPHY_DP18_READ_DELAY7_RANK_PAIR 0x4415c +#define A_MC_DDRPHY_DP18_READ_DELAY8_RANK_PAIR 0x44160 +#define A_MC_DDRPHY_DP18_READ_DELAY9_RANK_PAIR 0x44164 +#define A_MC_DDRPHY_DP18_READ_DELAY10_RANK_PAIR 0x44168 +#define A_MC_DDRPHY_DP18_READ_DELAY11_RANK_PAIR 0x4416c +#define A_MC_DDRPHY_DP18_INITIAL_DQS_ALIGN0_RANK_PAIR 0x44170 + +#define S_INITIAL_DQS_ROT_N0_N2 8 +#define M_INITIAL_DQS_ROT_N0_N2 0x7fU +#define V_INITIAL_DQS_ROT_N0_N2(x) ((x) << S_INITIAL_DQS_ROT_N0_N2) +#define G_INITIAL_DQS_ROT_N0_N2(x) (((x) >> S_INITIAL_DQS_ROT_N0_N2) & M_INITIAL_DQS_ROT_N0_N2) + +#define S_INITIAL_DQS_ROT_N1_N3 0 +#define M_INITIAL_DQS_ROT_N1_N3 0x7fU +#define V_INITIAL_DQS_ROT_N1_N3(x) ((x) << S_INITIAL_DQS_ROT_N1_N3) +#define G_INITIAL_DQS_ROT_N1_N3(x) (((x) >> S_INITIAL_DQS_ROT_N1_N3) & M_INITIAL_DQS_ROT_N1_N3) + +#define A_MC_DDRPHY_DP18_INITIAL_DQS_ALIGN1_RANK_PAIR 0x44174 +#define A_MC_DDRPHY_DP18_READ_EYE_SIZE0_RANK_PAIR 0x44180 + +#define S_RD_EYE_SIZE_BITS2_7 8 +#define M_RD_EYE_SIZE_BITS2_7 0x3fU +#define V_RD_EYE_SIZE_BITS2_7(x) ((x) << S_RD_EYE_SIZE_BITS2_7) +#define G_RD_EYE_SIZE_BITS2_7(x) (((x) >> S_RD_EYE_SIZE_BITS2_7) & M_RD_EYE_SIZE_BITS2_7) + +#define S_RD_EYE_SIZE_BITS10_15 0 +#define M_RD_EYE_SIZE_BITS10_15 0x3fU +#define V_RD_EYE_SIZE_BITS10_15(x) ((x) << S_RD_EYE_SIZE_BITS10_15) +#define G_RD_EYE_SIZE_BITS10_15(x) (((x) >> S_RD_EYE_SIZE_BITS10_15) & M_RD_EYE_SIZE_BITS10_15) + +#define A_MC_DDRPHY_DP18_READ_EYE_SIZE1_RANK_PAIR 0x44184 +#define A_MC_DDRPHY_DP18_READ_EYE_SIZE2_RANK_PAIR 0x44188 +#define A_MC_DDRPHY_DP18_READ_EYE_SIZE3_RANK_PAIR 0x4418c +#define A_MC_DDRPHY_DP18_READ_EYE_SIZE4_RANK_PAIR 0x44190 +#define A_MC_DDRPHY_DP18_READ_EYE_SIZE5_RANK_PAIR 0x44194 +#define A_MC_DDRPHY_DP18_READ_EYE_SIZE6_RANK_PAIR 0x44198 +#define A_MC_DDRPHY_DP18_READ_EYE_SIZE7_RANK_PAIR 0x4419c +#define A_MC_DDRPHY_DP18_READ_EYE_SIZE8_RANK_PAIR 0x441a0 +#define A_MC_DDRPHY_DP18_READ_EYE_SIZE9_RANK_PAIR 0x441a4 +#define A_MC_DDRPHY_DP18_READ_EYE_SIZE10_RANK_PAIR 0x441a8 +#define A_MC_DDRPHY_DP18_READ_EYE_SIZE11_RANK_PAIR 0x441ac +#define A_MC_DDRPHY_DP18_RD_DIA_CONFIG3 0x441b4 +#define A_MC_DDRPHY_DP18_RD_DIA_CONFIG4 0x441b8 +#define A_MC_DDRPHY_DP18_READ_TIMING_REFERENCE0 0x441c0 + +#define S_REFERENCE_BITS1_7 8 +#define M_REFERENCE_BITS1_7 0x7fU +#define V_REFERENCE_BITS1_7(x) ((x) << S_REFERENCE_BITS1_7) +#define G_REFERENCE_BITS1_7(x) (((x) >> S_REFERENCE_BITS1_7) & M_REFERENCE_BITS1_7) + +#define S_REFERENCE_BITS9_15 0 +#define M_REFERENCE_BITS9_15 0x7fU +#define V_REFERENCE_BITS9_15(x) ((x) << S_REFERENCE_BITS9_15) +#define G_REFERENCE_BITS9_15(x) (((x) >> S_REFERENCE_BITS9_15) & M_REFERENCE_BITS9_15) + +#define A_MC_DDRPHY_DP18_READ_TIMING_REFERENCE1 0x441c4 +#define A_MC_DDRPHY_DP18_READ_DQS_TIMING_REFERENCE 0x441c8 + +#define S_REFERENCE 8 +#define M_REFERENCE 0x7fU +#define V_REFERENCE(x) ((x) << S_REFERENCE) +#define G_REFERENCE(x) (((x) >> S_REFERENCE) & M_REFERENCE) + +#define A_MC_DDRPHY_DP18_SYSCLK_PR_VALUE 0x441cc +#define A_MC_DDRPHY_DP18_WRCLK_PR 0x441d0 +#define A_MC_DDRPHY_DP18_IO_TX_CONFIG0 0x441d4 + +#define S_INTERP_SIG_SLEW 12 +#define M_INTERP_SIG_SLEW 0xfU +#define V_INTERP_SIG_SLEW(x) ((x) << S_INTERP_SIG_SLEW) +#define G_INTERP_SIG_SLEW(x) (((x) >> S_INTERP_SIG_SLEW) & M_INTERP_SIG_SLEW) + +#define S_POST_CURSOR 8 +#define M_POST_CURSOR 0xfU +#define V_POST_CURSOR(x) ((x) << S_POST_CURSOR) +#define G_POST_CURSOR(x) (((x) >> S_POST_CURSOR) & M_POST_CURSOR) + +#define S_SLEW_CTL 4 +#define M_SLEW_CTL 0xfU +#define V_SLEW_CTL(x) ((x) << S_SLEW_CTL) +#define G_SLEW_CTL(x) (((x) >> S_SLEW_CTL) & M_SLEW_CTL) + +#define A_MC_DDRPHY_DP18_PLL_CONFIG0 0x441d8 +#define A_MC_DDRPHY_DP18_PLL_CONFIG1 0x441dc + +#define S_CE0DLTVCCA 7 +#define V_CE0DLTVCCA(x) ((x) << S_CE0DLTVCCA) +#define F_CE0DLTVCCA V_CE0DLTVCCA(1U) + +#define S_CE0DLTVCCD1 4 +#define V_CE0DLTVCCD1(x) ((x) << S_CE0DLTVCCD1) +#define F_CE0DLTVCCD1 V_CE0DLTVCCD1(1U) + +#define S_CE0DLTVCCD2 3 +#define V_CE0DLTVCCD2(x) ((x) << S_CE0DLTVCCD2) +#define F_CE0DLTVCCD2 V_CE0DLTVCCD2(1U) + +#define S_S0INSDLYTAP 2 +#define V_S0INSDLYTAP(x) ((x) << S_S0INSDLYTAP) +#define F_S0INSDLYTAP V_S0INSDLYTAP(1U) + +#define S_S1INSDLYTAP 1 +#define V_S1INSDLYTAP(x) ((x) << S_S1INSDLYTAP) +#define F_S1INSDLYTAP V_S1INSDLYTAP(1U) + +#define A_MC_DDRPHY_DP18_IO_TX_NFET_SLICE 0x441e0 + +#define S_EN_SLICE_N_WR 8 +#define M_EN_SLICE_N_WR 0xffU +#define V_EN_SLICE_N_WR(x) ((x) << S_EN_SLICE_N_WR) +#define G_EN_SLICE_N_WR(x) (((x) >> S_EN_SLICE_N_WR) & M_EN_SLICE_N_WR) + +#define A_MC_DDRPHY_DP18_IO_TX_PFET_SLICE 0x441e4 +#define A_MC_DDRPHY_DP18_IO_TX_NFET_TERM 0x441e8 + +#define S_EN_TERM_N_WR 8 +#define M_EN_TERM_N_WR 0xffU +#define V_EN_TERM_N_WR(x) ((x) << S_EN_TERM_N_WR) +#define G_EN_TERM_N_WR(x) (((x) >> S_EN_TERM_N_WR) & M_EN_TERM_N_WR) + +#define S_EN_TERM_N_WR_FFE 4 +#define M_EN_TERM_N_WR_FFE 0xfU +#define V_EN_TERM_N_WR_FFE(x) ((x) << S_EN_TERM_N_WR_FFE) +#define G_EN_TERM_N_WR_FFE(x) (((x) >> S_EN_TERM_N_WR_FFE) & M_EN_TERM_N_WR_FFE) + +#define A_MC_DDRPHY_DP18_IO_TX_PFET_TERM 0x441ec + +#define S_EN_TERM_P_WR 8 +#define M_EN_TERM_P_WR 0xffU +#define V_EN_TERM_P_WR(x) ((x) << S_EN_TERM_P_WR) +#define G_EN_TERM_P_WR(x) (((x) >> S_EN_TERM_P_WR) & M_EN_TERM_P_WR) + +#define S_EN_TERM_P_WR_FFE 4 +#define M_EN_TERM_P_WR_FFE 0xfU +#define V_EN_TERM_P_WR_FFE(x) ((x) << S_EN_TERM_P_WR_FFE) +#define G_EN_TERM_P_WR_FFE(x) (((x) >> S_EN_TERM_P_WR_FFE) & M_EN_TERM_P_WR_FFE) + +#define A_MC_DDRPHY_DP18_DATA_BIT_DISABLE0_RP 0x441f0 + +#define S_DATA_BIT_DISABLE_0_15 0 +#define M_DATA_BIT_DISABLE_0_15 0xffffU +#define V_DATA_BIT_DISABLE_0_15(x) ((x) << S_DATA_BIT_DISABLE_0_15) +#define G_DATA_BIT_DISABLE_0_15(x) (((x) >> S_DATA_BIT_DISABLE_0_15) & M_DATA_BIT_DISABLE_0_15) + +#define A_MC_DDRPHY_DP18_DATA_BIT_DISABLE1_RP 0x441f4 + +#define S_DATA_BIT_DISABLE_16_23 8 +#define M_DATA_BIT_DISABLE_16_23 0xffU +#define V_DATA_BIT_DISABLE_16_23(x) ((x) << S_DATA_BIT_DISABLE_16_23) +#define G_DATA_BIT_DISABLE_16_23(x) (((x) >> S_DATA_BIT_DISABLE_16_23) & M_DATA_BIT_DISABLE_16_23) + +#define A_MC_DDRPHY_DP18_DQ_WR_OFFSET_RP 0x441f8 + +#define S_DQ_WR_OFFSET_N0 12 +#define M_DQ_WR_OFFSET_N0 0xfU +#define V_DQ_WR_OFFSET_N0(x) ((x) << S_DQ_WR_OFFSET_N0) +#define G_DQ_WR_OFFSET_N0(x) (((x) >> S_DQ_WR_OFFSET_N0) & M_DQ_WR_OFFSET_N0) + +#define S_DQ_WR_OFFSET_N1 8 +#define M_DQ_WR_OFFSET_N1 0xfU +#define V_DQ_WR_OFFSET_N1(x) ((x) << S_DQ_WR_OFFSET_N1) +#define G_DQ_WR_OFFSET_N1(x) (((x) >> S_DQ_WR_OFFSET_N1) & M_DQ_WR_OFFSET_N1) + +#define S_DQ_WR_OFFSET_N2 4 +#define M_DQ_WR_OFFSET_N2 0xfU +#define V_DQ_WR_OFFSET_N2(x) ((x) << S_DQ_WR_OFFSET_N2) +#define G_DQ_WR_OFFSET_N2(x) (((x) >> S_DQ_WR_OFFSET_N2) & M_DQ_WR_OFFSET_N2) + +#define S_DQ_WR_OFFSET_N3 0 +#define M_DQ_WR_OFFSET_N3 0xfU +#define V_DQ_WR_OFFSET_N3(x) ((x) << S_DQ_WR_OFFSET_N3) +#define G_DQ_WR_OFFSET_N3(x) (((x) >> S_DQ_WR_OFFSET_N3) & M_DQ_WR_OFFSET_N3) + +#define A_MC_DDRPHY_DP18_POWERDOWN_1 0x441fc +#define A_MC_ADR_DDRPHY_ADR_BIT_ENABLE 0x45000 + +#define S_BIT_ENABLE_0_11 4 +#define M_BIT_ENABLE_0_11 0xfffU +#define V_BIT_ENABLE_0_11(x) ((x) << S_BIT_ENABLE_0_11) +#define G_BIT_ENABLE_0_11(x) (((x) >> S_BIT_ENABLE_0_11) & M_BIT_ENABLE_0_11) + +#define S_BIT_ENABLE_12_15 0 +#define M_BIT_ENABLE_12_15 0xfU +#define V_BIT_ENABLE_12_15(x) ((x) << S_BIT_ENABLE_12_15) +#define G_BIT_ENABLE_12_15(x) (((x) >> S_BIT_ENABLE_12_15) & M_BIT_ENABLE_12_15) + +#define A_MC_ADR_DDRPHY_ADR_DIFFPAIR_ENABLE 0x45004 + +#define S_DI_ADR0_ADR1 15 +#define V_DI_ADR0_ADR1(x) ((x) << S_DI_ADR0_ADR1) +#define F_DI_ADR0_ADR1 V_DI_ADR0_ADR1(1U) + +#define S_DI_ADR2_ADR3 14 +#define V_DI_ADR2_ADR3(x) ((x) << S_DI_ADR2_ADR3) +#define F_DI_ADR2_ADR3 V_DI_ADR2_ADR3(1U) + +#define S_DI_ADR4_ADR5 13 +#define V_DI_ADR4_ADR5(x) ((x) << S_DI_ADR4_ADR5) +#define F_DI_ADR4_ADR5 V_DI_ADR4_ADR5(1U) + +#define S_DI_ADR6_ADR7 12 +#define V_DI_ADR6_ADR7(x) ((x) << S_DI_ADR6_ADR7) +#define F_DI_ADR6_ADR7 V_DI_ADR6_ADR7(1U) + +#define S_DI_ADR8_ADR9 11 +#define V_DI_ADR8_ADR9(x) ((x) << S_DI_ADR8_ADR9) +#define F_DI_ADR8_ADR9 V_DI_ADR8_ADR9(1U) + +#define S_DI_ADR10_ADR11 10 +#define V_DI_ADR10_ADR11(x) ((x) << S_DI_ADR10_ADR11) +#define F_DI_ADR10_ADR11 V_DI_ADR10_ADR11(1U) + +#define S_DI_ADR12_ADR13 9 +#define V_DI_ADR12_ADR13(x) ((x) << S_DI_ADR12_ADR13) +#define F_DI_ADR12_ADR13 V_DI_ADR12_ADR13(1U) + +#define S_DI_ADR14_ADR15 8 +#define V_DI_ADR14_ADR15(x) ((x) << S_DI_ADR14_ADR15) +#define F_DI_ADR14_ADR15 V_DI_ADR14_ADR15(1U) + +#define A_MC_ADR_DDRPHY_ADR_DELAY0 0x45010 + +#define S_ADR_DELAY_BITS1_7 8 +#define M_ADR_DELAY_BITS1_7 0x7fU +#define V_ADR_DELAY_BITS1_7(x) ((x) << S_ADR_DELAY_BITS1_7) +#define G_ADR_DELAY_BITS1_7(x) (((x) >> S_ADR_DELAY_BITS1_7) & M_ADR_DELAY_BITS1_7) + +#define S_ADR_DELAY_BITS9_15 0 +#define M_ADR_DELAY_BITS9_15 0x7fU +#define V_ADR_DELAY_BITS9_15(x) ((x) << S_ADR_DELAY_BITS9_15) +#define G_ADR_DELAY_BITS9_15(x) (((x) >> S_ADR_DELAY_BITS9_15) & M_ADR_DELAY_BITS9_15) + +#define A_MC_ADR_DDRPHY_ADR_DELAY1 0x45014 +#define A_MC_ADR_DDRPHY_ADR_DELAY2 0x45018 +#define A_MC_ADR_DDRPHY_ADR_DELAY3 0x4501c +#define A_MC_ADR_DDRPHY_ADR_DELAY4 0x45020 +#define A_MC_ADR_DDRPHY_ADR_DELAY5 0x45024 +#define A_MC_ADR_DDRPHY_ADR_DELAY6 0x45028 +#define A_MC_ADR_DDRPHY_ADR_DELAY7 0x4502c +#define A_MC_ADR_DDRPHY_ADR_DFT_WRAP_STATUS_CONTROL 0x45030 + +#define S_ADR_TEST_LANE_PAIR_FAIL 8 +#define M_ADR_TEST_LANE_PAIR_FAIL 0xffU +#define V_ADR_TEST_LANE_PAIR_FAIL(x) ((x) << S_ADR_TEST_LANE_PAIR_FAIL) +#define G_ADR_TEST_LANE_PAIR_FAIL(x) (((x) >> S_ADR_TEST_LANE_PAIR_FAIL) & M_ADR_TEST_LANE_PAIR_FAIL) + +#define S_ADR_TEST_DATA_EN 7 +#define V_ADR_TEST_DATA_EN(x) ((x) << S_ADR_TEST_DATA_EN) +#define F_ADR_TEST_DATA_EN V_ADR_TEST_DATA_EN(1U) + +#define S_DADR_TEST_MODE 5 +#define M_DADR_TEST_MODE 0x3U +#define V_DADR_TEST_MODE(x) ((x) << S_DADR_TEST_MODE) +#define G_DADR_TEST_MODE(x) (((x) >> S_DADR_TEST_MODE) & M_DADR_TEST_MODE) + +#define S_ADR_TEST_4TO1_MODE 4 +#define V_ADR_TEST_4TO1_MODE(x) ((x) << S_ADR_TEST_4TO1_MODE) +#define F_ADR_TEST_4TO1_MODE V_ADR_TEST_4TO1_MODE(1U) + +#define S_ADR_TEST_RESET 3 +#define V_ADR_TEST_RESET(x) ((x) << S_ADR_TEST_RESET) +#define F_ADR_TEST_RESET V_ADR_TEST_RESET(1U) + +#define S_ADR_TEST_GEN_EN 2 +#define V_ADR_TEST_GEN_EN(x) ((x) << S_ADR_TEST_GEN_EN) +#define F_ADR_TEST_GEN_EN V_ADR_TEST_GEN_EN(1U) + +#define S_ADR_TEST_CLEAR_ERROR 1 +#define V_ADR_TEST_CLEAR_ERROR(x) ((x) << S_ADR_TEST_CLEAR_ERROR) +#define F_ADR_TEST_CLEAR_ERROR V_ADR_TEST_CLEAR_ERROR(1U) + +#define S_ADR_TEST_CHECK_EN 0 +#define V_ADR_TEST_CHECK_EN(x) ((x) << S_ADR_TEST_CHECK_EN) +#define F_ADR_TEST_CHECK_EN V_ADR_TEST_CHECK_EN(1U) + +#define A_MC_ADR_DDRPHY_ADR_IO_NFET_SLICE_EN0 0x45040 + +#define S_EN_SLICE_N_WR_0 8 +#define M_EN_SLICE_N_WR_0 0xffU +#define V_EN_SLICE_N_WR_0(x) ((x) << S_EN_SLICE_N_WR_0) +#define G_EN_SLICE_N_WR_0(x) (((x) >> S_EN_SLICE_N_WR_0) & M_EN_SLICE_N_WR_0) + +#define S_EN_SLICE_N_WR_FFE 4 +#define M_EN_SLICE_N_WR_FFE 0xfU +#define V_EN_SLICE_N_WR_FFE(x) ((x) << S_EN_SLICE_N_WR_FFE) +#define G_EN_SLICE_N_WR_FFE(x) (((x) >> S_EN_SLICE_N_WR_FFE) & M_EN_SLICE_N_WR_FFE) + +#define A_MC_ADR_DDRPHY_ADR_IO_NFET_SLICE_EN1 0x45044 + +#define S_EN_SLICE_N_WR_1 8 +#define M_EN_SLICE_N_WR_1 0xffU +#define V_EN_SLICE_N_WR_1(x) ((x) << S_EN_SLICE_N_WR_1) +#define G_EN_SLICE_N_WR_1(x) (((x) >> S_EN_SLICE_N_WR_1) & M_EN_SLICE_N_WR_1) + +#define A_MC_ADR_DDRPHY_ADR_IO_NFET_SLICE_EN2 0x45048 + +#define S_EN_SLICE_N_WR_2 8 +#define M_EN_SLICE_N_WR_2 0xffU +#define V_EN_SLICE_N_WR_2(x) ((x) << S_EN_SLICE_N_WR_2) +#define G_EN_SLICE_N_WR_2(x) (((x) >> S_EN_SLICE_N_WR_2) & M_EN_SLICE_N_WR_2) + +#define A_MC_ADR_DDRPHY_ADR_IO_NFET_SLICE_EN3 0x4504c + +#define S_EN_SLICE_N_WR_3 8 +#define M_EN_SLICE_N_WR_3 0xffU +#define V_EN_SLICE_N_WR_3(x) ((x) << S_EN_SLICE_N_WR_3) +#define G_EN_SLICE_N_WR_3(x) (((x) >> S_EN_SLICE_N_WR_3) & M_EN_SLICE_N_WR_3) + +#define A_MC_ADR_DDRPHY_ADR_IO_PFET_SLICE_EN0 0x45050 + +#define S_EN_SLICE_P_WR 8 +#define M_EN_SLICE_P_WR 0xffU +#define V_EN_SLICE_P_WR(x) ((x) << S_EN_SLICE_P_WR) +#define G_EN_SLICE_P_WR(x) (((x) >> S_EN_SLICE_P_WR) & M_EN_SLICE_P_WR) + +#define S_EN_SLICE_P_WR_FFE 4 +#define M_EN_SLICE_P_WR_FFE 0xfU +#define V_EN_SLICE_P_WR_FFE(x) ((x) << S_EN_SLICE_P_WR_FFE) +#define G_EN_SLICE_P_WR_FFE(x) (((x) >> S_EN_SLICE_P_WR_FFE) & M_EN_SLICE_P_WR_FFE) + +#define A_MC_ADR_DDRPHY_ADR_IO_PFET_SLICE_EN1 0x45054 +#define A_MC_ADR_DDRPHY_ADR_IO_PFET_SLICE_EN2 0x45058 +#define A_MC_ADR_DDRPHY_ADR_IO_PFET_SLICE_EN3 0x4505c +#define A_MC_ADR_DDRPHY_ADR_IO_POST_CURSOR_VALUE 0x45060 + +#define S_POST_CURSOR0 12 +#define M_POST_CURSOR0 0xfU +#define V_POST_CURSOR0(x) ((x) << S_POST_CURSOR0) +#define G_POST_CURSOR0(x) (((x) >> S_POST_CURSOR0) & M_POST_CURSOR0) + +#define S_POST_CURSOR1 8 +#define M_POST_CURSOR1 0xfU +#define V_POST_CURSOR1(x) ((x) << S_POST_CURSOR1) +#define G_POST_CURSOR1(x) (((x) >> S_POST_CURSOR1) & M_POST_CURSOR1) + +#define S_POST_CURSOR2 4 +#define M_POST_CURSOR2 0xfU +#define V_POST_CURSOR2(x) ((x) << S_POST_CURSOR2) +#define G_POST_CURSOR2(x) (((x) >> S_POST_CURSOR2) & M_POST_CURSOR2) + +#define S_POST_CURSOR3 0 +#define M_POST_CURSOR3 0xfU +#define V_POST_CURSOR3(x) ((x) << S_POST_CURSOR3) +#define G_POST_CURSOR3(x) (((x) >> S_POST_CURSOR3) & M_POST_CURSOR3) + +#define A_MC_ADR_DDRPHY_ADR_IO_SLEW_CTL_VALUE 0x45068 + +#define S_SLEW_CTL0 12 +#define M_SLEW_CTL0 0xfU +#define V_SLEW_CTL0(x) ((x) << S_SLEW_CTL0) +#define G_SLEW_CTL0(x) (((x) >> S_SLEW_CTL0) & M_SLEW_CTL0) + +#define S_SLEW_CTL1 8 +#define M_SLEW_CTL1 0xfU +#define V_SLEW_CTL1(x) ((x) << S_SLEW_CTL1) +#define G_SLEW_CTL1(x) (((x) >> S_SLEW_CTL1) & M_SLEW_CTL1) + +#define S_SLEW_CTL2 4 +#define M_SLEW_CTL2 0xfU +#define V_SLEW_CTL2(x) ((x) << S_SLEW_CTL2) +#define G_SLEW_CTL2(x) (((x) >> S_SLEW_CTL2) & M_SLEW_CTL2) + +#define S_SLEW_CTL3 0 +#define M_SLEW_CTL3 0xfU +#define V_SLEW_CTL3(x) ((x) << S_SLEW_CTL3) +#define G_SLEW_CTL3(x) (((x) >> S_SLEW_CTL3) & M_SLEW_CTL3) + +#define A_MC_ADR_DDRPHY_ADR_IO_FET_SLICE_EN_MAP0 0x45080 + +#define S_SLICE_SEL_REG_BITS0_1 14 +#define M_SLICE_SEL_REG_BITS0_1 0x3U +#define V_SLICE_SEL_REG_BITS0_1(x) ((x) << S_SLICE_SEL_REG_BITS0_1) +#define G_SLICE_SEL_REG_BITS0_1(x) (((x) >> S_SLICE_SEL_REG_BITS0_1) & M_SLICE_SEL_REG_BITS0_1) + +#define S_SLICE_SEL_REG_BITS2_3 12 +#define M_SLICE_SEL_REG_BITS2_3 0x3U +#define V_SLICE_SEL_REG_BITS2_3(x) ((x) << S_SLICE_SEL_REG_BITS2_3) +#define G_SLICE_SEL_REG_BITS2_3(x) (((x) >> S_SLICE_SEL_REG_BITS2_3) & M_SLICE_SEL_REG_BITS2_3) + +#define S_SLICE_SEL_REG_BITS4_5 10 +#define M_SLICE_SEL_REG_BITS4_5 0x3U +#define V_SLICE_SEL_REG_BITS4_5(x) ((x) << S_SLICE_SEL_REG_BITS4_5) +#define G_SLICE_SEL_REG_BITS4_5(x) (((x) >> S_SLICE_SEL_REG_BITS4_5) & M_SLICE_SEL_REG_BITS4_5) + +#define S_SLICE_SEL_REG_BITS6_7 8 +#define M_SLICE_SEL_REG_BITS6_7 0x3U +#define V_SLICE_SEL_REG_BITS6_7(x) ((x) << S_SLICE_SEL_REG_BITS6_7) +#define G_SLICE_SEL_REG_BITS6_7(x) (((x) >> S_SLICE_SEL_REG_BITS6_7) & M_SLICE_SEL_REG_BITS6_7) + +#define S_SLICE_SEL_REG_BITS8_9 6 +#define M_SLICE_SEL_REG_BITS8_9 0x3U +#define V_SLICE_SEL_REG_BITS8_9(x) ((x) << S_SLICE_SEL_REG_BITS8_9) +#define G_SLICE_SEL_REG_BITS8_9(x) (((x) >> S_SLICE_SEL_REG_BITS8_9) & M_SLICE_SEL_REG_BITS8_9) + +#define S_SLICE_SEL_REG_BITS10_11 4 +#define M_SLICE_SEL_REG_BITS10_11 0x3U +#define V_SLICE_SEL_REG_BITS10_11(x) ((x) << S_SLICE_SEL_REG_BITS10_11) +#define G_SLICE_SEL_REG_BITS10_11(x) (((x) >> S_SLICE_SEL_REG_BITS10_11) & M_SLICE_SEL_REG_BITS10_11) + +#define S_SLICE_SEL_REG_BITS12_13 2 +#define M_SLICE_SEL_REG_BITS12_13 0x3U +#define V_SLICE_SEL_REG_BITS12_13(x) ((x) << S_SLICE_SEL_REG_BITS12_13) +#define G_SLICE_SEL_REG_BITS12_13(x) (((x) >> S_SLICE_SEL_REG_BITS12_13) & M_SLICE_SEL_REG_BITS12_13) + +#define S_SLICE_SEL_REG_BITS14_15 0 +#define M_SLICE_SEL_REG_BITS14_15 0x3U +#define V_SLICE_SEL_REG_BITS14_15(x) ((x) << S_SLICE_SEL_REG_BITS14_15) +#define G_SLICE_SEL_REG_BITS14_15(x) (((x) >> S_SLICE_SEL_REG_BITS14_15) & M_SLICE_SEL_REG_BITS14_15) + +#define A_MC_ADR_DDRPHY_ADR_IO_FET_SLICE_EN_MAP1 0x45084 +#define A_MC_ADR_DDRPHY_ADR_IO_POST_CURSOR_VALUE_MAP0 0x450a0 + +#define S_POST_CUR_SEL_BITS0_1 14 +#define M_POST_CUR_SEL_BITS0_1 0x3U +#define V_POST_CUR_SEL_BITS0_1(x) ((x) << S_POST_CUR_SEL_BITS0_1) +#define G_POST_CUR_SEL_BITS0_1(x) (((x) >> S_POST_CUR_SEL_BITS0_1) & M_POST_CUR_SEL_BITS0_1) + +#define S_POST_CUR_SEL_BITS2_3 12 +#define M_POST_CUR_SEL_BITS2_3 0x3U +#define V_POST_CUR_SEL_BITS2_3(x) ((x) << S_POST_CUR_SEL_BITS2_3) +#define G_POST_CUR_SEL_BITS2_3(x) (((x) >> S_POST_CUR_SEL_BITS2_3) & M_POST_CUR_SEL_BITS2_3) + +#define S_POST_CUR_SEL_BITS4_5 10 +#define M_POST_CUR_SEL_BITS4_5 0x3U +#define V_POST_CUR_SEL_BITS4_5(x) ((x) << S_POST_CUR_SEL_BITS4_5) +#define G_POST_CUR_SEL_BITS4_5(x) (((x) >> S_POST_CUR_SEL_BITS4_5) & M_POST_CUR_SEL_BITS4_5) + +#define S_POST_CUR_SEL_BITS6_7 8 +#define M_POST_CUR_SEL_BITS6_7 0x3U +#define V_POST_CUR_SEL_BITS6_7(x) ((x) << S_POST_CUR_SEL_BITS6_7) +#define G_POST_CUR_SEL_BITS6_7(x) (((x) >> S_POST_CUR_SEL_BITS6_7) & M_POST_CUR_SEL_BITS6_7) + +#define S_POST_CUR_SEL_BITS8_9 6 +#define M_POST_CUR_SEL_BITS8_9 0x3U +#define V_POST_CUR_SEL_BITS8_9(x) ((x) << S_POST_CUR_SEL_BITS8_9) +#define G_POST_CUR_SEL_BITS8_9(x) (((x) >> S_POST_CUR_SEL_BITS8_9) & M_POST_CUR_SEL_BITS8_9) + +#define S_POST_CUR_SEL_BITS10_11 4 +#define M_POST_CUR_SEL_BITS10_11 0x3U +#define V_POST_CUR_SEL_BITS10_11(x) ((x) << S_POST_CUR_SEL_BITS10_11) +#define G_POST_CUR_SEL_BITS10_11(x) (((x) >> S_POST_CUR_SEL_BITS10_11) & M_POST_CUR_SEL_BITS10_11) + +#define S_POST_CUR_SEL_BITS12_13 2 +#define M_POST_CUR_SEL_BITS12_13 0x3U +#define V_POST_CUR_SEL_BITS12_13(x) ((x) << S_POST_CUR_SEL_BITS12_13) +#define G_POST_CUR_SEL_BITS12_13(x) (((x) >> S_POST_CUR_SEL_BITS12_13) & M_POST_CUR_SEL_BITS12_13) + +#define S_POST_CUR_SEL_BITS14_15 0 +#define M_POST_CUR_SEL_BITS14_15 0x3U +#define V_POST_CUR_SEL_BITS14_15(x) ((x) << S_POST_CUR_SEL_BITS14_15) +#define G_POST_CUR_SEL_BITS14_15(x) (((x) >> S_POST_CUR_SEL_BITS14_15) & M_POST_CUR_SEL_BITS14_15) + +#define A_MC_ADR_DDRPHY_ADR_IO_POST_CURSOR_VALUE_MAP1 0x450a4 +#define A_MC_ADR_DDRPHY_ADR_IO_SLEW_CTL_VALUE_MAP0 0x450a8 + +#define S_SLEW_CTL_SEL_BITS0_1 14 +#define M_SLEW_CTL_SEL_BITS0_1 0x3U +#define V_SLEW_CTL_SEL_BITS0_1(x) ((x) << S_SLEW_CTL_SEL_BITS0_1) +#define G_SLEW_CTL_SEL_BITS0_1(x) (((x) >> S_SLEW_CTL_SEL_BITS0_1) & M_SLEW_CTL_SEL_BITS0_1) + +#define S_SLEW_CTL_SEL_BITS2_3 12 +#define M_SLEW_CTL_SEL_BITS2_3 0x3U +#define V_SLEW_CTL_SEL_BITS2_3(x) ((x) << S_SLEW_CTL_SEL_BITS2_3) +#define G_SLEW_CTL_SEL_BITS2_3(x) (((x) >> S_SLEW_CTL_SEL_BITS2_3) & M_SLEW_CTL_SEL_BITS2_3) + +#define S_SLEW_CTL_SEL_BITS4_5 10 +#define M_SLEW_CTL_SEL_BITS4_5 0x3U +#define V_SLEW_CTL_SEL_BITS4_5(x) ((x) << S_SLEW_CTL_SEL_BITS4_5) +#define G_SLEW_CTL_SEL_BITS4_5(x) (((x) >> S_SLEW_CTL_SEL_BITS4_5) & M_SLEW_CTL_SEL_BITS4_5) + +#define S_SLEW_CTL_SEL_BITS6_7 8 +#define M_SLEW_CTL_SEL_BITS6_7 0x3U +#define V_SLEW_CTL_SEL_BITS6_7(x) ((x) << S_SLEW_CTL_SEL_BITS6_7) +#define G_SLEW_CTL_SEL_BITS6_7(x) (((x) >> S_SLEW_CTL_SEL_BITS6_7) & M_SLEW_CTL_SEL_BITS6_7) + +#define S_SLEW_CTL_SEL_BITS8_9 6 +#define M_SLEW_CTL_SEL_BITS8_9 0x3U +#define V_SLEW_CTL_SEL_BITS8_9(x) ((x) << S_SLEW_CTL_SEL_BITS8_9) +#define G_SLEW_CTL_SEL_BITS8_9(x) (((x) >> S_SLEW_CTL_SEL_BITS8_9) & M_SLEW_CTL_SEL_BITS8_9) + +#define S_SLEW_CTL_SEL_BITS10_11 4 +#define M_SLEW_CTL_SEL_BITS10_11 0x3U +#define V_SLEW_CTL_SEL_BITS10_11(x) ((x) << S_SLEW_CTL_SEL_BITS10_11) +#define G_SLEW_CTL_SEL_BITS10_11(x) (((x) >> S_SLEW_CTL_SEL_BITS10_11) & M_SLEW_CTL_SEL_BITS10_11) + +#define S_SLEW_CTL_SEL_BITS12_13 2 +#define M_SLEW_CTL_SEL_BITS12_13 0x3U +#define V_SLEW_CTL_SEL_BITS12_13(x) ((x) << S_SLEW_CTL_SEL_BITS12_13) +#define G_SLEW_CTL_SEL_BITS12_13(x) (((x) >> S_SLEW_CTL_SEL_BITS12_13) & M_SLEW_CTL_SEL_BITS12_13) + +#define S_SLEW_CTL_SEL_BITS14_15 0 +#define M_SLEW_CTL_SEL_BITS14_15 0x3U +#define V_SLEW_CTL_SEL_BITS14_15(x) ((x) << S_SLEW_CTL_SEL_BITS14_15) +#define G_SLEW_CTL_SEL_BITS14_15(x) (((x) >> S_SLEW_CTL_SEL_BITS14_15) & M_SLEW_CTL_SEL_BITS14_15) + +#define A_MC_ADR_DDRPHY_ADR_IO_SLEW_CTL_VALUE_MAP1 0x450ac +#define A_MC_ADR_DDRPHY_ADR_POWERDOWN_2 0x450b0 + +#define S_ADR_LANE_0_11_PD 4 +#define M_ADR_LANE_0_11_PD 0xfffU +#define V_ADR_LANE_0_11_PD(x) ((x) << S_ADR_LANE_0_11_PD) +#define G_ADR_LANE_0_11_PD(x) (((x) >> S_ADR_LANE_0_11_PD) & M_ADR_LANE_0_11_PD) + +#define S_ADR_LANE_12_15_PD 0 +#define M_ADR_LANE_12_15_PD 0xfU +#define V_ADR_LANE_12_15_PD(x) ((x) << S_ADR_LANE_12_15_PD) +#define G_ADR_LANE_12_15_PD(x) (((x) >> S_ADR_LANE_12_15_PD) & M_ADR_LANE_12_15_PD) + +#define A_MC_DDRPHY_ADR_PLL_VREG_CONFIG_0 0x460c0 + +#define S_PLL_TUNE_0_2 13 +#define M_PLL_TUNE_0_2 0x7U +#define V_PLL_TUNE_0_2(x) ((x) << S_PLL_TUNE_0_2) +#define G_PLL_TUNE_0_2(x) (((x) >> S_PLL_TUNE_0_2) & M_PLL_TUNE_0_2) + +#define S_PLL_TUNECP_0_2 10 +#define M_PLL_TUNECP_0_2 0x7U +#define V_PLL_TUNECP_0_2(x) ((x) << S_PLL_TUNECP_0_2) +#define G_PLL_TUNECP_0_2(x) (((x) >> S_PLL_TUNECP_0_2) & M_PLL_TUNECP_0_2) + +#define S_PLL_TUNEF_0_5 4 +#define M_PLL_TUNEF_0_5 0x3fU +#define V_PLL_TUNEF_0_5(x) ((x) << S_PLL_TUNEF_0_5) +#define G_PLL_TUNEF_0_5(x) (((x) >> S_PLL_TUNEF_0_5) & M_PLL_TUNEF_0_5) + +#define S_PLL_TUNEVCO_0_1 2 +#define M_PLL_TUNEVCO_0_1 0x3U +#define V_PLL_TUNEVCO_0_1(x) ((x) << S_PLL_TUNEVCO_0_1) +#define G_PLL_TUNEVCO_0_1(x) (((x) >> S_PLL_TUNEVCO_0_1) & M_PLL_TUNEVCO_0_1) + +#define S_PLL_PLLXTR_0_1 0 +#define M_PLL_PLLXTR_0_1 0x3U +#define V_PLL_PLLXTR_0_1(x) ((x) << S_PLL_PLLXTR_0_1) +#define G_PLL_PLLXTR_0_1(x) (((x) >> S_PLL_PLLXTR_0_1) & M_PLL_PLLXTR_0_1) + +#define A_MC_DDRPHY_ADR_PLL_VREG_CONFIG_1 0x460c4 + +#define S_PLL_TUNETDIV_0_2 13 +#define M_PLL_TUNETDIV_0_2 0x7U +#define V_PLL_TUNETDIV_0_2(x) ((x) << S_PLL_TUNETDIV_0_2) +#define G_PLL_TUNETDIV_0_2(x) (((x) >> S_PLL_TUNETDIV_0_2) & M_PLL_TUNETDIV_0_2) + +#define S_PLL_TUNEMDIV_0_1 11 +#define M_PLL_TUNEMDIV_0_1 0x3U +#define V_PLL_TUNEMDIV_0_1(x) ((x) << S_PLL_TUNEMDIV_0_1) +#define G_PLL_TUNEMDIV_0_1(x) (((x) >> S_PLL_TUNEMDIV_0_1) & M_PLL_TUNEMDIV_0_1) + +#define S_PLL_TUNEATST 10 +#define V_PLL_TUNEATST(x) ((x) << S_PLL_TUNEATST) +#define F_PLL_TUNEATST V_PLL_TUNEATST(1U) + +#define S_VREG_RANGE_0_1 8 +#define M_VREG_RANGE_0_1 0x3U +#define V_VREG_RANGE_0_1(x) ((x) << S_VREG_RANGE_0_1) +#define G_VREG_RANGE_0_1(x) (((x) >> S_VREG_RANGE_0_1) & M_VREG_RANGE_0_1) + +#define S_VREG_VREGSPARE 7 +#define V_VREG_VREGSPARE(x) ((x) << S_VREG_VREGSPARE) +#define F_VREG_VREGSPARE V_VREG_VREGSPARE(1U) + +#define S_VREG_VCCTUNE_0_1 5 +#define M_VREG_VCCTUNE_0_1 0x3U +#define V_VREG_VCCTUNE_0_1(x) ((x) << S_VREG_VCCTUNE_0_1) +#define G_VREG_VCCTUNE_0_1(x) (((x) >> S_VREG_VCCTUNE_0_1) & M_VREG_VCCTUNE_0_1) + +#define S_INTERP_SIG_SLEW_0_3 1 +#define M_INTERP_SIG_SLEW_0_3 0xfU +#define V_INTERP_SIG_SLEW_0_3(x) ((x) << S_INTERP_SIG_SLEW_0_3) +#define G_INTERP_SIG_SLEW_0_3(x) (((x) >> S_INTERP_SIG_SLEW_0_3) & M_INTERP_SIG_SLEW_0_3) + +#define S_ANALOG_WRAPON 0 +#define V_ANALOG_WRAPON(x) ((x) << S_ANALOG_WRAPON) +#define F_ANALOG_WRAPON V_ANALOG_WRAPON(1U) + +#define A_MC_DDRPHY_ADR_SYSCLK_CNTL_PR 0x460c8 + +#define S_SYSCLK_ENABLE 15 +#define V_SYSCLK_ENABLE(x) ((x) << S_SYSCLK_ENABLE) +#define F_SYSCLK_ENABLE V_SYSCLK_ENABLE(1U) + +#define S_SYSCLK_ROT_OVERRIDE 8 +#define M_SYSCLK_ROT_OVERRIDE 0x7fU +#define V_SYSCLK_ROT_OVERRIDE(x) ((x) << S_SYSCLK_ROT_OVERRIDE) +#define G_SYSCLK_ROT_OVERRIDE(x) (((x) >> S_SYSCLK_ROT_OVERRIDE) & M_SYSCLK_ROT_OVERRIDE) + +#define S_SYSCLK_ROT_OVERRIDE_EN 7 +#define V_SYSCLK_ROT_OVERRIDE_EN(x) ((x) << S_SYSCLK_ROT_OVERRIDE_EN) +#define F_SYSCLK_ROT_OVERRIDE_EN V_SYSCLK_ROT_OVERRIDE_EN(1U) + +#define S_SYSCLK_PHASE_ALIGN_RESE 6 +#define V_SYSCLK_PHASE_ALIGN_RESE(x) ((x) << S_SYSCLK_PHASE_ALIGN_RESE) +#define F_SYSCLK_PHASE_ALIGN_RESE V_SYSCLK_PHASE_ALIGN_RESE(1U) + +#define S_SYSCLK_PHASE_CNTL_EN 5 +#define V_SYSCLK_PHASE_CNTL_EN(x) ((x) << S_SYSCLK_PHASE_CNTL_EN) +#define F_SYSCLK_PHASE_CNTL_EN V_SYSCLK_PHASE_CNTL_EN(1U) + +#define S_SYSCLK_PHASE_DEFAULT_EN 4 +#define V_SYSCLK_PHASE_DEFAULT_EN(x) ((x) << S_SYSCLK_PHASE_DEFAULT_EN) +#define F_SYSCLK_PHASE_DEFAULT_EN V_SYSCLK_PHASE_DEFAULT_EN(1U) + +#define S_SYSCLK_POS_EDGE_ALIGN 3 +#define V_SYSCLK_POS_EDGE_ALIGN(x) ((x) << S_SYSCLK_POS_EDGE_ALIGN) +#define F_SYSCLK_POS_EDGE_ALIGN V_SYSCLK_POS_EDGE_ALIGN(1U) + +#define S_CONTINUOUS_UPDATE 2 +#define V_CONTINUOUS_UPDATE(x) ((x) << S_CONTINUOUS_UPDATE) +#define F_CONTINUOUS_UPDATE V_CONTINUOUS_UPDATE(1U) + +#define S_CE0DLTVCC 0 +#define M_CE0DLTVCC 0x3U +#define V_CE0DLTVCC(x) ((x) << S_CE0DLTVCC) +#define G_CE0DLTVCC(x) (((x) >> S_CE0DLTVCC) & M_CE0DLTVCC) + +#define A_MC_DDRPHY_ADR_MCCLK_WRCLK_PR_STATIC_OFFSET 0x460cc + +#define S_TSYS_WRCLK 8 +#define M_TSYS_WRCLK 0x7fU +#define V_TSYS_WRCLK(x) ((x) << S_TSYS_WRCLK) +#define G_TSYS_WRCLK(x) (((x) >> S_TSYS_WRCLK) & M_TSYS_WRCLK) + +#define A_MC_DDRPHY_ADR_SYSCLK_PR_VALUE_RO 0x460d0 + +#define S_SLEW_LATE_SAMPLE 15 +#define V_SLEW_LATE_SAMPLE(x) ((x) << S_SLEW_LATE_SAMPLE) +#define F_SLEW_LATE_SAMPLE V_SLEW_LATE_SAMPLE(1U) + +#define S_SYSCLK_ROT 8 +#define M_SYSCLK_ROT 0x7fU +#define V_SYSCLK_ROT(x) ((x) << S_SYSCLK_ROT) +#define G_SYSCLK_ROT(x) (((x) >> S_SYSCLK_ROT) & M_SYSCLK_ROT) + +#define S_BB_LOCK 7 +#define V_BB_LOCK(x) ((x) << S_BB_LOCK) +#define F_BB_LOCK V_BB_LOCK(1U) + +#define S_SLEW_EARLY_SAMPLE 6 +#define V_SLEW_EARLY_SAMPLE(x) ((x) << S_SLEW_EARLY_SAMPLE) +#define F_SLEW_EARLY_SAMPLE V_SLEW_EARLY_SAMPLE(1U) + +#define S_SLEW_DONE_STATUS 4 +#define M_SLEW_DONE_STATUS 0x3U +#define V_SLEW_DONE_STATUS(x) ((x) << S_SLEW_DONE_STATUS) +#define G_SLEW_DONE_STATUS(x) (((x) >> S_SLEW_DONE_STATUS) & M_SLEW_DONE_STATUS) + +#define S_SLEW_CNTL 0 +#define M_SLEW_CNTL 0xfU +#define V_SLEW_CNTL(x) ((x) << S_SLEW_CNTL) +#define G_SLEW_CNTL(x) (((x) >> S_SLEW_CNTL) & M_SLEW_CNTL) + +#define A_MC_DDRPHY_ADR_GMTEST_ATEST_CNTL 0x460d4 + +#define S_FLUSH 15 +#define V_FLUSH(x) ((x) << S_FLUSH) +#define F_FLUSH V_FLUSH(1U) + +#define S_GIANT_MUX_TEST_EN 14 +#define V_GIANT_MUX_TEST_EN(x) ((x) << S_GIANT_MUX_TEST_EN) +#define F_GIANT_MUX_TEST_EN V_GIANT_MUX_TEST_EN(1U) + +#define S_GIANT_MUX_TEST_VAL 13 +#define V_GIANT_MUX_TEST_VAL(x) ((x) << S_GIANT_MUX_TEST_VAL) +#define F_GIANT_MUX_TEST_VAL V_GIANT_MUX_TEST_VAL(1U) + +#define S_HS_PROBE_A_SEL_ 8 +#define M_HS_PROBE_A_SEL_ 0xfU +#define V_HS_PROBE_A_SEL_(x) ((x) << S_HS_PROBE_A_SEL_) +#define G_HS_PROBE_A_SEL_(x) (((x) >> S_HS_PROBE_A_SEL_) & M_HS_PROBE_A_SEL_) + +#define S_HS_PROBE_B_SEL_ 4 +#define M_HS_PROBE_B_SEL_ 0xfU +#define V_HS_PROBE_B_SEL_(x) ((x) << S_HS_PROBE_B_SEL_) +#define G_HS_PROBE_B_SEL_(x) (((x) >> S_HS_PROBE_B_SEL_) & M_HS_PROBE_B_SEL_) + +#define S_ATEST1CTL0 3 +#define V_ATEST1CTL0(x) ((x) << S_ATEST1CTL0) +#define F_ATEST1CTL0 V_ATEST1CTL0(1U) + +#define S_ATEST1CTL1 2 +#define V_ATEST1CTL1(x) ((x) << S_ATEST1CTL1) +#define F_ATEST1CTL1 V_ATEST1CTL1(1U) + +#define S_ATEST1CTL2 1 +#define V_ATEST1CTL2(x) ((x) << S_ATEST1CTL2) +#define F_ATEST1CTL2 V_ATEST1CTL2(1U) + +#define S_ATEST1CTL3 0 +#define V_ATEST1CTL3(x) ((x) << S_ATEST1CTL3) +#define F_ATEST1CTL3 V_ATEST1CTL3(1U) + +#define A_MC_DDRPHY_ADR_GIANT_MUX_RESULTS_A0 0x460d8 + +#define S_GIANT_MUX_TEST_RESULTS 0 +#define M_GIANT_MUX_TEST_RESULTS 0xffffU +#define V_GIANT_MUX_TEST_RESULTS(x) ((x) << S_GIANT_MUX_TEST_RESULTS) +#define G_GIANT_MUX_TEST_RESULTS(x) (((x) >> S_GIANT_MUX_TEST_RESULTS) & M_GIANT_MUX_TEST_RESULTS) + +#define A_MC_DDRPHY_ADR_GIANT_MUX_RESULTS_A1 0x460dc +#define A_MC_DDRPHY_ADR_POWERDOWN_1 0x460e0 + +#define S_MASTER_PD_CNTL 15 +#define V_MASTER_PD_CNTL(x) ((x) << S_MASTER_PD_CNTL) +#define F_MASTER_PD_CNTL V_MASTER_PD_CNTL(1U) + +#define S_ANALOG_INPUT_STAB2 14 +#define V_ANALOG_INPUT_STAB2(x) ((x) << S_ANALOG_INPUT_STAB2) +#define F_ANALOG_INPUT_STAB2 V_ANALOG_INPUT_STAB2(1U) + +#define S_ANALOG_INPUT_STAB1 8 +#define V_ANALOG_INPUT_STAB1(x) ((x) << S_ANALOG_INPUT_STAB1) +#define F_ANALOG_INPUT_STAB1 V_ANALOG_INPUT_STAB1(1U) + +#define S_SYSCLK_CLK_GATE 6 +#define M_SYSCLK_CLK_GATE 0x3U +#define V_SYSCLK_CLK_GATE(x) ((x) << S_SYSCLK_CLK_GATE) +#define G_SYSCLK_CLK_GATE(x) (((x) >> S_SYSCLK_CLK_GATE) & M_SYSCLK_CLK_GATE) + +#define S_WR_FIFO_STAB 5 +#define V_WR_FIFO_STAB(x) ((x) << S_WR_FIFO_STAB) +#define F_WR_FIFO_STAB V_WR_FIFO_STAB(1U) + +#define S_ADR_RX_PD 4 +#define V_ADR_RX_PD(x) ((x) << S_ADR_RX_PD) +#define F_ADR_RX_PD V_ADR_RX_PD(1U) + +#define S_TX_TRISTATE_CNTL 1 +#define V_TX_TRISTATE_CNTL(x) ((x) << S_TX_TRISTATE_CNTL) +#define F_TX_TRISTATE_CNTL V_TX_TRISTATE_CNTL(1U) + +#define S_DVCC_REG_PD 0 +#define V_DVCC_REG_PD(x) ((x) << S_DVCC_REG_PD) +#define F_DVCC_REG_PD V_DVCC_REG_PD(1U) + +#define A_MC_DDRPHY_ADR_SLEW_CAL_CNTL 0x460e4 + +#define S_SLEW_CAL_ENABLE 15 +#define V_SLEW_CAL_ENABLE(x) ((x) << S_SLEW_CAL_ENABLE) +#define F_SLEW_CAL_ENABLE V_SLEW_CAL_ENABLE(1U) + +#define S_SLEW_CAL_START 14 +#define V_SLEW_CAL_START(x) ((x) << S_SLEW_CAL_START) +#define F_SLEW_CAL_START V_SLEW_CAL_START(1U) + +#define S_SLEW_CAL_OVERRIDE_EN 12 +#define V_SLEW_CAL_OVERRIDE_EN(x) ((x) << S_SLEW_CAL_OVERRIDE_EN) +#define F_SLEW_CAL_OVERRIDE_EN V_SLEW_CAL_OVERRIDE_EN(1U) + +#define S_SLEW_CAL_OVERRIDE 8 +#define M_SLEW_CAL_OVERRIDE 0xfU +#define V_SLEW_CAL_OVERRIDE(x) ((x) << S_SLEW_CAL_OVERRIDE) +#define G_SLEW_CAL_OVERRIDE(x) (((x) >> S_SLEW_CAL_OVERRIDE) & M_SLEW_CAL_OVERRIDE) + +#define S_SLEW_TARGET_PR_OFFSET 0 +#define M_SLEW_TARGET_PR_OFFSET 0x1fU +#define V_SLEW_TARGET_PR_OFFSET(x) ((x) << S_SLEW_TARGET_PR_OFFSET) +#define G_SLEW_TARGET_PR_OFFSET(x) (((x) >> S_SLEW_TARGET_PR_OFFSET) & M_SLEW_TARGET_PR_OFFSET) + +#define A_MC_DDRPHY_PC_DP18_PLL_LOCK_STATUS 0x47000 + +#define S_DP18_PLL_LOCK 1 +#define M_DP18_PLL_LOCK 0x7fffU +#define V_DP18_PLL_LOCK(x) ((x) << S_DP18_PLL_LOCK) +#define G_DP18_PLL_LOCK(x) (((x) >> S_DP18_PLL_LOCK) & M_DP18_PLL_LOCK) + +#define A_MC_DDRPHY_PC_AD32S_PLL_LOCK_STATUS 0x47004 + +#define S_AD32S_PLL_LOCK 14 +#define M_AD32S_PLL_LOCK 0x3U +#define V_AD32S_PLL_LOCK(x) ((x) << S_AD32S_PLL_LOCK) +#define G_AD32S_PLL_LOCK(x) (((x) >> S_AD32S_PLL_LOCK) & M_AD32S_PLL_LOCK) + +#define A_MC_DDRPHY_PC_RANK_PAIR0 0x47008 + +#define S_RANK_PAIR0_PRI 13 +#define M_RANK_PAIR0_PRI 0x7U +#define V_RANK_PAIR0_PRI(x) ((x) << S_RANK_PAIR0_PRI) +#define G_RANK_PAIR0_PRI(x) (((x) >> S_RANK_PAIR0_PRI) & M_RANK_PAIR0_PRI) + +#define S_RANK_PAIR0_PRI_V 12 +#define V_RANK_PAIR0_PRI_V(x) ((x) << S_RANK_PAIR0_PRI_V) +#define F_RANK_PAIR0_PRI_V V_RANK_PAIR0_PRI_V(1U) + +#define S_RANK_PAIR0_SEC 9 +#define M_RANK_PAIR0_SEC 0x7U +#define V_RANK_PAIR0_SEC(x) ((x) << S_RANK_PAIR0_SEC) +#define G_RANK_PAIR0_SEC(x) (((x) >> S_RANK_PAIR0_SEC) & M_RANK_PAIR0_SEC) + +#define S_RANK_PAIR0_SEC_V 8 +#define V_RANK_PAIR0_SEC_V(x) ((x) << S_RANK_PAIR0_SEC_V) +#define F_RANK_PAIR0_SEC_V V_RANK_PAIR0_SEC_V(1U) + +#define S_RANK_PAIR1_PRI 5 +#define M_RANK_PAIR1_PRI 0x7U +#define V_RANK_PAIR1_PRI(x) ((x) << S_RANK_PAIR1_PRI) +#define G_RANK_PAIR1_PRI(x) (((x) >> S_RANK_PAIR1_PRI) & M_RANK_PAIR1_PRI) + +#define S_RANK_PAIR1_PRI_V 4 +#define V_RANK_PAIR1_PRI_V(x) ((x) << S_RANK_PAIR1_PRI_V) +#define F_RANK_PAIR1_PRI_V V_RANK_PAIR1_PRI_V(1U) + +#define S_RANK_PAIR1_SEC 1 +#define M_RANK_PAIR1_SEC 0x7U +#define V_RANK_PAIR1_SEC(x) ((x) << S_RANK_PAIR1_SEC) +#define G_RANK_PAIR1_SEC(x) (((x) >> S_RANK_PAIR1_SEC) & M_RANK_PAIR1_SEC) + +#define S_RANK_PAIR1_SEC_V 0 +#define V_RANK_PAIR1_SEC_V(x) ((x) << S_RANK_PAIR1_SEC_V) +#define F_RANK_PAIR1_SEC_V V_RANK_PAIR1_SEC_V(1U) + +#define A_MC_DDRPHY_PC_RANK_PAIR1 0x4700c + +#define S_RANK_PAIR2_PRI 13 +#define M_RANK_PAIR2_PRI 0x7U +#define V_RANK_PAIR2_PRI(x) ((x) << S_RANK_PAIR2_PRI) +#define G_RANK_PAIR2_PRI(x) (((x) >> S_RANK_PAIR2_PRI) & M_RANK_PAIR2_PRI) + +#define S_RANK_PAIR2_PRI_V 12 +#define V_RANK_PAIR2_PRI_V(x) ((x) << S_RANK_PAIR2_PRI_V) +#define F_RANK_PAIR2_PRI_V V_RANK_PAIR2_PRI_V(1U) + +#define S_RANK_PAIR2_SEC 9 +#define M_RANK_PAIR2_SEC 0x7U +#define V_RANK_PAIR2_SEC(x) ((x) << S_RANK_PAIR2_SEC) +#define G_RANK_PAIR2_SEC(x) (((x) >> S_RANK_PAIR2_SEC) & M_RANK_PAIR2_SEC) + +#define S_RANK_PAIR2_SEC_V 8 +#define V_RANK_PAIR2_SEC_V(x) ((x) << S_RANK_PAIR2_SEC_V) +#define F_RANK_PAIR2_SEC_V V_RANK_PAIR2_SEC_V(1U) + +#define S_RANK_PAIR3_PRI 5 +#define M_RANK_PAIR3_PRI 0x7U +#define V_RANK_PAIR3_PRI(x) ((x) << S_RANK_PAIR3_PRI) +#define G_RANK_PAIR3_PRI(x) (((x) >> S_RANK_PAIR3_PRI) & M_RANK_PAIR3_PRI) + +#define S_RANK_PAIR3_PRI_V 4 +#define V_RANK_PAIR3_PRI_V(x) ((x) << S_RANK_PAIR3_PRI_V) +#define F_RANK_PAIR3_PRI_V V_RANK_PAIR3_PRI_V(1U) + +#define S_RANK_PAIR3_SEC 1 +#define M_RANK_PAIR3_SEC 0x7U +#define V_RANK_PAIR3_SEC(x) ((x) << S_RANK_PAIR3_SEC) +#define G_RANK_PAIR3_SEC(x) (((x) >> S_RANK_PAIR3_SEC) & M_RANK_PAIR3_SEC) + +#define S_RANK_PAIR3_SEC_V 0 +#define V_RANK_PAIR3_SEC_V(x) ((x) << S_RANK_PAIR3_SEC_V) +#define F_RANK_PAIR3_SEC_V V_RANK_PAIR3_SEC_V(1U) + +#define A_MC_DDRPHY_PC_BASE_CNTR0 0x47010 + +#define S_PERIODIC_BASE_CNTR0 0 +#define M_PERIODIC_BASE_CNTR0 0xffffU +#define V_PERIODIC_BASE_CNTR0(x) ((x) << S_PERIODIC_BASE_CNTR0) +#define G_PERIODIC_BASE_CNTR0(x) (((x) >> S_PERIODIC_BASE_CNTR0) & M_PERIODIC_BASE_CNTR0) + +#define A_MC_DDRPHY_PC_RELOAD_VALUE0 0x47014 + +#define S_PERIODIC_CAL_REQ_EN 15 +#define V_PERIODIC_CAL_REQ_EN(x) ((x) << S_PERIODIC_CAL_REQ_EN) +#define F_PERIODIC_CAL_REQ_EN V_PERIODIC_CAL_REQ_EN(1U) + +#define S_PERIODIC_RELOAD_VALUE0 0 +#define M_PERIODIC_RELOAD_VALUE0 0x7fffU +#define V_PERIODIC_RELOAD_VALUE0(x) ((x) << S_PERIODIC_RELOAD_VALUE0) +#define G_PERIODIC_RELOAD_VALUE0(x) (((x) >> S_PERIODIC_RELOAD_VALUE0) & M_PERIODIC_RELOAD_VALUE0) + +#define A_MC_DDRPHY_PC_BASE_CNTR1 0x47018 + +#define S_PERIODIC_BASE_CNTR1 0 +#define M_PERIODIC_BASE_CNTR1 0xffffU +#define V_PERIODIC_BASE_CNTR1(x) ((x) << S_PERIODIC_BASE_CNTR1) +#define G_PERIODIC_BASE_CNTR1(x) (((x) >> S_PERIODIC_BASE_CNTR1) & M_PERIODIC_BASE_CNTR1) + +#define A_MC_DDRPHY_PC_CAL_TIMER 0x4701c + +#define S_PERIODIC_CAL_TIMER 0 +#define M_PERIODIC_CAL_TIMER 0xffffU +#define V_PERIODIC_CAL_TIMER(x) ((x) << S_PERIODIC_CAL_TIMER) +#define G_PERIODIC_CAL_TIMER(x) (((x) >> S_PERIODIC_CAL_TIMER) & M_PERIODIC_CAL_TIMER) + +#define A_MC_DDRPHY_PC_CAL_TIMER_RELOAD_VALUE 0x47020 + +#define S_PERIODIC_TIMER_RELOAD_VALUE 0 +#define M_PERIODIC_TIMER_RELOAD_VALUE 0xffffU +#define V_PERIODIC_TIMER_RELOAD_VALUE(x) ((x) << S_PERIODIC_TIMER_RELOAD_VALUE) +#define G_PERIODIC_TIMER_RELOAD_VALUE(x) (((x) >> S_PERIODIC_TIMER_RELOAD_VALUE) & M_PERIODIC_TIMER_RELOAD_VALUE) + +#define A_MC_DDRPHY_PC_ZCAL_TIMER 0x47024 + +#define S_PERIODIC_ZCAL_TIMER 0 +#define M_PERIODIC_ZCAL_TIMER 0xffffU +#define V_PERIODIC_ZCAL_TIMER(x) ((x) << S_PERIODIC_ZCAL_TIMER) +#define G_PERIODIC_ZCAL_TIMER(x) (((x) >> S_PERIODIC_ZCAL_TIMER) & M_PERIODIC_ZCAL_TIMER) + +#define A_MC_DDRPHY_PC_ZCAL_TIMER_RELOAD_VALUE 0x47028 +#define A_MC_DDRPHY_PC_PER_CAL_CONFIG 0x4702c + +#define S_PER_ENA_RANK_PAIR 12 +#define M_PER_ENA_RANK_PAIR 0xfU +#define V_PER_ENA_RANK_PAIR(x) ((x) << S_PER_ENA_RANK_PAIR) +#define G_PER_ENA_RANK_PAIR(x) (((x) >> S_PER_ENA_RANK_PAIR) & M_PER_ENA_RANK_PAIR) + +#define S_PER_ENA_ZCAL 11 +#define V_PER_ENA_ZCAL(x) ((x) << S_PER_ENA_ZCAL) +#define F_PER_ENA_ZCAL V_PER_ENA_ZCAL(1U) + +#define S_PER_ENA_SYSCLK_ALIGN 10 +#define V_PER_ENA_SYSCLK_ALIGN(x) ((x) << S_PER_ENA_SYSCLK_ALIGN) +#define F_PER_ENA_SYSCLK_ALIGN V_PER_ENA_SYSCLK_ALIGN(1U) + +#define S_ENA_PER_RDCLK_ALIGN 9 +#define V_ENA_PER_RDCLK_ALIGN(x) ((x) << S_ENA_PER_RDCLK_ALIGN) +#define F_ENA_PER_RDCLK_ALIGN V_ENA_PER_RDCLK_ALIGN(1U) + +#define S_ENA_PER_DQS_ALIGN 8 +#define V_ENA_PER_DQS_ALIGN(x) ((x) << S_ENA_PER_DQS_ALIGN) +#define F_ENA_PER_DQS_ALIGN V_ENA_PER_DQS_ALIGN(1U) + +#define S_ENA_PER_READ_CTR 7 +#define V_ENA_PER_READ_CTR(x) ((x) << S_ENA_PER_READ_CTR) +#define F_ENA_PER_READ_CTR V_ENA_PER_READ_CTR(1U) + +#define S_PER_NEXT_RANK_PAIR 5 +#define M_PER_NEXT_RANK_PAIR 0x3U +#define V_PER_NEXT_RANK_PAIR(x) ((x) << S_PER_NEXT_RANK_PAIR) +#define G_PER_NEXT_RANK_PAIR(x) (((x) >> S_PER_NEXT_RANK_PAIR) & M_PER_NEXT_RANK_PAIR) + +#define S_FAST_SIM_PER_CNTR 4 +#define V_FAST_SIM_PER_CNTR(x) ((x) << S_FAST_SIM_PER_CNTR) +#define F_FAST_SIM_PER_CNTR V_FAST_SIM_PER_CNTR(1U) + +#define S_START_INIT_CAL 3 +#define V_START_INIT_CAL(x) ((x) << S_START_INIT_CAL) +#define F_START_INIT_CAL V_START_INIT_CAL(1U) + +#define S_START_PER_CAL 2 +#define V_START_PER_CAL(x) ((x) << S_START_PER_CAL) +#define F_START_PER_CAL V_START_PER_CAL(1U) + +#define A_MC_DDRPHY_PC_CONFIG0 0x47030 + +#define S_PROTOCOL_DDR 12 +#define M_PROTOCOL_DDR 0xfU +#define V_PROTOCOL_DDR(x) ((x) << S_PROTOCOL_DDR) +#define G_PROTOCOL_DDR(x) (((x) >> S_PROTOCOL_DDR) & M_PROTOCOL_DDR) + +#define S_DATA_MUX4_1MODE 11 +#define V_DATA_MUX4_1MODE(x) ((x) << S_DATA_MUX4_1MODE) +#define F_DATA_MUX4_1MODE V_DATA_MUX4_1MODE(1U) + +#define S_DDR4_CMD_SIG_REDUCTION 9 +#define V_DDR4_CMD_SIG_REDUCTION(x) ((x) << S_DDR4_CMD_SIG_REDUCTION) +#define F_DDR4_CMD_SIG_REDUCTION V_DDR4_CMD_SIG_REDUCTION(1U) + +#define S_SYSCLK_2X_MEMINTCLKO 8 +#define V_SYSCLK_2X_MEMINTCLKO(x) ((x) << S_SYSCLK_2X_MEMINTCLKO) +#define F_SYSCLK_2X_MEMINTCLKO V_SYSCLK_2X_MEMINTCLKO(1U) + +#define S_RANK_OVERRIDE 7 +#define V_RANK_OVERRIDE(x) ((x) << S_RANK_OVERRIDE) +#define F_RANK_OVERRIDE V_RANK_OVERRIDE(1U) + +#define S_RANK_OVERRIDE_VALUE 4 +#define M_RANK_OVERRIDE_VALUE 0x7U +#define V_RANK_OVERRIDE_VALUE(x) ((x) << S_RANK_OVERRIDE_VALUE) +#define G_RANK_OVERRIDE_VALUE(x) (((x) >> S_RANK_OVERRIDE_VALUE) & M_RANK_OVERRIDE_VALUE) + +#define S_LOW_LATENCY 3 +#define V_LOW_LATENCY(x) ((x) << S_LOW_LATENCY) +#define F_LOW_LATENCY V_LOW_LATENCY(1U) + +#define S_DDR4_BANK_REFRESH 2 +#define V_DDR4_BANK_REFRESH(x) ((x) << S_DDR4_BANK_REFRESH) +#define F_DDR4_BANK_REFRESH V_DDR4_BANK_REFRESH(1U) + +#define S_DDR4_VLEVEL_BANK_GROUP 1 +#define V_DDR4_VLEVEL_BANK_GROUP(x) ((x) << S_DDR4_VLEVEL_BANK_GROUP) +#define F_DDR4_VLEVEL_BANK_GROUP V_DDR4_VLEVEL_BANK_GROUP(1U) + +#define A_MC_DDRPHY_PC_CONFIG1 0x47034 + +#define S_WRITE_LATENCY_OFFSET 12 +#define M_WRITE_LATENCY_OFFSET 0xfU +#define V_WRITE_LATENCY_OFFSET(x) ((x) << S_WRITE_LATENCY_OFFSET) +#define G_WRITE_LATENCY_OFFSET(x) (((x) >> S_WRITE_LATENCY_OFFSET) & M_WRITE_LATENCY_OFFSET) + +#define S_READ_LATENCY_OFFSET 8 +#define M_READ_LATENCY_OFFSET 0xfU +#define V_READ_LATENCY_OFFSET(x) ((x) << S_READ_LATENCY_OFFSET) +#define G_READ_LATENCY_OFFSET(x) (((x) >> S_READ_LATENCY_OFFSET) & M_READ_LATENCY_OFFSET) + +#define S_MEMCTL_CIC_FAST 7 +#define V_MEMCTL_CIC_FAST(x) ((x) << S_MEMCTL_CIC_FAST) +#define F_MEMCTL_CIC_FAST V_MEMCTL_CIC_FAST(1U) + +#define S_MEMCTL_CTRN_IGNORE 6 +#define V_MEMCTL_CTRN_IGNORE(x) ((x) << S_MEMCTL_CTRN_IGNORE) +#define F_MEMCTL_CTRN_IGNORE V_MEMCTL_CTRN_IGNORE(1U) + +#define S_DISABLE_MEMCTL_CAL 5 +#define V_DISABLE_MEMCTL_CAL(x) ((x) << S_DISABLE_MEMCTL_CAL) +#define F_DISABLE_MEMCTL_CAL V_DISABLE_MEMCTL_CAL(1U) + +#define A_MC_DDRPHY_PC_RESETS 0x47038 + +#define S_PLL_RESET 15 +#define V_PLL_RESET(x) ((x) << S_PLL_RESET) +#define F_PLL_RESET V_PLL_RESET(1U) + +#define S_SYSCLK_RESET 14 +#define V_SYSCLK_RESET(x) ((x) << S_SYSCLK_RESET) +#define F_SYSCLK_RESET V_SYSCLK_RESET(1U) + +#define A_MC_DDRPHY_PC_PER_ZCAL_CONFIG 0x4703c + +#define S_PER_ZCAL_ENA_RANK 8 +#define M_PER_ZCAL_ENA_RANK 0xffU +#define V_PER_ZCAL_ENA_RANK(x) ((x) << S_PER_ZCAL_ENA_RANK) +#define G_PER_ZCAL_ENA_RANK(x) (((x) >> S_PER_ZCAL_ENA_RANK) & M_PER_ZCAL_ENA_RANK) + +#define S_PER_ZCAL_NEXT_RANK 5 +#define M_PER_ZCAL_NEXT_RANK 0x7U +#define V_PER_ZCAL_NEXT_RANK(x) ((x) << S_PER_ZCAL_NEXT_RANK) +#define G_PER_ZCAL_NEXT_RANK(x) (((x) >> S_PER_ZCAL_NEXT_RANK) & M_PER_ZCAL_NEXT_RANK) + +#define S_START_PER_ZCAL 4 +#define V_START_PER_ZCAL(x) ((x) << S_START_PER_ZCAL) +#define F_START_PER_ZCAL V_START_PER_ZCAL(1U) + +#define A_MC_DDRPHY_PC_RANK_GROUP 0x47044 + +#define S_ADDR_MIRROR_RP0_PRI 15 +#define V_ADDR_MIRROR_RP0_PRI(x) ((x) << S_ADDR_MIRROR_RP0_PRI) +#define F_ADDR_MIRROR_RP0_PRI V_ADDR_MIRROR_RP0_PRI(1U) + +#define S_ADDR_MIRROR_RP0_SEC 14 +#define V_ADDR_MIRROR_RP0_SEC(x) ((x) << S_ADDR_MIRROR_RP0_SEC) +#define F_ADDR_MIRROR_RP0_SEC V_ADDR_MIRROR_RP0_SEC(1U) + +#define S_ADDR_MIRROR_RP1_PRI 13 +#define V_ADDR_MIRROR_RP1_PRI(x) ((x) << S_ADDR_MIRROR_RP1_PRI) +#define F_ADDR_MIRROR_RP1_PRI V_ADDR_MIRROR_RP1_PRI(1U) + +#define S_ADDR_MIRROR_RP1_SEC 12 +#define V_ADDR_MIRROR_RP1_SEC(x) ((x) << S_ADDR_MIRROR_RP1_SEC) +#define F_ADDR_MIRROR_RP1_SEC V_ADDR_MIRROR_RP1_SEC(1U) + +#define S_ADDR_MIRROR_RP2_PRI 11 +#define V_ADDR_MIRROR_RP2_PRI(x) ((x) << S_ADDR_MIRROR_RP2_PRI) +#define F_ADDR_MIRROR_RP2_PRI V_ADDR_MIRROR_RP2_PRI(1U) + +#define S_ADDR_MIRROR_RP2_SEC 10 +#define V_ADDR_MIRROR_RP2_SEC(x) ((x) << S_ADDR_MIRROR_RP2_SEC) +#define F_ADDR_MIRROR_RP2_SEC V_ADDR_MIRROR_RP2_SEC(1U) + +#define S_ADDR_MIRROR_RP3_PRI 9 +#define V_ADDR_MIRROR_RP3_PRI(x) ((x) << S_ADDR_MIRROR_RP3_PRI) +#define F_ADDR_MIRROR_RP3_PRI V_ADDR_MIRROR_RP3_PRI(1U) + +#define S_ADDR_MIRROR_RP3_SEC 8 +#define V_ADDR_MIRROR_RP3_SEC(x) ((x) << S_ADDR_MIRROR_RP3_SEC) +#define F_ADDR_MIRROR_RP3_SEC V_ADDR_MIRROR_RP3_SEC(1U) + +#define S_RANK_GROUPING 6 +#define M_RANK_GROUPING 0x3U +#define V_RANK_GROUPING(x) ((x) << S_RANK_GROUPING) +#define G_RANK_GROUPING(x) (((x) >> S_RANK_GROUPING) & M_RANK_GROUPING) + +#define A_MC_DDRPHY_PC_ERROR_STATUS0 0x47048 + +#define S_RC_ERROR 15 +#define V_RC_ERROR(x) ((x) << S_RC_ERROR) +#define F_RC_ERROR V_RC_ERROR(1U) + +#define S_WC_ERROR 14 +#define V_WC_ERROR(x) ((x) << S_WC_ERROR) +#define F_WC_ERROR V_WC_ERROR(1U) + +#define S_SEQ_ERROR 13 +#define V_SEQ_ERROR(x) ((x) << S_SEQ_ERROR) +#define F_SEQ_ERROR V_SEQ_ERROR(1U) + +#define S_CC_ERROR 12 +#define V_CC_ERROR(x) ((x) << S_CC_ERROR) +#define F_CC_ERROR V_CC_ERROR(1U) + +#define S_APB_ERROR 11 +#define V_APB_ERROR(x) ((x) << S_APB_ERROR) +#define F_APB_ERROR V_APB_ERROR(1U) + +#define S_PC_ERROR 10 +#define V_PC_ERROR(x) ((x) << S_PC_ERROR) +#define F_PC_ERROR V_PC_ERROR(1U) + +#define A_MC_DDRPHY_PC_ERROR_MASK0 0x4704c + +#define S_RC_ERROR_MASK 15 +#define V_RC_ERROR_MASK(x) ((x) << S_RC_ERROR_MASK) +#define F_RC_ERROR_MASK V_RC_ERROR_MASK(1U) + +#define S_WC_ERROR_MASK 14 +#define V_WC_ERROR_MASK(x) ((x) << S_WC_ERROR_MASK) +#define F_WC_ERROR_MASK V_WC_ERROR_MASK(1U) + +#define S_SEQ_ERROR_MASK 13 +#define V_SEQ_ERROR_MASK(x) ((x) << S_SEQ_ERROR_MASK) +#define F_SEQ_ERROR_MASK V_SEQ_ERROR_MASK(1U) + +#define S_CC_ERROR_MASK 12 +#define V_CC_ERROR_MASK(x) ((x) << S_CC_ERROR_MASK) +#define F_CC_ERROR_MASK V_CC_ERROR_MASK(1U) + +#define S_APB_ERROR_MASK 11 +#define V_APB_ERROR_MASK(x) ((x) << S_APB_ERROR_MASK) +#define F_APB_ERROR_MASK V_APB_ERROR_MASK(1U) + +#define S_PC_ERROR_MASK 10 +#define V_PC_ERROR_MASK(x) ((x) << S_PC_ERROR_MASK) +#define F_PC_ERROR_MASK V_PC_ERROR_MASK(1U) + +#define A_MC_DDRPHY_PC_IO_PVT_FET_CONTROL 0x47050 + +#define S_PVTP 11 +#define M_PVTP 0x1fU +#define V_PVTP(x) ((x) << S_PVTP) +#define G_PVTP(x) (((x) >> S_PVTP) & M_PVTP) + +#define S_PVTN 6 +#define M_PVTN 0x1fU +#define V_PVTN(x) ((x) << S_PVTN) +#define G_PVTN(x) (((x) >> S_PVTN) & M_PVTN) + +#define S_PVT_OVERRIDE 5 +#define V_PVT_OVERRIDE(x) ((x) << S_PVT_OVERRIDE) +#define F_PVT_OVERRIDE V_PVT_OVERRIDE(1U) + +#define S_ENABLE_ZCAL 4 +#define V_ENABLE_ZCAL(x) ((x) << S_ENABLE_ZCAL) +#define F_ENABLE_ZCAL V_ENABLE_ZCAL(1U) + +#define A_MC_DDRPHY_PC_VREF_DRV_CONTROL 0x47054 + +#define S_VREFDQ0DSGN 15 +#define V_VREFDQ0DSGN(x) ((x) << S_VREFDQ0DSGN) +#define F_VREFDQ0DSGN V_VREFDQ0DSGN(1U) + +#define S_VREFDQ0D 11 +#define M_VREFDQ0D 0xfU +#define V_VREFDQ0D(x) ((x) << S_VREFDQ0D) +#define G_VREFDQ0D(x) (((x) >> S_VREFDQ0D) & M_VREFDQ0D) + +#define S_VREFDQ1DSGN 10 +#define V_VREFDQ1DSGN(x) ((x) << S_VREFDQ1DSGN) +#define F_VREFDQ1DSGN V_VREFDQ1DSGN(1U) + +#define S_VREFDQ1D 6 +#define M_VREFDQ1D 0xfU +#define V_VREFDQ1D(x) ((x) << S_VREFDQ1D) +#define G_VREFDQ1D(x) (((x) >> S_VREFDQ1D) & M_VREFDQ1D) + +#define A_MC_DDRPHY_PC_INIT_CAL_CONFIG0 0x47058 + +#define S_ENA_WR_LEVEL 15 +#define V_ENA_WR_LEVEL(x) ((x) << S_ENA_WR_LEVEL) +#define F_ENA_WR_LEVEL V_ENA_WR_LEVEL(1U) + +#define S_ENA_INITIAL_PAT_WR 14 +#define V_ENA_INITIAL_PAT_WR(x) ((x) << S_ENA_INITIAL_PAT_WR) +#define F_ENA_INITIAL_PAT_WR V_ENA_INITIAL_PAT_WR(1U) + +#define S_ENA_DQS_ALIGN 13 +#define V_ENA_DQS_ALIGN(x) ((x) << S_ENA_DQS_ALIGN) +#define F_ENA_DQS_ALIGN V_ENA_DQS_ALIGN(1U) + +#define S_ENA_RDCLK_ALIGN 12 +#define V_ENA_RDCLK_ALIGN(x) ((x) << S_ENA_RDCLK_ALIGN) +#define F_ENA_RDCLK_ALIGN V_ENA_RDCLK_ALIGN(1U) + +#define S_ENA_READ_CTR 11 +#define V_ENA_READ_CTR(x) ((x) << S_ENA_READ_CTR) +#define F_ENA_READ_CTR V_ENA_READ_CTR(1U) + +#define S_ENA_WRITE_CTR 10 +#define V_ENA_WRITE_CTR(x) ((x) << S_ENA_WRITE_CTR) +#define F_ENA_WRITE_CTR V_ENA_WRITE_CTR(1U) + +#define S_ENA_INITIAL_COARSE_WR 9 +#define V_ENA_INITIAL_COARSE_WR(x) ((x) << S_ENA_INITIAL_COARSE_WR) +#define F_ENA_INITIAL_COARSE_WR V_ENA_INITIAL_COARSE_WR(1U) + +#define S_ENA_COARSE_RD 8 +#define V_ENA_COARSE_RD(x) ((x) << S_ENA_COARSE_RD) +#define F_ENA_COARSE_RD V_ENA_COARSE_RD(1U) + +#define S_ENA_CUSTOM_RD 7 +#define V_ENA_CUSTOM_RD(x) ((x) << S_ENA_CUSTOM_RD) +#define F_ENA_CUSTOM_RD V_ENA_CUSTOM_RD(1U) + +#define S_ENA_CUSTOM_WR 6 +#define V_ENA_CUSTOM_WR(x) ((x) << S_ENA_CUSTOM_WR) +#define F_ENA_CUSTOM_WR V_ENA_CUSTOM_WR(1U) + +#define S_ABORT_ON_CAL_ERROR 5 +#define V_ABORT_ON_CAL_ERROR(x) ((x) << S_ABORT_ON_CAL_ERROR) +#define F_ABORT_ON_CAL_ERROR V_ABORT_ON_CAL_ERROR(1U) + +#define S_ENA_DIGITAL_EYE 4 +#define V_ENA_DIGITAL_EYE(x) ((x) << S_ENA_DIGITAL_EYE) +#define F_ENA_DIGITAL_EYE V_ENA_DIGITAL_EYE(1U) + +#define S_ENA_RANK_PAIR 0 +#define M_ENA_RANK_PAIR 0xfU +#define V_ENA_RANK_PAIR(x) ((x) << S_ENA_RANK_PAIR) +#define G_ENA_RANK_PAIR(x) (((x) >> S_ENA_RANK_PAIR) & M_ENA_RANK_PAIR) + +#define A_MC_DDRPHY_PC_INIT_CAL_CONFIG1 0x4705c + +#define S_REFRESH_COUNT 12 +#define M_REFRESH_COUNT 0xfU +#define V_REFRESH_COUNT(x) ((x) << S_REFRESH_COUNT) +#define G_REFRESH_COUNT(x) (((x) >> S_REFRESH_COUNT) & M_REFRESH_COUNT) + +#define S_REFRESH_CONTROL 10 +#define M_REFRESH_CONTROL 0x3U +#define V_REFRESH_CONTROL(x) ((x) << S_REFRESH_CONTROL) +#define G_REFRESH_CONTROL(x) (((x) >> S_REFRESH_CONTROL) & M_REFRESH_CONTROL) + +#define S_REFRESH_ALL_RANKS 9 +#define V_REFRESH_ALL_RANKS(x) ((x) << S_REFRESH_ALL_RANKS) +#define F_REFRESH_ALL_RANKS V_REFRESH_ALL_RANKS(1U) + +#define S_REFRESH_INTERVAL 0 +#define M_REFRESH_INTERVAL 0x7fU +#define V_REFRESH_INTERVAL(x) ((x) << S_REFRESH_INTERVAL) +#define G_REFRESH_INTERVAL(x) (((x) >> S_REFRESH_INTERVAL) & M_REFRESH_INTERVAL) + +#define A_MC_DDRPHY_PC_INIT_CAL_ERROR 0x47060 + +#define S_ERROR_WR_LEVEL 15 +#define V_ERROR_WR_LEVEL(x) ((x) << S_ERROR_WR_LEVEL) +#define F_ERROR_WR_LEVEL V_ERROR_WR_LEVEL(1U) + +#define S_ERROR_INITIAL_PAT_WRITE 14 +#define V_ERROR_INITIAL_PAT_WRITE(x) ((x) << S_ERROR_INITIAL_PAT_WRITE) +#define F_ERROR_INITIAL_PAT_WRITE V_ERROR_INITIAL_PAT_WRITE(1U) + +#define S_ERROR_DQS_ALIGN 13 +#define V_ERROR_DQS_ALIGN(x) ((x) << S_ERROR_DQS_ALIGN) +#define F_ERROR_DQS_ALIGN V_ERROR_DQS_ALIGN(1U) + +#define S_ERROR_RDCLK_ALIGN 12 +#define V_ERROR_RDCLK_ALIGN(x) ((x) << S_ERROR_RDCLK_ALIGN) +#define F_ERROR_RDCLK_ALIGN V_ERROR_RDCLK_ALIGN(1U) + +#define S_ERROR_READ_CTR 11 +#define V_ERROR_READ_CTR(x) ((x) << S_ERROR_READ_CTR) +#define F_ERROR_READ_CTR V_ERROR_READ_CTR(1U) + +#define S_ERROR_WRITE_CTR 10 +#define V_ERROR_WRITE_CTR(x) ((x) << S_ERROR_WRITE_CTR) +#define F_ERROR_WRITE_CTR V_ERROR_WRITE_CTR(1U) + +#define S_ERROR_INITIAL_COARSE_WR 9 +#define V_ERROR_INITIAL_COARSE_WR(x) ((x) << S_ERROR_INITIAL_COARSE_WR) +#define F_ERROR_INITIAL_COARSE_WR V_ERROR_INITIAL_COARSE_WR(1U) + +#define S_ERROR_COARSE_RD 8 +#define V_ERROR_COARSE_RD(x) ((x) << S_ERROR_COARSE_RD) +#define F_ERROR_COARSE_RD V_ERROR_COARSE_RD(1U) + +#define S_ERROR_CUSTOM_RD 7 +#define V_ERROR_CUSTOM_RD(x) ((x) << S_ERROR_CUSTOM_RD) +#define F_ERROR_CUSTOM_RD V_ERROR_CUSTOM_RD(1U) + +#define S_ERROR_CUSTOM_WR 6 +#define V_ERROR_CUSTOM_WR(x) ((x) << S_ERROR_CUSTOM_WR) +#define F_ERROR_CUSTOM_WR V_ERROR_CUSTOM_WR(1U) + +#define S_ERROR_DIGITAL_EYE 5 +#define V_ERROR_DIGITAL_EYE(x) ((x) << S_ERROR_DIGITAL_EYE) +#define F_ERROR_DIGITAL_EYE V_ERROR_DIGITAL_EYE(1U) + +#define S_ERROR_RANK_PAIR 0 +#define M_ERROR_RANK_PAIR 0xfU +#define V_ERROR_RANK_PAIR(x) ((x) << S_ERROR_RANK_PAIR) +#define G_ERROR_RANK_PAIR(x) (((x) >> S_ERROR_RANK_PAIR) & M_ERROR_RANK_PAIR) + +#define A_MC_DDRPHY_PC_INIT_CAL_STATUS 0x47064 + +#define S_INIT_CAL_COMPLETE 12 +#define M_INIT_CAL_COMPLETE 0xfU +#define V_INIT_CAL_COMPLETE(x) ((x) << S_INIT_CAL_COMPLETE) +#define G_INIT_CAL_COMPLETE(x) (((x) >> S_INIT_CAL_COMPLETE) & M_INIT_CAL_COMPLETE) + +#define A_MC_DDRPHY_PC_INIT_CAL_MASK 0x47068 + +#define S_ERROR_WR_LEVEL_MASK 15 +#define V_ERROR_WR_LEVEL_MASK(x) ((x) << S_ERROR_WR_LEVEL_MASK) +#define F_ERROR_WR_LEVEL_MASK V_ERROR_WR_LEVEL_MASK(1U) + +#define S_ERROR_INITIAL_PAT_WRITE_MASK 14 +#define V_ERROR_INITIAL_PAT_WRITE_MASK(x) ((x) << S_ERROR_INITIAL_PAT_WRITE_MASK) +#define F_ERROR_INITIAL_PAT_WRITE_MASK V_ERROR_INITIAL_PAT_WRITE_MASK(1U) + +#define S_ERROR_DQS_ALIGN_MASK 13 +#define V_ERROR_DQS_ALIGN_MASK(x) ((x) << S_ERROR_DQS_ALIGN_MASK) +#define F_ERROR_DQS_ALIGN_MASK V_ERROR_DQS_ALIGN_MASK(1U) + +#define S_ERROR_RDCLK_ALIGN_MASK 12 +#define V_ERROR_RDCLK_ALIGN_MASK(x) ((x) << S_ERROR_RDCLK_ALIGN_MASK) +#define F_ERROR_RDCLK_ALIGN_MASK V_ERROR_RDCLK_ALIGN_MASK(1U) + +#define S_ERROR_READ_CTR_MASK 11 +#define V_ERROR_READ_CTR_MASK(x) ((x) << S_ERROR_READ_CTR_MASK) +#define F_ERROR_READ_CTR_MASK V_ERROR_READ_CTR_MASK(1U) + +#define S_ERROR_WRITE_CTR_MASK 10 +#define V_ERROR_WRITE_CTR_MASK(x) ((x) << S_ERROR_WRITE_CTR_MASK) +#define F_ERROR_WRITE_CTR_MASK V_ERROR_WRITE_CTR_MASK(1U) + +#define S_ERROR_INITIAL_COARSE_WR_MASK 9 +#define V_ERROR_INITIAL_COARSE_WR_MASK(x) ((x) << S_ERROR_INITIAL_COARSE_WR_MASK) +#define F_ERROR_INITIAL_COARSE_WR_MASK V_ERROR_INITIAL_COARSE_WR_MASK(1U) + +#define S_ERROR_COARSE_RD_MASK 8 +#define V_ERROR_COARSE_RD_MASK(x) ((x) << S_ERROR_COARSE_RD_MASK) +#define F_ERROR_COARSE_RD_MASK V_ERROR_COARSE_RD_MASK(1U) + +#define S_ERROR_CUSTOM_RD_MASK 7 +#define V_ERROR_CUSTOM_RD_MASK(x) ((x) << S_ERROR_CUSTOM_RD_MASK) +#define F_ERROR_CUSTOM_RD_MASK V_ERROR_CUSTOM_RD_MASK(1U) + +#define S_ERROR_CUSTOM_WR_MASK 6 +#define V_ERROR_CUSTOM_WR_MASK(x) ((x) << S_ERROR_CUSTOM_WR_MASK) +#define F_ERROR_CUSTOM_WR_MASK V_ERROR_CUSTOM_WR_MASK(1U) + +#define S_ERROR_DIGITAL_EYE_MASK 5 +#define V_ERROR_DIGITAL_EYE_MASK(x) ((x) << S_ERROR_DIGITAL_EYE_MASK) +#define F_ERROR_DIGITAL_EYE_MASK V_ERROR_DIGITAL_EYE_MASK(1U) + +#define A_MC_DDRPHY_PC_IO_PVT_FET_STATUS 0x4706c +#define A_MC_DDRPHY_PC_MR0_PRI_RP 0x47070 + +#define S_MODEREGISTER0VALUE 0 +#define M_MODEREGISTER0VALUE 0xffffU +#define V_MODEREGISTER0VALUE(x) ((x) << S_MODEREGISTER0VALUE) +#define G_MODEREGISTER0VALUE(x) (((x) >> S_MODEREGISTER0VALUE) & M_MODEREGISTER0VALUE) + +#define A_MC_DDRPHY_PC_MR1_PRI_RP 0x47074 + +#define S_MODEREGISTER1VALUE 0 +#define M_MODEREGISTER1VALUE 0xffffU +#define V_MODEREGISTER1VALUE(x) ((x) << S_MODEREGISTER1VALUE) +#define G_MODEREGISTER1VALUE(x) (((x) >> S_MODEREGISTER1VALUE) & M_MODEREGISTER1VALUE) + +#define A_MC_DDRPHY_PC_MR2_PRI_RP 0x47078 + +#define S_MODEREGISTER2VALUE 0 +#define M_MODEREGISTER2VALUE 0xffffU +#define V_MODEREGISTER2VALUE(x) ((x) << S_MODEREGISTER2VALUE) +#define G_MODEREGISTER2VALUE(x) (((x) >> S_MODEREGISTER2VALUE) & M_MODEREGISTER2VALUE) + +#define A_MC_DDRPHY_PC_MR3_PRI_RP 0x4707c + +#define S_MODEREGISTER3VALUE 0 +#define M_MODEREGISTER3VALUE 0xffffU +#define V_MODEREGISTER3VALUE(x) ((x) << S_MODEREGISTER3VALUE) +#define G_MODEREGISTER3VALUE(x) (((x) >> S_MODEREGISTER3VALUE) & M_MODEREGISTER3VALUE) + +#define A_MC_DDRPHY_PC_MR0_SEC_RP 0x47080 +#define A_MC_DDRPHY_PC_MR1_SEC_RP 0x47084 +#define A_MC_DDRPHY_PC_MR2_SEC_RP 0x47088 +#define A_MC_DDRPHY_PC_MR3_SEC_RP 0x4708c + +#define S_MODE_REGISTER_3_VALUE 0 +#define M_MODE_REGISTER_3_VALUE 0xffffU +#define V_MODE_REGISTER_3_VALUE(x) ((x) << S_MODE_REGISTER_3_VALUE) +#define G_MODE_REGISTER_3_VALUE(x) (((x) >> S_MODE_REGISTER_3_VALUE) & M_MODE_REGISTER_3_VALUE) + +#define A_MC_DDRPHY_SEQ_RD_WR_DATA0 0x47200 + +#define S_DRD_WR_DATA_REG 0 +#define M_DRD_WR_DATA_REG 0xffffU +#define V_DRD_WR_DATA_REG(x) ((x) << S_DRD_WR_DATA_REG) +#define G_DRD_WR_DATA_REG(x) (((x) >> S_DRD_WR_DATA_REG) & M_DRD_WR_DATA_REG) + +#define A_MC_DDRPHY_SEQ_RD_WR_DATA1 0x47204 +#define A_MC_DDRPHY_SEQ_CONFIG0 0x47208 + +#define S_MPR_PATTERN_BIT 15 +#define V_MPR_PATTERN_BIT(x) ((x) << S_MPR_PATTERN_BIT) +#define F_MPR_PATTERN_BIT V_MPR_PATTERN_BIT(1U) + +#define S_TWO_CYCLE_ADDR_EN 14 +#define V_TWO_CYCLE_ADDR_EN(x) ((x) << S_TWO_CYCLE_ADDR_EN) +#define F_TWO_CYCLE_ADDR_EN V_TWO_CYCLE_ADDR_EN(1U) + +#define S_MR_MASK_EN 10 +#define M_MR_MASK_EN 0xfU +#define V_MR_MASK_EN(x) ((x) << S_MR_MASK_EN) +#define G_MR_MASK_EN(x) (((x) >> S_MR_MASK_EN) & M_MR_MASK_EN) + +#define A_MC_DDRPHY_SEQ_RESERVED_ADDR0 0x4720c +#define A_MC_DDRPHY_SEQ_RESERVED_ADDR1 0x47210 +#define A_MC_DDRPHY_SEQ_RESERVED_ADDR2 0x47214 +#define A_MC_DDRPHY_SEQ_RESERVED_ADDR3 0x47218 +#define A_MC_DDRPHY_SEQ_RESERVED_ADDR4 0x4721c +#define A_MC_DDRPHY_SEQ_ERROR_STATUS0 0x47220 + +#define S_MULTIPLE_REQ_ERROR 15 +#define V_MULTIPLE_REQ_ERROR(x) ((x) << S_MULTIPLE_REQ_ERROR) +#define F_MULTIPLE_REQ_ERROR V_MULTIPLE_REQ_ERROR(1U) + +#define S_INVALID_REQTYPE_ERRO 14 +#define V_INVALID_REQTYPE_ERRO(x) ((x) << S_INVALID_REQTYPE_ERRO) +#define F_INVALID_REQTYPE_ERRO V_INVALID_REQTYPE_ERRO(1U) + +#define S_EARLY_REQ_ERROR 13 +#define V_EARLY_REQ_ERROR(x) ((x) << S_EARLY_REQ_ERROR) +#define F_EARLY_REQ_ERROR V_EARLY_REQ_ERROR(1U) + +#define S_MULTIPLE_REQ_SOURCE 10 +#define M_MULTIPLE_REQ_SOURCE 0x7U +#define V_MULTIPLE_REQ_SOURCE(x) ((x) << S_MULTIPLE_REQ_SOURCE) +#define G_MULTIPLE_REQ_SOURCE(x) (((x) >> S_MULTIPLE_REQ_SOURCE) & M_MULTIPLE_REQ_SOURCE) + +#define S_INVALID_REQTYPE 6 +#define M_INVALID_REQTYPE 0xfU +#define V_INVALID_REQTYPE(x) ((x) << S_INVALID_REQTYPE) +#define G_INVALID_REQTYPE(x) (((x) >> S_INVALID_REQTYPE) & M_INVALID_REQTYPE) + +#define S_INVALID_REQ_SOURCE 3 +#define M_INVALID_REQ_SOURCE 0x7U +#define V_INVALID_REQ_SOURCE(x) ((x) << S_INVALID_REQ_SOURCE) +#define G_INVALID_REQ_SOURCE(x) (((x) >> S_INVALID_REQ_SOURCE) & M_INVALID_REQ_SOURCE) + +#define S_EARLY_REQ_SOURCE 0 +#define M_EARLY_REQ_SOURCE 0x7U +#define V_EARLY_REQ_SOURCE(x) ((x) << S_EARLY_REQ_SOURCE) +#define G_EARLY_REQ_SOURCE(x) (((x) >> S_EARLY_REQ_SOURCE) & M_EARLY_REQ_SOURCE) + +#define A_MC_DDRPHY_SEQ_ERROR_MASK0 0x47224 + +#define S_MULT_REQ_ERR_MASK 15 +#define V_MULT_REQ_ERR_MASK(x) ((x) << S_MULT_REQ_ERR_MASK) +#define F_MULT_REQ_ERR_MASK V_MULT_REQ_ERR_MASK(1U) + +#define S_INVALID_REQTYPE_ERR_MASK 14 +#define V_INVALID_REQTYPE_ERR_MASK(x) ((x) << S_INVALID_REQTYPE_ERR_MASK) +#define F_INVALID_REQTYPE_ERR_MASK V_INVALID_REQTYPE_ERR_MASK(1U) + +#define S_EARLY_REQ_ERR_MASK 13 +#define V_EARLY_REQ_ERR_MASK(x) ((x) << S_EARLY_REQ_ERR_MASK) +#define F_EARLY_REQ_ERR_MASK V_EARLY_REQ_ERR_MASK(1U) + +#define A_MC_DDRPHY_SEQ_ODT_WR_CONFIG0 0x47228 + +#define S_ODT_WR_VALUES_BITS0_7 8 +#define M_ODT_WR_VALUES_BITS0_7 0xffU +#define V_ODT_WR_VALUES_BITS0_7(x) ((x) << S_ODT_WR_VALUES_BITS0_7) +#define G_ODT_WR_VALUES_BITS0_7(x) (((x) >> S_ODT_WR_VALUES_BITS0_7) & M_ODT_WR_VALUES_BITS0_7) + +#define S_ODT_WR_VALUES_BITS8_15 0 +#define M_ODT_WR_VALUES_BITS8_15 0xffU +#define V_ODT_WR_VALUES_BITS8_15(x) ((x) << S_ODT_WR_VALUES_BITS8_15) +#define G_ODT_WR_VALUES_BITS8_15(x) (((x) >> S_ODT_WR_VALUES_BITS8_15) & M_ODT_WR_VALUES_BITS8_15) + +#define A_MC_DDRPHY_SEQ_ODT_WR_CONFIG1 0x4722c +#define A_MC_DDRPHY_SEQ_ODT_WR_CONFIG2 0x47230 +#define A_MC_DDRPHY_SEQ_ODT_WR_CONFIG3 0x47234 +#define A_MC_DDRPHY_SEQ_ODT_RD_CONFIG0 0x47238 + +#define S_ODT_RD_VALUES_X2 8 +#define M_ODT_RD_VALUES_X2 0xffU +#define V_ODT_RD_VALUES_X2(x) ((x) << S_ODT_RD_VALUES_X2) +#define G_ODT_RD_VALUES_X2(x) (((x) >> S_ODT_RD_VALUES_X2) & M_ODT_RD_VALUES_X2) + +#define S_ODT_RD_VALUES_X2PLUS1 0 +#define M_ODT_RD_VALUES_X2PLUS1 0xffU +#define V_ODT_RD_VALUES_X2PLUS1(x) ((x) << S_ODT_RD_VALUES_X2PLUS1) +#define G_ODT_RD_VALUES_X2PLUS1(x) (((x) >> S_ODT_RD_VALUES_X2PLUS1) & M_ODT_RD_VALUES_X2PLUS1) + +#define A_MC_DDRPHY_SEQ_ODT_RD_CONFIG1 0x4723c +#define A_MC_DDRPHY_SEQ_ODT_RD_CONFIG2 0x47240 +#define A_MC_DDRPHY_SEQ_ODT_RD_CONFIG3 0x47244 +#define A_MC_DDRPHY_SEQ_MEM_TIMING_PARAM0 0x47248 + +#define S_TMOD_CYCLES 12 +#define M_TMOD_CYCLES 0xfU +#define V_TMOD_CYCLES(x) ((x) << S_TMOD_CYCLES) +#define G_TMOD_CYCLES(x) (((x) >> S_TMOD_CYCLES) & M_TMOD_CYCLES) + +#define S_TRCD_CYCLES 8 +#define M_TRCD_CYCLES 0xfU +#define V_TRCD_CYCLES(x) ((x) << S_TRCD_CYCLES) +#define G_TRCD_CYCLES(x) (((x) >> S_TRCD_CYCLES) & M_TRCD_CYCLES) + +#define S_TRP_CYCLES 4 +#define M_TRP_CYCLES 0xfU +#define V_TRP_CYCLES(x) ((x) << S_TRP_CYCLES) +#define G_TRP_CYCLES(x) (((x) >> S_TRP_CYCLES) & M_TRP_CYCLES) + +#define S_TRFC_CYCLES 0 +#define M_TRFC_CYCLES 0xfU +#define V_TRFC_CYCLES(x) ((x) << S_TRFC_CYCLES) +#define G_TRFC_CYCLES(x) (((x) >> S_TRFC_CYCLES) & M_TRFC_CYCLES) + +#define A_MC_DDRPHY_SEQ_MEM_TIMING_PARAM1 0x4724c + +#define S_TZQINIT_CYCLES 12 +#define M_TZQINIT_CYCLES 0xfU +#define V_TZQINIT_CYCLES(x) ((x) << S_TZQINIT_CYCLES) +#define G_TZQINIT_CYCLES(x) (((x) >> S_TZQINIT_CYCLES) & M_TZQINIT_CYCLES) + +#define S_TZQCS_CYCLES 8 +#define M_TZQCS_CYCLES 0xfU +#define V_TZQCS_CYCLES(x) ((x) << S_TZQCS_CYCLES) +#define G_TZQCS_CYCLES(x) (((x) >> S_TZQCS_CYCLES) & M_TZQCS_CYCLES) + +#define S_TWLDQSEN_CYCLES 4 +#define M_TWLDQSEN_CYCLES 0xfU +#define V_TWLDQSEN_CYCLES(x) ((x) << S_TWLDQSEN_CYCLES) +#define G_TWLDQSEN_CYCLES(x) (((x) >> S_TWLDQSEN_CYCLES) & M_TWLDQSEN_CYCLES) + +#define S_TWRMRD_CYCLES 0 +#define M_TWRMRD_CYCLES 0xfU +#define V_TWRMRD_CYCLES(x) ((x) << S_TWRMRD_CYCLES) +#define G_TWRMRD_CYCLES(x) (((x) >> S_TWRMRD_CYCLES) & M_TWRMRD_CYCLES) + +#define A_MC_DDRPHY_SEQ_MEM_TIMING_PARAM2 0x47250 + +#define S_TODTLON_OFF_CYCLES 12 +#define M_TODTLON_OFF_CYCLES 0xfU +#define V_TODTLON_OFF_CYCLES(x) ((x) << S_TODTLON_OFF_CYCLES) +#define G_TODTLON_OFF_CYCLES(x) (((x) >> S_TODTLON_OFF_CYCLES) & M_TODTLON_OFF_CYCLES) + +#define S_TRC_CYCLES 8 +#define M_TRC_CYCLES 0xfU +#define V_TRC_CYCLES(x) ((x) << S_TRC_CYCLES) +#define G_TRC_CYCLES(x) (((x) >> S_TRC_CYCLES) & M_TRC_CYCLES) + +#define S_TMRSC_CYCLES 4 +#define M_TMRSC_CYCLES 0xfU +#define V_TMRSC_CYCLES(x) ((x) << S_TMRSC_CYCLES) +#define G_TMRSC_CYCLES(x) (((x) >> S_TMRSC_CYCLES) & M_TMRSC_CYCLES) + +#define A_MC_DDRPHY_RC_CONFIG0 0x47400 + +#define S_GLOBAL_PHY_OFFSET 12 +#define M_GLOBAL_PHY_OFFSET 0xfU +#define V_GLOBAL_PHY_OFFSET(x) ((x) << S_GLOBAL_PHY_OFFSET) +#define G_GLOBAL_PHY_OFFSET(x) (((x) >> S_GLOBAL_PHY_OFFSET) & M_GLOBAL_PHY_OFFSET) + +#define S_ADVANCE_RD_VALID 11 +#define V_ADVANCE_RD_VALID(x) ((x) << S_ADVANCE_RD_VALID) +#define F_ADVANCE_RD_VALID V_ADVANCE_RD_VALID(1U) + +#define S_SINGLE_BIT_MPR_RP0 6 +#define V_SINGLE_BIT_MPR_RP0(x) ((x) << S_SINGLE_BIT_MPR_RP0) +#define F_SINGLE_BIT_MPR_RP0 V_SINGLE_BIT_MPR_RP0(1U) + +#define S_SINGLE_BIT_MPR_RP1 5 +#define V_SINGLE_BIT_MPR_RP1(x) ((x) << S_SINGLE_BIT_MPR_RP1) +#define F_SINGLE_BIT_MPR_RP1 V_SINGLE_BIT_MPR_RP1(1U) + +#define S_SINGLE_BIT_MPR_RP2 4 +#define V_SINGLE_BIT_MPR_RP2(x) ((x) << S_SINGLE_BIT_MPR_RP2) +#define F_SINGLE_BIT_MPR_RP2 V_SINGLE_BIT_MPR_RP2(1U) + +#define S_SINGLE_BIT_MPR_RP3 3 +#define V_SINGLE_BIT_MPR_RP3(x) ((x) << S_SINGLE_BIT_MPR_RP3) +#define F_SINGLE_BIT_MPR_RP3 V_SINGLE_BIT_MPR_RP3(1U) + +#define S_ALIGN_ON_EVEN_CYCLES 2 +#define V_ALIGN_ON_EVEN_CYCLES(x) ((x) << S_ALIGN_ON_EVEN_CYCLES) +#define F_ALIGN_ON_EVEN_CYCLES V_ALIGN_ON_EVEN_CYCLES(1U) + +#define S_PERFORM_RDCLK_ALIGN 1 +#define V_PERFORM_RDCLK_ALIGN(x) ((x) << S_PERFORM_RDCLK_ALIGN) +#define F_PERFORM_RDCLK_ALIGN V_PERFORM_RDCLK_ALIGN(1U) + +#define S_STAGGERED_PATTERN 0 +#define V_STAGGERED_PATTERN(x) ((x) << S_STAGGERED_PATTERN) +#define F_STAGGERED_PATTERN V_STAGGERED_PATTERN(1U) + +#define A_MC_DDRPHY_RC_CONFIG1 0x47404 + +#define S_OUTER_LOOP_CNT 2 +#define M_OUTER_LOOP_CNT 0x3fffU +#define V_OUTER_LOOP_CNT(x) ((x) << S_OUTER_LOOP_CNT) +#define G_OUTER_LOOP_CNT(x) (((x) >> S_OUTER_LOOP_CNT) & M_OUTER_LOOP_CNT) + +#define A_MC_DDRPHY_RC_CONFIG2 0x47408 + +#define S_CONSEQ_PASS 11 +#define M_CONSEQ_PASS 0x1fU +#define V_CONSEQ_PASS(x) ((x) << S_CONSEQ_PASS) +#define G_CONSEQ_PASS(x) (((x) >> S_CONSEQ_PASS) & M_CONSEQ_PASS) + +#define S_BURST_WINDOW 5 +#define M_BURST_WINDOW 0x3U +#define V_BURST_WINDOW(x) ((x) << S_BURST_WINDOW) +#define G_BURST_WINDOW(x) (((x) >> S_BURST_WINDOW) & M_BURST_WINDOW) + +#define S_ALLOW_RD_FIFO_AUTO_R_ESET 4 +#define V_ALLOW_RD_FIFO_AUTO_R_ESET(x) ((x) << S_ALLOW_RD_FIFO_AUTO_R_ESET) +#define F_ALLOW_RD_FIFO_AUTO_R_ESET V_ALLOW_RD_FIFO_AUTO_R_ESET(1U) + +#define A_MC_DDRPHY_RC_ERROR_STATUS0 0x47414 + +#define S_RD_CNTL_ERROR 15 +#define V_RD_CNTL_ERROR(x) ((x) << S_RD_CNTL_ERROR) +#define F_RD_CNTL_ERROR V_RD_CNTL_ERROR(1U) + +#define A_MC_DDRPHY_RC_ERROR_MASK0 0x47418 + +#define S_RD_CNTL_ERROR_MASK 15 +#define V_RD_CNTL_ERROR_MASK(x) ((x) << S_RD_CNTL_ERROR_MASK) +#define F_RD_CNTL_ERROR_MASK V_RD_CNTL_ERROR_MASK(1U) + +#define A_MC_DDRPHY_RC_CONFIG3 0x4741c + +#define S_FINE_CAL_STEP_SIZE 13 +#define M_FINE_CAL_STEP_SIZE 0x7U +#define V_FINE_CAL_STEP_SIZE(x) ((x) << S_FINE_CAL_STEP_SIZE) +#define G_FINE_CAL_STEP_SIZE(x) (((x) >> S_FINE_CAL_STEP_SIZE) & M_FINE_CAL_STEP_SIZE) + +#define S_COARSE_CAL_STEP_SIZE 9 +#define M_COARSE_CAL_STEP_SIZE 0xfU +#define V_COARSE_CAL_STEP_SIZE(x) ((x) << S_COARSE_CAL_STEP_SIZE) +#define G_COARSE_CAL_STEP_SIZE(x) (((x) >> S_COARSE_CAL_STEP_SIZE) & M_COARSE_CAL_STEP_SIZE) + +#define S_DQ_SEL_QUAD 7 +#define M_DQ_SEL_QUAD 0x3U +#define V_DQ_SEL_QUAD(x) ((x) << S_DQ_SEL_QUAD) +#define G_DQ_SEL_QUAD(x) (((x) >> S_DQ_SEL_QUAD) & M_DQ_SEL_QUAD) + +#define S_DQ_SEL_LANE 4 +#define M_DQ_SEL_LANE 0x7U +#define V_DQ_SEL_LANE(x) ((x) << S_DQ_SEL_LANE) +#define G_DQ_SEL_LANE(x) (((x) >> S_DQ_SEL_LANE) & M_DQ_SEL_LANE) + +#define A_MC_DDRPHY_RC_PERIODIC 0x47420 +#define A_MC_DDRPHY_WC_CONFIG0 0x47600 + +#define S_TWLO_TWLOE 8 +#define M_TWLO_TWLOE 0xffU +#define V_TWLO_TWLOE(x) ((x) << S_TWLO_TWLOE) +#define G_TWLO_TWLOE(x) (((x) >> S_TWLO_TWLOE) & M_TWLO_TWLOE) + +#define S_WL_ONE_DQS_PULSE 7 +#define V_WL_ONE_DQS_PULSE(x) ((x) << S_WL_ONE_DQS_PULSE) +#define F_WL_ONE_DQS_PULSE V_WL_ONE_DQS_PULSE(1U) + +#define S_FW_WR_RD 1 +#define M_FW_WR_RD 0x3fU +#define V_FW_WR_RD(x) ((x) << S_FW_WR_RD) +#define G_FW_WR_RD(x) (((x) >> S_FW_WR_RD) & M_FW_WR_RD) + +#define S_CUSTOM_INIT_WRITE 0 +#define V_CUSTOM_INIT_WRITE(x) ((x) << S_CUSTOM_INIT_WRITE) +#define F_CUSTOM_INIT_WRITE V_CUSTOM_INIT_WRITE(1U) + +#define A_MC_DDRPHY_WC_CONFIG1 0x47604 + +#define S_BIG_STEP 12 +#define M_BIG_STEP 0xfU +#define V_BIG_STEP(x) ((x) << S_BIG_STEP) +#define G_BIG_STEP(x) (((x) >> S_BIG_STEP) & M_BIG_STEP) + +#define S_SMALL_STEP 9 +#define M_SMALL_STEP 0x7U +#define V_SMALL_STEP(x) ((x) << S_SMALL_STEP) +#define G_SMALL_STEP(x) (((x) >> S_SMALL_STEP) & M_SMALL_STEP) + +#define S_WR_PRE_DLY 3 +#define M_WR_PRE_DLY 0x3fU +#define V_WR_PRE_DLY(x) ((x) << S_WR_PRE_DLY) +#define G_WR_PRE_DLY(x) (((x) >> S_WR_PRE_DLY) & M_WR_PRE_DLY) + +#define A_MC_DDRPHY_WC_CONFIG2 0x47608 + +#define S_NUM_VALID_SAMPLES 12 +#define M_NUM_VALID_SAMPLES 0xfU +#define V_NUM_VALID_SAMPLES(x) ((x) << S_NUM_VALID_SAMPLES) +#define G_NUM_VALID_SAMPLES(x) (((x) >> S_NUM_VALID_SAMPLES) & M_NUM_VALID_SAMPLES) + +#define S_FW_RD_WR 6 +#define M_FW_RD_WR 0x3fU +#define V_FW_RD_WR(x) ((x) << S_FW_RD_WR) +#define G_FW_RD_WR(x) (((x) >> S_FW_RD_WR) & M_FW_RD_WR) + +#define A_MC_DDRPHY_WC_ERROR_STATUS0 0x4760c + +#define S_WR_CNTL_ERROR 15 +#define V_WR_CNTL_ERROR(x) ((x) << S_WR_CNTL_ERROR) +#define F_WR_CNTL_ERROR V_WR_CNTL_ERROR(1U) + +#define A_MC_DDRPHY_WC_ERROR_MASK0 0x47610 + +#define S_WR_CNTL_ERROR_MASK 15 +#define V_WR_CNTL_ERROR_MASK(x) ((x) << S_WR_CNTL_ERROR_MASK) +#define F_WR_CNTL_ERROR_MASK V_WR_CNTL_ERROR_MASK(1U) + +#define A_MC_DDRPHY_WC_CONFIG3 0x47614 + +#define S_DDR4_MRS_CMD_DQ_EN 15 +#define V_DDR4_MRS_CMD_DQ_EN(x) ((x) << S_DDR4_MRS_CMD_DQ_EN) +#define F_DDR4_MRS_CMD_DQ_EN V_DDR4_MRS_CMD_DQ_EN(1U) + +#define S_MRS_CMD_DQ_ON 9 +#define M_MRS_CMD_DQ_ON 0x3fU +#define V_MRS_CMD_DQ_ON(x) ((x) << S_MRS_CMD_DQ_ON) +#define G_MRS_CMD_DQ_ON(x) (((x) >> S_MRS_CMD_DQ_ON) & M_MRS_CMD_DQ_ON) + +#define S_MRS_CMD_DQ_OFF 3 +#define M_MRS_CMD_DQ_OFF 0x3fU +#define V_MRS_CMD_DQ_OFF(x) ((x) << S_MRS_CMD_DQ_OFF) +#define G_MRS_CMD_DQ_OFF(x) (((x) >> S_MRS_CMD_DQ_OFF) & M_MRS_CMD_DQ_OFF) + +#define A_MC_DDRPHY_WC_WRCLK_CNTL 0x47618 + +#define S_WRCLK_CAL_START 15 +#define V_WRCLK_CAL_START(x) ((x) << S_WRCLK_CAL_START) +#define F_WRCLK_CAL_START V_WRCLK_CAL_START(1U) + +#define S_WRCLK_CAL_DONE 14 +#define V_WRCLK_CAL_DONE(x) ((x) << S_WRCLK_CAL_DONE) +#define F_WRCLK_CAL_DONE V_WRCLK_CAL_DONE(1U) + +#define A_MC_DDRPHY_APB_CONFIG0 0x47800 + +#define S_DISABLE_PARITY_CHECKER 15 +#define V_DISABLE_PARITY_CHECKER(x) ((x) << S_DISABLE_PARITY_CHECKER) +#define F_DISABLE_PARITY_CHECKER V_DISABLE_PARITY_CHECKER(1U) + +#define S_GENERATE_EVEN_PARITY 14 +#define V_GENERATE_EVEN_PARITY(x) ((x) << S_GENERATE_EVEN_PARITY) +#define F_GENERATE_EVEN_PARITY V_GENERATE_EVEN_PARITY(1U) + +#define S_FORCE_ON_CLK_GATE 13 +#define V_FORCE_ON_CLK_GATE(x) ((x) << S_FORCE_ON_CLK_GATE) +#define F_FORCE_ON_CLK_GATE V_FORCE_ON_CLK_GATE(1U) + +#define S_DEBUG_BUS_SEL_LO 12 +#define V_DEBUG_BUS_SEL_LO(x) ((x) << S_DEBUG_BUS_SEL_LO) +#define F_DEBUG_BUS_SEL_LO V_DEBUG_BUS_SEL_LO(1U) + +#define S_DEBUG_BUS_SEL_HI 8 +#define M_DEBUG_BUS_SEL_HI 0xfU +#define V_DEBUG_BUS_SEL_HI(x) ((x) << S_DEBUG_BUS_SEL_HI) +#define G_DEBUG_BUS_SEL_HI(x) (((x) >> S_DEBUG_BUS_SEL_HI) & M_DEBUG_BUS_SEL_HI) + +#define A_MC_DDRPHY_APB_ERROR_STATUS0 0x47804 + +#define S_INVALID_ADDRESS 15 +#define V_INVALID_ADDRESS(x) ((x) << S_INVALID_ADDRESS) +#define F_INVALID_ADDRESS V_INVALID_ADDRESS(1U) + +#define S_WR_PAR_ERR 14 +#define V_WR_PAR_ERR(x) ((x) << S_WR_PAR_ERR) +#define F_WR_PAR_ERR V_WR_PAR_ERR(1U) + +#define A_MC_DDRPHY_APB_ERROR_MASK0 0x47808 + +#define S_INVALID_ADDRESS_MASK 15 +#define V_INVALID_ADDRESS_MASK(x) ((x) << S_INVALID_ADDRESS_MASK) +#define F_INVALID_ADDRESS_MASK V_INVALID_ADDRESS_MASK(1U) + +#define S_WR_PAR_ERR_MASK 14 +#define V_WR_PAR_ERR_MASK(x) ((x) << S_WR_PAR_ERR_MASK) +#define F_WR_PAR_ERR_MASK V_WR_PAR_ERR_MASK(1U) + +#define A_MC_DDRPHY_APB_DP18_POPULATION 0x4780c + +#define S_DP18_0_POPULATED 15 +#define V_DP18_0_POPULATED(x) ((x) << S_DP18_0_POPULATED) +#define F_DP18_0_POPULATED V_DP18_0_POPULATED(1U) + +#define S_DP18_1_POPULATED 14 +#define V_DP18_1_POPULATED(x) ((x) << S_DP18_1_POPULATED) +#define F_DP18_1_POPULATED V_DP18_1_POPULATED(1U) + +#define S_DP18_2_POPULATED 13 +#define V_DP18_2_POPULATED(x) ((x) << S_DP18_2_POPULATED) +#define F_DP18_2_POPULATED V_DP18_2_POPULATED(1U) + +#define S_DP18_3_POPULATED 12 +#define V_DP18_3_POPULATED(x) ((x) << S_DP18_3_POPULATED) +#define F_DP18_3_POPULATED V_DP18_3_POPULATED(1U) + +#define S_DP18_4_POPULATED 11 +#define V_DP18_4_POPULATED(x) ((x) << S_DP18_4_POPULATED) +#define F_DP18_4_POPULATED V_DP18_4_POPULATED(1U) + +#define S_DP18_5_POPULATED 10 +#define V_DP18_5_POPULATED(x) ((x) << S_DP18_5_POPULATED) +#define F_DP18_5_POPULATED V_DP18_5_POPULATED(1U) + +#define S_DP18_6_POPULATED 9 +#define V_DP18_6_POPULATED(x) ((x) << S_DP18_6_POPULATED) +#define F_DP18_6_POPULATED V_DP18_6_POPULATED(1U) + +#define S_DP18_7_POPULATED 8 +#define V_DP18_7_POPULATED(x) ((x) << S_DP18_7_POPULATED) +#define F_DP18_7_POPULATED V_DP18_7_POPULATED(1U) + +#define S_DP18_8_POPULATED 7 +#define V_DP18_8_POPULATED(x) ((x) << S_DP18_8_POPULATED) +#define F_DP18_8_POPULATED V_DP18_8_POPULATED(1U) + +#define S_DP18_9_POPULATED 6 +#define V_DP18_9_POPULATED(x) ((x) << S_DP18_9_POPULATED) +#define F_DP18_9_POPULATED V_DP18_9_POPULATED(1U) + +#define S_DP18_10_POPULATED 5 +#define V_DP18_10_POPULATED(x) ((x) << S_DP18_10_POPULATED) +#define F_DP18_10_POPULATED V_DP18_10_POPULATED(1U) + +#define S_DP18_11_POPULATED 4 +#define V_DP18_11_POPULATED(x) ((x) << S_DP18_11_POPULATED) +#define F_DP18_11_POPULATED V_DP18_11_POPULATED(1U) + +#define S_DP18_12_POPULATED 3 +#define V_DP18_12_POPULATED(x) ((x) << S_DP18_12_POPULATED) +#define F_DP18_12_POPULATED V_DP18_12_POPULATED(1U) + +#define S_DP18_13_POPULATED 2 +#define V_DP18_13_POPULATED(x) ((x) << S_DP18_13_POPULATED) +#define F_DP18_13_POPULATED V_DP18_13_POPULATED(1U) + +#define S_DP18_14_POPULATED 1 +#define V_DP18_14_POPULATED(x) ((x) << S_DP18_14_POPULATED) +#define F_DP18_14_POPULATED V_DP18_14_POPULATED(1U) + +#define A_MC_DDRPHY_APB_ADR_POPULATION 0x47810 + +#define S_ADR16_0_POPULATED 15 +#define V_ADR16_0_POPULATED(x) ((x) << S_ADR16_0_POPULATED) +#define F_ADR16_0_POPULATED V_ADR16_0_POPULATED(1U) + +#define S_ADR16_1_POPULATED 14 +#define V_ADR16_1_POPULATED(x) ((x) << S_ADR16_1_POPULATED) +#define F_ADR16_1_POPULATED V_ADR16_1_POPULATED(1U) + +#define S_ADR16_2_POPULATED 13 +#define V_ADR16_2_POPULATED(x) ((x) << S_ADR16_2_POPULATED) +#define F_ADR16_2_POPULATED V_ADR16_2_POPULATED(1U) + +#define S_ADR16_3_POPULATED 12 +#define V_ADR16_3_POPULATED(x) ((x) << S_ADR16_3_POPULATED) +#define F_ADR16_3_POPULATED V_ADR16_3_POPULATED(1U) + +#define S_ADR12_0_POPULATED 7 +#define V_ADR12_0_POPULATED(x) ((x) << S_ADR12_0_POPULATED) +#define F_ADR12_0_POPULATED V_ADR12_0_POPULATED(1U) + +#define S_ADR12_1_POPULATED 6 +#define V_ADR12_1_POPULATED(x) ((x) << S_ADR12_1_POPULATED) +#define F_ADR12_1_POPULATED V_ADR12_1_POPULATED(1U) + +#define S_ADR12_2_POPULATED 5 +#define V_ADR12_2_POPULATED(x) ((x) << S_ADR12_2_POPULATED) +#define F_ADR12_2_POPULATED V_ADR12_2_POPULATED(1U) + +#define S_ADR12_3_POPULATED 4 +#define V_ADR12_3_POPULATED(x) ((x) << S_ADR12_3_POPULATED) +#define F_ADR12_3_POPULATED V_ADR12_3_POPULATED(1U) + +#define A_MC_DDRPHY_APB_ATEST_MUX_SEL 0x47814 + +#define S_ATEST_CNTL 10 +#define M_ATEST_CNTL 0x3fU +#define V_ATEST_CNTL(x) ((x) << S_ATEST_CNTL) +#define G_ATEST_CNTL(x) (((x) >> S_ATEST_CNTL) & M_ATEST_CNTL) + +/* registers for module MC_1 */ +#define MC_1_BASE_ADDR 0x48000 + +/* registers for module EDC_T50 */ +#define EDC_T50_BASE_ADDR 0x50000 + +#define A_EDC_H_REF 0x50000 + +#define S_EDC_SLEEPSTATUS 31 +#define V_EDC_SLEEPSTATUS(x) ((x) << S_EDC_SLEEPSTATUS) +#define F_EDC_SLEEPSTATUS V_EDC_SLEEPSTATUS(1U) + +#define S_EDC_SLEEPREQ 30 +#define V_EDC_SLEEPREQ(x) ((x) << S_EDC_SLEEPREQ) +#define F_EDC_SLEEPREQ V_EDC_SLEEPREQ(1U) + +#define S_PING_PONG 29 +#define V_PING_PONG(x) ((x) << S_PING_PONG) +#define F_PING_PONG V_PING_PONG(1U) + +#define A_EDC_H_BIST_CMD 0x50004 +#define A_EDC_H_BIST_CMD_ADDR 0x50008 +#define A_EDC_H_BIST_CMD_LEN 0x5000c +#define A_EDC_H_BIST_DATA_PATTERN 0x50010 +#define A_EDC_H_BIST_USER_WDATA0 0x50014 +#define A_EDC_H_BIST_USER_WDATA1 0x50018 +#define A_EDC_H_BIST_USER_WDATA2 0x5001c +#define A_EDC_H_BIST_NUM_ERR 0x50020 +#define A_EDC_H_BIST_ERR_FIRST_ADDR 0x50024 +#define A_EDC_H_BIST_STATUS_RDATA 0x50028 +#define A_EDC_H_PAR_ENABLE 0x50070 + +#define S_PERR_PAR_ENABLE 0 +#define V_PERR_PAR_ENABLE(x) ((x) << S_PERR_PAR_ENABLE) +#define F_PERR_PAR_ENABLE V_PERR_PAR_ENABLE(1U) + +#define A_EDC_H_INT_ENABLE 0x50074 +#define A_EDC_H_INT_CAUSE 0x50078 +#define A_EDC_H_ECC_STATUS 0x5007c +#define A_EDC_H_ECC_ERR_SEL 0x50080 + +#define S_CFG 0 +#define M_CFG 0x3U +#define V_CFG(x) ((x) << S_CFG) +#define G_CFG(x) (((x) >> S_CFG) & M_CFG) + +#define A_EDC_H_ECC_ERR_ADDR 0x50084 + +#define S_ECC_ADDR 0 +#define M_ECC_ADDR 0x7fffffU +#define V_ECC_ADDR(x) ((x) << S_ECC_ADDR) +#define G_ECC_ADDR(x) (((x) >> S_ECC_ADDR) & M_ECC_ADDR) + +#define A_EDC_H_ECC_ERR_DATA_RDATA 0x50090 +#define A_EDC_H_BIST_CRC_SEED 0x50400 + +/* registers for module EDC_T51 */ +#define EDC_T51_BASE_ADDR 0x50800 + +/* registers for module HMA_T5 */ +#define HMA_T5_BASE_ADDR 0x51000 + +#define A_HMA_TABLE_ACCESS 0x51000 + +#define S_TRIG 31 +#define V_TRIG(x) ((x) << S_TRIG) +#define F_TRIG V_TRIG(1U) + +#define S_RW 30 +#define V_RW(x) ((x) << S_RW) +#define F_RW V_RW(1U) + +#define S_L_SEL 0 +#define M_L_SEL 0xfU +#define V_L_SEL(x) ((x) << S_L_SEL) +#define G_L_SEL(x) (((x) >> S_L_SEL) & M_L_SEL) + +#define A_HMA_TABLE_LINE0 0x51004 + +#define S_CLIENT_EN 0 +#define M_CLIENT_EN 0x1fffU +#define V_CLIENT_EN(x) ((x) << S_CLIENT_EN) +#define G_CLIENT_EN(x) (((x) >> S_CLIENT_EN) & M_CLIENT_EN) + +#define A_HMA_TABLE_LINE1 0x51008 +#define A_HMA_TABLE_LINE2 0x5100c +#define A_HMA_TABLE_LINE3 0x51010 +#define A_HMA_TABLE_LINE4 0x51014 +#define A_HMA_TABLE_LINE5 0x51018 + +#define S_FID 16 +#define M_FID 0x7ffU +#define V_FID(x) ((x) << S_FID) +#define G_FID(x) (((x) >> S_FID) & M_FID) + +#define S_NOS 15 +#define V_NOS(x) ((x) << S_NOS) +#define F_NOS V_NOS(1U) + +#define S_RO 14 +#define V_RO(x) ((x) << S_RO) +#define F_RO V_RO(1U) + +#define A_HMA_COOKIE 0x5101c + +#define S_C_REQ 31 +#define V_C_REQ(x) ((x) << S_C_REQ) +#define F_C_REQ V_C_REQ(1U) + +#define S_C_FID 18 +#define M_C_FID 0x7ffU +#define V_C_FID(x) ((x) << S_C_FID) +#define G_C_FID(x) (((x) >> S_C_FID) & M_C_FID) + +#define S_C_VAL 8 +#define M_C_VAL 0x3ffU +#define V_C_VAL(x) ((x) << S_C_VAL) +#define G_C_VAL(x) (((x) >> S_C_VAL) & M_C_VAL) + +#define S_C_SEL 0 +#define M_C_SEL 0xfU +#define V_C_SEL(x) ((x) << S_C_SEL) +#define G_C_SEL(x) (((x) >> S_C_SEL) & M_C_SEL) + +#define A_HMA_PAR_ENABLE 0x51300 +#define A_HMA_INT_ENABLE 0x51304 +#define A_HMA_INT_CAUSE 0x51308 Index: head/contrib/ofed/libcxgb4/src/t4fw_interface.h =================================================================== --- head/contrib/ofed/libcxgb4/src/t4fw_interface.h (nonexistent) +++ head/contrib/ofed/libcxgb4/src/t4fw_interface.h (revision 273806) @@ -0,0 +1,7811 @@ +/* + * Chelsio Terminator 4 (T4) Firmware interface header file. + * + * Copyright (C) 2009-2014 Chelsio Communications. All rights reserved. + * + * Written by felix marti (felix@chelsio.com) + * + * This program 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 LICENSE file included in this + * release for licensing terms and conditions. + */ + +#ifndef _T4FW_INTERFACE_H_ +#define _T4FW_INTERFACE_H_ + +/****************************************************************************** + * R E T U R N V A L U E S + ********************************/ + +enum fw_retval { + FW_SUCCESS = 0, /* completed sucessfully */ + FW_EPERM = 1, /* operation not permitted */ + FW_ENOENT = 2, /* no such file or directory */ + FW_EIO = 5, /* input/output error; hw bad */ + FW_ENOEXEC = 8, /* exec format error; inv microcode */ + FW_EAGAIN = 11, /* try again */ + FW_ENOMEM = 12, /* out of memory */ + FW_EFAULT = 14, /* bad address; fw bad */ + FW_EBUSY = 16, /* resource busy */ + FW_EEXIST = 17, /* file exists */ + FW_ENODEV = 19, /* no such device */ + FW_EINVAL = 22, /* invalid argument */ + FW_ENOSPC = 28, /* no space left on device */ + FW_ENOSYS = 38, /* functionality not implemented */ + FW_ENODATA = 61, /* no data available */ + FW_EPROTO = 71, /* protocol error */ + FW_EADDRINUSE = 98, /* address already in use */ + FW_EADDRNOTAVAIL = 99, /* cannot assigned requested address */ + FW_ENETDOWN = 100, /* network is down */ + FW_ENETUNREACH = 101, /* network is unreachable */ + FW_ENOBUFS = 105, /* no buffer space available */ + FW_ETIMEDOUT = 110, /* timeout */ + FW_EINPROGRESS = 115, /* fw internal */ + FW_SCSI_ABORT_REQUESTED = 128, /* */ + FW_SCSI_ABORT_TIMEDOUT = 129, /* */ + FW_SCSI_ABORTED = 130, /* */ + FW_SCSI_CLOSE_REQUESTED = 131, /* */ + FW_ERR_LINK_DOWN = 132, /* */ + FW_RDEV_NOT_READY = 133, /* */ + FW_ERR_RDEV_LOST = 134, /* */ + FW_ERR_RDEV_LOGO = 135, /* */ + FW_FCOE_NO_XCHG = 136, /* */ + FW_SCSI_RSP_ERR = 137, /* */ + FW_ERR_RDEV_IMPL_LOGO = 138, /* */ + FW_SCSI_UNDER_FLOW_ERR = 139, /* */ + FW_SCSI_OVER_FLOW_ERR = 140, /* */ + FW_SCSI_DDP_ERR = 141, /* DDP error*/ + FW_SCSI_TASK_ERR = 142, /* No SCSI tasks available */ +}; + +/****************************************************************************** + * M E M O R Y T Y P E s + ******************************/ + +enum fw_memtype { + FW_MEMTYPE_EDC0 = 0x0, + FW_MEMTYPE_EDC1 = 0x1, + FW_MEMTYPE_EXTMEM = 0x2, + FW_MEMTYPE_FLASH = 0x4, + FW_MEMTYPE_INTERNAL = 0x5, + FW_MEMTYPE_EXTMEM1 = 0x6, +}; + +/****************************************************************************** + * W O R K R E Q U E S T s + ********************************/ + +enum fw_wr_opcodes { + FW_FRAG_WR = 0x1d, + FW_FILTER_WR = 0x02, + FW_ULPTX_WR = 0x04, + FW_TP_WR = 0x05, + FW_ETH_TX_PKT_WR = 0x08, + FW_ETH_TX_PKT2_WR = 0x44, + FW_ETH_TX_PKTS_WR = 0x09, + FW_ETH_TX_UO_WR = 0x1c, + FW_EQ_FLUSH_WR = 0x1b, + FW_OFLD_CONNECTION_WR = 0x2f, + FW_FLOWC_WR = 0x0a, + FW_OFLD_TX_DATA_WR = 0x0b, + FW_CMD_WR = 0x10, + FW_ETH_TX_PKT_VM_WR = 0x11, + FW_RI_RES_WR = 0x0c, + FW_RI_RDMA_WRITE_WR = 0x14, + FW_RI_SEND_WR = 0x15, + FW_RI_RDMA_READ_WR = 0x16, + FW_RI_RECV_WR = 0x17, + FW_RI_BIND_MW_WR = 0x18, + FW_RI_FR_NSMR_WR = 0x19, + FW_RI_INV_LSTAG_WR = 0x1a, + FW_RI_SEND_IMMEDIATE_WR = 0x15, + FW_RI_ATOMIC_WR = 0x16, + FW_RI_WR = 0x0d, + FW_CHNET_IFCONF_WR = 0x6b, + FW_RDEV_WR = 0x38, + FW_FOISCSI_NODE_WR = 0x60, + FW_FOISCSI_CTRL_WR = 0x6a, + FW_FOISCSI_CHAP_WR = 0x6c, + FW_FCOE_ELS_CT_WR = 0x30, + FW_SCSI_WRITE_WR = 0x31, + FW_SCSI_READ_WR = 0x32, + FW_SCSI_CMD_WR = 0x33, + FW_SCSI_ABRT_CLS_WR = 0x34, + FW_SCSI_TGT_ACC_WR = 0x35, + FW_SCSI_TGT_XMIT_WR = 0x36, + FW_SCSI_TGT_RSP_WR = 0x37, + FW_POFCOE_TCB_WR = 0x42, + FW_POFCOE_ULPTX_WR = 0x43, + FW_LASTC2E_WR = 0x70 +}; + +/* + * Generic work request header flit0 + */ +struct fw_wr_hdr { + __be32 hi; + __be32 lo; +}; + +/* work request opcode (hi) + */ +#define S_FW_WR_OP 24 +#define M_FW_WR_OP 0xff +#define V_FW_WR_OP(x) ((x) << S_FW_WR_OP) +#define G_FW_WR_OP(x) (((x) >> S_FW_WR_OP) & M_FW_WR_OP) + +/* atomic flag (hi) - firmware encapsulates CPLs in CPL_BARRIER + */ +#define S_FW_WR_ATOMIC 23 +#define M_FW_WR_ATOMIC 0x1 +#define V_FW_WR_ATOMIC(x) ((x) << S_FW_WR_ATOMIC) +#define G_FW_WR_ATOMIC(x) \ + (((x) >> S_FW_WR_ATOMIC) & M_FW_WR_ATOMIC) +#define F_FW_WR_ATOMIC V_FW_WR_ATOMIC(1U) + +/* flush flag (hi) - firmware flushes flushable work request buffered + * in the flow context. + */ +#define S_FW_WR_FLUSH 22 +#define M_FW_WR_FLUSH 0x1 +#define V_FW_WR_FLUSH(x) ((x) << S_FW_WR_FLUSH) +#define G_FW_WR_FLUSH(x) \ + (((x) >> S_FW_WR_FLUSH) & M_FW_WR_FLUSH) +#define F_FW_WR_FLUSH V_FW_WR_FLUSH(1U) + +/* completion flag (hi) - firmware generates a cpl_fw6_ack + */ +#define S_FW_WR_COMPL 21 +#define M_FW_WR_COMPL 0x1 +#define V_FW_WR_COMPL(x) ((x) << S_FW_WR_COMPL) +#define G_FW_WR_COMPL(x) \ + (((x) >> S_FW_WR_COMPL) & M_FW_WR_COMPL) +#define F_FW_WR_COMPL V_FW_WR_COMPL(1U) + + +/* work request immediate data lengh (hi) + */ +#define S_FW_WR_IMMDLEN 0 +#define M_FW_WR_IMMDLEN 0xff +#define V_FW_WR_IMMDLEN(x) ((x) << S_FW_WR_IMMDLEN) +#define G_FW_WR_IMMDLEN(x) \ + (((x) >> S_FW_WR_IMMDLEN) & M_FW_WR_IMMDLEN) + +/* egress queue status update to associated ingress queue entry (lo) + */ +#define S_FW_WR_EQUIQ 31 +#define M_FW_WR_EQUIQ 0x1 +#define V_FW_WR_EQUIQ(x) ((x) << S_FW_WR_EQUIQ) +#define G_FW_WR_EQUIQ(x) (((x) >> S_FW_WR_EQUIQ) & M_FW_WR_EQUIQ) +#define F_FW_WR_EQUIQ V_FW_WR_EQUIQ(1U) + +/* egress queue status update to egress queue status entry (lo) + */ +#define S_FW_WR_EQUEQ 30 +#define M_FW_WR_EQUEQ 0x1 +#define V_FW_WR_EQUEQ(x) ((x) << S_FW_WR_EQUEQ) +#define G_FW_WR_EQUEQ(x) (((x) >> S_FW_WR_EQUEQ) & M_FW_WR_EQUEQ) +#define F_FW_WR_EQUEQ V_FW_WR_EQUEQ(1U) + +/* flow context identifier (lo) + */ +#define S_FW_WR_FLOWID 8 +#define M_FW_WR_FLOWID 0xfffff +#define V_FW_WR_FLOWID(x) ((x) << S_FW_WR_FLOWID) +#define G_FW_WR_FLOWID(x) (((x) >> S_FW_WR_FLOWID) & M_FW_WR_FLOWID) + +/* length in units of 16-bytes (lo) + */ +#define S_FW_WR_LEN16 0 +#define M_FW_WR_LEN16 0xff +#define V_FW_WR_LEN16(x) ((x) << S_FW_WR_LEN16) +#define G_FW_WR_LEN16(x) (((x) >> S_FW_WR_LEN16) & M_FW_WR_LEN16) + +struct fw_frag_wr { + __be32 op_to_fragoff16; + __be32 flowid_len16; + __be64 r4; +}; + +#define S_FW_FRAG_WR_EOF 15 +#define M_FW_FRAG_WR_EOF 0x1 +#define V_FW_FRAG_WR_EOF(x) ((x) << S_FW_FRAG_WR_EOF) +#define G_FW_FRAG_WR_EOF(x) (((x) >> S_FW_FRAG_WR_EOF) & M_FW_FRAG_WR_EOF) +#define F_FW_FRAG_WR_EOF V_FW_FRAG_WR_EOF(1U) + +#define S_FW_FRAG_WR_FRAGOFF16 8 +#define M_FW_FRAG_WR_FRAGOFF16 0x7f +#define V_FW_FRAG_WR_FRAGOFF16(x) ((x) << S_FW_FRAG_WR_FRAGOFF16) +#define G_FW_FRAG_WR_FRAGOFF16(x) \ + (((x) >> S_FW_FRAG_WR_FRAGOFF16) & M_FW_FRAG_WR_FRAGOFF16) + +/* valid filter configurations for compressed tuple + * Encodings: TPL - Compressed TUPLE for filter in addition to 4-tuple + * FR - FRAGMENT, FC - FCoE, MT - MPS MATCH TYPE, M - MPS MATCH, + * E - Ethertype, P - Port, PR - Protocol, T - TOS, IV - Inner VLAN, + * OV - Outer VLAN/VNIC_ID, +*/ +#define HW_TPL_FR_MT_M_E_P_FC 0x3C3 +#define HW_TPL_FR_MT_M_PR_T_FC 0x3B3 +#define HW_TPL_FR_MT_M_IV_P_FC 0x38B +#define HW_TPL_FR_MT_M_OV_P_FC 0x387 +#define HW_TPL_FR_MT_E_PR_T 0x370 +#define HW_TPL_FR_MT_E_PR_P_FC 0X363 +#define HW_TPL_FR_MT_E_T_P_FC 0X353 +#define HW_TPL_FR_MT_PR_IV_P_FC 0X32B +#define HW_TPL_FR_MT_PR_OV_P_FC 0X327 +#define HW_TPL_FR_MT_T_IV_P_FC 0X31B +#define HW_TPL_FR_MT_T_OV_P_FC 0X317 +#define HW_TPL_FR_M_E_PR_FC 0X2E1 +#define HW_TPL_FR_M_E_T_FC 0X2D1 +#define HW_TPL_FR_M_PR_IV_FC 0X2A9 +#define HW_TPL_FR_M_PR_OV_FC 0X2A5 +#define HW_TPL_FR_M_T_IV_FC 0X299 +#define HW_TPL_FR_M_T_OV_FC 0X295 +#define HW_TPL_FR_E_PR_T_P 0X272 +#define HW_TPL_FR_E_PR_T_FC 0X271 +#define HW_TPL_FR_E_IV_FC 0X249 +#define HW_TPL_FR_E_OV_FC 0X245 +#define HW_TPL_FR_PR_T_IV_FC 0X239 +#define HW_TPL_FR_PR_T_OV_FC 0X235 +#define HW_TPL_FR_IV_OV_FC 0X20D +#define HW_TPL_MT_M_E_PR 0X1E0 +#define HW_TPL_MT_M_E_T 0X1D0 +#define HW_TPL_MT_E_PR_T_FC 0X171 +#define HW_TPL_MT_E_IV 0X148 +#define HW_TPL_MT_E_OV 0X144 +#define HW_TPL_MT_PR_T_IV 0X138 +#define HW_TPL_MT_PR_T_OV 0X134 +#define HW_TPL_M_E_PR_P 0X0E2 +#define HW_TPL_M_E_T_P 0X0D2 +#define HW_TPL_E_PR_T_P_FC 0X073 +#define HW_TPL_E_IV_P 0X04A +#define HW_TPL_E_OV_P 0X046 +#define HW_TPL_PR_T_IV_P 0X03A +#define HW_TPL_PR_T_OV_P 0X036 + +/* filter wr reply code in cookie in CPL_SET_TCB_RPL */ +enum fw_filter_wr_cookie { + FW_FILTER_WR_SUCCESS, + FW_FILTER_WR_FLT_ADDED, + FW_FILTER_WR_FLT_DELETED, + FW_FILTER_WR_SMT_TBL_FULL, + FW_FILTER_WR_EINVAL, +}; + +struct fw_filter_wr { + __be32 op_pkd; + __be32 len16_pkd; + __be64 r3; + __be32 tid_to_iq; + __be32 del_filter_to_l2tix; + __be16 ethtype; + __be16 ethtypem; + __u8 frag_to_ovlan_vldm; + __u8 smac_sel; + __be16 rx_chan_rx_rpl_iq; + __be32 maci_to_matchtypem; + __u8 ptcl; + __u8 ptclm; + __u8 ttyp; + __u8 ttypm; + __be16 ivlan; + __be16 ivlanm; + __be16 ovlan; + __be16 ovlanm; + __u8 lip[16]; + __u8 lipm[16]; + __u8 fip[16]; + __u8 fipm[16]; + __be16 lp; + __be16 lpm; + __be16 fp; + __be16 fpm; + __be16 r7; + __u8 sma[6]; +}; + +#define S_FW_FILTER_WR_TID 12 +#define M_FW_FILTER_WR_TID 0xfffff +#define V_FW_FILTER_WR_TID(x) ((x) << S_FW_FILTER_WR_TID) +#define G_FW_FILTER_WR_TID(x) \ + (((x) >> S_FW_FILTER_WR_TID) & M_FW_FILTER_WR_TID) + +#define S_FW_FILTER_WR_RQTYPE 11 +#define M_FW_FILTER_WR_RQTYPE 0x1 +#define V_FW_FILTER_WR_RQTYPE(x) ((x) << S_FW_FILTER_WR_RQTYPE) +#define G_FW_FILTER_WR_RQTYPE(x) \ + (((x) >> S_FW_FILTER_WR_RQTYPE) & M_FW_FILTER_WR_RQTYPE) +#define F_FW_FILTER_WR_RQTYPE V_FW_FILTER_WR_RQTYPE(1U) + +#define S_FW_FILTER_WR_NOREPLY 10 +#define M_FW_FILTER_WR_NOREPLY 0x1 +#define V_FW_FILTER_WR_NOREPLY(x) ((x) << S_FW_FILTER_WR_NOREPLY) +#define G_FW_FILTER_WR_NOREPLY(x) \ + (((x) >> S_FW_FILTER_WR_NOREPLY) & M_FW_FILTER_WR_NOREPLY) +#define F_FW_FILTER_WR_NOREPLY V_FW_FILTER_WR_NOREPLY(1U) + +#define S_FW_FILTER_WR_IQ 0 +#define M_FW_FILTER_WR_IQ 0x3ff +#define V_FW_FILTER_WR_IQ(x) ((x) << S_FW_FILTER_WR_IQ) +#define G_FW_FILTER_WR_IQ(x) \ + (((x) >> S_FW_FILTER_WR_IQ) & M_FW_FILTER_WR_IQ) + +#define S_FW_FILTER_WR_DEL_FILTER 31 +#define M_FW_FILTER_WR_DEL_FILTER 0x1 +#define V_FW_FILTER_WR_DEL_FILTER(x) ((x) << S_FW_FILTER_WR_DEL_FILTER) +#define G_FW_FILTER_WR_DEL_FILTER(x) \ + (((x) >> S_FW_FILTER_WR_DEL_FILTER) & M_FW_FILTER_WR_DEL_FILTER) +#define F_FW_FILTER_WR_DEL_FILTER V_FW_FILTER_WR_DEL_FILTER(1U) + +#define S_FW_FILTER_WR_RPTTID 25 +#define M_FW_FILTER_WR_RPTTID 0x1 +#define V_FW_FILTER_WR_RPTTID(x) ((x) << S_FW_FILTER_WR_RPTTID) +#define G_FW_FILTER_WR_RPTTID(x) \ + (((x) >> S_FW_FILTER_WR_RPTTID) & M_FW_FILTER_WR_RPTTID) +#define F_FW_FILTER_WR_RPTTID V_FW_FILTER_WR_RPTTID(1U) + +#define S_FW_FILTER_WR_DROP 24 +#define M_FW_FILTER_WR_DROP 0x1 +#define V_FW_FILTER_WR_DROP(x) ((x) << S_FW_FILTER_WR_DROP) +#define G_FW_FILTER_WR_DROP(x) \ + (((x) >> S_FW_FILTER_WR_DROP) & M_FW_FILTER_WR_DROP) +#define F_FW_FILTER_WR_DROP V_FW_FILTER_WR_DROP(1U) + +#define S_FW_FILTER_WR_DIRSTEER 23 +#define M_FW_FILTER_WR_DIRSTEER 0x1 +#define V_FW_FILTER_WR_DIRSTEER(x) ((x) << S_FW_FILTER_WR_DIRSTEER) +#define G_FW_FILTER_WR_DIRSTEER(x) \ + (((x) >> S_FW_FILTER_WR_DIRSTEER) & M_FW_FILTER_WR_DIRSTEER) +#define F_FW_FILTER_WR_DIRSTEER V_FW_FILTER_WR_DIRSTEER(1U) + +#define S_FW_FILTER_WR_MASKHASH 22 +#define M_FW_FILTER_WR_MASKHASH 0x1 +#define V_FW_FILTER_WR_MASKHASH(x) ((x) << S_FW_FILTER_WR_MASKHASH) +#define G_FW_FILTER_WR_MASKHASH(x) \ + (((x) >> S_FW_FILTER_WR_MASKHASH) & M_FW_FILTER_WR_MASKHASH) +#define F_FW_FILTER_WR_MASKHASH V_FW_FILTER_WR_MASKHASH(1U) + +#define S_FW_FILTER_WR_DIRSTEERHASH 21 +#define M_FW_FILTER_WR_DIRSTEERHASH 0x1 +#define V_FW_FILTER_WR_DIRSTEERHASH(x) ((x) << S_FW_FILTER_WR_DIRSTEERHASH) +#define G_FW_FILTER_WR_DIRSTEERHASH(x) \ + (((x) >> S_FW_FILTER_WR_DIRSTEERHASH) & M_FW_FILTER_WR_DIRSTEERHASH) +#define F_FW_FILTER_WR_DIRSTEERHASH V_FW_FILTER_WR_DIRSTEERHASH(1U) + +#define S_FW_FILTER_WR_LPBK 20 +#define M_FW_FILTER_WR_LPBK 0x1 +#define V_FW_FILTER_WR_LPBK(x) ((x) << S_FW_FILTER_WR_LPBK) +#define G_FW_FILTER_WR_LPBK(x) \ + (((x) >> S_FW_FILTER_WR_LPBK) & M_FW_FILTER_WR_LPBK) +#define F_FW_FILTER_WR_LPBK V_FW_FILTER_WR_LPBK(1U) + +#define S_FW_FILTER_WR_DMAC 19 +#define M_FW_FILTER_WR_DMAC 0x1 +#define V_FW_FILTER_WR_DMAC(x) ((x) << S_FW_FILTER_WR_DMAC) +#define G_FW_FILTER_WR_DMAC(x) \ + (((x) >> S_FW_FILTER_WR_DMAC) & M_FW_FILTER_WR_DMAC) +#define F_FW_FILTER_WR_DMAC V_FW_FILTER_WR_DMAC(1U) + +#define S_FW_FILTER_WR_SMAC 18 +#define M_FW_FILTER_WR_SMAC 0x1 +#define V_FW_FILTER_WR_SMAC(x) ((x) << S_FW_FILTER_WR_SMAC) +#define G_FW_FILTER_WR_SMAC(x) \ + (((x) >> S_FW_FILTER_WR_SMAC) & M_FW_FILTER_WR_SMAC) +#define F_FW_FILTER_WR_SMAC V_FW_FILTER_WR_SMAC(1U) + +#define S_FW_FILTER_WR_INSVLAN 17 +#define M_FW_FILTER_WR_INSVLAN 0x1 +#define V_FW_FILTER_WR_INSVLAN(x) ((x) << S_FW_FILTER_WR_INSVLAN) +#define G_FW_FILTER_WR_INSVLAN(x) \ + (((x) >> S_FW_FILTER_WR_INSVLAN) & M_FW_FILTER_WR_INSVLAN) +#define F_FW_FILTER_WR_INSVLAN V_FW_FILTER_WR_INSVLAN(1U) + +#define S_FW_FILTER_WR_RMVLAN 16 +#define M_FW_FILTER_WR_RMVLAN 0x1 +#define V_FW_FILTER_WR_RMVLAN(x) ((x) << S_FW_FILTER_WR_RMVLAN) +#define G_FW_FILTER_WR_RMVLAN(x) \ + (((x) >> S_FW_FILTER_WR_RMVLAN) & M_FW_FILTER_WR_RMVLAN) +#define F_FW_FILTER_WR_RMVLAN V_FW_FILTER_WR_RMVLAN(1U) + +#define S_FW_FILTER_WR_HITCNTS 15 +#define M_FW_FILTER_WR_HITCNTS 0x1 +#define V_FW_FILTER_WR_HITCNTS(x) ((x) << S_FW_FILTER_WR_HITCNTS) +#define G_FW_FILTER_WR_HITCNTS(x) \ + (((x) >> S_FW_FILTER_WR_HITCNTS) & M_FW_FILTER_WR_HITCNTS) +#define F_FW_FILTER_WR_HITCNTS V_FW_FILTER_WR_HITCNTS(1U) + +#define S_FW_FILTER_WR_TXCHAN 13 +#define M_FW_FILTER_WR_TXCHAN 0x3 +#define V_FW_FILTER_WR_TXCHAN(x) ((x) << S_FW_FILTER_WR_TXCHAN) +#define G_FW_FILTER_WR_TXCHAN(x) \ + (((x) >> S_FW_FILTER_WR_TXCHAN) & M_FW_FILTER_WR_TXCHAN) + +#define S_FW_FILTER_WR_PRIO 12 +#define M_FW_FILTER_WR_PRIO 0x1 +#define V_FW_FILTER_WR_PRIO(x) ((x) << S_FW_FILTER_WR_PRIO) +#define G_FW_FILTER_WR_PRIO(x) \ + (((x) >> S_FW_FILTER_WR_PRIO) & M_FW_FILTER_WR_PRIO) +#define F_FW_FILTER_WR_PRIO V_FW_FILTER_WR_PRIO(1U) + +#define S_FW_FILTER_WR_L2TIX 0 +#define M_FW_FILTER_WR_L2TIX 0xfff +#define V_FW_FILTER_WR_L2TIX(x) ((x) << S_FW_FILTER_WR_L2TIX) +#define G_FW_FILTER_WR_L2TIX(x) \ + (((x) >> S_FW_FILTER_WR_L2TIX) & M_FW_FILTER_WR_L2TIX) + +#define S_FW_FILTER_WR_FRAG 7 +#define M_FW_FILTER_WR_FRAG 0x1 +#define V_FW_FILTER_WR_FRAG(x) ((x) << S_FW_FILTER_WR_FRAG) +#define G_FW_FILTER_WR_FRAG(x) \ + (((x) >> S_FW_FILTER_WR_FRAG) & M_FW_FILTER_WR_FRAG) +#define F_FW_FILTER_WR_FRAG V_FW_FILTER_WR_FRAG(1U) + +#define S_FW_FILTER_WR_FRAGM 6 +#define M_FW_FILTER_WR_FRAGM 0x1 +#define V_FW_FILTER_WR_FRAGM(x) ((x) << S_FW_FILTER_WR_FRAGM) +#define G_FW_FILTER_WR_FRAGM(x) \ + (((x) >> S_FW_FILTER_WR_FRAGM) & M_FW_FILTER_WR_FRAGM) +#define F_FW_FILTER_WR_FRAGM V_FW_FILTER_WR_FRAGM(1U) + +#define S_FW_FILTER_WR_IVLAN_VLD 5 +#define M_FW_FILTER_WR_IVLAN_VLD 0x1 +#define V_FW_FILTER_WR_IVLAN_VLD(x) ((x) << S_FW_FILTER_WR_IVLAN_VLD) +#define G_FW_FILTER_WR_IVLAN_VLD(x) \ + (((x) >> S_FW_FILTER_WR_IVLAN_VLD) & M_FW_FILTER_WR_IVLAN_VLD) +#define F_FW_FILTER_WR_IVLAN_VLD V_FW_FILTER_WR_IVLAN_VLD(1U) + +#define S_FW_FILTER_WR_OVLAN_VLD 4 +#define M_FW_FILTER_WR_OVLAN_VLD 0x1 +#define V_FW_FILTER_WR_OVLAN_VLD(x) ((x) << S_FW_FILTER_WR_OVLAN_VLD) +#define G_FW_FILTER_WR_OVLAN_VLD(x) \ + (((x) >> S_FW_FILTER_WR_OVLAN_VLD) & M_FW_FILTER_WR_OVLAN_VLD) +#define F_FW_FILTER_WR_OVLAN_VLD V_FW_FILTER_WR_OVLAN_VLD(1U) + +#define S_FW_FILTER_WR_IVLAN_VLDM 3 +#define M_FW_FILTER_WR_IVLAN_VLDM 0x1 +#define V_FW_FILTER_WR_IVLAN_VLDM(x) ((x) << S_FW_FILTER_WR_IVLAN_VLDM) +#define G_FW_FILTER_WR_IVLAN_VLDM(x) \ + (((x) >> S_FW_FILTER_WR_IVLAN_VLDM) & M_FW_FILTER_WR_IVLAN_VLDM) +#define F_FW_FILTER_WR_IVLAN_VLDM V_FW_FILTER_WR_IVLAN_VLDM(1U) + +#define S_FW_FILTER_WR_OVLAN_VLDM 2 +#define M_FW_FILTER_WR_OVLAN_VLDM 0x1 +#define V_FW_FILTER_WR_OVLAN_VLDM(x) ((x) << S_FW_FILTER_WR_OVLAN_VLDM) +#define G_FW_FILTER_WR_OVLAN_VLDM(x) \ + (((x) >> S_FW_FILTER_WR_OVLAN_VLDM) & M_FW_FILTER_WR_OVLAN_VLDM) +#define F_FW_FILTER_WR_OVLAN_VLDM V_FW_FILTER_WR_OVLAN_VLDM(1U) + +#define S_FW_FILTER_WR_RX_CHAN 15 +#define M_FW_FILTER_WR_RX_CHAN 0x1 +#define V_FW_FILTER_WR_RX_CHAN(x) ((x) << S_FW_FILTER_WR_RX_CHAN) +#define G_FW_FILTER_WR_RX_CHAN(x) \ + (((x) >> S_FW_FILTER_WR_RX_CHAN) & M_FW_FILTER_WR_RX_CHAN) +#define F_FW_FILTER_WR_RX_CHAN V_FW_FILTER_WR_RX_CHAN(1U) + +#define S_FW_FILTER_WR_RX_RPL_IQ 0 +#define M_FW_FILTER_WR_RX_RPL_IQ 0x3ff +#define V_FW_FILTER_WR_RX_RPL_IQ(x) ((x) << S_FW_FILTER_WR_RX_RPL_IQ) +#define G_FW_FILTER_WR_RX_RPL_IQ(x) \ + (((x) >> S_FW_FILTER_WR_RX_RPL_IQ) & M_FW_FILTER_WR_RX_RPL_IQ) + +#define S_FW_FILTER_WR_MACI 23 +#define M_FW_FILTER_WR_MACI 0x1ff +#define V_FW_FILTER_WR_MACI(x) ((x) << S_FW_FILTER_WR_MACI) +#define G_FW_FILTER_WR_MACI(x) \ + (((x) >> S_FW_FILTER_WR_MACI) & M_FW_FILTER_WR_MACI) + +#define S_FW_FILTER_WR_MACIM 14 +#define M_FW_FILTER_WR_MACIM 0x1ff +#define V_FW_FILTER_WR_MACIM(x) ((x) << S_FW_FILTER_WR_MACIM) +#define G_FW_FILTER_WR_MACIM(x) \ + (((x) >> S_FW_FILTER_WR_MACIM) & M_FW_FILTER_WR_MACIM) + +#define S_FW_FILTER_WR_FCOE 13 +#define M_FW_FILTER_WR_FCOE 0x1 +#define V_FW_FILTER_WR_FCOE(x) ((x) << S_FW_FILTER_WR_FCOE) +#define G_FW_FILTER_WR_FCOE(x) \ + (((x) >> S_FW_FILTER_WR_FCOE) & M_FW_FILTER_WR_FCOE) +#define F_FW_FILTER_WR_FCOE V_FW_FILTER_WR_FCOE(1U) + +#define S_FW_FILTER_WR_FCOEM 12 +#define M_FW_FILTER_WR_FCOEM 0x1 +#define V_FW_FILTER_WR_FCOEM(x) ((x) << S_FW_FILTER_WR_FCOEM) +#define G_FW_FILTER_WR_FCOEM(x) \ + (((x) >> S_FW_FILTER_WR_FCOEM) & M_FW_FILTER_WR_FCOEM) +#define F_FW_FILTER_WR_FCOEM V_FW_FILTER_WR_FCOEM(1U) + +#define S_FW_FILTER_WR_PORT 9 +#define M_FW_FILTER_WR_PORT 0x7 +#define V_FW_FILTER_WR_PORT(x) ((x) << S_FW_FILTER_WR_PORT) +#define G_FW_FILTER_WR_PORT(x) \ + (((x) >> S_FW_FILTER_WR_PORT) & M_FW_FILTER_WR_PORT) + +#define S_FW_FILTER_WR_PORTM 6 +#define M_FW_FILTER_WR_PORTM 0x7 +#define V_FW_FILTER_WR_PORTM(x) ((x) << S_FW_FILTER_WR_PORTM) +#define G_FW_FILTER_WR_PORTM(x) \ + (((x) >> S_FW_FILTER_WR_PORTM) & M_FW_FILTER_WR_PORTM) + +#define S_FW_FILTER_WR_MATCHTYPE 3 +#define M_FW_FILTER_WR_MATCHTYPE 0x7 +#define V_FW_FILTER_WR_MATCHTYPE(x) ((x) << S_FW_FILTER_WR_MATCHTYPE) +#define G_FW_FILTER_WR_MATCHTYPE(x) \ + (((x) >> S_FW_FILTER_WR_MATCHTYPE) & M_FW_FILTER_WR_MATCHTYPE) + +#define S_FW_FILTER_WR_MATCHTYPEM 0 +#define M_FW_FILTER_WR_MATCHTYPEM 0x7 +#define V_FW_FILTER_WR_MATCHTYPEM(x) ((x) << S_FW_FILTER_WR_MATCHTYPEM) +#define G_FW_FILTER_WR_MATCHTYPEM(x) \ + (((x) >> S_FW_FILTER_WR_MATCHTYPEM) & M_FW_FILTER_WR_MATCHTYPEM) + +struct fw_ulptx_wr { + __be32 op_to_compl; + __be32 flowid_len16; + __u64 cookie; +}; + +struct fw_tp_wr { + __be32 op_to_immdlen; + __be32 flowid_len16; + __u64 cookie; +}; + +struct fw_eth_tx_pkt_wr { + __be32 op_immdlen; + __be32 equiq_to_len16; + __be64 r3; +}; + +#define S_FW_ETH_TX_PKT_WR_IMMDLEN 0 +#define M_FW_ETH_TX_PKT_WR_IMMDLEN 0x1ff +#define V_FW_ETH_TX_PKT_WR_IMMDLEN(x) ((x) << S_FW_ETH_TX_PKT_WR_IMMDLEN) +#define G_FW_ETH_TX_PKT_WR_IMMDLEN(x) \ + (((x) >> S_FW_ETH_TX_PKT_WR_IMMDLEN) & M_FW_ETH_TX_PKT_WR_IMMDLEN) + +struct fw_eth_tx_pkt2_wr { + __be32 op_immdlen; + __be32 equiq_to_len16; + __be32 r3; + __be32 L4ChkDisable_to_IpHdrLen; +}; + +#define S_FW_ETH_TX_PKT2_WR_IMMDLEN 0 +#define M_FW_ETH_TX_PKT2_WR_IMMDLEN 0x1ff +#define V_FW_ETH_TX_PKT2_WR_IMMDLEN(x) ((x) << S_FW_ETH_TX_PKT2_WR_IMMDLEN) +#define G_FW_ETH_TX_PKT2_WR_IMMDLEN(x) \ + (((x) >> S_FW_ETH_TX_PKT2_WR_IMMDLEN) & M_FW_ETH_TX_PKT2_WR_IMMDLEN) + +#define S_FW_ETH_TX_PKT2_WR_L4CHKDISABLE 31 +#define M_FW_ETH_TX_PKT2_WR_L4CHKDISABLE 0x1 +#define V_FW_ETH_TX_PKT2_WR_L4CHKDISABLE(x) \ + ((x) << S_FW_ETH_TX_PKT2_WR_L4CHKDISABLE) +#define G_FW_ETH_TX_PKT2_WR_L4CHKDISABLE(x) \ + (((x) >> S_FW_ETH_TX_PKT2_WR_L4CHKDISABLE) & \ + M_FW_ETH_TX_PKT2_WR_L4CHKDISABLE) +#define F_FW_ETH_TX_PKT2_WR_L4CHKDISABLE \ + V_FW_ETH_TX_PKT2_WR_L4CHKDISABLE(1U) + +#define S_FW_ETH_TX_PKT2_WR_L3CHKDISABLE 30 +#define M_FW_ETH_TX_PKT2_WR_L3CHKDISABLE 0x1 +#define V_FW_ETH_TX_PKT2_WR_L3CHKDISABLE(x) \ + ((x) << S_FW_ETH_TX_PKT2_WR_L3CHKDISABLE) +#define G_FW_ETH_TX_PKT2_WR_L3CHKDISABLE(x) \ + (((x) >> S_FW_ETH_TX_PKT2_WR_L3CHKDISABLE) & \ + M_FW_ETH_TX_PKT2_WR_L3CHKDISABLE) +#define F_FW_ETH_TX_PKT2_WR_L3CHKDISABLE \ + V_FW_ETH_TX_PKT2_WR_L3CHKDISABLE(1U) + +#define S_FW_ETH_TX_PKT2_WR_IVLAN 28 +#define M_FW_ETH_TX_PKT2_WR_IVLAN 0x1 +#define V_FW_ETH_TX_PKT2_WR_IVLAN(x) ((x) << S_FW_ETH_TX_PKT2_WR_IVLAN) +#define G_FW_ETH_TX_PKT2_WR_IVLAN(x) \ + (((x) >> S_FW_ETH_TX_PKT2_WR_IVLAN) & M_FW_ETH_TX_PKT2_WR_IVLAN) +#define F_FW_ETH_TX_PKT2_WR_IVLAN V_FW_ETH_TX_PKT2_WR_IVLAN(1U) + +#define S_FW_ETH_TX_PKT2_WR_IVLANTAG 12 +#define M_FW_ETH_TX_PKT2_WR_IVLANTAG 0xffff +#define V_FW_ETH_TX_PKT2_WR_IVLANTAG(x) ((x) << S_FW_ETH_TX_PKT2_WR_IVLANTAG) +#define G_FW_ETH_TX_PKT2_WR_IVLANTAG(x) \ + (((x) >> S_FW_ETH_TX_PKT2_WR_IVLANTAG) & M_FW_ETH_TX_PKT2_WR_IVLANTAG) + +#define S_FW_ETH_TX_PKT2_WR_CHKTYPE 8 +#define M_FW_ETH_TX_PKT2_WR_CHKTYPE 0xf +#define V_FW_ETH_TX_PKT2_WR_CHKTYPE(x) ((x) << S_FW_ETH_TX_PKT2_WR_CHKTYPE) +#define G_FW_ETH_TX_PKT2_WR_CHKTYPE(x) \ + (((x) >> S_FW_ETH_TX_PKT2_WR_CHKTYPE) & M_FW_ETH_TX_PKT2_WR_CHKTYPE) + +#define S_FW_ETH_TX_PKT2_WR_IPHDRLEN 0 +#define M_FW_ETH_TX_PKT2_WR_IPHDRLEN 0xff +#define V_FW_ETH_TX_PKT2_WR_IPHDRLEN(x) ((x) << S_FW_ETH_TX_PKT2_WR_IPHDRLEN) +#define G_FW_ETH_TX_PKT2_WR_IPHDRLEN(x) \ + (((x) >> S_FW_ETH_TX_PKT2_WR_IPHDRLEN) & M_FW_ETH_TX_PKT2_WR_IPHDRLEN) + +struct fw_eth_tx_pkts_wr { + __be32 op_pkd; + __be32 equiq_to_len16; + __be32 r3; + __be16 plen; + __u8 npkt; + __u8 type; +}; + +struct fw_eth_tx_uo_wr { + __be32 op_immdlen; + __be32 equiq_to_len16; + __be64 r3; + __u8 r4; + __u8 ethlen; + __be16 iplen; + __u8 udplen; + __u8 rtplen; + __be16 r5; + __be16 mss; + __be16 schedpktsize; + __be32 length; +}; + +struct fw_eq_flush_wr { + __u8 opcode; + __u8 r1[3]; + __be32 equiq_to_len16; + __be64 r3; +}; + +struct fw_ofld_connection_wr { + __be32 op_compl; + __be32 len16_pkd; + __u64 cookie; + __be64 r2; + __be64 r3; + struct fw_ofld_connection_le { + __be32 version_cpl; + __be32 filter; + __be32 r1; + __be16 lport; + __be16 pport; + union fw_ofld_connection_leip { + struct fw_ofld_connection_le_ipv4 { + __be32 pip; + __be32 lip; + __be64 r0; + __be64 r1; + __be64 r2; + } ipv4; + struct fw_ofld_connection_le_ipv6 { + __be64 pip_hi; + __be64 pip_lo; + __be64 lip_hi; + __be64 lip_lo; + } ipv6; + } u; + } le; + struct fw_ofld_connection_tcb { + __be32 t_state_to_astid; + __be16 cplrxdataack_cplpassacceptrpl; + __be16 rcv_adv; + __be32 rcv_nxt; + __be32 tx_max; + __be64 opt0; + __be32 opt2; + __be32 r1; + __be64 r2; + __be64 r3; + } tcb; +}; + +#define S_FW_OFLD_CONNECTION_WR_VERSION 31 +#define M_FW_OFLD_CONNECTION_WR_VERSION 0x1 +#define V_FW_OFLD_CONNECTION_WR_VERSION(x) \ + ((x) << S_FW_OFLD_CONNECTION_WR_VERSION) +#define G_FW_OFLD_CONNECTION_WR_VERSION(x) \ + (((x) >> S_FW_OFLD_CONNECTION_WR_VERSION) & \ + M_FW_OFLD_CONNECTION_WR_VERSION) +#define F_FW_OFLD_CONNECTION_WR_VERSION V_FW_OFLD_CONNECTION_WR_VERSION(1U) + +#define S_FW_OFLD_CONNECTION_WR_CPL 30 +#define M_FW_OFLD_CONNECTION_WR_CPL 0x1 +#define V_FW_OFLD_CONNECTION_WR_CPL(x) ((x) << S_FW_OFLD_CONNECTION_WR_CPL) +#define G_FW_OFLD_CONNECTION_WR_CPL(x) \ + (((x) >> S_FW_OFLD_CONNECTION_WR_CPL) & M_FW_OFLD_CONNECTION_WR_CPL) +#define F_FW_OFLD_CONNECTION_WR_CPL V_FW_OFLD_CONNECTION_WR_CPL(1U) + +#define S_FW_OFLD_CONNECTION_WR_T_STATE 28 +#define M_FW_OFLD_CONNECTION_WR_T_STATE 0xf +#define V_FW_OFLD_CONNECTION_WR_T_STATE(x) \ + ((x) << S_FW_OFLD_CONNECTION_WR_T_STATE) +#define G_FW_OFLD_CONNECTION_WR_T_STATE(x) \ + (((x) >> S_FW_OFLD_CONNECTION_WR_T_STATE) & \ + M_FW_OFLD_CONNECTION_WR_T_STATE) + +#define S_FW_OFLD_CONNECTION_WR_RCV_SCALE 24 +#define M_FW_OFLD_CONNECTION_WR_RCV_SCALE 0xf +#define V_FW_OFLD_CONNECTION_WR_RCV_SCALE(x) \ + ((x) << S_FW_OFLD_CONNECTION_WR_RCV_SCALE) +#define G_FW_OFLD_CONNECTION_WR_RCV_SCALE(x) \ + (((x) >> S_FW_OFLD_CONNECTION_WR_RCV_SCALE) & \ + M_FW_OFLD_CONNECTION_WR_RCV_SCALE) + +#define S_FW_OFLD_CONNECTION_WR_ASTID 0 +#define M_FW_OFLD_CONNECTION_WR_ASTID 0xffffff +#define V_FW_OFLD_CONNECTION_WR_ASTID(x) \ + ((x) << S_FW_OFLD_CONNECTION_WR_ASTID) +#define G_FW_OFLD_CONNECTION_WR_ASTID(x) \ + (((x) >> S_FW_OFLD_CONNECTION_WR_ASTID) & M_FW_OFLD_CONNECTION_WR_ASTID) + +#define S_FW_OFLD_CONNECTION_WR_CPLRXDATAACK 15 +#define M_FW_OFLD_CONNECTION_WR_CPLRXDATAACK 0x1 +#define V_FW_OFLD_CONNECTION_WR_CPLRXDATAACK(x) \ + ((x) << S_FW_OFLD_CONNECTION_WR_CPLRXDATAACK) +#define G_FW_OFLD_CONNECTION_WR_CPLRXDATAACK(x) \ + (((x) >> S_FW_OFLD_CONNECTION_WR_CPLRXDATAACK) & \ + M_FW_OFLD_CONNECTION_WR_CPLRXDATAACK) +#define F_FW_OFLD_CONNECTION_WR_CPLRXDATAACK \ + V_FW_OFLD_CONNECTION_WR_CPLRXDATAACK(1U) + +#define S_FW_OFLD_CONNECTION_WR_CPLPASSACCEPTRPL 14 +#define M_FW_OFLD_CONNECTION_WR_CPLPASSACCEPTRPL 0x1 +#define V_FW_OFLD_CONNECTION_WR_CPLPASSACCEPTRPL(x) \ + ((x) << S_FW_OFLD_CONNECTION_WR_CPLPASSACCEPTRPL) +#define G_FW_OFLD_CONNECTION_WR_CPLPASSACCEPTRPL(x) \ + (((x) >> S_FW_OFLD_CONNECTION_WR_CPLPASSACCEPTRPL) & \ + M_FW_OFLD_CONNECTION_WR_CPLPASSACCEPTRPL) +#define F_FW_OFLD_CONNECTION_WR_CPLPASSACCEPTRPL \ + V_FW_OFLD_CONNECTION_WR_CPLPASSACCEPTRPL(1U) + +enum fw_flowc_mnem_tcpstate { + FW_FLOWC_MNEM_TCPSTATE_CLOSED = 0, /* illegal */ + FW_FLOWC_MNEM_TCPSTATE_LISTEN = 1, /* illegal */ + FW_FLOWC_MNEM_TCPSTATE_SYNSENT = 2, /* illegal */ + FW_FLOWC_MNEM_TCPSTATE_SYNRECEIVED = 3, /* illegal */ + FW_FLOWC_MNEM_TCPSTATE_ESTABLISHED = 4, /* default */ + FW_FLOWC_MNEM_TCPSTATE_CLOSEWAIT = 5, /* got peer close already */ + FW_FLOWC_MNEM_TCPSTATE_FINWAIT1 = 6, /* haven't gotten ACK for FIN and + * will resend FIN - equiv ESTAB + */ + FW_FLOWC_MNEM_TCPSTATE_CLOSING = 7, /* haven't gotten ACK for FIN and + * will resend FIN but have + * received FIN + */ + FW_FLOWC_MNEM_TCPSTATE_LASTACK = 8, /* haven't gotten ACK for FIN and + * will resend FIN but have + * received FIN + */ + FW_FLOWC_MNEM_TCPSTATE_FINWAIT2 = 9, /* sent FIN and got FIN + ACK, + * waiting for FIN + */ + FW_FLOWC_MNEM_TCPSTATE_TIMEWAIT = 10, /* not expected */ +}; + +enum fw_flowc_mnem_uostate { + FW_FLOWC_MNEM_UOSTATE_CLOSED = 0, /* illegal */ + FW_FLOWC_MNEM_UOSTATE_ESTABLISHED = 1, /* default */ + FW_FLOWC_MNEM_UOSTATE_CLOSING = 2, /* graceful close, after sending + * outstanding payload + */ + FW_FLOWC_MNEM_UOSTATE_ABORTING = 3, /* immediate close, after + * discarding outstanding payload + */ +}; + +enum fw_flowc_mnem { + FW_FLOWC_MNEM_PFNVFN = 0, /* PFN [15:8] VFN [7:0] */ + FW_FLOWC_MNEM_CH = 1, + FW_FLOWC_MNEM_PORT = 2, + FW_FLOWC_MNEM_IQID = 3, + FW_FLOWC_MNEM_SNDNXT = 4, + FW_FLOWC_MNEM_RCVNXT = 5, + FW_FLOWC_MNEM_SNDBUF = 6, + FW_FLOWC_MNEM_MSS = 7, + FW_FLOWC_MNEM_TXDATAPLEN_MAX = 8, + FW_FLOWC_MNEM_TCPSTATE = 9, + FW_FLOWC_MNEM_UOSTATE = 10, + FW_FLOWC_MNEM_SCHEDCLASS = 11, + FW_FLOWC_MNEM_DCBPRIO = 12, +}; + +struct fw_flowc_mnemval { + __u8 mnemonic; + __u8 r4[3]; + __be32 val; +}; + +struct fw_flowc_wr { + __be32 op_to_nparams; + __be32 flowid_len16; +#ifndef C99_NOT_SUPPORTED + struct fw_flowc_mnemval mnemval[0]; +#endif +}; + +#define S_FW_FLOWC_WR_NPARAMS 0 +#define M_FW_FLOWC_WR_NPARAMS 0xff +#define V_FW_FLOWC_WR_NPARAMS(x) ((x) << S_FW_FLOWC_WR_NPARAMS) +#define G_FW_FLOWC_WR_NPARAMS(x) \ + (((x) >> S_FW_FLOWC_WR_NPARAMS) & M_FW_FLOWC_WR_NPARAMS) + +struct fw_ofld_tx_data_wr { + __be32 op_to_immdlen; + __be32 flowid_len16; + __be32 plen; + __be32 lsodisable_to_proxy; +}; + +#define S_FW_OFLD_TX_DATA_WR_LSODISABLE 31 +#define M_FW_OFLD_TX_DATA_WR_LSODISABLE 0x1 +#define V_FW_OFLD_TX_DATA_WR_LSODISABLE(x) \ + ((x) << S_FW_OFLD_TX_DATA_WR_LSODISABLE) +#define G_FW_OFLD_TX_DATA_WR_LSODISABLE(x) \ + (((x) >> S_FW_OFLD_TX_DATA_WR_LSODISABLE) & \ + M_FW_OFLD_TX_DATA_WR_LSODISABLE) +#define F_FW_OFLD_TX_DATA_WR_LSODISABLE V_FW_OFLD_TX_DATA_WR_LSODISABLE(1U) + +#define S_FW_OFLD_TX_DATA_WR_ALIGNPLD 30 +#define M_FW_OFLD_TX_DATA_WR_ALIGNPLD 0x1 +#define V_FW_OFLD_TX_DATA_WR_ALIGNPLD(x) \ + ((x) << S_FW_OFLD_TX_DATA_WR_ALIGNPLD) +#define G_FW_OFLD_TX_DATA_WR_ALIGNPLD(x) \ + (((x) >> S_FW_OFLD_TX_DATA_WR_ALIGNPLD) & M_FW_OFLD_TX_DATA_WR_ALIGNPLD) +#define F_FW_OFLD_TX_DATA_WR_ALIGNPLD V_FW_OFLD_TX_DATA_WR_ALIGNPLD(1U) + +#define S_FW_OFLD_TX_DATA_WR_ALIGNPLDSHOVE 29 +#define M_FW_OFLD_TX_DATA_WR_ALIGNPLDSHOVE 0x1 +#define V_FW_OFLD_TX_DATA_WR_ALIGNPLDSHOVE(x) \ + ((x) << S_FW_OFLD_TX_DATA_WR_ALIGNPLDSHOVE) +#define G_FW_OFLD_TX_DATA_WR_ALIGNPLDSHOVE(x) \ + (((x) >> S_FW_OFLD_TX_DATA_WR_ALIGNPLDSHOVE) & \ + M_FW_OFLD_TX_DATA_WR_ALIGNPLDSHOVE) +#define F_FW_OFLD_TX_DATA_WR_ALIGNPLDSHOVE \ + V_FW_OFLD_TX_DATA_WR_ALIGNPLDSHOVE(1U) + +#define S_FW_OFLD_TX_DATA_WR_TUNNEL 19 +#define M_FW_OFLD_TX_DATA_WR_TUNNEL 0x1 +#define V_FW_OFLD_TX_DATA_WR_TUNNEL(x) ((x) << S_FW_OFLD_TX_DATA_WR_TUNNEL) +#define G_FW_OFLD_TX_DATA_WR_TUNNEL(x) \ + (((x) >> S_FW_OFLD_TX_DATA_WR_TUNNEL) & M_FW_OFLD_TX_DATA_WR_TUNNEL) +#define F_FW_OFLD_TX_DATA_WR_TUNNEL V_FW_OFLD_TX_DATA_WR_TUNNEL(1U) + +#define S_FW_OFLD_TX_DATA_WR_SAVE 18 +#define M_FW_OFLD_TX_DATA_WR_SAVE 0x1 +#define V_FW_OFLD_TX_DATA_WR_SAVE(x) ((x) << S_FW_OFLD_TX_DATA_WR_SAVE) +#define G_FW_OFLD_TX_DATA_WR_SAVE(x) \ + (((x) >> S_FW_OFLD_TX_DATA_WR_SAVE) & M_FW_OFLD_TX_DATA_WR_SAVE) +#define F_FW_OFLD_TX_DATA_WR_SAVE V_FW_OFLD_TX_DATA_WR_SAVE(1U) + +#define S_FW_OFLD_TX_DATA_WR_FLUSH 17 +#define M_FW_OFLD_TX_DATA_WR_FLUSH 0x1 +#define V_FW_OFLD_TX_DATA_WR_FLUSH(x) ((x) << S_FW_OFLD_TX_DATA_WR_FLUSH) +#define G_FW_OFLD_TX_DATA_WR_FLUSH(x) \ + (((x) >> S_FW_OFLD_TX_DATA_WR_FLUSH) & M_FW_OFLD_TX_DATA_WR_FLUSH) +#define F_FW_OFLD_TX_DATA_WR_FLUSH V_FW_OFLD_TX_DATA_WR_FLUSH(1U) + +#define S_FW_OFLD_TX_DATA_WR_URGENT 16 +#define M_FW_OFLD_TX_DATA_WR_URGENT 0x1 +#define V_FW_OFLD_TX_DATA_WR_URGENT(x) ((x) << S_FW_OFLD_TX_DATA_WR_URGENT) +#define G_FW_OFLD_TX_DATA_WR_URGENT(x) \ + (((x) >> S_FW_OFLD_TX_DATA_WR_URGENT) & M_FW_OFLD_TX_DATA_WR_URGENT) +#define F_FW_OFLD_TX_DATA_WR_URGENT V_FW_OFLD_TX_DATA_WR_URGENT(1U) + +#define S_FW_OFLD_TX_DATA_WR_MORE 15 +#define M_FW_OFLD_TX_DATA_WR_MORE 0x1 +#define V_FW_OFLD_TX_DATA_WR_MORE(x) ((x) << S_FW_OFLD_TX_DATA_WR_MORE) +#define G_FW_OFLD_TX_DATA_WR_MORE(x) \ + (((x) >> S_FW_OFLD_TX_DATA_WR_MORE) & M_FW_OFLD_TX_DATA_WR_MORE) +#define F_FW_OFLD_TX_DATA_WR_MORE V_FW_OFLD_TX_DATA_WR_MORE(1U) + +#define S_FW_OFLD_TX_DATA_WR_SHOVE 14 +#define M_FW_OFLD_TX_DATA_WR_SHOVE 0x1 +#define V_FW_OFLD_TX_DATA_WR_SHOVE(x) ((x) << S_FW_OFLD_TX_DATA_WR_SHOVE) +#define G_FW_OFLD_TX_DATA_WR_SHOVE(x) \ + (((x) >> S_FW_OFLD_TX_DATA_WR_SHOVE) & M_FW_OFLD_TX_DATA_WR_SHOVE) +#define F_FW_OFLD_TX_DATA_WR_SHOVE V_FW_OFLD_TX_DATA_WR_SHOVE(1U) + +#define S_FW_OFLD_TX_DATA_WR_ULPMODE 10 +#define M_FW_OFLD_TX_DATA_WR_ULPMODE 0xf +#define V_FW_OFLD_TX_DATA_WR_ULPMODE(x) ((x) << S_FW_OFLD_TX_DATA_WR_ULPMODE) +#define G_FW_OFLD_TX_DATA_WR_ULPMODE(x) \ + (((x) >> S_FW_OFLD_TX_DATA_WR_ULPMODE) & M_FW_OFLD_TX_DATA_WR_ULPMODE) + +#define S_FW_OFLD_TX_DATA_WR_ULPSUBMODE 6 +#define M_FW_OFLD_TX_DATA_WR_ULPSUBMODE 0xf +#define V_FW_OFLD_TX_DATA_WR_ULPSUBMODE(x) \ + ((x) << S_FW_OFLD_TX_DATA_WR_ULPSUBMODE) +#define G_FW_OFLD_TX_DATA_WR_ULPSUBMODE(x) \ + (((x) >> S_FW_OFLD_TX_DATA_WR_ULPSUBMODE) & \ + M_FW_OFLD_TX_DATA_WR_ULPSUBMODE) + +#define S_FW_OFLD_TX_DATA_WR_PROXY 5 +#define M_FW_OFLD_TX_DATA_WR_PROXY 0x1 +#define V_FW_OFLD_TX_DATA_WR_PROXY(x) ((x) << S_FW_OFLD_TX_DATA_WR_PROXY) +#define G_FW_OFLD_TX_DATA_WR_PROXY(x) \ + (((x) >> S_FW_OFLD_TX_DATA_WR_PROXY) & M_FW_OFLD_TX_DATA_WR_PROXY) +#define F_FW_OFLD_TX_DATA_WR_PROXY V_FW_OFLD_TX_DATA_WR_PROXY(1U) + +struct fw_cmd_wr { + __be32 op_dma; + __be32 len16_pkd; + __be64 cookie_daddr; +}; + +#define S_FW_CMD_WR_DMA 17 +#define M_FW_CMD_WR_DMA 0x1 +#define V_FW_CMD_WR_DMA(x) ((x) << S_FW_CMD_WR_DMA) +#define G_FW_CMD_WR_DMA(x) (((x) >> S_FW_CMD_WR_DMA) & M_FW_CMD_WR_DMA) +#define F_FW_CMD_WR_DMA V_FW_CMD_WR_DMA(1U) + +struct fw_eth_tx_pkt_vm_wr { + __be32 op_immdlen; + __be32 equiq_to_len16; + __be32 r3[2]; + __u8 ethmacdst[6]; + __u8 ethmacsrc[6]; + __be16 ethtype; + __be16 vlantci; +}; + +/****************************************************************************** + * R I W O R K R E Q U E S T s + **************************************/ + +enum fw_ri_wr_opcode { + FW_RI_RDMA_WRITE = 0x0, /* IETF RDMAP v1.0 ... */ + FW_RI_READ_REQ = 0x1, + FW_RI_READ_RESP = 0x2, + FW_RI_SEND = 0x3, + FW_RI_SEND_WITH_INV = 0x4, + FW_RI_SEND_WITH_SE = 0x5, + FW_RI_SEND_WITH_SE_INV = 0x6, + FW_RI_TERMINATE = 0x7, + FW_RI_RDMA_INIT = 0x8, /* CHELSIO RI specific ... */ + FW_RI_BIND_MW = 0x9, + FW_RI_FAST_REGISTER = 0xa, + FW_RI_LOCAL_INV = 0xb, + FW_RI_QP_MODIFY = 0xc, + FW_RI_BYPASS = 0xd, + FW_RI_RECEIVE = 0xe, +#if 0 + FW_RI_SEND_IMMEDIATE = 0x8, + FW_RI_SEND_IMMEDIATE_WITH_SE = 0x9, + FW_RI_ATOMIC_REQUEST = 0xa, + FW_RI_ATOMIC_RESPONSE = 0xb, + + FW_RI_BIND_MW = 0xc, /* CHELSIO RI specific ... */ + FW_RI_FAST_REGISTER = 0xd, + FW_RI_LOCAL_INV = 0xe, +#endif + FW_RI_SGE_EC_CR_RETURN = 0xf +}; + +enum fw_ri_wr_flags { + FW_RI_COMPLETION_FLAG = 0x01, + FW_RI_NOTIFICATION_FLAG = 0x02, + FW_RI_SOLICITED_EVENT_FLAG = 0x04, + FW_RI_READ_FENCE_FLAG = 0x08, + FW_RI_LOCAL_FENCE_FLAG = 0x10, + FW_RI_RDMA_READ_INVALIDATE = 0x20 +}; + +enum fw_ri_mpa_attrs { + FW_RI_MPA_RX_MARKER_ENABLE = 0x01, + FW_RI_MPA_TX_MARKER_ENABLE = 0x02, + FW_RI_MPA_CRC_ENABLE = 0x04, + FW_RI_MPA_IETF_ENABLE = 0x08 +}; + +enum fw_ri_qp_caps { + FW_RI_QP_RDMA_READ_ENABLE = 0x01, + FW_RI_QP_RDMA_WRITE_ENABLE = 0x02, + FW_RI_QP_BIND_ENABLE = 0x04, + FW_RI_QP_FAST_REGISTER_ENABLE = 0x08, + FW_RI_QP_STAG0_ENABLE = 0x10, + FW_RI_QP_RDMA_READ_REQ_0B_ENABLE= 0x80, +}; + +enum fw_ri_addr_type { + FW_RI_ZERO_BASED_TO = 0x00, + FW_RI_VA_BASED_TO = 0x01 +}; + +enum fw_ri_mem_perms { + FW_RI_MEM_ACCESS_REM_WRITE = 0x01, + FW_RI_MEM_ACCESS_REM_READ = 0x02, + FW_RI_MEM_ACCESS_REM = 0x03, + FW_RI_MEM_ACCESS_LOCAL_WRITE = 0x04, + FW_RI_MEM_ACCESS_LOCAL_READ = 0x08, + FW_RI_MEM_ACCESS_LOCAL = 0x0C +}; + +enum fw_ri_stag_type { + FW_RI_STAG_NSMR = 0x00, + FW_RI_STAG_SMR = 0x01, + FW_RI_STAG_MW = 0x02, + FW_RI_STAG_MW_RELAXED = 0x03 +}; + +enum fw_ri_data_op { + FW_RI_DATA_IMMD = 0x81, + FW_RI_DATA_DSGL = 0x82, + FW_RI_DATA_ISGL = 0x83 +}; + +enum fw_ri_sgl_depth { + FW_RI_SGL_DEPTH_MAX_SQ = 16, + FW_RI_SGL_DEPTH_MAX_RQ = 4 +}; + +enum fw_ri_cqe_err { + FW_RI_CQE_ERR_SUCCESS = 0x00, /* success, no error detected */ + FW_RI_CQE_ERR_STAG = 0x01, /* STAG invalid */ + FW_RI_CQE_ERR_PDID = 0x02, /* PDID mismatch */ + FW_RI_CQE_ERR_QPID = 0x03, /* QPID mismatch */ + FW_RI_CQE_ERR_ACCESS = 0x04, /* Invalid access right */ + FW_RI_CQE_ERR_WRAP = 0x05, /* Wrap error */ + FW_RI_CQE_ERR_BOUND = 0x06, /* base and bounds violation */ + FW_RI_CQE_ERR_INVALIDATE_SHARED_MR = 0x07, /* attempt to invalidate a SMR */ + FW_RI_CQE_ERR_INVALIDATE_MR_WITH_MW_BOUND = 0x08, /* attempt to invalidate a MR w MW */ + FW_RI_CQE_ERR_ECC = 0x09, /* ECC error detected */ + FW_RI_CQE_ERR_ECC_PSTAG = 0x0A, /* ECC error detected when reading the PSTAG for a MW Invalidate */ + FW_RI_CQE_ERR_PBL_ADDR_BOUND = 0x0B, /* pbl address out of bound : software error */ + FW_RI_CQE_ERR_CRC = 0x10, /* CRC error */ + FW_RI_CQE_ERR_MARKER = 0x11, /* Marker error */ + FW_RI_CQE_ERR_PDU_LEN_ERR = 0x12, /* invalid PDU length */ + FW_RI_CQE_ERR_OUT_OF_RQE = 0x13, /* out of RQE */ + FW_RI_CQE_ERR_DDP_VERSION = 0x14, /* wrong DDP version */ + FW_RI_CQE_ERR_RDMA_VERSION = 0x15, /* wrong RDMA version */ + FW_RI_CQE_ERR_OPCODE = 0x16, /* invalid rdma opcode */ + FW_RI_CQE_ERR_DDP_QUEUE_NUM = 0x17, /* invalid ddp queue number */ + FW_RI_CQE_ERR_MSN = 0x18, /* MSN error */ + FW_RI_CQE_ERR_TBIT = 0x19, /* tag bit not set correctly */ + FW_RI_CQE_ERR_MO = 0x1A, /* MO not zero for TERMINATE or READ_REQ */ + FW_RI_CQE_ERR_MSN_GAP = 0x1B, /* */ + FW_RI_CQE_ERR_MSN_RANGE = 0x1C, /* */ + FW_RI_CQE_ERR_IRD_OVERFLOW = 0x1D, /* */ + FW_RI_CQE_ERR_RQE_ADDR_BOUND = 0x1E, /* RQE address out of bound : software error */ + FW_RI_CQE_ERR_INTERNAL_ERR = 0x1F /* internel error (opcode mismatch) */ + +}; + +struct fw_ri_dsge_pair { + __be32 len[2]; + __be64 addr[2]; +}; + +struct fw_ri_dsgl { + __u8 op; + __u8 r1; + __be16 nsge; + __be32 len0; + __be64 addr0; +#ifndef C99_NOT_SUPPORTED + struct fw_ri_dsge_pair sge[0]; +#endif +}; + +struct fw_ri_sge { + __be32 stag; + __be32 len; + __be64 to; +}; + +struct fw_ri_isgl { + __u8 op; + __u8 r1; + __be16 nsge; + __be32 r2; +#ifndef C99_NOT_SUPPORTED + struct fw_ri_sge sge[0]; +#endif +}; + +struct fw_ri_immd { + __u8 op; + __u8 r1; + __be16 r2; + __be32 immdlen; +#ifndef C99_NOT_SUPPORTED + __u8 data[0]; +#endif +}; + +struct fw_ri_tpte { + __be32 valid_to_pdid; + __be32 locread_to_qpid; + __be32 nosnoop_pbladdr; + __be32 len_lo; + __be32 va_hi; + __be32 va_lo_fbo; + __be32 dca_mwbcnt_pstag; + __be32 len_hi; +}; + +#define S_FW_RI_TPTE_VALID 31 +#define M_FW_RI_TPTE_VALID 0x1 +#define V_FW_RI_TPTE_VALID(x) ((x) << S_FW_RI_TPTE_VALID) +#define G_FW_RI_TPTE_VALID(x) \ + (((x) >> S_FW_RI_TPTE_VALID) & M_FW_RI_TPTE_VALID) +#define F_FW_RI_TPTE_VALID V_FW_RI_TPTE_VALID(1U) + +#define S_FW_RI_TPTE_STAGKEY 23 +#define M_FW_RI_TPTE_STAGKEY 0xff +#define V_FW_RI_TPTE_STAGKEY(x) ((x) << S_FW_RI_TPTE_STAGKEY) +#define G_FW_RI_TPTE_STAGKEY(x) \ + (((x) >> S_FW_RI_TPTE_STAGKEY) & M_FW_RI_TPTE_STAGKEY) + +#define S_FW_RI_TPTE_STAGSTATE 22 +#define M_FW_RI_TPTE_STAGSTATE 0x1 +#define V_FW_RI_TPTE_STAGSTATE(x) ((x) << S_FW_RI_TPTE_STAGSTATE) +#define G_FW_RI_TPTE_STAGSTATE(x) \ + (((x) >> S_FW_RI_TPTE_STAGSTATE) & M_FW_RI_TPTE_STAGSTATE) +#define F_FW_RI_TPTE_STAGSTATE V_FW_RI_TPTE_STAGSTATE(1U) + +#define S_FW_RI_TPTE_STAGTYPE 20 +#define M_FW_RI_TPTE_STAGTYPE 0x3 +#define V_FW_RI_TPTE_STAGTYPE(x) ((x) << S_FW_RI_TPTE_STAGTYPE) +#define G_FW_RI_TPTE_STAGTYPE(x) \ + (((x) >> S_FW_RI_TPTE_STAGTYPE) & M_FW_RI_TPTE_STAGTYPE) + +#define S_FW_RI_TPTE_PDID 0 +#define M_FW_RI_TPTE_PDID 0xfffff +#define V_FW_RI_TPTE_PDID(x) ((x) << S_FW_RI_TPTE_PDID) +#define G_FW_RI_TPTE_PDID(x) \ + (((x) >> S_FW_RI_TPTE_PDID) & M_FW_RI_TPTE_PDID) + +#define S_FW_RI_TPTE_PERM 28 +#define M_FW_RI_TPTE_PERM 0xf +#define V_FW_RI_TPTE_PERM(x) ((x) << S_FW_RI_TPTE_PERM) +#define G_FW_RI_TPTE_PERM(x) \ + (((x) >> S_FW_RI_TPTE_PERM) & M_FW_RI_TPTE_PERM) + +#define S_FW_RI_TPTE_REMINVDIS 27 +#define M_FW_RI_TPTE_REMINVDIS 0x1 +#define V_FW_RI_TPTE_REMINVDIS(x) ((x) << S_FW_RI_TPTE_REMINVDIS) +#define G_FW_RI_TPTE_REMINVDIS(x) \ + (((x) >> S_FW_RI_TPTE_REMINVDIS) & M_FW_RI_TPTE_REMINVDIS) +#define F_FW_RI_TPTE_REMINVDIS V_FW_RI_TPTE_REMINVDIS(1U) + +#define S_FW_RI_TPTE_ADDRTYPE 26 +#define M_FW_RI_TPTE_ADDRTYPE 1 +#define V_FW_RI_TPTE_ADDRTYPE(x) ((x) << S_FW_RI_TPTE_ADDRTYPE) +#define G_FW_RI_TPTE_ADDRTYPE(x) \ + (((x) >> S_FW_RI_TPTE_ADDRTYPE) & M_FW_RI_TPTE_ADDRTYPE) +#define F_FW_RI_TPTE_ADDRTYPE V_FW_RI_TPTE_ADDRTYPE(1U) + +#define S_FW_RI_TPTE_MWBINDEN 25 +#define M_FW_RI_TPTE_MWBINDEN 0x1 +#define V_FW_RI_TPTE_MWBINDEN(x) ((x) << S_FW_RI_TPTE_MWBINDEN) +#define G_FW_RI_TPTE_MWBINDEN(x) \ + (((x) >> S_FW_RI_TPTE_MWBINDEN) & M_FW_RI_TPTE_MWBINDEN) +#define F_FW_RI_TPTE_MWBINDEN V_FW_RI_TPTE_MWBINDEN(1U) + +#define S_FW_RI_TPTE_PS 20 +#define M_FW_RI_TPTE_PS 0x1f +#define V_FW_RI_TPTE_PS(x) ((x) << S_FW_RI_TPTE_PS) +#define G_FW_RI_TPTE_PS(x) \ + (((x) >> S_FW_RI_TPTE_PS) & M_FW_RI_TPTE_PS) + +#define S_FW_RI_TPTE_QPID 0 +#define M_FW_RI_TPTE_QPID 0xfffff +#define V_FW_RI_TPTE_QPID(x) ((x) << S_FW_RI_TPTE_QPID) +#define G_FW_RI_TPTE_QPID(x) \ + (((x) >> S_FW_RI_TPTE_QPID) & M_FW_RI_TPTE_QPID) + +#define S_FW_RI_TPTE_NOSNOOP 31 +#define M_FW_RI_TPTE_NOSNOOP 0x1 +#define V_FW_RI_TPTE_NOSNOOP(x) ((x) << S_FW_RI_TPTE_NOSNOOP) +#define G_FW_RI_TPTE_NOSNOOP(x) \ + (((x) >> S_FW_RI_TPTE_NOSNOOP) & M_FW_RI_TPTE_NOSNOOP) +#define F_FW_RI_TPTE_NOSNOOP V_FW_RI_TPTE_NOSNOOP(1U) + +#define S_FW_RI_TPTE_PBLADDR 0 +#define M_FW_RI_TPTE_PBLADDR 0x1fffffff +#define V_FW_RI_TPTE_PBLADDR(x) ((x) << S_FW_RI_TPTE_PBLADDR) +#define G_FW_RI_TPTE_PBLADDR(x) \ + (((x) >> S_FW_RI_TPTE_PBLADDR) & M_FW_RI_TPTE_PBLADDR) + +#define S_FW_RI_TPTE_DCA 24 +#define M_FW_RI_TPTE_DCA 0x1f +#define V_FW_RI_TPTE_DCA(x) ((x) << S_FW_RI_TPTE_DCA) +#define G_FW_RI_TPTE_DCA(x) \ + (((x) >> S_FW_RI_TPTE_DCA) & M_FW_RI_TPTE_DCA) + +#define S_FW_RI_TPTE_MWBCNT_PSTAG 0 +#define M_FW_RI_TPTE_MWBCNT_PSTAG 0xffffff +#define V_FW_RI_TPTE_MWBCNT_PSTAT(x) \ + ((x) << S_FW_RI_TPTE_MWBCNT_PSTAG) +#define G_FW_RI_TPTE_MWBCNT_PSTAG(x) \ + (((x) >> S_FW_RI_TPTE_MWBCNT_PSTAG) & M_FW_RI_TPTE_MWBCNT_PSTAG) + +enum fw_ri_cqe_rxtx { + FW_RI_CQE_RXTX_RX = 0x0, + FW_RI_CQE_RXTX_TX = 0x1, +}; + +struct fw_ri_cqe { + union fw_ri_rxtx { + struct fw_ri_scqe { + __be32 qpid_n_stat_rxtx_type; + __be32 plen; + __be32 reserved; + __be32 wrid; + } scqe; + struct fw_ri_rcqe { + __be32 qpid_n_stat_rxtx_type; + __be32 plen; + __be32 stag; + __be32 msn; + } rcqe; + } u; +}; + +#define S_FW_RI_CQE_QPID 12 +#define M_FW_RI_CQE_QPID 0xfffff +#define V_FW_RI_CQE_QPID(x) ((x) << S_FW_RI_CQE_QPID) +#define G_FW_RI_CQE_QPID(x) \ + (((x) >> S_FW_RI_CQE_QPID) & M_FW_RI_CQE_QPID) + +#define S_FW_RI_CQE_NOTIFY 10 +#define M_FW_RI_CQE_NOTIFY 0x1 +#define V_FW_RI_CQE_NOTIFY(x) ((x) << S_FW_RI_CQE_NOTIFY) +#define G_FW_RI_CQE_NOTIFY(x) \ + (((x) >> S_FW_RI_CQE_NOTIFY) & M_FW_RI_CQE_NOTIFY) + +#define S_FW_RI_CQE_STATUS 5 +#define M_FW_RI_CQE_STATUS 0x1f +#define V_FW_RI_CQE_STATUS(x) ((x) << S_FW_RI_CQE_STATUS) +#define G_FW_RI_CQE_STATUS(x) \ + (((x) >> S_FW_RI_CQE_STATUS) & M_FW_RI_CQE_STATUS) + + +#define S_FW_RI_CQE_RXTX 4 +#define M_FW_RI_CQE_RXTX 0x1 +#define V_FW_RI_CQE_RXTX(x) ((x) << S_FW_RI_CQE_RXTX) +#define G_FW_RI_CQE_RXTX(x) \ + (((x) >> S_FW_RI_CQE_RXTX) & M_FW_RI_CQE_RXTX) + +#define S_FW_RI_CQE_TYPE 0 +#define M_FW_RI_CQE_TYPE 0xf +#define V_FW_RI_CQE_TYPE(x) ((x) << S_FW_RI_CQE_TYPE) +#define G_FW_RI_CQE_TYPE(x) \ + (((x) >> S_FW_RI_CQE_TYPE) & M_FW_RI_CQE_TYPE) + +enum fw_ri_res_type { + FW_RI_RES_TYPE_SQ, + FW_RI_RES_TYPE_RQ, + FW_RI_RES_TYPE_CQ, +}; + +enum fw_ri_res_op { + FW_RI_RES_OP_WRITE, + FW_RI_RES_OP_RESET, +}; + +struct fw_ri_res { + union fw_ri_restype { + struct fw_ri_res_sqrq { + __u8 restype; + __u8 op; + __be16 r3; + __be32 eqid; + __be32 r4[2]; + __be32 fetchszm_to_iqid; + __be32 dcaen_to_eqsize; + __be64 eqaddr; + } sqrq; + struct fw_ri_res_cq { + __u8 restype; + __u8 op; + __be16 r3; + __be32 iqid; + __be32 r4[2]; + __be32 iqandst_to_iqandstindex; + __be16 iqdroprss_to_iqesize; + __be16 iqsize; + __be64 iqaddr; + __be32 iqns_iqro; + __be32 r6_lo; + __be64 r7; + } cq; + } u; +}; + +struct fw_ri_res_wr { + __be32 op_nres; + __be32 len16_pkd; + __u64 cookie; +#ifndef C99_NOT_SUPPORTED + struct fw_ri_res res[0]; +#endif +}; + +#define S_FW_RI_RES_WR_NRES 0 +#define M_FW_RI_RES_WR_NRES 0xff +#define V_FW_RI_RES_WR_NRES(x) ((x) << S_FW_RI_RES_WR_NRES) +#define G_FW_RI_RES_WR_NRES(x) \ + (((x) >> S_FW_RI_RES_WR_NRES) & M_FW_RI_RES_WR_NRES) + +#define S_FW_RI_RES_WR_FETCHSZM 26 +#define M_FW_RI_RES_WR_FETCHSZM 0x1 +#define V_FW_RI_RES_WR_FETCHSZM(x) ((x) << S_FW_RI_RES_WR_FETCHSZM) +#define G_FW_RI_RES_WR_FETCHSZM(x) \ + (((x) >> S_FW_RI_RES_WR_FETCHSZM) & M_FW_RI_RES_WR_FETCHSZM) +#define F_FW_RI_RES_WR_FETCHSZM V_FW_RI_RES_WR_FETCHSZM(1U) + +#define S_FW_RI_RES_WR_STATUSPGNS 25 +#define M_FW_RI_RES_WR_STATUSPGNS 0x1 +#define V_FW_RI_RES_WR_STATUSPGNS(x) ((x) << S_FW_RI_RES_WR_STATUSPGNS) +#define G_FW_RI_RES_WR_STATUSPGNS(x) \ + (((x) >> S_FW_RI_RES_WR_STATUSPGNS) & M_FW_RI_RES_WR_STATUSPGNS) +#define F_FW_RI_RES_WR_STATUSPGNS V_FW_RI_RES_WR_STATUSPGNS(1U) + +#define S_FW_RI_RES_WR_STATUSPGRO 24 +#define M_FW_RI_RES_WR_STATUSPGRO 0x1 +#define V_FW_RI_RES_WR_STATUSPGRO(x) ((x) << S_FW_RI_RES_WR_STATUSPGRO) +#define G_FW_RI_RES_WR_STATUSPGRO(x) \ + (((x) >> S_FW_RI_RES_WR_STATUSPGRO) & M_FW_RI_RES_WR_STATUSPGRO) +#define F_FW_RI_RES_WR_STATUSPGRO V_FW_RI_RES_WR_STATUSPGRO(1U) + +#define S_FW_RI_RES_WR_FETCHNS 23 +#define M_FW_RI_RES_WR_FETCHNS 0x1 +#define V_FW_RI_RES_WR_FETCHNS(x) ((x) << S_FW_RI_RES_WR_FETCHNS) +#define G_FW_RI_RES_WR_FETCHNS(x) \ + (((x) >> S_FW_RI_RES_WR_FETCHNS) & M_FW_RI_RES_WR_FETCHNS) +#define F_FW_RI_RES_WR_FETCHNS V_FW_RI_RES_WR_FETCHNS(1U) + +#define S_FW_RI_RES_WR_FETCHRO 22 +#define M_FW_RI_RES_WR_FETCHRO 0x1 +#define V_FW_RI_RES_WR_FETCHRO(x) ((x) << S_FW_RI_RES_WR_FETCHRO) +#define G_FW_RI_RES_WR_FETCHRO(x) \ + (((x) >> S_FW_RI_RES_WR_FETCHRO) & M_FW_RI_RES_WR_FETCHRO) +#define F_FW_RI_RES_WR_FETCHRO V_FW_RI_RES_WR_FETCHRO(1U) + +#define S_FW_RI_RES_WR_HOSTFCMODE 20 +#define M_FW_RI_RES_WR_HOSTFCMODE 0x3 +#define V_FW_RI_RES_WR_HOSTFCMODE(x) ((x) << S_FW_RI_RES_WR_HOSTFCMODE) +#define G_FW_RI_RES_WR_HOSTFCMODE(x) \ + (((x) >> S_FW_RI_RES_WR_HOSTFCMODE) & M_FW_RI_RES_WR_HOSTFCMODE) + +#define S_FW_RI_RES_WR_CPRIO 19 +#define M_FW_RI_RES_WR_CPRIO 0x1 +#define V_FW_RI_RES_WR_CPRIO(x) ((x) << S_FW_RI_RES_WR_CPRIO) +#define G_FW_RI_RES_WR_CPRIO(x) \ + (((x) >> S_FW_RI_RES_WR_CPRIO) & M_FW_RI_RES_WR_CPRIO) +#define F_FW_RI_RES_WR_CPRIO V_FW_RI_RES_WR_CPRIO(1U) + +#define S_FW_RI_RES_WR_ONCHIP 18 +#define M_FW_RI_RES_WR_ONCHIP 0x1 +#define V_FW_RI_RES_WR_ONCHIP(x) ((x) << S_FW_RI_RES_WR_ONCHIP) +#define G_FW_RI_RES_WR_ONCHIP(x) \ + (((x) >> S_FW_RI_RES_WR_ONCHIP) & M_FW_RI_RES_WR_ONCHIP) +#define F_FW_RI_RES_WR_ONCHIP V_FW_RI_RES_WR_ONCHIP(1U) + +#define S_FW_RI_RES_WR_PCIECHN 16 +#define M_FW_RI_RES_WR_PCIECHN 0x3 +#define V_FW_RI_RES_WR_PCIECHN(x) ((x) << S_FW_RI_RES_WR_PCIECHN) +#define G_FW_RI_RES_WR_PCIECHN(x) \ + (((x) >> S_FW_RI_RES_WR_PCIECHN) & M_FW_RI_RES_WR_PCIECHN) + +#define S_FW_RI_RES_WR_IQID 0 +#define M_FW_RI_RES_WR_IQID 0xffff +#define V_FW_RI_RES_WR_IQID(x) ((x) << S_FW_RI_RES_WR_IQID) +#define G_FW_RI_RES_WR_IQID(x) \ + (((x) >> S_FW_RI_RES_WR_IQID) & M_FW_RI_RES_WR_IQID) + +#define S_FW_RI_RES_WR_DCAEN 31 +#define M_FW_RI_RES_WR_DCAEN 0x1 +#define V_FW_RI_RES_WR_DCAEN(x) ((x) << S_FW_RI_RES_WR_DCAEN) +#define G_FW_RI_RES_WR_DCAEN(x) \ + (((x) >> S_FW_RI_RES_WR_DCAEN) & M_FW_RI_RES_WR_DCAEN) +#define F_FW_RI_RES_WR_DCAEN V_FW_RI_RES_WR_DCAEN(1U) + +#define S_FW_RI_RES_WR_DCACPU 26 +#define M_FW_RI_RES_WR_DCACPU 0x1f +#define V_FW_RI_RES_WR_DCACPU(x) ((x) << S_FW_RI_RES_WR_DCACPU) +#define G_FW_RI_RES_WR_DCACPU(x) \ + (((x) >> S_FW_RI_RES_WR_DCACPU) & M_FW_RI_RES_WR_DCACPU) + +#define S_FW_RI_RES_WR_FBMIN 23 +#define M_FW_RI_RES_WR_FBMIN 0x7 +#define V_FW_RI_RES_WR_FBMIN(x) ((x) << S_FW_RI_RES_WR_FBMIN) +#define G_FW_RI_RES_WR_FBMIN(x) \ + (((x) >> S_FW_RI_RES_WR_FBMIN) & M_FW_RI_RES_WR_FBMIN) + +#define S_FW_RI_RES_WR_FBMAX 20 +#define M_FW_RI_RES_WR_FBMAX 0x7 +#define V_FW_RI_RES_WR_FBMAX(x) ((x) << S_FW_RI_RES_WR_FBMAX) +#define G_FW_RI_RES_WR_FBMAX(x) \ + (((x) >> S_FW_RI_RES_WR_FBMAX) & M_FW_RI_RES_WR_FBMAX) + +#define S_FW_RI_RES_WR_CIDXFTHRESHO 19 +#define M_FW_RI_RES_WR_CIDXFTHRESHO 0x1 +#define V_FW_RI_RES_WR_CIDXFTHRESHO(x) ((x) << S_FW_RI_RES_WR_CIDXFTHRESHO) +#define G_FW_RI_RES_WR_CIDXFTHRESHO(x) \ + (((x) >> S_FW_RI_RES_WR_CIDXFTHRESHO) & M_FW_RI_RES_WR_CIDXFTHRESHO) +#define F_FW_RI_RES_WR_CIDXFTHRESHO V_FW_RI_RES_WR_CIDXFTHRESHO(1U) + +#define S_FW_RI_RES_WR_CIDXFTHRESH 16 +#define M_FW_RI_RES_WR_CIDXFTHRESH 0x7 +#define V_FW_RI_RES_WR_CIDXFTHRESH(x) ((x) << S_FW_RI_RES_WR_CIDXFTHRESH) +#define G_FW_RI_RES_WR_CIDXFTHRESH(x) \ + (((x) >> S_FW_RI_RES_WR_CIDXFTHRESH) & M_FW_RI_RES_WR_CIDXFTHRESH) + +#define S_FW_RI_RES_WR_EQSIZE 0 +#define M_FW_RI_RES_WR_EQSIZE 0xffff +#define V_FW_RI_RES_WR_EQSIZE(x) ((x) << S_FW_RI_RES_WR_EQSIZE) +#define G_FW_RI_RES_WR_EQSIZE(x) \ + (((x) >> S_FW_RI_RES_WR_EQSIZE) & M_FW_RI_RES_WR_EQSIZE) + +#define S_FW_RI_RES_WR_IQANDST 15 +#define M_FW_RI_RES_WR_IQANDST 0x1 +#define V_FW_RI_RES_WR_IQANDST(x) ((x) << S_FW_RI_RES_WR_IQANDST) +#define G_FW_RI_RES_WR_IQANDST(x) \ + (((x) >> S_FW_RI_RES_WR_IQANDST) & M_FW_RI_RES_WR_IQANDST) +#define F_FW_RI_RES_WR_IQANDST V_FW_RI_RES_WR_IQANDST(1U) + +#define S_FW_RI_RES_WR_IQANUS 14 +#define M_FW_RI_RES_WR_IQANUS 0x1 +#define V_FW_RI_RES_WR_IQANUS(x) ((x) << S_FW_RI_RES_WR_IQANUS) +#define G_FW_RI_RES_WR_IQANUS(x) \ + (((x) >> S_FW_RI_RES_WR_IQANUS) & M_FW_RI_RES_WR_IQANUS) +#define F_FW_RI_RES_WR_IQANUS V_FW_RI_RES_WR_IQANUS(1U) + +#define S_FW_RI_RES_WR_IQANUD 12 +#define M_FW_RI_RES_WR_IQANUD 0x3 +#define V_FW_RI_RES_WR_IQANUD(x) ((x) << S_FW_RI_RES_WR_IQANUD) +#define G_FW_RI_RES_WR_IQANUD(x) \ + (((x) >> S_FW_RI_RES_WR_IQANUD) & M_FW_RI_RES_WR_IQANUD) + +#define S_FW_RI_RES_WR_IQANDSTINDEX 0 +#define M_FW_RI_RES_WR_IQANDSTINDEX 0xfff +#define V_FW_RI_RES_WR_IQANDSTINDEX(x) ((x) << S_FW_RI_RES_WR_IQANDSTINDEX) +#define G_FW_RI_RES_WR_IQANDSTINDEX(x) \ + (((x) >> S_FW_RI_RES_WR_IQANDSTINDEX) & M_FW_RI_RES_WR_IQANDSTINDEX) + +#define S_FW_RI_RES_WR_IQDROPRSS 15 +#define M_FW_RI_RES_WR_IQDROPRSS 0x1 +#define V_FW_RI_RES_WR_IQDROPRSS(x) ((x) << S_FW_RI_RES_WR_IQDROPRSS) +#define G_FW_RI_RES_WR_IQDROPRSS(x) \ + (((x) >> S_FW_RI_RES_WR_IQDROPRSS) & M_FW_RI_RES_WR_IQDROPRSS) +#define F_FW_RI_RES_WR_IQDROPRSS V_FW_RI_RES_WR_IQDROPRSS(1U) + +#define S_FW_RI_RES_WR_IQGTSMODE 14 +#define M_FW_RI_RES_WR_IQGTSMODE 0x1 +#define V_FW_RI_RES_WR_IQGTSMODE(x) ((x) << S_FW_RI_RES_WR_IQGTSMODE) +#define G_FW_RI_RES_WR_IQGTSMODE(x) \ + (((x) >> S_FW_RI_RES_WR_IQGTSMODE) & M_FW_RI_RES_WR_IQGTSMODE) +#define F_FW_RI_RES_WR_IQGTSMODE V_FW_RI_RES_WR_IQGTSMODE(1U) + +#define S_FW_RI_RES_WR_IQPCIECH 12 +#define M_FW_RI_RES_WR_IQPCIECH 0x3 +#define V_FW_RI_RES_WR_IQPCIECH(x) ((x) << S_FW_RI_RES_WR_IQPCIECH) +#define G_FW_RI_RES_WR_IQPCIECH(x) \ + (((x) >> S_FW_RI_RES_WR_IQPCIECH) & M_FW_RI_RES_WR_IQPCIECH) + +#define S_FW_RI_RES_WR_IQDCAEN 11 +#define M_FW_RI_RES_WR_IQDCAEN 0x1 +#define V_FW_RI_RES_WR_IQDCAEN(x) ((x) << S_FW_RI_RES_WR_IQDCAEN) +#define G_FW_RI_RES_WR_IQDCAEN(x) \ + (((x) >> S_FW_RI_RES_WR_IQDCAEN) & M_FW_RI_RES_WR_IQDCAEN) +#define F_FW_RI_RES_WR_IQDCAEN V_FW_RI_RES_WR_IQDCAEN(1U) + +#define S_FW_RI_RES_WR_IQDCACPU 6 +#define M_FW_RI_RES_WR_IQDCACPU 0x1f +#define V_FW_RI_RES_WR_IQDCACPU(x) ((x) << S_FW_RI_RES_WR_IQDCACPU) +#define G_FW_RI_RES_WR_IQDCACPU(x) \ + (((x) >> S_FW_RI_RES_WR_IQDCACPU) & M_FW_RI_RES_WR_IQDCACPU) + +#define S_FW_RI_RES_WR_IQINTCNTTHRESH 4 +#define M_FW_RI_RES_WR_IQINTCNTTHRESH 0x3 +#define V_FW_RI_RES_WR_IQINTCNTTHRESH(x) \ + ((x) << S_FW_RI_RES_WR_IQINTCNTTHRESH) +#define G_FW_RI_RES_WR_IQINTCNTTHRESH(x) \ + (((x) >> S_FW_RI_RES_WR_IQINTCNTTHRESH) & M_FW_RI_RES_WR_IQINTCNTTHRESH) + +#define S_FW_RI_RES_WR_IQO 3 +#define M_FW_RI_RES_WR_IQO 0x1 +#define V_FW_RI_RES_WR_IQO(x) ((x) << S_FW_RI_RES_WR_IQO) +#define G_FW_RI_RES_WR_IQO(x) \ + (((x) >> S_FW_RI_RES_WR_IQO) & M_FW_RI_RES_WR_IQO) +#define F_FW_RI_RES_WR_IQO V_FW_RI_RES_WR_IQO(1U) + +#define S_FW_RI_RES_WR_IQCPRIO 2 +#define M_FW_RI_RES_WR_IQCPRIO 0x1 +#define V_FW_RI_RES_WR_IQCPRIO(x) ((x) << S_FW_RI_RES_WR_IQCPRIO) +#define G_FW_RI_RES_WR_IQCPRIO(x) \ + (((x) >> S_FW_RI_RES_WR_IQCPRIO) & M_FW_RI_RES_WR_IQCPRIO) +#define F_FW_RI_RES_WR_IQCPRIO V_FW_RI_RES_WR_IQCPRIO(1U) + +#define S_FW_RI_RES_WR_IQESIZE 0 +#define M_FW_RI_RES_WR_IQESIZE 0x3 +#define V_FW_RI_RES_WR_IQESIZE(x) ((x) << S_FW_RI_RES_WR_IQESIZE) +#define G_FW_RI_RES_WR_IQESIZE(x) \ + (((x) >> S_FW_RI_RES_WR_IQESIZE) & M_FW_RI_RES_WR_IQESIZE) + +#define S_FW_RI_RES_WR_IQNS 31 +#define M_FW_RI_RES_WR_IQNS 0x1 +#define V_FW_RI_RES_WR_IQNS(x) ((x) << S_FW_RI_RES_WR_IQNS) +#define G_FW_RI_RES_WR_IQNS(x) \ + (((x) >> S_FW_RI_RES_WR_IQNS) & M_FW_RI_RES_WR_IQNS) +#define F_FW_RI_RES_WR_IQNS V_FW_RI_RES_WR_IQNS(1U) + +#define S_FW_RI_RES_WR_IQRO 30 +#define M_FW_RI_RES_WR_IQRO 0x1 +#define V_FW_RI_RES_WR_IQRO(x) ((x) << S_FW_RI_RES_WR_IQRO) +#define G_FW_RI_RES_WR_IQRO(x) \ + (((x) >> S_FW_RI_RES_WR_IQRO) & M_FW_RI_RES_WR_IQRO) +#define F_FW_RI_RES_WR_IQRO V_FW_RI_RES_WR_IQRO(1U) + +struct fw_ri_rdma_write_wr { + __u8 opcode; + __u8 flags; + __u16 wrid; + __u8 r1[3]; + __u8 len16; + __be64 r2; + __be32 plen; + __be32 stag_sink; + __be64 to_sink; +#ifndef C99_NOT_SUPPORTED + union { + struct fw_ri_immd immd_src[0]; + struct fw_ri_isgl isgl_src[0]; + } u; +#endif +}; + +struct fw_ri_send_wr { + __u8 opcode; + __u8 flags; + __u16 wrid; + __u8 r1[3]; + __u8 len16; + __be32 sendop_pkd; + __be32 stag_inv; + __be32 plen; + __be32 r3; + __be64 r4; +#ifndef C99_NOT_SUPPORTED + union { + struct fw_ri_immd immd_src[0]; + struct fw_ri_isgl isgl_src[0]; + } u; +#endif +}; + +#define S_FW_RI_SEND_WR_SENDOP 0 +#define M_FW_RI_SEND_WR_SENDOP 0xf +#define V_FW_RI_SEND_WR_SENDOP(x) ((x) << S_FW_RI_SEND_WR_SENDOP) +#define G_FW_RI_SEND_WR_SENDOP(x) \ + (((x) >> S_FW_RI_SEND_WR_SENDOP) & M_FW_RI_SEND_WR_SENDOP) + +struct fw_ri_rdma_read_wr { + __u8 opcode; + __u8 flags; + __u16 wrid; + __u8 r1[3]; + __u8 len16; + __be64 r2; + __be32 stag_sink; + __be32 to_sink_hi; + __be32 to_sink_lo; + __be32 plen; + __be32 stag_src; + __be32 to_src_hi; + __be32 to_src_lo; + __be32 r5; +}; + +struct fw_ri_recv_wr { + __u8 opcode; + __u8 r1; + __u16 wrid; + __u8 r2[3]; + __u8 len16; + struct fw_ri_isgl isgl; +}; + +struct fw_ri_bind_mw_wr { + __u8 opcode; + __u8 flags; + __u16 wrid; + __u8 r1[3]; + __u8 len16; + __u8 qpbinde_to_dcacpu; + __u8 pgsz_shift; + __u8 addr_type; + __u8 mem_perms; + __be32 stag_mr; + __be32 stag_mw; + __be32 r3; + __be64 len_mw; + __be64 va_fbo; + __be64 r4; +}; + +#define S_FW_RI_BIND_MW_WR_QPBINDE 6 +#define M_FW_RI_BIND_MW_WR_QPBINDE 0x1 +#define V_FW_RI_BIND_MW_WR_QPBINDE(x) ((x) << S_FW_RI_BIND_MW_WR_QPBINDE) +#define G_FW_RI_BIND_MW_WR_QPBINDE(x) \ + (((x) >> S_FW_RI_BIND_MW_WR_QPBINDE) & M_FW_RI_BIND_MW_WR_QPBINDE) +#define F_FW_RI_BIND_MW_WR_QPBINDE V_FW_RI_BIND_MW_WR_QPBINDE(1U) + +#define S_FW_RI_BIND_MW_WR_NS 5 +#define M_FW_RI_BIND_MW_WR_NS 0x1 +#define V_FW_RI_BIND_MW_WR_NS(x) ((x) << S_FW_RI_BIND_MW_WR_NS) +#define G_FW_RI_BIND_MW_WR_NS(x) \ + (((x) >> S_FW_RI_BIND_MW_WR_NS) & M_FW_RI_BIND_MW_WR_NS) +#define F_FW_RI_BIND_MW_WR_NS V_FW_RI_BIND_MW_WR_NS(1U) + +#define S_FW_RI_BIND_MW_WR_DCACPU 0 +#define M_FW_RI_BIND_MW_WR_DCACPU 0x1f +#define V_FW_RI_BIND_MW_WR_DCACPU(x) ((x) << S_FW_RI_BIND_MW_WR_DCACPU) +#define G_FW_RI_BIND_MW_WR_DCACPU(x) \ + (((x) >> S_FW_RI_BIND_MW_WR_DCACPU) & M_FW_RI_BIND_MW_WR_DCACPU) + +struct fw_ri_fr_nsmr_wr { + __u8 opcode; + __u8 flags; + __u16 wrid; + __u8 r1[3]; + __u8 len16; + __u8 qpbinde_to_dcacpu; + __u8 pgsz_shift; + __u8 addr_type; + __u8 mem_perms; + __be32 stag; + __be32 len_hi; + __be32 len_lo; + __be32 va_hi; + __be32 va_lo_fbo; +}; + +#define S_FW_RI_FR_NSMR_WR_QPBINDE 6 +#define M_FW_RI_FR_NSMR_WR_QPBINDE 0x1 +#define V_FW_RI_FR_NSMR_WR_QPBINDE(x) ((x) << S_FW_RI_FR_NSMR_WR_QPBINDE) +#define G_FW_RI_FR_NSMR_WR_QPBINDE(x) \ + (((x) >> S_FW_RI_FR_NSMR_WR_QPBINDE) & M_FW_RI_FR_NSMR_WR_QPBINDE) +#define F_FW_RI_FR_NSMR_WR_QPBINDE V_FW_RI_FR_NSMR_WR_QPBINDE(1U) + +#define S_FW_RI_FR_NSMR_WR_NS 5 +#define M_FW_RI_FR_NSMR_WR_NS 0x1 +#define V_FW_RI_FR_NSMR_WR_NS(x) ((x) << S_FW_RI_FR_NSMR_WR_NS) +#define G_FW_RI_FR_NSMR_WR_NS(x) \ + (((x) >> S_FW_RI_FR_NSMR_WR_NS) & M_FW_RI_FR_NSMR_WR_NS) +#define F_FW_RI_FR_NSMR_WR_NS V_FW_RI_FR_NSMR_WR_NS(1U) + +#define S_FW_RI_FR_NSMR_WR_DCACPU 0 +#define M_FW_RI_FR_NSMR_WR_DCACPU 0x1f +#define V_FW_RI_FR_NSMR_WR_DCACPU(x) ((x) << S_FW_RI_FR_NSMR_WR_DCACPU) +#define G_FW_RI_FR_NSMR_WR_DCACPU(x) \ + (((x) >> S_FW_RI_FR_NSMR_WR_DCACPU) & M_FW_RI_FR_NSMR_WR_DCACPU) + +struct fw_ri_inv_lstag_wr { + __u8 opcode; + __u8 flags; + __u16 wrid; + __u8 r1[3]; + __u8 len16; + __be32 r2; + __be32 stag_inv; +}; + +struct fw_ri_send_immediate_wr { + __u8 opcode; + __u8 flags; + __u16 wrid; + __u8 r1[3]; + __u8 len16; + __be32 sendimmop_pkd; + __be32 r3; + __be32 plen; + __be32 r4; + __be64 r5; +#ifndef C99_NOT_SUPPORTED + struct fw_ri_immd immd_src[0]; +#endif +}; + +#define S_FW_RI_SEND_IMMEDIATE_WR_SENDIMMOP 0 +#define M_FW_RI_SEND_IMMEDIATE_WR_SENDIMMOP 0xf +#define V_FW_RI_SEND_IMMEDIATE_WR_SENDIMMOP(x) \ + ((x) << S_FW_RI_SEND_IMMEDIATE_WR_SENDIMMOP) +#define G_FW_RI_SEND_IMMEDIATE_WR_SENDIMMOP(x) \ + (((x) >> S_FW_RI_SEND_IMMEDIATE_WR_SENDIMMOP) & \ + M_FW_RI_SEND_IMMEDIATE_WR_SENDIMMOP) + +enum fw_ri_atomic_op { + FW_RI_ATOMIC_OP_FETCHADD, + FW_RI_ATOMIC_OP_SWAP, + FW_RI_ATOMIC_OP_CMDSWAP, +}; + +struct fw_ri_atomic_wr { + __u8 opcode; + __u8 flags; + __u16 wrid; + __u8 r1[3]; + __u8 len16; + __be32 atomicop_pkd; + __be64 r3; + __be32 aopcode_pkd; + __be32 reqid; + __be32 stag; + __be32 to_hi; + __be32 to_lo; + __be32 addswap_data_hi; + __be32 addswap_data_lo; + __be32 addswap_mask_hi; + __be32 addswap_mask_lo; + __be32 compare_data_hi; + __be32 compare_data_lo; + __be32 compare_mask_hi; + __be32 compare_mask_lo; + __be32 r5; +}; + +#define S_FW_RI_ATOMIC_WR_ATOMICOP 0 +#define M_FW_RI_ATOMIC_WR_ATOMICOP 0xf +#define V_FW_RI_ATOMIC_WR_ATOMICOP(x) ((x) << S_FW_RI_ATOMIC_WR_ATOMICOP) +#define G_FW_RI_ATOMIC_WR_ATOMICOP(x) \ + (((x) >> S_FW_RI_ATOMIC_WR_ATOMICOP) & M_FW_RI_ATOMIC_WR_ATOMICOP) + +#define S_FW_RI_ATOMIC_WR_AOPCODE 0 +#define M_FW_RI_ATOMIC_WR_AOPCODE 0xf +#define V_FW_RI_ATOMIC_WR_AOPCODE(x) ((x) << S_FW_RI_ATOMIC_WR_AOPCODE) +#define G_FW_RI_ATOMIC_WR_AOPCODE(x) \ + (((x) >> S_FW_RI_ATOMIC_WR_AOPCODE) & M_FW_RI_ATOMIC_WR_AOPCODE) + +enum fw_ri_type { + FW_RI_TYPE_INIT, + FW_RI_TYPE_FINI, + FW_RI_TYPE_TERMINATE +}; + +enum fw_ri_init_p2ptype { + FW_RI_INIT_P2PTYPE_RDMA_WRITE = FW_RI_RDMA_WRITE, + FW_RI_INIT_P2PTYPE_READ_REQ = FW_RI_READ_REQ, + FW_RI_INIT_P2PTYPE_SEND = FW_RI_SEND, + FW_RI_INIT_P2PTYPE_SEND_WITH_INV = FW_RI_SEND_WITH_INV, + FW_RI_INIT_P2PTYPE_SEND_WITH_SE = FW_RI_SEND_WITH_SE, + FW_RI_INIT_P2PTYPE_SEND_WITH_SE_INV = FW_RI_SEND_WITH_SE_INV, + FW_RI_INIT_P2PTYPE_DISABLED = 0xf, +}; + +struct fw_ri_wr { + __be32 op_compl; + __be32 flowid_len16; + __u64 cookie; + union fw_ri { + struct fw_ri_init { + __u8 type; + __u8 mpareqbit_p2ptype; + __u8 r4[2]; + __u8 mpa_attrs; + __u8 qp_caps; + __be16 nrqe; + __be32 pdid; + __be32 qpid; + __be32 sq_eqid; + __be32 rq_eqid; + __be32 scqid; + __be32 rcqid; + __be32 ord_max; + __be32 ird_max; + __be32 iss; + __be32 irs; + __be32 hwrqsize; + __be32 hwrqaddr; + __be64 r5; + union fw_ri_init_p2p { + struct fw_ri_rdma_write_wr write; + struct fw_ri_rdma_read_wr read; + struct fw_ri_send_wr send; + } u; + } init; + struct fw_ri_fini { + __u8 type; + __u8 r3[7]; + __be64 r4; + } fini; + struct fw_ri_terminate { + __u8 type; + __u8 r3[3]; + __be32 immdlen; + __u8 termmsg[40]; + } terminate; + } u; +}; + +#define S_FW_RI_WR_MPAREQBIT 7 +#define M_FW_RI_WR_MPAREQBIT 0x1 +#define V_FW_RI_WR_MPAREQBIT(x) ((x) << S_FW_RI_WR_MPAREQBIT) +#define G_FW_RI_WR_MPAREQBIT(x) \ + (((x) >> S_FW_RI_WR_MPAREQBIT) & M_FW_RI_WR_MPAREQBIT) +#define F_FW_RI_WR_MPAREQBIT V_FW_RI_WR_MPAREQBIT(1U) + +#define S_FW_RI_WR_0BRRBIT 6 +#define M_FW_RI_WR_0BRRBIT 0x1 +#define V_FW_RI_WR_0BRRBIT(x) ((x) << S_FW_RI_WR_0BRRBIT) +#define G_FW_RI_WR_0BRRBIT(x) \ + (((x) >> S_FW_RI_WR_0BRRBIT) & M_FW_RI_WR_0BRRBIT) +#define F_FW_RI_WR_0BRRBIT V_FW_RI_WR_0BRRBIT(1U) + +#define S_FW_RI_WR_P2PTYPE 0 +#define M_FW_RI_WR_P2PTYPE 0xf +#define V_FW_RI_WR_P2PTYPE(x) ((x) << S_FW_RI_WR_P2PTYPE) +#define G_FW_RI_WR_P2PTYPE(x) \ + (((x) >> S_FW_RI_WR_P2PTYPE) & M_FW_RI_WR_P2PTYPE) + +/****************************************************************************** + * F O i S C S I W O R K R E Q U E S T s + *********************************************/ + +#define FW_FOISCSI_NAME_MAX_LEN 224 +#define FW_FOISCSI_ALIAS_MAX_LEN 224 +#define FW_FOISCSI_CHAP_SEC_MAX_LEN 128 +#define FW_FOISCSI_INIT_NODE_MAX 8 + +enum fw_chnet_ifconf_wr_subop { + FW_CHNET_IFCONF_WR_SUBOP_NONE = 0, + + FW_CHNET_IFCONF_WR_SUBOP_IPV4_SET, + FW_CHNET_IFCONF_WR_SUBOP_IPV4_GET, + + FW_CHNET_IFCONF_WR_SUBOP_VLAN_IPV4_SET, + FW_CHNET_IFCONF_WR_SUBOP_VLAN_IPV4_GET, + + FW_CHNET_IFCONF_WR_SUBOP_IPV6_SET, + FW_CHNET_IFCONF_WR_SUBOP_IPV6_GET, + + FW_CHNET_IFCONF_WR_SUBOP_VLAN_SET, + FW_CHNET_IFCONF_WR_SUBOP_VLAN_GET, + + FW_CHNET_IFCONF_WR_SUBOP_MTU_SET, + FW_CHNET_IFCONF_WR_SUBOP_MTU_GET, + + FW_CHNET_IFCONF_WR_SUBOP_DHCP_SET, + FW_CHNET_IFCONF_WR_SUBOP_DHCP_GET, + + FW_CHNET_IFCONF_WR_SUBOP_MAX, +}; + +struct fw_chnet_ifconf_wr { + __be32 op_compl; + __be32 flowid_len16; + __be64 cookie; + __be32 if_flowid; + __u8 idx; + __u8 subop; + __u8 retval; + __u8 r2; + __be64 r3; + struct fw_chnet_ifconf_params { + __be32 r0; + __be16 vlanid; + __be16 mtu; + union fw_chnet_ifconf_addr_type { + struct fw_chnet_ifconf_ipv4 { + __be32 addr; + __be32 mask; + __be32 router; + __be32 r0; + __be64 r1; + } ipv4; + struct fw_chnet_ifconf_ipv6 { + __be64 linklocal_lo; + __be64 linklocal_hi; + __be64 router_hi; + __be64 router_lo; + __be64 aconf_hi; + __be64 aconf_lo; + __be64 linklocal_aconf_hi; + __be64 linklocal_aconf_lo; + __be64 router_aconf_hi; + __be64 router_aconf_lo; + __be64 r0; + } ipv6; + } in_attr; + } param; +}; + +enum fw_foiscsi_node_type { + FW_FOISCSI_NODE_TYPE_INITIATOR = 0, + FW_FOISCSI_NODE_TYPE_TARGET, +}; + +enum fw_foiscsi_session_type { + FW_FOISCSI_SESSION_TYPE_DISCOVERY = 0, + FW_FOISCSI_SESSION_TYPE_NORMAL, +}; + +enum fw_foiscsi_auth_policy { + FW_FOISCSI_AUTH_POLICY_ONEWAY = 0, + FW_FOISCSI_AUTH_POLICY_MUTUAL, +}; + +enum fw_foiscsi_auth_method { + FW_FOISCSI_AUTH_METHOD_NONE = 0, + FW_FOISCSI_AUTH_METHOD_CHAP, + FW_FOISCSI_AUTH_METHOD_CHAP_FST, + FW_FOISCSI_AUTH_METHOD_CHAP_SEC, +}; + +enum fw_foiscsi_digest_type { + FW_FOISCSI_DIGEST_TYPE_NONE = 0, + FW_FOISCSI_DIGEST_TYPE_CRC32, + FW_FOISCSI_DIGEST_TYPE_CRC32_FST, + FW_FOISCSI_DIGEST_TYPE_CRC32_SEC, +}; + +enum fw_foiscsi_wr_subop { + FW_FOISCSI_WR_SUBOP_ADD = 1, + FW_FOISCSI_WR_SUBOP_DEL = 2, + FW_FOISCSI_WR_SUBOP_MOD = 4, +}; + +enum fw_foiscsi_ctrl_state { + FW_FOISCSI_CTRL_STATE_FREE = 0, + FW_FOISCSI_CTRL_STATE_ONLINE = 1, + FW_FOISCSI_CTRL_STATE_FAILED, + FW_FOISCSI_CTRL_STATE_IN_RECOVERY, + FW_FOISCSI_CTRL_STATE_REDIRECT, +}; + +struct fw_rdev_wr { + __be32 op_to_immdlen; + __be32 alloc_to_len16; + __be64 cookie; + __u8 protocol; + __u8 event_cause; + __u8 cur_state; + __u8 prev_state; + __be32 flags_to_assoc_flowid; + union rdev_entry { + struct fcoe_rdev_entry { + __be32 flowid; + __u8 protocol; + __u8 event_cause; + __u8 flags; + __u8 rjt_reason; + __u8 cur_login_st; + __u8 prev_login_st; + __be16 rcv_fr_sz; + __u8 rd_xfer_rdy_to_rport_type; + __u8 vft_to_qos; + __u8 org_proc_assoc_to_acc_rsp_code; + __u8 enh_disc_to_tgt; + __u8 wwnn[8]; + __u8 wwpn[8]; + __be16 iqid; + __u8 fc_oui[3]; + __u8 r_id[3]; + } fcoe_rdev; + struct iscsi_rdev_entry { + __be32 flowid; + __u8 protocol; + __u8 event_cause; + __u8 flags; + __u8 r3; + __be16 iscsi_opts; + __be16 tcp_opts; + __be16 ip_opts; + __be16 max_rcv_len; + __be16 max_snd_len; + __be16 first_brst_len; + __be16 max_brst_len; + __be16 r4; + __be16 def_time2wait; + __be16 def_time2ret; + __be16 nop_out_intrvl; + __be16 non_scsi_to; + __be16 isid; + __be16 tsid; + __be16 port; + __be16 tpgt; + __u8 r5[6]; + __be16 iqid; + } iscsi_rdev; + } u; +}; + +#define S_FW_RDEV_WR_IMMDLEN 0 +#define M_FW_RDEV_WR_IMMDLEN 0xff +#define V_FW_RDEV_WR_IMMDLEN(x) ((x) << S_FW_RDEV_WR_IMMDLEN) +#define G_FW_RDEV_WR_IMMDLEN(x) \ + (((x) >> S_FW_RDEV_WR_IMMDLEN) & M_FW_RDEV_WR_IMMDLEN) + +#define S_FW_RDEV_WR_ALLOC 31 +#define M_FW_RDEV_WR_ALLOC 0x1 +#define V_FW_RDEV_WR_ALLOC(x) ((x) << S_FW_RDEV_WR_ALLOC) +#define G_FW_RDEV_WR_ALLOC(x) \ + (((x) >> S_FW_RDEV_WR_ALLOC) & M_FW_RDEV_WR_ALLOC) +#define F_FW_RDEV_WR_ALLOC V_FW_RDEV_WR_ALLOC(1U) + +#define S_FW_RDEV_WR_FREE 30 +#define M_FW_RDEV_WR_FREE 0x1 +#define V_FW_RDEV_WR_FREE(x) ((x) << S_FW_RDEV_WR_FREE) +#define G_FW_RDEV_WR_FREE(x) \ + (((x) >> S_FW_RDEV_WR_FREE) & M_FW_RDEV_WR_FREE) +#define F_FW_RDEV_WR_FREE V_FW_RDEV_WR_FREE(1U) + +#define S_FW_RDEV_WR_MODIFY 29 +#define M_FW_RDEV_WR_MODIFY 0x1 +#define V_FW_RDEV_WR_MODIFY(x) ((x) << S_FW_RDEV_WR_MODIFY) +#define G_FW_RDEV_WR_MODIFY(x) \ + (((x) >> S_FW_RDEV_WR_MODIFY) & M_FW_RDEV_WR_MODIFY) +#define F_FW_RDEV_WR_MODIFY V_FW_RDEV_WR_MODIFY(1U) + +#define S_FW_RDEV_WR_FLOWID 8 +#define M_FW_RDEV_WR_FLOWID 0xfffff +#define V_FW_RDEV_WR_FLOWID(x) ((x) << S_FW_RDEV_WR_FLOWID) +#define G_FW_RDEV_WR_FLOWID(x) \ + (((x) >> S_FW_RDEV_WR_FLOWID) & M_FW_RDEV_WR_FLOWID) + +#define S_FW_RDEV_WR_LEN16 0 +#define M_FW_RDEV_WR_LEN16 0xff +#define V_FW_RDEV_WR_LEN16(x) ((x) << S_FW_RDEV_WR_LEN16) +#define G_FW_RDEV_WR_LEN16(x) \ + (((x) >> S_FW_RDEV_WR_LEN16) & M_FW_RDEV_WR_LEN16) + +#define S_FW_RDEV_WR_FLAGS 24 +#define M_FW_RDEV_WR_FLAGS 0xff +#define V_FW_RDEV_WR_FLAGS(x) ((x) << S_FW_RDEV_WR_FLAGS) +#define G_FW_RDEV_WR_FLAGS(x) \ + (((x) >> S_FW_RDEV_WR_FLAGS) & M_FW_RDEV_WR_FLAGS) + +#define S_FW_RDEV_WR_GET_NEXT 20 +#define M_FW_RDEV_WR_GET_NEXT 0xf +#define V_FW_RDEV_WR_GET_NEXT(x) ((x) << S_FW_RDEV_WR_GET_NEXT) +#define G_FW_RDEV_WR_GET_NEXT(x) \ + (((x) >> S_FW_RDEV_WR_GET_NEXT) & M_FW_RDEV_WR_GET_NEXT) + +#define S_FW_RDEV_WR_ASSOC_FLOWID 0 +#define M_FW_RDEV_WR_ASSOC_FLOWID 0xfffff +#define V_FW_RDEV_WR_ASSOC_FLOWID(x) ((x) << S_FW_RDEV_WR_ASSOC_FLOWID) +#define G_FW_RDEV_WR_ASSOC_FLOWID(x) \ + (((x) >> S_FW_RDEV_WR_ASSOC_FLOWID) & M_FW_RDEV_WR_ASSOC_FLOWID) + +#define S_FW_RDEV_WR_RJT 7 +#define M_FW_RDEV_WR_RJT 0x1 +#define V_FW_RDEV_WR_RJT(x) ((x) << S_FW_RDEV_WR_RJT) +#define G_FW_RDEV_WR_RJT(x) (((x) >> S_FW_RDEV_WR_RJT) & M_FW_RDEV_WR_RJT) +#define F_FW_RDEV_WR_RJT V_FW_RDEV_WR_RJT(1U) + +#define S_FW_RDEV_WR_REASON 0 +#define M_FW_RDEV_WR_REASON 0x7f +#define V_FW_RDEV_WR_REASON(x) ((x) << S_FW_RDEV_WR_REASON) +#define G_FW_RDEV_WR_REASON(x) \ + (((x) >> S_FW_RDEV_WR_REASON) & M_FW_RDEV_WR_REASON) + +#define S_FW_RDEV_WR_RD_XFER_RDY 7 +#define M_FW_RDEV_WR_RD_XFER_RDY 0x1 +#define V_FW_RDEV_WR_RD_XFER_RDY(x) ((x) << S_FW_RDEV_WR_RD_XFER_RDY) +#define G_FW_RDEV_WR_RD_XFER_RDY(x) \ + (((x) >> S_FW_RDEV_WR_RD_XFER_RDY) & M_FW_RDEV_WR_RD_XFER_RDY) +#define F_FW_RDEV_WR_RD_XFER_RDY V_FW_RDEV_WR_RD_XFER_RDY(1U) + +#define S_FW_RDEV_WR_WR_XFER_RDY 6 +#define M_FW_RDEV_WR_WR_XFER_RDY 0x1 +#define V_FW_RDEV_WR_WR_XFER_RDY(x) ((x) << S_FW_RDEV_WR_WR_XFER_RDY) +#define G_FW_RDEV_WR_WR_XFER_RDY(x) \ + (((x) >> S_FW_RDEV_WR_WR_XFER_RDY) & M_FW_RDEV_WR_WR_XFER_RDY) +#define F_FW_RDEV_WR_WR_XFER_RDY V_FW_RDEV_WR_WR_XFER_RDY(1U) + +#define S_FW_RDEV_WR_FC_SP 5 +#define M_FW_RDEV_WR_FC_SP 0x1 +#define V_FW_RDEV_WR_FC_SP(x) ((x) << S_FW_RDEV_WR_FC_SP) +#define G_FW_RDEV_WR_FC_SP(x) \ + (((x) >> S_FW_RDEV_WR_FC_SP) & M_FW_RDEV_WR_FC_SP) +#define F_FW_RDEV_WR_FC_SP V_FW_RDEV_WR_FC_SP(1U) + +#define S_FW_RDEV_WR_RPORT_TYPE 0 +#define M_FW_RDEV_WR_RPORT_TYPE 0x1f +#define V_FW_RDEV_WR_RPORT_TYPE(x) ((x) << S_FW_RDEV_WR_RPORT_TYPE) +#define G_FW_RDEV_WR_RPORT_TYPE(x) \ + (((x) >> S_FW_RDEV_WR_RPORT_TYPE) & M_FW_RDEV_WR_RPORT_TYPE) + +#define S_FW_RDEV_WR_VFT 7 +#define M_FW_RDEV_WR_VFT 0x1 +#define V_FW_RDEV_WR_VFT(x) ((x) << S_FW_RDEV_WR_VFT) +#define G_FW_RDEV_WR_VFT(x) (((x) >> S_FW_RDEV_WR_VFT) & M_FW_RDEV_WR_VFT) +#define F_FW_RDEV_WR_VFT V_FW_RDEV_WR_VFT(1U) + +#define S_FW_RDEV_WR_NPIV 6 +#define M_FW_RDEV_WR_NPIV 0x1 +#define V_FW_RDEV_WR_NPIV(x) ((x) << S_FW_RDEV_WR_NPIV) +#define G_FW_RDEV_WR_NPIV(x) \ + (((x) >> S_FW_RDEV_WR_NPIV) & M_FW_RDEV_WR_NPIV) +#define F_FW_RDEV_WR_NPIV V_FW_RDEV_WR_NPIV(1U) + +#define S_FW_RDEV_WR_CLASS 4 +#define M_FW_RDEV_WR_CLASS 0x3 +#define V_FW_RDEV_WR_CLASS(x) ((x) << S_FW_RDEV_WR_CLASS) +#define G_FW_RDEV_WR_CLASS(x) \ + (((x) >> S_FW_RDEV_WR_CLASS) & M_FW_RDEV_WR_CLASS) + +#define S_FW_RDEV_WR_SEQ_DEL 3 +#define M_FW_RDEV_WR_SEQ_DEL 0x1 +#define V_FW_RDEV_WR_SEQ_DEL(x) ((x) << S_FW_RDEV_WR_SEQ_DEL) +#define G_FW_RDEV_WR_SEQ_DEL(x) \ + (((x) >> S_FW_RDEV_WR_SEQ_DEL) & M_FW_RDEV_WR_SEQ_DEL) +#define F_FW_RDEV_WR_SEQ_DEL V_FW_RDEV_WR_SEQ_DEL(1U) + +#define S_FW_RDEV_WR_PRIO_PREEMP 2 +#define M_FW_RDEV_WR_PRIO_PREEMP 0x1 +#define V_FW_RDEV_WR_PRIO_PREEMP(x) ((x) << S_FW_RDEV_WR_PRIO_PREEMP) +#define G_FW_RDEV_WR_PRIO_PREEMP(x) \ + (((x) >> S_FW_RDEV_WR_PRIO_PREEMP) & M_FW_RDEV_WR_PRIO_PREEMP) +#define F_FW_RDEV_WR_PRIO_PREEMP V_FW_RDEV_WR_PRIO_PREEMP(1U) + +#define S_FW_RDEV_WR_PREF 1 +#define M_FW_RDEV_WR_PREF 0x1 +#define V_FW_RDEV_WR_PREF(x) ((x) << S_FW_RDEV_WR_PREF) +#define G_FW_RDEV_WR_PREF(x) \ + (((x) >> S_FW_RDEV_WR_PREF) & M_FW_RDEV_WR_PREF) +#define F_FW_RDEV_WR_PREF V_FW_RDEV_WR_PREF(1U) + +#define S_FW_RDEV_WR_QOS 0 +#define M_FW_RDEV_WR_QOS 0x1 +#define V_FW_RDEV_WR_QOS(x) ((x) << S_FW_RDEV_WR_QOS) +#define G_FW_RDEV_WR_QOS(x) (((x) >> S_FW_RDEV_WR_QOS) & M_FW_RDEV_WR_QOS) +#define F_FW_RDEV_WR_QOS V_FW_RDEV_WR_QOS(1U) + +#define S_FW_RDEV_WR_ORG_PROC_ASSOC 7 +#define M_FW_RDEV_WR_ORG_PROC_ASSOC 0x1 +#define V_FW_RDEV_WR_ORG_PROC_ASSOC(x) ((x) << S_FW_RDEV_WR_ORG_PROC_ASSOC) +#define G_FW_RDEV_WR_ORG_PROC_ASSOC(x) \ + (((x) >> S_FW_RDEV_WR_ORG_PROC_ASSOC) & M_FW_RDEV_WR_ORG_PROC_ASSOC) +#define F_FW_RDEV_WR_ORG_PROC_ASSOC V_FW_RDEV_WR_ORG_PROC_ASSOC(1U) + +#define S_FW_RDEV_WR_RSP_PROC_ASSOC 6 +#define M_FW_RDEV_WR_RSP_PROC_ASSOC 0x1 +#define V_FW_RDEV_WR_RSP_PROC_ASSOC(x) ((x) << S_FW_RDEV_WR_RSP_PROC_ASSOC) +#define G_FW_RDEV_WR_RSP_PROC_ASSOC(x) \ + (((x) >> S_FW_RDEV_WR_RSP_PROC_ASSOC) & M_FW_RDEV_WR_RSP_PROC_ASSOC) +#define F_FW_RDEV_WR_RSP_PROC_ASSOC V_FW_RDEV_WR_RSP_PROC_ASSOC(1U) + +#define S_FW_RDEV_WR_IMAGE_PAIR 5 +#define M_FW_RDEV_WR_IMAGE_PAIR 0x1 +#define V_FW_RDEV_WR_IMAGE_PAIR(x) ((x) << S_FW_RDEV_WR_IMAGE_PAIR) +#define G_FW_RDEV_WR_IMAGE_PAIR(x) \ + (((x) >> S_FW_RDEV_WR_IMAGE_PAIR) & M_FW_RDEV_WR_IMAGE_PAIR) +#define F_FW_RDEV_WR_IMAGE_PAIR V_FW_RDEV_WR_IMAGE_PAIR(1U) + +#define S_FW_RDEV_WR_ACC_RSP_CODE 0 +#define M_FW_RDEV_WR_ACC_RSP_CODE 0x1f +#define V_FW_RDEV_WR_ACC_RSP_CODE(x) ((x) << S_FW_RDEV_WR_ACC_RSP_CODE) +#define G_FW_RDEV_WR_ACC_RSP_CODE(x) \ + (((x) >> S_FW_RDEV_WR_ACC_RSP_CODE) & M_FW_RDEV_WR_ACC_RSP_CODE) + +#define S_FW_RDEV_WR_ENH_DISC 7 +#define M_FW_RDEV_WR_ENH_DISC 0x1 +#define V_FW_RDEV_WR_ENH_DISC(x) ((x) << S_FW_RDEV_WR_ENH_DISC) +#define G_FW_RDEV_WR_ENH_DISC(x) \ + (((x) >> S_FW_RDEV_WR_ENH_DISC) & M_FW_RDEV_WR_ENH_DISC) +#define F_FW_RDEV_WR_ENH_DISC V_FW_RDEV_WR_ENH_DISC(1U) + +#define S_FW_RDEV_WR_REC 6 +#define M_FW_RDEV_WR_REC 0x1 +#define V_FW_RDEV_WR_REC(x) ((x) << S_FW_RDEV_WR_REC) +#define G_FW_RDEV_WR_REC(x) (((x) >> S_FW_RDEV_WR_REC) & M_FW_RDEV_WR_REC) +#define F_FW_RDEV_WR_REC V_FW_RDEV_WR_REC(1U) + +#define S_FW_RDEV_WR_TASK_RETRY_ID 5 +#define M_FW_RDEV_WR_TASK_RETRY_ID 0x1 +#define V_FW_RDEV_WR_TASK_RETRY_ID(x) ((x) << S_FW_RDEV_WR_TASK_RETRY_ID) +#define G_FW_RDEV_WR_TASK_RETRY_ID(x) \ + (((x) >> S_FW_RDEV_WR_TASK_RETRY_ID) & M_FW_RDEV_WR_TASK_RETRY_ID) +#define F_FW_RDEV_WR_TASK_RETRY_ID V_FW_RDEV_WR_TASK_RETRY_ID(1U) + +#define S_FW_RDEV_WR_RETRY 4 +#define M_FW_RDEV_WR_RETRY 0x1 +#define V_FW_RDEV_WR_RETRY(x) ((x) << S_FW_RDEV_WR_RETRY) +#define G_FW_RDEV_WR_RETRY(x) \ + (((x) >> S_FW_RDEV_WR_RETRY) & M_FW_RDEV_WR_RETRY) +#define F_FW_RDEV_WR_RETRY V_FW_RDEV_WR_RETRY(1U) + +#define S_FW_RDEV_WR_CONF_CMPL 3 +#define M_FW_RDEV_WR_CONF_CMPL 0x1 +#define V_FW_RDEV_WR_CONF_CMPL(x) ((x) << S_FW_RDEV_WR_CONF_CMPL) +#define G_FW_RDEV_WR_CONF_CMPL(x) \ + (((x) >> S_FW_RDEV_WR_CONF_CMPL) & M_FW_RDEV_WR_CONF_CMPL) +#define F_FW_RDEV_WR_CONF_CMPL V_FW_RDEV_WR_CONF_CMPL(1U) + +#define S_FW_RDEV_WR_DATA_OVLY 2 +#define M_FW_RDEV_WR_DATA_OVLY 0x1 +#define V_FW_RDEV_WR_DATA_OVLY(x) ((x) << S_FW_RDEV_WR_DATA_OVLY) +#define G_FW_RDEV_WR_DATA_OVLY(x) \ + (((x) >> S_FW_RDEV_WR_DATA_OVLY) & M_FW_RDEV_WR_DATA_OVLY) +#define F_FW_RDEV_WR_DATA_OVLY V_FW_RDEV_WR_DATA_OVLY(1U) + +#define S_FW_RDEV_WR_INI 1 +#define M_FW_RDEV_WR_INI 0x1 +#define V_FW_RDEV_WR_INI(x) ((x) << S_FW_RDEV_WR_INI) +#define G_FW_RDEV_WR_INI(x) (((x) >> S_FW_RDEV_WR_INI) & M_FW_RDEV_WR_INI) +#define F_FW_RDEV_WR_INI V_FW_RDEV_WR_INI(1U) + +#define S_FW_RDEV_WR_TGT 0 +#define M_FW_RDEV_WR_TGT 0x1 +#define V_FW_RDEV_WR_TGT(x) ((x) << S_FW_RDEV_WR_TGT) +#define G_FW_RDEV_WR_TGT(x) (((x) >> S_FW_RDEV_WR_TGT) & M_FW_RDEV_WR_TGT) +#define F_FW_RDEV_WR_TGT V_FW_RDEV_WR_TGT(1U) + +struct fw_foiscsi_node_wr { + __be32 op_to_immdlen; + __be32 flowid_len16; + __u64 cookie; + __u8 subop; + __u8 status; + __u8 alias_len; + __u8 iqn_len; + __be32 node_flowid; + __be16 nodeid; + __be16 login_retry; + __be16 retry_timeout; + __be16 r3; + __u8 iqn[224]; + __u8 alias[224]; +}; + +#define S_FW_FOISCSI_NODE_WR_IMMDLEN 0 +#define M_FW_FOISCSI_NODE_WR_IMMDLEN 0xffff +#define V_FW_FOISCSI_NODE_WR_IMMDLEN(x) ((x) << S_FW_FOISCSI_NODE_WR_IMMDLEN) +#define G_FW_FOISCSI_NODE_WR_IMMDLEN(x) \ + (((x) >> S_FW_FOISCSI_NODE_WR_IMMDLEN) & M_FW_FOISCSI_NODE_WR_IMMDLEN) + +struct fw_foiscsi_ctrl_wr { + __be32 op_compl; + __be32 flowid_len16; + __u64 cookie; + __u8 subop; + __u8 status; + __u8 ctrl_state; + __u8 io_state; + __be32 node_id; + __be32 ctrl_id; + __be32 io_id; + struct fw_foiscsi_sess_attr { + __be32 sess_type_to_erl; + __be16 max_conn; + __be16 max_r2t; + __be16 time2wait; + __be16 time2retain; + __be32 max_burst; + __be32 first_burst; + __be32 r1; + } sess_attr; + struct fw_foiscsi_conn_attr { + __be32 hdigest_to_ddp_pgsz; + __be32 max_rcv_dsl; + __be32 ping_tmo; + __be16 dst_port; + __be16 src_port; + union fw_foiscsi_conn_attr_addr { + struct fw_foiscsi_conn_attr_ipv6 { + __be64 dst_addr[2]; + __be64 src_addr[2]; + } ipv6_addr; + struct fw_foiscsi_conn_attr_ipv4 { + __be32 dst_addr; + __be32 src_addr; + } ipv4_addr; + } u; + } conn_attr; + __u8 tgt_name_len; + __u8 r3[7]; + __u8 tgt_name[FW_FOISCSI_NAME_MAX_LEN]; +}; + +#define S_FW_FOISCSI_CTRL_WR_SESS_TYPE 30 +#define M_FW_FOISCSI_CTRL_WR_SESS_TYPE 0x3 +#define V_FW_FOISCSI_CTRL_WR_SESS_TYPE(x) \ + ((x) << S_FW_FOISCSI_CTRL_WR_SESS_TYPE) +#define G_FW_FOISCSI_CTRL_WR_SESS_TYPE(x) \ + (((x) >> S_FW_FOISCSI_CTRL_WR_SESS_TYPE) & M_FW_FOISCSI_CTRL_WR_SESS_TYPE) + +#define S_FW_FOISCSI_CTRL_WR_SEQ_INORDER 29 +#define M_FW_FOISCSI_CTRL_WR_SEQ_INORDER 0x1 +#define V_FW_FOISCSI_CTRL_WR_SEQ_INORDER(x) \ + ((x) << S_FW_FOISCSI_CTRL_WR_SEQ_INORDER) +#define G_FW_FOISCSI_CTRL_WR_SEQ_INORDER(x) \ + (((x) >> S_FW_FOISCSI_CTRL_WR_SEQ_INORDER) & \ + M_FW_FOISCSI_CTRL_WR_SEQ_INORDER) +#define F_FW_FOISCSI_CTRL_WR_SEQ_INORDER \ + V_FW_FOISCSI_CTRL_WR_SEQ_INORDER(1U) + +#define S_FW_FOISCSI_CTRL_WR_PDU_INORDER 28 +#define M_FW_FOISCSI_CTRL_WR_PDU_INORDER 0x1 +#define V_FW_FOISCSI_CTRL_WR_PDU_INORDER(x) \ + ((x) << S_FW_FOISCSI_CTRL_WR_PDU_INORDER) +#define G_FW_FOISCSI_CTRL_WR_PDU_INORDER(x) \ + (((x) >> S_FW_FOISCSI_CTRL_WR_PDU_INORDER) & \ + M_FW_FOISCSI_CTRL_WR_PDU_INORDER) +#define F_FW_FOISCSI_CTRL_WR_PDU_INORDER \ + V_FW_FOISCSI_CTRL_WR_PDU_INORDER(1U) + +#define S_FW_FOISCSI_CTRL_WR_IMMD_DATA_EN 27 +#define M_FW_FOISCSI_CTRL_WR_IMMD_DATA_EN 0x1 +#define V_FW_FOISCSI_CTRL_WR_IMMD_DATA_EN(x) \ + ((x) << S_FW_FOISCSI_CTRL_WR_IMMD_DATA_EN) +#define G_FW_FOISCSI_CTRL_WR_IMMD_DATA_EN(x) \ + (((x) >> S_FW_FOISCSI_CTRL_WR_IMMD_DATA_EN) & \ + M_FW_FOISCSI_CTRL_WR_IMMD_DATA_EN) +#define F_FW_FOISCSI_CTRL_WR_IMMD_DATA_EN \ + V_FW_FOISCSI_CTRL_WR_IMMD_DATA_EN(1U) + +#define S_FW_FOISCSI_CTRL_WR_INIT_R2T_EN 26 +#define M_FW_FOISCSI_CTRL_WR_INIT_R2T_EN 0x1 +#define V_FW_FOISCSI_CTRL_WR_INIT_R2T_EN(x) \ + ((x) << S_FW_FOISCSI_CTRL_WR_INIT_R2T_EN) +#define G_FW_FOISCSI_CTRL_WR_INIT_R2T_EN(x) \ + (((x) >> S_FW_FOISCSI_CTRL_WR_INIT_R2T_EN) & \ + M_FW_FOISCSI_CTRL_WR_INIT_R2T_EN) +#define F_FW_FOISCSI_CTRL_WR_INIT_R2T_EN \ + V_FW_FOISCSI_CTRL_WR_INIT_R2T_EN(1U) + +#define S_FW_FOISCSI_CTRL_WR_ERL 24 +#define M_FW_FOISCSI_CTRL_WR_ERL 0x3 +#define V_FW_FOISCSI_CTRL_WR_ERL(x) ((x) << S_FW_FOISCSI_CTRL_WR_ERL) +#define G_FW_FOISCSI_CTRL_WR_ERL(x) \ + (((x) >> S_FW_FOISCSI_CTRL_WR_ERL) & M_FW_FOISCSI_CTRL_WR_ERL) + +#define S_FW_FOISCSI_CTRL_WR_HDIGEST 30 +#define M_FW_FOISCSI_CTRL_WR_HDIGEST 0x3 +#define V_FW_FOISCSI_CTRL_WR_HDIGEST(x) ((x) << S_FW_FOISCSI_CTRL_WR_HDIGEST) +#define G_FW_FOISCSI_CTRL_WR_HDIGEST(x) \ + (((x) >> S_FW_FOISCSI_CTRL_WR_HDIGEST) & M_FW_FOISCSI_CTRL_WR_HDIGEST) + +#define S_FW_FOISCSI_CTRL_WR_DDIGEST 28 +#define M_FW_FOISCSI_CTRL_WR_DDIGEST 0x3 +#define V_FW_FOISCSI_CTRL_WR_DDIGEST(x) ((x) << S_FW_FOISCSI_CTRL_WR_DDIGEST) +#define G_FW_FOISCSI_CTRL_WR_DDIGEST(x) \ + (((x) >> S_FW_FOISCSI_CTRL_WR_DDIGEST) & M_FW_FOISCSI_CTRL_WR_DDIGEST) + +#define S_FW_FOISCSI_CTRL_WR_AUTH_METHOD 25 +#define M_FW_FOISCSI_CTRL_WR_AUTH_METHOD 0x7 +#define V_FW_FOISCSI_CTRL_WR_AUTH_METHOD(x) \ + ((x) << S_FW_FOISCSI_CTRL_WR_AUTH_METHOD) +#define G_FW_FOISCSI_CTRL_WR_AUTH_METHOD(x) \ + (((x) >> S_FW_FOISCSI_CTRL_WR_AUTH_METHOD) & \ + M_FW_FOISCSI_CTRL_WR_AUTH_METHOD) + +#define S_FW_FOISCSI_CTRL_WR_AUTH_POLICY 23 +#define M_FW_FOISCSI_CTRL_WR_AUTH_POLICY 0x3 +#define V_FW_FOISCSI_CTRL_WR_AUTH_POLICY(x) \ + ((x) << S_FW_FOISCSI_CTRL_WR_AUTH_POLICY) +#define G_FW_FOISCSI_CTRL_WR_AUTH_POLICY(x) \ + (((x) >> S_FW_FOISCSI_CTRL_WR_AUTH_POLICY) & \ + M_FW_FOISCSI_CTRL_WR_AUTH_POLICY) + +#define S_FW_FOISCSI_CTRL_WR_DDP_PGSZ 21 +#define M_FW_FOISCSI_CTRL_WR_DDP_PGSZ 0x3 +#define V_FW_FOISCSI_CTRL_WR_DDP_PGSZ(x) \ + ((x) << S_FW_FOISCSI_CTRL_WR_DDP_PGSZ) +#define G_FW_FOISCSI_CTRL_WR_DDP_PGSZ(x) \ + (((x) >> S_FW_FOISCSI_CTRL_WR_DDP_PGSZ) & M_FW_FOISCSI_CTRL_WR_DDP_PGSZ) + +struct fw_foiscsi_chap_wr { + __be32 op_compl; + __be32 flowid_len16; + __u64 cookie; + __u8 status; + __u8 id_len; + __u8 sec_len; + __u8 node_type; + __be16 node_id; + __u8 r3[2]; + __u8 chap_id[FW_FOISCSI_NAME_MAX_LEN]; + __u8 chap_sec[FW_FOISCSI_CHAP_SEC_MAX_LEN]; +}; + +/****************************************************************************** + * F O F C O E W O R K R E Q U E S T s + *******************************************/ + +struct fw_fcoe_els_ct_wr { + __be32 op_immdlen; + __be32 flowid_len16; + __be64 cookie; + __be16 iqid; + __u8 tmo_val; + __u8 els_ct_type; + __u8 ctl_pri; + __u8 cp_en_class; + __be16 xfer_cnt; + __u8 fl_to_sp; + __u8 l_id[3]; + __u8 r5; + __u8 r_id[3]; + __be64 rsp_dmaaddr; + __be32 rsp_dmalen; + __be32 r6; +}; + +#define S_FW_FCOE_ELS_CT_WR_OPCODE 24 +#define M_FW_FCOE_ELS_CT_WR_OPCODE 0xff +#define V_FW_FCOE_ELS_CT_WR_OPCODE(x) ((x) << S_FW_FCOE_ELS_CT_WR_OPCODE) +#define G_FW_FCOE_ELS_CT_WR_OPCODE(x) \ + (((x) >> S_FW_FCOE_ELS_CT_WR_OPCODE) & M_FW_FCOE_ELS_CT_WR_OPCODE) + +#define S_FW_FCOE_ELS_CT_WR_IMMDLEN 0 +#define M_FW_FCOE_ELS_CT_WR_IMMDLEN 0xff +#define V_FW_FCOE_ELS_CT_WR_IMMDLEN(x) ((x) << S_FW_FCOE_ELS_CT_WR_IMMDLEN) +#define G_FW_FCOE_ELS_CT_WR_IMMDLEN(x) \ + (((x) >> S_FW_FCOE_ELS_CT_WR_IMMDLEN) & M_FW_FCOE_ELS_CT_WR_IMMDLEN) + +#define S_FW_FCOE_ELS_CT_WR_FLOWID 8 +#define M_FW_FCOE_ELS_CT_WR_FLOWID 0xfffff +#define V_FW_FCOE_ELS_CT_WR_FLOWID(x) ((x) << S_FW_FCOE_ELS_CT_WR_FLOWID) +#define G_FW_FCOE_ELS_CT_WR_FLOWID(x) \ + (((x) >> S_FW_FCOE_ELS_CT_WR_FLOWID) & M_FW_FCOE_ELS_CT_WR_FLOWID) + +#define S_FW_FCOE_ELS_CT_WR_LEN16 0 +#define M_FW_FCOE_ELS_CT_WR_LEN16 0xff +#define V_FW_FCOE_ELS_CT_WR_LEN16(x) ((x) << S_FW_FCOE_ELS_CT_WR_LEN16) +#define G_FW_FCOE_ELS_CT_WR_LEN16(x) \ + (((x) >> S_FW_FCOE_ELS_CT_WR_LEN16) & M_FW_FCOE_ELS_CT_WR_LEN16) + +#define S_FW_FCOE_ELS_CT_WR_CP_EN 6 +#define M_FW_FCOE_ELS_CT_WR_CP_EN 0x3 +#define V_FW_FCOE_ELS_CT_WR_CP_EN(x) ((x) << S_FW_FCOE_ELS_CT_WR_CP_EN) +#define G_FW_FCOE_ELS_CT_WR_CP_EN(x) \ + (((x) >> S_FW_FCOE_ELS_CT_WR_CP_EN) & M_FW_FCOE_ELS_CT_WR_CP_EN) + +#define S_FW_FCOE_ELS_CT_WR_CLASS 4 +#define M_FW_FCOE_ELS_CT_WR_CLASS 0x3 +#define V_FW_FCOE_ELS_CT_WR_CLASS(x) ((x) << S_FW_FCOE_ELS_CT_WR_CLASS) +#define G_FW_FCOE_ELS_CT_WR_CLASS(x) \ + (((x) >> S_FW_FCOE_ELS_CT_WR_CLASS) & M_FW_FCOE_ELS_CT_WR_CLASS) + +#define S_FW_FCOE_ELS_CT_WR_FL 2 +#define M_FW_FCOE_ELS_CT_WR_FL 0x1 +#define V_FW_FCOE_ELS_CT_WR_FL(x) ((x) << S_FW_FCOE_ELS_CT_WR_FL) +#define G_FW_FCOE_ELS_CT_WR_FL(x) \ + (((x) >> S_FW_FCOE_ELS_CT_WR_FL) & M_FW_FCOE_ELS_CT_WR_FL) +#define F_FW_FCOE_ELS_CT_WR_FL V_FW_FCOE_ELS_CT_WR_FL(1U) + +#define S_FW_FCOE_ELS_CT_WR_NPIV 1 +#define M_FW_FCOE_ELS_CT_WR_NPIV 0x1 +#define V_FW_FCOE_ELS_CT_WR_NPIV(x) ((x) << S_FW_FCOE_ELS_CT_WR_NPIV) +#define G_FW_FCOE_ELS_CT_WR_NPIV(x) \ + (((x) >> S_FW_FCOE_ELS_CT_WR_NPIV) & M_FW_FCOE_ELS_CT_WR_NPIV) +#define F_FW_FCOE_ELS_CT_WR_NPIV V_FW_FCOE_ELS_CT_WR_NPIV(1U) + +#define S_FW_FCOE_ELS_CT_WR_SP 0 +#define M_FW_FCOE_ELS_CT_WR_SP 0x1 +#define V_FW_FCOE_ELS_CT_WR_SP(x) ((x) << S_FW_FCOE_ELS_CT_WR_SP) +#define G_FW_FCOE_ELS_CT_WR_SP(x) \ + (((x) >> S_FW_FCOE_ELS_CT_WR_SP) & M_FW_FCOE_ELS_CT_WR_SP) +#define F_FW_FCOE_ELS_CT_WR_SP V_FW_FCOE_ELS_CT_WR_SP(1U) + +/****************************************************************************** + * S C S I W O R K R E Q U E S T s (FOiSCSI and FCOE unified data path) + *****************************************************************************/ + +struct fw_scsi_write_wr { + __be32 op_immdlen; + __be32 flowid_len16; + __be64 cookie; + __be16 iqid; + __u8 tmo_val; + __u8 use_xfer_cnt; + union fw_scsi_write_priv { + struct fcoe_write_priv { + __u8 ctl_pri; + __u8 cp_en_class; + __u8 r3_lo[2]; + } fcoe; + struct iscsi_write_priv { + __u8 r3[4]; + } iscsi; + } u; + __be32 xfer_cnt; + __be32 ini_xfer_cnt; + __be64 rsp_dmaaddr; + __be32 rsp_dmalen; + __be32 r4; +}; + +#define S_FW_SCSI_WRITE_WR_OPCODE 24 +#define M_FW_SCSI_WRITE_WR_OPCODE 0xff +#define V_FW_SCSI_WRITE_WR_OPCODE(x) ((x) << S_FW_SCSI_WRITE_WR_OPCODE) +#define G_FW_SCSI_WRITE_WR_OPCODE(x) \ + (((x) >> S_FW_SCSI_WRITE_WR_OPCODE) & M_FW_SCSI_WRITE_WR_OPCODE) + +#define S_FW_SCSI_WRITE_WR_IMMDLEN 0 +#define M_FW_SCSI_WRITE_WR_IMMDLEN 0xff +#define V_FW_SCSI_WRITE_WR_IMMDLEN(x) ((x) << S_FW_SCSI_WRITE_WR_IMMDLEN) +#define G_FW_SCSI_WRITE_WR_IMMDLEN(x) \ + (((x) >> S_FW_SCSI_WRITE_WR_IMMDLEN) & M_FW_SCSI_WRITE_WR_IMMDLEN) + +#define S_FW_SCSI_WRITE_WR_FLOWID 8 +#define M_FW_SCSI_WRITE_WR_FLOWID 0xfffff +#define V_FW_SCSI_WRITE_WR_FLOWID(x) ((x) << S_FW_SCSI_WRITE_WR_FLOWID) +#define G_FW_SCSI_WRITE_WR_FLOWID(x) \ + (((x) >> S_FW_SCSI_WRITE_WR_FLOWID) & M_FW_SCSI_WRITE_WR_FLOWID) + +#define S_FW_SCSI_WRITE_WR_LEN16 0 +#define M_FW_SCSI_WRITE_WR_LEN16 0xff +#define V_FW_SCSI_WRITE_WR_LEN16(x) ((x) << S_FW_SCSI_WRITE_WR_LEN16) +#define G_FW_SCSI_WRITE_WR_LEN16(x) \ + (((x) >> S_FW_SCSI_WRITE_WR_LEN16) & M_FW_SCSI_WRITE_WR_LEN16) + +#define S_FW_SCSI_WRITE_WR_CP_EN 6 +#define M_FW_SCSI_WRITE_WR_CP_EN 0x3 +#define V_FW_SCSI_WRITE_WR_CP_EN(x) ((x) << S_FW_SCSI_WRITE_WR_CP_EN) +#define G_FW_SCSI_WRITE_WR_CP_EN(x) \ + (((x) >> S_FW_SCSI_WRITE_WR_CP_EN) & M_FW_SCSI_WRITE_WR_CP_EN) + +#define S_FW_SCSI_WRITE_WR_CLASS 4 +#define M_FW_SCSI_WRITE_WR_CLASS 0x3 +#define V_FW_SCSI_WRITE_WR_CLASS(x) ((x) << S_FW_SCSI_WRITE_WR_CLASS) +#define G_FW_SCSI_WRITE_WR_CLASS(x) \ + (((x) >> S_FW_SCSI_WRITE_WR_CLASS) & M_FW_SCSI_WRITE_WR_CLASS) + +struct fw_scsi_read_wr { + __be32 op_immdlen; + __be32 flowid_len16; + __be64 cookie; + __be16 iqid; + __u8 tmo_val; + __u8 use_xfer_cnt; + union fw_scsi_read_priv { + struct fcoe_read_priv { + __u8 ctl_pri; + __u8 cp_en_class; + __u8 r3_lo[2]; + } fcoe; + struct iscsi_read_priv { + __u8 r3[4]; + } iscsi; + } u; + __be32 xfer_cnt; + __be32 ini_xfer_cnt; + __be64 rsp_dmaaddr; + __be32 rsp_dmalen; + __be32 r4; +}; + +#define S_FW_SCSI_READ_WR_OPCODE 24 +#define M_FW_SCSI_READ_WR_OPCODE 0xff +#define V_FW_SCSI_READ_WR_OPCODE(x) ((x) << S_FW_SCSI_READ_WR_OPCODE) +#define G_FW_SCSI_READ_WR_OPCODE(x) \ + (((x) >> S_FW_SCSI_READ_WR_OPCODE) & M_FW_SCSI_READ_WR_OPCODE) + +#define S_FW_SCSI_READ_WR_IMMDLEN 0 +#define M_FW_SCSI_READ_WR_IMMDLEN 0xff +#define V_FW_SCSI_READ_WR_IMMDLEN(x) ((x) << S_FW_SCSI_READ_WR_IMMDLEN) +#define G_FW_SCSI_READ_WR_IMMDLEN(x) \ + (((x) >> S_FW_SCSI_READ_WR_IMMDLEN) & M_FW_SCSI_READ_WR_IMMDLEN) + +#define S_FW_SCSI_READ_WR_FLOWID 8 +#define M_FW_SCSI_READ_WR_FLOWID 0xfffff +#define V_FW_SCSI_READ_WR_FLOWID(x) ((x) << S_FW_SCSI_READ_WR_FLOWID) +#define G_FW_SCSI_READ_WR_FLOWID(x) \ + (((x) >> S_FW_SCSI_READ_WR_FLOWID) & M_FW_SCSI_READ_WR_FLOWID) + +#define S_FW_SCSI_READ_WR_LEN16 0 +#define M_FW_SCSI_READ_WR_LEN16 0xff +#define V_FW_SCSI_READ_WR_LEN16(x) ((x) << S_FW_SCSI_READ_WR_LEN16) +#define G_FW_SCSI_READ_WR_LEN16(x) \ + (((x) >> S_FW_SCSI_READ_WR_LEN16) & M_FW_SCSI_READ_WR_LEN16) + +#define S_FW_SCSI_READ_WR_CP_EN 6 +#define M_FW_SCSI_READ_WR_CP_EN 0x3 +#define V_FW_SCSI_READ_WR_CP_EN(x) ((x) << S_FW_SCSI_READ_WR_CP_EN) +#define G_FW_SCSI_READ_WR_CP_EN(x) \ + (((x) >> S_FW_SCSI_READ_WR_CP_EN) & M_FW_SCSI_READ_WR_CP_EN) + +#define S_FW_SCSI_READ_WR_CLASS 4 +#define M_FW_SCSI_READ_WR_CLASS 0x3 +#define V_FW_SCSI_READ_WR_CLASS(x) ((x) << S_FW_SCSI_READ_WR_CLASS) +#define G_FW_SCSI_READ_WR_CLASS(x) \ + (((x) >> S_FW_SCSI_READ_WR_CLASS) & M_FW_SCSI_READ_WR_CLASS) + +struct fw_scsi_cmd_wr { + __be32 op_immdlen; + __be32 flowid_len16; + __be64 cookie; + __be16 iqid; + __u8 tmo_val; + __u8 r3; + union fw_scsi_cmd_priv { + struct fcoe_cmd_priv { + __u8 ctl_pri; + __u8 cp_en_class; + __u8 r4_lo[2]; + } fcoe; + struct iscsi_cmd_priv { + __u8 r4[4]; + } iscsi; + } u; + __u8 r5[8]; + __be64 rsp_dmaaddr; + __be32 rsp_dmalen; + __be32 r6; +}; + +#define S_FW_SCSI_CMD_WR_OPCODE 24 +#define M_FW_SCSI_CMD_WR_OPCODE 0xff +#define V_FW_SCSI_CMD_WR_OPCODE(x) ((x) << S_FW_SCSI_CMD_WR_OPCODE) +#define G_FW_SCSI_CMD_WR_OPCODE(x) \ + (((x) >> S_FW_SCSI_CMD_WR_OPCODE) & M_FW_SCSI_CMD_WR_OPCODE) + +#define S_FW_SCSI_CMD_WR_IMMDLEN 0 +#define M_FW_SCSI_CMD_WR_IMMDLEN 0xff +#define V_FW_SCSI_CMD_WR_IMMDLEN(x) ((x) << S_FW_SCSI_CMD_WR_IMMDLEN) +#define G_FW_SCSI_CMD_WR_IMMDLEN(x) \ + (((x) >> S_FW_SCSI_CMD_WR_IMMDLEN) & M_FW_SCSI_CMD_WR_IMMDLEN) + +#define S_FW_SCSI_CMD_WR_FLOWID 8 +#define M_FW_SCSI_CMD_WR_FLOWID 0xfffff +#define V_FW_SCSI_CMD_WR_FLOWID(x) ((x) << S_FW_SCSI_CMD_WR_FLOWID) +#define G_FW_SCSI_CMD_WR_FLOWID(x) \ + (((x) >> S_FW_SCSI_CMD_WR_FLOWID) & M_FW_SCSI_CMD_WR_FLOWID) + +#define S_FW_SCSI_CMD_WR_LEN16 0 +#define M_FW_SCSI_CMD_WR_LEN16 0xff +#define V_FW_SCSI_CMD_WR_LEN16(x) ((x) << S_FW_SCSI_CMD_WR_LEN16) +#define G_FW_SCSI_CMD_WR_LEN16(x) \ + (((x) >> S_FW_SCSI_CMD_WR_LEN16) & M_FW_SCSI_CMD_WR_LEN16) + +#define S_FW_SCSI_CMD_WR_CP_EN 6 +#define M_FW_SCSI_CMD_WR_CP_EN 0x3 +#define V_FW_SCSI_CMD_WR_CP_EN(x) ((x) << S_FW_SCSI_CMD_WR_CP_EN) +#define G_FW_SCSI_CMD_WR_CP_EN(x) \ + (((x) >> S_FW_SCSI_CMD_WR_CP_EN) & M_FW_SCSI_CMD_WR_CP_EN) + +#define S_FW_SCSI_CMD_WR_CLASS 4 +#define M_FW_SCSI_CMD_WR_CLASS 0x3 +#define V_FW_SCSI_CMD_WR_CLASS(x) ((x) << S_FW_SCSI_CMD_WR_CLASS) +#define G_FW_SCSI_CMD_WR_CLASS(x) \ + (((x) >> S_FW_SCSI_CMD_WR_CLASS) & M_FW_SCSI_CMD_WR_CLASS) + +struct fw_scsi_abrt_cls_wr { + __be32 op_immdlen; + __be32 flowid_len16; + __be64 cookie; + __be16 iqid; + __u8 tmo_val; + __u8 sub_opcode_to_chk_all_io; + __u8 r3[4]; + __be64 t_cookie; +}; + +#define S_FW_SCSI_ABRT_CLS_WR_OPCODE 24 +#define M_FW_SCSI_ABRT_CLS_WR_OPCODE 0xff +#define V_FW_SCSI_ABRT_CLS_WR_OPCODE(x) ((x) << S_FW_SCSI_ABRT_CLS_WR_OPCODE) +#define G_FW_SCSI_ABRT_CLS_WR_OPCODE(x) \ + (((x) >> S_FW_SCSI_ABRT_CLS_WR_OPCODE) & M_FW_SCSI_ABRT_CLS_WR_OPCODE) + +#define S_FW_SCSI_ABRT_CLS_WR_IMMDLEN 0 +#define M_FW_SCSI_ABRT_CLS_WR_IMMDLEN 0xff +#define V_FW_SCSI_ABRT_CLS_WR_IMMDLEN(x) \ + ((x) << S_FW_SCSI_ABRT_CLS_WR_IMMDLEN) +#define G_FW_SCSI_ABRT_CLS_WR_IMMDLEN(x) \ + (((x) >> S_FW_SCSI_ABRT_CLS_WR_IMMDLEN) & M_FW_SCSI_ABRT_CLS_WR_IMMDLEN) + +#define S_FW_SCSI_ABRT_CLS_WR_FLOWID 8 +#define M_FW_SCSI_ABRT_CLS_WR_FLOWID 0xfffff +#define V_FW_SCSI_ABRT_CLS_WR_FLOWID(x) ((x) << S_FW_SCSI_ABRT_CLS_WR_FLOWID) +#define G_FW_SCSI_ABRT_CLS_WR_FLOWID(x) \ + (((x) >> S_FW_SCSI_ABRT_CLS_WR_FLOWID) & M_FW_SCSI_ABRT_CLS_WR_FLOWID) + +#define S_FW_SCSI_ABRT_CLS_WR_LEN16 0 +#define M_FW_SCSI_ABRT_CLS_WR_LEN16 0xff +#define V_FW_SCSI_ABRT_CLS_WR_LEN16(x) ((x) << S_FW_SCSI_ABRT_CLS_WR_LEN16) +#define G_FW_SCSI_ABRT_CLS_WR_LEN16(x) \ + (((x) >> S_FW_SCSI_ABRT_CLS_WR_LEN16) & M_FW_SCSI_ABRT_CLS_WR_LEN16) + +#define S_FW_SCSI_ABRT_CLS_WR_SUB_OPCODE 2 +#define M_FW_SCSI_ABRT_CLS_WR_SUB_OPCODE 0x3f +#define V_FW_SCSI_ABRT_CLS_WR_SUB_OPCODE(x) \ + ((x) << S_FW_SCSI_ABRT_CLS_WR_SUB_OPCODE) +#define G_FW_SCSI_ABRT_CLS_WR_SUB_OPCODE(x) \ + (((x) >> S_FW_SCSI_ABRT_CLS_WR_SUB_OPCODE) & \ + M_FW_SCSI_ABRT_CLS_WR_SUB_OPCODE) + +#define S_FW_SCSI_ABRT_CLS_WR_UNSOL 1 +#define M_FW_SCSI_ABRT_CLS_WR_UNSOL 0x1 +#define V_FW_SCSI_ABRT_CLS_WR_UNSOL(x) ((x) << S_FW_SCSI_ABRT_CLS_WR_UNSOL) +#define G_FW_SCSI_ABRT_CLS_WR_UNSOL(x) \ + (((x) >> S_FW_SCSI_ABRT_CLS_WR_UNSOL) & M_FW_SCSI_ABRT_CLS_WR_UNSOL) +#define F_FW_SCSI_ABRT_CLS_WR_UNSOL V_FW_SCSI_ABRT_CLS_WR_UNSOL(1U) + +#define S_FW_SCSI_ABRT_CLS_WR_CHK_ALL_IO 0 +#define M_FW_SCSI_ABRT_CLS_WR_CHK_ALL_IO 0x1 +#define V_FW_SCSI_ABRT_CLS_WR_CHK_ALL_IO(x) \ + ((x) << S_FW_SCSI_ABRT_CLS_WR_CHK_ALL_IO) +#define G_FW_SCSI_ABRT_CLS_WR_CHK_ALL_IO(x) \ + (((x) >> S_FW_SCSI_ABRT_CLS_WR_CHK_ALL_IO) & \ + M_FW_SCSI_ABRT_CLS_WR_CHK_ALL_IO) +#define F_FW_SCSI_ABRT_CLS_WR_CHK_ALL_IO \ + V_FW_SCSI_ABRT_CLS_WR_CHK_ALL_IO(1U) + +struct fw_scsi_tgt_acc_wr { + __be32 op_immdlen; + __be32 flowid_len16; + __be64 cookie; + __be16 iqid; + __u8 r3; + __u8 use_burst_len; + union fw_scsi_tgt_acc_priv { + struct fcoe_tgt_acc_priv { + __u8 ctl_pri; + __u8 cp_en_class; + __u8 r4_lo[2]; + } fcoe; + struct iscsi_tgt_acc_priv { + __u8 r4[4]; + } iscsi; + } u; + __be32 burst_len; + __be32 rel_off; + __be64 r5; + __be32 r6; + __be32 tot_xfer_len; +}; + +#define S_FW_SCSI_TGT_ACC_WR_OPCODE 24 +#define M_FW_SCSI_TGT_ACC_WR_OPCODE 0xff +#define V_FW_SCSI_TGT_ACC_WR_OPCODE(x) ((x) << S_FW_SCSI_TGT_ACC_WR_OPCODE) +#define G_FW_SCSI_TGT_ACC_WR_OPCODE(x) \ + (((x) >> S_FW_SCSI_TGT_ACC_WR_OPCODE) & M_FW_SCSI_TGT_ACC_WR_OPCODE) + +#define S_FW_SCSI_TGT_ACC_WR_IMMDLEN 0 +#define M_FW_SCSI_TGT_ACC_WR_IMMDLEN 0xff +#define V_FW_SCSI_TGT_ACC_WR_IMMDLEN(x) ((x) << S_FW_SCSI_TGT_ACC_WR_IMMDLEN) +#define G_FW_SCSI_TGT_ACC_WR_IMMDLEN(x) \ + (((x) >> S_FW_SCSI_TGT_ACC_WR_IMMDLEN) & M_FW_SCSI_TGT_ACC_WR_IMMDLEN) + +#define S_FW_SCSI_TGT_ACC_WR_FLOWID 8 +#define M_FW_SCSI_TGT_ACC_WR_FLOWID 0xfffff +#define V_FW_SCSI_TGT_ACC_WR_FLOWID(x) ((x) << S_FW_SCSI_TGT_ACC_WR_FLOWID) +#define G_FW_SCSI_TGT_ACC_WR_FLOWID(x) \ + (((x) >> S_FW_SCSI_TGT_ACC_WR_FLOWID) & M_FW_SCSI_TGT_ACC_WR_FLOWID) + +#define S_FW_SCSI_TGT_ACC_WR_LEN16 0 +#define M_FW_SCSI_TGT_ACC_WR_LEN16 0xff +#define V_FW_SCSI_TGT_ACC_WR_LEN16(x) ((x) << S_FW_SCSI_TGT_ACC_WR_LEN16) +#define G_FW_SCSI_TGT_ACC_WR_LEN16(x) \ + (((x) >> S_FW_SCSI_TGT_ACC_WR_LEN16) & M_FW_SCSI_TGT_ACC_WR_LEN16) + +#define S_FW_SCSI_TGT_ACC_WR_CP_EN 6 +#define M_FW_SCSI_TGT_ACC_WR_CP_EN 0x3 +#define V_FW_SCSI_TGT_ACC_WR_CP_EN(x) ((x) << S_FW_SCSI_TGT_ACC_WR_CP_EN) +#define G_FW_SCSI_TGT_ACC_WR_CP_EN(x) \ + (((x) >> S_FW_SCSI_TGT_ACC_WR_CP_EN) & M_FW_SCSI_TGT_ACC_WR_CP_EN) + +#define S_FW_SCSI_TGT_ACC_WR_CLASS 4 +#define M_FW_SCSI_TGT_ACC_WR_CLASS 0x3 +#define V_FW_SCSI_TGT_ACC_WR_CLASS(x) ((x) << S_FW_SCSI_TGT_ACC_WR_CLASS) +#define G_FW_SCSI_TGT_ACC_WR_CLASS(x) \ + (((x) >> S_FW_SCSI_TGT_ACC_WR_CLASS) & M_FW_SCSI_TGT_ACC_WR_CLASS) + +struct fw_scsi_tgt_xmit_wr { + __be32 op_immdlen; + __be32 flowid_len16; + __be64 cookie; + __be16 iqid; + __u8 auto_rsp; + __u8 use_xfer_cnt; + union fw_scsi_tgt_xmit_priv { + struct fcoe_tgt_xmit_priv { + __u8 ctl_pri; + __u8 cp_en_class; + __u8 r3_lo[2]; + } fcoe; + struct iscsi_tgt_xmit_priv { + __u8 r3[4]; + } iscsi; + } u; + __be32 xfer_cnt; + __be32 r4; + __be64 r5; + __be32 r6; + __be32 tot_xfer_len; +}; + +#define S_FW_SCSI_TGT_XMIT_WR_OPCODE 24 +#define M_FW_SCSI_TGT_XMIT_WR_OPCODE 0xff +#define V_FW_SCSI_TGT_XMIT_WR_OPCODE(x) ((x) << S_FW_SCSI_TGT_XMIT_WR_OPCODE) +#define G_FW_SCSI_TGT_XMIT_WR_OPCODE(x) \ + (((x) >> S_FW_SCSI_TGT_XMIT_WR_OPCODE) & M_FW_SCSI_TGT_XMIT_WR_OPCODE) + +#define S_FW_SCSI_TGT_XMIT_WR_IMMDLEN 0 +#define M_FW_SCSI_TGT_XMIT_WR_IMMDLEN 0xff +#define V_FW_SCSI_TGT_XMIT_WR_IMMDLEN(x) \ + ((x) << S_FW_SCSI_TGT_XMIT_WR_IMMDLEN) +#define G_FW_SCSI_TGT_XMIT_WR_IMMDLEN(x) \ + (((x) >> S_FW_SCSI_TGT_XMIT_WR_IMMDLEN) & M_FW_SCSI_TGT_XMIT_WR_IMMDLEN) + +#define S_FW_SCSI_TGT_XMIT_WR_FLOWID 8 +#define M_FW_SCSI_TGT_XMIT_WR_FLOWID 0xfffff +#define V_FW_SCSI_TGT_XMIT_WR_FLOWID(x) ((x) << S_FW_SCSI_TGT_XMIT_WR_FLOWID) +#define G_FW_SCSI_TGT_XMIT_WR_FLOWID(x) \ + (((x) >> S_FW_SCSI_TGT_XMIT_WR_FLOWID) & M_FW_SCSI_TGT_XMIT_WR_FLOWID) + +#define S_FW_SCSI_TGT_XMIT_WR_LEN16 0 +#define M_FW_SCSI_TGT_XMIT_WR_LEN16 0xff +#define V_FW_SCSI_TGT_XMIT_WR_LEN16(x) ((x) << S_FW_SCSI_TGT_XMIT_WR_LEN16) +#define G_FW_SCSI_TGT_XMIT_WR_LEN16(x) \ + (((x) >> S_FW_SCSI_TGT_XMIT_WR_LEN16) & M_FW_SCSI_TGT_XMIT_WR_LEN16) + +#define S_FW_SCSI_TGT_XMIT_WR_CP_EN 6 +#define M_FW_SCSI_TGT_XMIT_WR_CP_EN 0x3 +#define V_FW_SCSI_TGT_XMIT_WR_CP_EN(x) ((x) << S_FW_SCSI_TGT_XMIT_WR_CP_EN) +#define G_FW_SCSI_TGT_XMIT_WR_CP_EN(x) \ + (((x) >> S_FW_SCSI_TGT_XMIT_WR_CP_EN) & M_FW_SCSI_TGT_XMIT_WR_CP_EN) + +#define S_FW_SCSI_TGT_XMIT_WR_CLASS 4 +#define M_FW_SCSI_TGT_XMIT_WR_CLASS 0x3 +#define V_FW_SCSI_TGT_XMIT_WR_CLASS(x) ((x) << S_FW_SCSI_TGT_XMIT_WR_CLASS) +#define G_FW_SCSI_TGT_XMIT_WR_CLASS(x) \ + (((x) >> S_FW_SCSI_TGT_XMIT_WR_CLASS) & M_FW_SCSI_TGT_XMIT_WR_CLASS) + +struct fw_scsi_tgt_rsp_wr { + __be32 op_immdlen; + __be32 flowid_len16; + __be64 cookie; + __be16 iqid; + __u8 r3[2]; + union fw_scsi_tgt_rsp_priv { + struct fcoe_tgt_rsp_priv { + __u8 ctl_pri; + __u8 cp_en_class; + __u8 r4_lo[2]; + } fcoe; + struct iscsi_tgt_rsp_priv { + __u8 r4[4]; + } iscsi; + } u; + __u8 r5[8]; +}; + +#define S_FW_SCSI_TGT_RSP_WR_OPCODE 24 +#define M_FW_SCSI_TGT_RSP_WR_OPCODE 0xff +#define V_FW_SCSI_TGT_RSP_WR_OPCODE(x) ((x) << S_FW_SCSI_TGT_RSP_WR_OPCODE) +#define G_FW_SCSI_TGT_RSP_WR_OPCODE(x) \ + (((x) >> S_FW_SCSI_TGT_RSP_WR_OPCODE) & M_FW_SCSI_TGT_RSP_WR_OPCODE) + +#define S_FW_SCSI_TGT_RSP_WR_IMMDLEN 0 +#define M_FW_SCSI_TGT_RSP_WR_IMMDLEN 0xff +#define V_FW_SCSI_TGT_RSP_WR_IMMDLEN(x) ((x) << S_FW_SCSI_TGT_RSP_WR_IMMDLEN) +#define G_FW_SCSI_TGT_RSP_WR_IMMDLEN(x) \ + (((x) >> S_FW_SCSI_TGT_RSP_WR_IMMDLEN) & M_FW_SCSI_TGT_RSP_WR_IMMDLEN) + +#define S_FW_SCSI_TGT_RSP_WR_FLOWID 8 +#define M_FW_SCSI_TGT_RSP_WR_FLOWID 0xfffff +#define V_FW_SCSI_TGT_RSP_WR_FLOWID(x) ((x) << S_FW_SCSI_TGT_RSP_WR_FLOWID) +#define G_FW_SCSI_TGT_RSP_WR_FLOWID(x) \ + (((x) >> S_FW_SCSI_TGT_RSP_WR_FLOWID) & M_FW_SCSI_TGT_RSP_WR_FLOWID) + +#define S_FW_SCSI_TGT_RSP_WR_LEN16 0 +#define M_FW_SCSI_TGT_RSP_WR_LEN16 0xff +#define V_FW_SCSI_TGT_RSP_WR_LEN16(x) ((x) << S_FW_SCSI_TGT_RSP_WR_LEN16) +#define G_FW_SCSI_TGT_RSP_WR_LEN16(x) \ + (((x) >> S_FW_SCSI_TGT_RSP_WR_LEN16) & M_FW_SCSI_TGT_RSP_WR_LEN16) + +#define S_FW_SCSI_TGT_RSP_WR_CP_EN 6 +#define M_FW_SCSI_TGT_RSP_WR_CP_EN 0x3 +#define V_FW_SCSI_TGT_RSP_WR_CP_EN(x) ((x) << S_FW_SCSI_TGT_RSP_WR_CP_EN) +#define G_FW_SCSI_TGT_RSP_WR_CP_EN(x) \ + (((x) >> S_FW_SCSI_TGT_RSP_WR_CP_EN) & M_FW_SCSI_TGT_RSP_WR_CP_EN) + +#define S_FW_SCSI_TGT_RSP_WR_CLASS 4 +#define M_FW_SCSI_TGT_RSP_WR_CLASS 0x3 +#define V_FW_SCSI_TGT_RSP_WR_CLASS(x) ((x) << S_FW_SCSI_TGT_RSP_WR_CLASS) +#define G_FW_SCSI_TGT_RSP_WR_CLASS(x) \ + (((x) >> S_FW_SCSI_TGT_RSP_WR_CLASS) & M_FW_SCSI_TGT_RSP_WR_CLASS) + +struct fw_pofcoe_tcb_wr { + __be32 op_compl; + __be32 equiq_to_len16; + __be64 cookie; + __be32 tid_to_port; + __be16 x_id; + __be16 vlan_id; + __be32 s_id; + __be32 d_id; + __be32 tag; + __be32 xfer_len; + __be32 r4; + __be16 r5; + __be16 iqid; +}; + +#define S_FW_POFCOE_TCB_WR_TID 12 +#define M_FW_POFCOE_TCB_WR_TID 0xfffff +#define V_FW_POFCOE_TCB_WR_TID(x) ((x) << S_FW_POFCOE_TCB_WR_TID) +#define G_FW_POFCOE_TCB_WR_TID(x) \ + (((x) >> S_FW_POFCOE_TCB_WR_TID) & M_FW_POFCOE_TCB_WR_TID) + +#define S_FW_POFCOE_TCB_WR_ALLOC 4 +#define M_FW_POFCOE_TCB_WR_ALLOC 0x1 +#define V_FW_POFCOE_TCB_WR_ALLOC(x) ((x) << S_FW_POFCOE_TCB_WR_ALLOC) +#define G_FW_POFCOE_TCB_WR_ALLOC(x) \ + (((x) >> S_FW_POFCOE_TCB_WR_ALLOC) & M_FW_POFCOE_TCB_WR_ALLOC) +#define F_FW_POFCOE_TCB_WR_ALLOC V_FW_POFCOE_TCB_WR_ALLOC(1U) + +#define S_FW_POFCOE_TCB_WR_FREE 3 +#define M_FW_POFCOE_TCB_WR_FREE 0x1 +#define V_FW_POFCOE_TCB_WR_FREE(x) ((x) << S_FW_POFCOE_TCB_WR_FREE) +#define G_FW_POFCOE_TCB_WR_FREE(x) \ + (((x) >> S_FW_POFCOE_TCB_WR_FREE) & M_FW_POFCOE_TCB_WR_FREE) +#define F_FW_POFCOE_TCB_WR_FREE V_FW_POFCOE_TCB_WR_FREE(1U) + +#define S_FW_POFCOE_TCB_WR_PORT 0 +#define M_FW_POFCOE_TCB_WR_PORT 0x7 +#define V_FW_POFCOE_TCB_WR_PORT(x) ((x) << S_FW_POFCOE_TCB_WR_PORT) +#define G_FW_POFCOE_TCB_WR_PORT(x) \ + (((x) >> S_FW_POFCOE_TCB_WR_PORT) & M_FW_POFCOE_TCB_WR_PORT) + +struct fw_pofcoe_ulptx_wr { + __be32 op_pkd; + __be32 equiq_to_len16; + __u64 cookie; +}; + + +/****************************************************************************** + * C O M M A N D s + *********************/ + +/* + * The maximum length of time, in miliseconds, that we expect any firmware + * command to take to execute and return a reply to the host. The RESET + * and INITIALIZE commands can take a fair amount of time to execute but + * most execute in far less time than this maximum. This constant is used + * by host software to determine how long to wait for a firmware command + * reply before declaring the firmware as dead/unreachable ... + */ +#define FW_CMD_MAX_TIMEOUT 10000 + +/* + * If a host driver does a HELLO and discovers that there's already a MASTER + * selected, we may have to wait for that MASTER to finish issuing RESET, + * configuration and INITIALIZE commands. Also, there's a possibility that + * our own HELLO may get lost if it happens right as the MASTER is issuign a + * RESET command, so we need to be willing to make a few retries of our HELLO. + */ +#define FW_CMD_HELLO_TIMEOUT (3 * FW_CMD_MAX_TIMEOUT) +#define FW_CMD_HELLO_RETRIES 3 + +enum fw_cmd_opcodes { + FW_LDST_CMD = 0x01, + FW_RESET_CMD = 0x03, + FW_HELLO_CMD = 0x04, + FW_BYE_CMD = 0x05, + FW_INITIALIZE_CMD = 0x06, + FW_CAPS_CONFIG_CMD = 0x07, + FW_PARAMS_CMD = 0x08, + FW_PFVF_CMD = 0x09, + FW_IQ_CMD = 0x10, + FW_EQ_MNGT_CMD = 0x11, + FW_EQ_ETH_CMD = 0x12, + FW_EQ_CTRL_CMD = 0x13, + FW_EQ_OFLD_CMD = 0x21, + FW_VI_CMD = 0x14, + FW_VI_MAC_CMD = 0x15, + FW_VI_RXMODE_CMD = 0x16, + FW_VI_ENABLE_CMD = 0x17, + FW_VI_STATS_CMD = 0x1a, + FW_ACL_MAC_CMD = 0x18, + FW_ACL_VLAN_CMD = 0x19, + FW_PORT_CMD = 0x1b, + FW_PORT_STATS_CMD = 0x1c, + FW_PORT_LB_STATS_CMD = 0x1d, + FW_PORT_TRACE_CMD = 0x1e, + FW_PORT_TRACE_MMAP_CMD = 0x1f, + FW_RSS_IND_TBL_CMD = 0x20, + FW_RSS_GLB_CONFIG_CMD = 0x22, + FW_RSS_VI_CONFIG_CMD = 0x23, + FW_SCHED_CMD = 0x24, + FW_DEVLOG_CMD = 0x25, + FW_WATCHDOG_CMD = 0x27, + FW_CLIP_CMD = 0x28, + FW_CHNET_IFACE_CMD = 0x26, + FW_FCOE_RES_INFO_CMD = 0x31, + FW_FCOE_LINK_CMD = 0x32, + FW_FCOE_VNP_CMD = 0x33, + FW_FCOE_SPARAMS_CMD = 0x35, + FW_FCOE_STATS_CMD = 0x37, + FW_FCOE_FCF_CMD = 0x38, + FW_LASTC2E_CMD = 0x40, + FW_ERROR_CMD = 0x80, + FW_DEBUG_CMD = 0x81, +}; + +enum fw_cmd_cap { + FW_CMD_CAP_PF = 0x01, + FW_CMD_CAP_DMAQ = 0x02, + FW_CMD_CAP_PORT = 0x04, + FW_CMD_CAP_PORTPROMISC = 0x08, + FW_CMD_CAP_PORTSTATS = 0x10, + FW_CMD_CAP_VF = 0x80, +}; + +/* + * Generic command header flit0 + */ +struct fw_cmd_hdr { + __be32 hi; + __be32 lo; +}; + +#define S_FW_CMD_OP 24 +#define M_FW_CMD_OP 0xff +#define V_FW_CMD_OP(x) ((x) << S_FW_CMD_OP) +#define G_FW_CMD_OP(x) (((x) >> S_FW_CMD_OP) & M_FW_CMD_OP) + +#define S_FW_CMD_REQUEST 23 +#define M_FW_CMD_REQUEST 0x1 +#define V_FW_CMD_REQUEST(x) ((x) << S_FW_CMD_REQUEST) +#define G_FW_CMD_REQUEST(x) (((x) >> S_FW_CMD_REQUEST) & M_FW_CMD_REQUEST) +#define F_FW_CMD_REQUEST V_FW_CMD_REQUEST(1U) + +#define S_FW_CMD_READ 22 +#define M_FW_CMD_READ 0x1 +#define V_FW_CMD_READ(x) ((x) << S_FW_CMD_READ) +#define G_FW_CMD_READ(x) (((x) >> S_FW_CMD_READ) & M_FW_CMD_READ) +#define F_FW_CMD_READ V_FW_CMD_READ(1U) + +#define S_FW_CMD_WRITE 21 +#define M_FW_CMD_WRITE 0x1 +#define V_FW_CMD_WRITE(x) ((x) << S_FW_CMD_WRITE) +#define G_FW_CMD_WRITE(x) (((x) >> S_FW_CMD_WRITE) & M_FW_CMD_WRITE) +#define F_FW_CMD_WRITE V_FW_CMD_WRITE(1U) + +#define S_FW_CMD_EXEC 20 +#define M_FW_CMD_EXEC 0x1 +#define V_FW_CMD_EXEC(x) ((x) << S_FW_CMD_EXEC) +#define G_FW_CMD_EXEC(x) (((x) >> S_FW_CMD_EXEC) & M_FW_CMD_EXEC) +#define F_FW_CMD_EXEC V_FW_CMD_EXEC(1U) + +#define S_FW_CMD_RAMASK 20 +#define M_FW_CMD_RAMASK 0xf +#define V_FW_CMD_RAMASK(x) ((x) << S_FW_CMD_RAMASK) +#define G_FW_CMD_RAMASK(x) (((x) >> S_FW_CMD_RAMASK) & M_FW_CMD_RAMASK) + +#define S_FW_CMD_RETVAL 8 +#define M_FW_CMD_RETVAL 0xff +#define V_FW_CMD_RETVAL(x) ((x) << S_FW_CMD_RETVAL) +#define G_FW_CMD_RETVAL(x) (((x) >> S_FW_CMD_RETVAL) & M_FW_CMD_RETVAL) + +#define S_FW_CMD_LEN16 0 +#define M_FW_CMD_LEN16 0xff +#define V_FW_CMD_LEN16(x) ((x) << S_FW_CMD_LEN16) +#define G_FW_CMD_LEN16(x) (((x) >> S_FW_CMD_LEN16) & M_FW_CMD_LEN16) + +#define FW_LEN16(fw_struct) V_FW_CMD_LEN16(sizeof(fw_struct) / 16) + +/* + * address spaces + */ +enum fw_ldst_addrspc { + FW_LDST_ADDRSPC_FIRMWARE = 0x0001, + FW_LDST_ADDRSPC_SGE_EGRC = 0x0008, + FW_LDST_ADDRSPC_SGE_INGC = 0x0009, + FW_LDST_ADDRSPC_SGE_FLMC = 0x000a, + FW_LDST_ADDRSPC_SGE_CONMC = 0x000b, + FW_LDST_ADDRSPC_TP_PIO = 0x0010, + FW_LDST_ADDRSPC_TP_TM_PIO = 0x0011, + FW_LDST_ADDRSPC_TP_MIB = 0x0012, + FW_LDST_ADDRSPC_MDIO = 0x0018, + FW_LDST_ADDRSPC_MPS = 0x0020, + FW_LDST_ADDRSPC_FUNC = 0x0028, + FW_LDST_ADDRSPC_FUNC_PCIE = 0x0029, + FW_LDST_ADDRSPC_FUNC_I2C = 0x002A, /* legacy */ + FW_LDST_ADDRSPC_LE = 0x0030, + FW_LDST_ADDRSPC_I2C = 0x0038, + FW_LDST_ADDRSPC_PCIE_CFGS = 0x0040, + FW_LDST_ADDRSPC_PCIE_DBG = 0x0041, + FW_LDST_ADDRSPC_PCIE_PHY = 0x0042, +}; + +/* + * MDIO VSC8634 register access control field + */ +enum fw_ldst_mdio_vsc8634_aid { + FW_LDST_MDIO_VS_STANDARD, + FW_LDST_MDIO_VS_EXTENDED, + FW_LDST_MDIO_VS_GPIO +}; + +enum fw_ldst_mps_fid { + FW_LDST_MPS_ATRB, + FW_LDST_MPS_RPLC +}; + +enum fw_ldst_func_access_ctl { + FW_LDST_FUNC_ACC_CTL_VIID, + FW_LDST_FUNC_ACC_CTL_FID +}; + +enum fw_ldst_func_mod_index { + FW_LDST_FUNC_MPS +}; + +struct fw_ldst_cmd { + __be32 op_to_addrspace; + __be32 cycles_to_len16; + union fw_ldst { + struct fw_ldst_addrval { + __be32 addr; + __be32 val; + } addrval; + struct fw_ldst_idctxt { + __be32 physid; + __be32 msg_ctxtflush; + __be32 ctxt_data7; + __be32 ctxt_data6; + __be32 ctxt_data5; + __be32 ctxt_data4; + __be32 ctxt_data3; + __be32 ctxt_data2; + __be32 ctxt_data1; + __be32 ctxt_data0; + } idctxt; + struct fw_ldst_mdio { + __be16 paddr_mmd; + __be16 raddr; + __be16 vctl; + __be16 rval; + } mdio; + struct fw_ldst_mps { + __be16 fid_ctl; + __be16 rplcpf_pkd; + __be32 rplc127_96; + __be32 rplc95_64; + __be32 rplc63_32; + __be32 rplc31_0; + __be32 atrb; + __be16 vlan[16]; + } mps; + struct fw_ldst_func { + __u8 access_ctl; + __u8 mod_index; + __be16 ctl_id; + __be32 offset; + __be64 data0; + __be64 data1; + } func; + struct fw_ldst_pcie { + __u8 ctrl_to_fn; + __u8 bnum; + __u8 r; + __u8 ext_r; + __u8 select_naccess; + __u8 pcie_fn; + __be16 nset_pkd; + __be32 data[12]; + } pcie; + struct fw_ldst_i2c_deprecated { + __u8 pid_pkd; + __u8 base; + __u8 boffset; + __u8 data; + __be32 r9; + } i2c_deprecated; + struct fw_ldst_i2c { + __u8 pid; + __u8 did; + __u8 boffset; + __u8 blen; + __be32 r9; + __u8 data[48]; + } i2c; + struct fw_ldst_le { + __be32 index; + __be32 r9; + __u8 val[33]; + __u8 r11[7]; + } le; + } u; +}; + +#define S_FW_LDST_CMD_ADDRSPACE 0 +#define M_FW_LDST_CMD_ADDRSPACE 0xff +#define V_FW_LDST_CMD_ADDRSPACE(x) ((x) << S_FW_LDST_CMD_ADDRSPACE) +#define G_FW_LDST_CMD_ADDRSPACE(x) \ + (((x) >> S_FW_LDST_CMD_ADDRSPACE) & M_FW_LDST_CMD_ADDRSPACE) + +#define S_FW_LDST_CMD_CYCLES 16 +#define M_FW_LDST_CMD_CYCLES 0xffff +#define V_FW_LDST_CMD_CYCLES(x) ((x) << S_FW_LDST_CMD_CYCLES) +#define G_FW_LDST_CMD_CYCLES(x) \ + (((x) >> S_FW_LDST_CMD_CYCLES) & M_FW_LDST_CMD_CYCLES) + +#define S_FW_LDST_CMD_MSG 31 +#define M_FW_LDST_CMD_MSG 0x1 +#define V_FW_LDST_CMD_MSG(x) ((x) << S_FW_LDST_CMD_MSG) +#define G_FW_LDST_CMD_MSG(x) \ + (((x) >> S_FW_LDST_CMD_MSG) & M_FW_LDST_CMD_MSG) +#define F_FW_LDST_CMD_MSG V_FW_LDST_CMD_MSG(1U) + +#define S_FW_LDST_CMD_CTXTFLUSH 30 +#define M_FW_LDST_CMD_CTXTFLUSH 0x1 +#define V_FW_LDST_CMD_CTXTFLUSH(x) ((x) << S_FW_LDST_CMD_CTXTFLUSH) +#define G_FW_LDST_CMD_CTXTFLUSH(x) \ + (((x) >> S_FW_LDST_CMD_CTXTFLUSH) & M_FW_LDST_CMD_CTXTFLUSH) +#define F_FW_LDST_CMD_CTXTFLUSH V_FW_LDST_CMD_CTXTFLUSH(1U) + +#define S_FW_LDST_CMD_PADDR 8 +#define M_FW_LDST_CMD_PADDR 0x1f +#define V_FW_LDST_CMD_PADDR(x) ((x) << S_FW_LDST_CMD_PADDR) +#define G_FW_LDST_CMD_PADDR(x) \ + (((x) >> S_FW_LDST_CMD_PADDR) & M_FW_LDST_CMD_PADDR) + +#define S_FW_LDST_CMD_MMD 0 +#define M_FW_LDST_CMD_MMD 0x1f +#define V_FW_LDST_CMD_MMD(x) ((x) << S_FW_LDST_CMD_MMD) +#define G_FW_LDST_CMD_MMD(x) \ + (((x) >> S_FW_LDST_CMD_MMD) & M_FW_LDST_CMD_MMD) + +#define S_FW_LDST_CMD_FID 15 +#define M_FW_LDST_CMD_FID 0x1 +#define V_FW_LDST_CMD_FID(x) ((x) << S_FW_LDST_CMD_FID) +#define G_FW_LDST_CMD_FID(x) \ + (((x) >> S_FW_LDST_CMD_FID) & M_FW_LDST_CMD_FID) +#define F_FW_LDST_CMD_FID V_FW_LDST_CMD_FID(1U) + +#define S_FW_LDST_CMD_CTL 0 +#define M_FW_LDST_CMD_CTL 0x7fff +#define V_FW_LDST_CMD_CTL(x) ((x) << S_FW_LDST_CMD_CTL) +#define G_FW_LDST_CMD_CTL(x) \ + (((x) >> S_FW_LDST_CMD_CTL) & M_FW_LDST_CMD_CTL) + +#define S_FW_LDST_CMD_RPLCPF 0 +#define M_FW_LDST_CMD_RPLCPF 0xff +#define V_FW_LDST_CMD_RPLCPF(x) ((x) << S_FW_LDST_CMD_RPLCPF) +#define G_FW_LDST_CMD_RPLCPF(x) \ + (((x) >> S_FW_LDST_CMD_RPLCPF) & M_FW_LDST_CMD_RPLCPF) + +#define S_FW_LDST_CMD_CTRL 7 +#define M_FW_LDST_CMD_CTRL 0x1 +#define V_FW_LDST_CMD_CTRL(x) ((x) << S_FW_LDST_CMD_CTRL) +#define G_FW_LDST_CMD_CTRL(x) \ + (((x) >> S_FW_LDST_CMD_CTRL) & M_FW_LDST_CMD_CTRL) +#define F_FW_LDST_CMD_CTRL V_FW_LDST_CMD_CTRL(1U) + +#define S_FW_LDST_CMD_LC 4 +#define M_FW_LDST_CMD_LC 0x1 +#define V_FW_LDST_CMD_LC(x) ((x) << S_FW_LDST_CMD_LC) +#define G_FW_LDST_CMD_LC(x) (((x) >> S_FW_LDST_CMD_LC) & M_FW_LDST_CMD_LC) +#define F_FW_LDST_CMD_LC V_FW_LDST_CMD_LC(1U) + +#define S_FW_LDST_CMD_AI 3 +#define M_FW_LDST_CMD_AI 0x1 +#define V_FW_LDST_CMD_AI(x) ((x) << S_FW_LDST_CMD_AI) +#define G_FW_LDST_CMD_AI(x) (((x) >> S_FW_LDST_CMD_AI) & M_FW_LDST_CMD_AI) +#define F_FW_LDST_CMD_AI V_FW_LDST_CMD_AI(1U) + +#define S_FW_LDST_CMD_FN 0 +#define M_FW_LDST_CMD_FN 0x7 +#define V_FW_LDST_CMD_FN(x) ((x) << S_FW_LDST_CMD_FN) +#define G_FW_LDST_CMD_FN(x) (((x) >> S_FW_LDST_CMD_FN) & M_FW_LDST_CMD_FN) + +#define S_FW_LDST_CMD_SELECT 4 +#define M_FW_LDST_CMD_SELECT 0xf +#define V_FW_LDST_CMD_SELECT(x) ((x) << S_FW_LDST_CMD_SELECT) +#define G_FW_LDST_CMD_SELECT(x) \ + (((x) >> S_FW_LDST_CMD_SELECT) & M_FW_LDST_CMD_SELECT) + +#define S_FW_LDST_CMD_NACCESS 0 +#define M_FW_LDST_CMD_NACCESS 0xf +#define V_FW_LDST_CMD_NACCESS(x) ((x) << S_FW_LDST_CMD_NACCESS) +#define G_FW_LDST_CMD_NACCESS(x) \ + (((x) >> S_FW_LDST_CMD_NACCESS) & M_FW_LDST_CMD_NACCESS) + +#define S_FW_LDST_CMD_NSET 14 +#define M_FW_LDST_CMD_NSET 0x3 +#define V_FW_LDST_CMD_NSET(x) ((x) << S_FW_LDST_CMD_NSET) +#define G_FW_LDST_CMD_NSET(x) \ + (((x) >> S_FW_LDST_CMD_NSET) & M_FW_LDST_CMD_NSET) + +#define S_FW_LDST_CMD_PID 6 +#define M_FW_LDST_CMD_PID 0x3 +#define V_FW_LDST_CMD_PID(x) ((x) << S_FW_LDST_CMD_PID) +#define G_FW_LDST_CMD_PID(x) \ + (((x) >> S_FW_LDST_CMD_PID) & M_FW_LDST_CMD_PID) + +struct fw_reset_cmd { + __be32 op_to_write; + __be32 retval_len16; + __be32 val; + __be32 halt_pkd; +}; + +#define S_FW_RESET_CMD_HALT 31 +#define M_FW_RESET_CMD_HALT 0x1 +#define V_FW_RESET_CMD_HALT(x) ((x) << S_FW_RESET_CMD_HALT) +#define G_FW_RESET_CMD_HALT(x) \ + (((x) >> S_FW_RESET_CMD_HALT) & M_FW_RESET_CMD_HALT) +#define F_FW_RESET_CMD_HALT V_FW_RESET_CMD_HALT(1U) + +enum { + FW_HELLO_CMD_STAGE_OS = 0, + FW_HELLO_CMD_STAGE_PREOS0 = 1, + FW_HELLO_CMD_STAGE_PREOS1 = 2, + FW_HELLO_CMD_STAGE_POSTOS = 3, +}; + +struct fw_hello_cmd { + __be32 op_to_write; + __be32 retval_len16; + __be32 err_to_clearinit; + __be32 fwrev; +}; + +#define S_FW_HELLO_CMD_ERR 31 +#define M_FW_HELLO_CMD_ERR 0x1 +#define V_FW_HELLO_CMD_ERR(x) ((x) << S_FW_HELLO_CMD_ERR) +#define G_FW_HELLO_CMD_ERR(x) \ + (((x) >> S_FW_HELLO_CMD_ERR) & M_FW_HELLO_CMD_ERR) +#define F_FW_HELLO_CMD_ERR V_FW_HELLO_CMD_ERR(1U) + +#define S_FW_HELLO_CMD_INIT 30 +#define M_FW_HELLO_CMD_INIT 0x1 +#define V_FW_HELLO_CMD_INIT(x) ((x) << S_FW_HELLO_CMD_INIT) +#define G_FW_HELLO_CMD_INIT(x) \ + (((x) >> S_FW_HELLO_CMD_INIT) & M_FW_HELLO_CMD_INIT) +#define F_FW_HELLO_CMD_INIT V_FW_HELLO_CMD_INIT(1U) + +#define S_FW_HELLO_CMD_MASTERDIS 29 +#define M_FW_HELLO_CMD_MASTERDIS 0x1 +#define V_FW_HELLO_CMD_MASTERDIS(x) ((x) << S_FW_HELLO_CMD_MASTERDIS) +#define G_FW_HELLO_CMD_MASTERDIS(x) \ + (((x) >> S_FW_HELLO_CMD_MASTERDIS) & M_FW_HELLO_CMD_MASTERDIS) +#define F_FW_HELLO_CMD_MASTERDIS V_FW_HELLO_CMD_MASTERDIS(1U) + +#define S_FW_HELLO_CMD_MASTERFORCE 28 +#define M_FW_HELLO_CMD_MASTERFORCE 0x1 +#define V_FW_HELLO_CMD_MASTERFORCE(x) ((x) << S_FW_HELLO_CMD_MASTERFORCE) +#define G_FW_HELLO_CMD_MASTERFORCE(x) \ + (((x) >> S_FW_HELLO_CMD_MASTERFORCE) & M_FW_HELLO_CMD_MASTERFORCE) +#define F_FW_HELLO_CMD_MASTERFORCE V_FW_HELLO_CMD_MASTERFORCE(1U) + +#define S_FW_HELLO_CMD_MBMASTER 24 +#define M_FW_HELLO_CMD_MBMASTER 0xf +#define V_FW_HELLO_CMD_MBMASTER(x) ((x) << S_FW_HELLO_CMD_MBMASTER) +#define G_FW_HELLO_CMD_MBMASTER(x) \ + (((x) >> S_FW_HELLO_CMD_MBMASTER) & M_FW_HELLO_CMD_MBMASTER) + +#define S_FW_HELLO_CMD_MBASYNCNOTINT 23 +#define M_FW_HELLO_CMD_MBASYNCNOTINT 0x1 +#define V_FW_HELLO_CMD_MBASYNCNOTINT(x) ((x) << S_FW_HELLO_CMD_MBASYNCNOTINT) +#define G_FW_HELLO_CMD_MBASYNCNOTINT(x) \ + (((x) >> S_FW_HELLO_CMD_MBASYNCNOTINT) & M_FW_HELLO_CMD_MBASYNCNOTINT) +#define F_FW_HELLO_CMD_MBASYNCNOTINT V_FW_HELLO_CMD_MBASYNCNOTINT(1U) + +#define S_FW_HELLO_CMD_MBASYNCNOT 20 +#define M_FW_HELLO_CMD_MBASYNCNOT 0x7 +#define V_FW_HELLO_CMD_MBASYNCNOT(x) ((x) << S_FW_HELLO_CMD_MBASYNCNOT) +#define G_FW_HELLO_CMD_MBASYNCNOT(x) \ + (((x) >> S_FW_HELLO_CMD_MBASYNCNOT) & M_FW_HELLO_CMD_MBASYNCNOT) + +#define S_FW_HELLO_CMD_STAGE 17 +#define M_FW_HELLO_CMD_STAGE 0x7 +#define V_FW_HELLO_CMD_STAGE(x) ((x) << S_FW_HELLO_CMD_STAGE) +#define G_FW_HELLO_CMD_STAGE(x) \ + (((x) >> S_FW_HELLO_CMD_STAGE) & M_FW_HELLO_CMD_STAGE) + +#define S_FW_HELLO_CMD_CLEARINIT 16 +#define M_FW_HELLO_CMD_CLEARINIT 0x1 +#define V_FW_HELLO_CMD_CLEARINIT(x) ((x) << S_FW_HELLO_CMD_CLEARINIT) +#define G_FW_HELLO_CMD_CLEARINIT(x) \ + (((x) >> S_FW_HELLO_CMD_CLEARINIT) & M_FW_HELLO_CMD_CLEARINIT) +#define F_FW_HELLO_CMD_CLEARINIT V_FW_HELLO_CMD_CLEARINIT(1U) + +struct fw_bye_cmd { + __be32 op_to_write; + __be32 retval_len16; + __be64 r3; +}; + +struct fw_initialize_cmd { + __be32 op_to_write; + __be32 retval_len16; + __be64 r3; +}; + +enum fw_caps_config_hm { + FW_CAPS_CONFIG_HM_PCIE = 0x00000001, + FW_CAPS_CONFIG_HM_PL = 0x00000002, + FW_CAPS_CONFIG_HM_SGE = 0x00000004, + FW_CAPS_CONFIG_HM_CIM = 0x00000008, + FW_CAPS_CONFIG_HM_ULPTX = 0x00000010, + FW_CAPS_CONFIG_HM_TP = 0x00000020, + FW_CAPS_CONFIG_HM_ULPRX = 0x00000040, + FW_CAPS_CONFIG_HM_PMRX = 0x00000080, + FW_CAPS_CONFIG_HM_PMTX = 0x00000100, + FW_CAPS_CONFIG_HM_MC = 0x00000200, + FW_CAPS_CONFIG_HM_LE = 0x00000400, + FW_CAPS_CONFIG_HM_MPS = 0x00000800, + FW_CAPS_CONFIG_HM_XGMAC = 0x00001000, + FW_CAPS_CONFIG_HM_CPLSWITCH = 0x00002000, + FW_CAPS_CONFIG_HM_T4DBG = 0x00004000, + FW_CAPS_CONFIG_HM_MI = 0x00008000, + FW_CAPS_CONFIG_HM_I2CM = 0x00010000, + FW_CAPS_CONFIG_HM_NCSI = 0x00020000, + FW_CAPS_CONFIG_HM_SMB = 0x00040000, + FW_CAPS_CONFIG_HM_MA = 0x00080000, + FW_CAPS_CONFIG_HM_EDRAM = 0x00100000, + FW_CAPS_CONFIG_HM_PMU = 0x00200000, + FW_CAPS_CONFIG_HM_UART = 0x00400000, + FW_CAPS_CONFIG_HM_SF = 0x00800000, +}; + +/* + * The VF Register Map. + * + * The Scatter Gather Engine (SGE), Multiport Support module (MPS), PIO Local + * bus module (PL) and CPU Interface Module (CIM) components are mapped via + * the Slice to Module Map Table (see below) in the Physical Function Register + * Map. The Mail Box Data (MBDATA) range is mapped via the PCI-E Mailbox Base + * and Offset registers in the PF Register Map. The MBDATA base address is + * quite constrained as it determines the Mailbox Data addresses for both PFs + * and VFs, and therefore must fit in both the VF and PF Register Maps without + * overlapping other registers. + */ +#define FW_T4VF_SGE_BASE_ADDR 0x0000 +#define FW_T4VF_MPS_BASE_ADDR 0x0100 +#define FW_T4VF_PL_BASE_ADDR 0x0200 +#define FW_T4VF_MBDATA_BASE_ADDR 0x0240 +#define FW_T4VF_CIM_BASE_ADDR 0x0300 + +#define FW_T4VF_REGMAP_START 0x0000 +#define FW_T4VF_REGMAP_SIZE 0x0400 + +enum fw_caps_config_nbm { + FW_CAPS_CONFIG_NBM_IPMI = 0x00000001, + FW_CAPS_CONFIG_NBM_NCSI = 0x00000002, +}; + +enum fw_caps_config_link { + FW_CAPS_CONFIG_LINK_PPP = 0x00000001, + FW_CAPS_CONFIG_LINK_QFC = 0x00000002, + FW_CAPS_CONFIG_LINK_DCBX = 0x00000004, +}; + +enum fw_caps_config_switch { + FW_CAPS_CONFIG_SWITCH_INGRESS = 0x00000001, + FW_CAPS_CONFIG_SWITCH_EGRESS = 0x00000002, +}; + +enum fw_caps_config_nic { + FW_CAPS_CONFIG_NIC = 0x00000001, + FW_CAPS_CONFIG_NIC_VM = 0x00000002, + FW_CAPS_CONFIG_NIC_IDS = 0x00000004, + FW_CAPS_CONFIG_NIC_UM = 0x00000008, + FW_CAPS_CONFIG_NIC_UM_ISGL = 0x00000010, + FW_CAPS_CONFIG_NIC_HASHFILTER = 0x00000020, + FW_CAPS_CONFIG_NIC_ETHOFLD = 0x00000040, +}; + +enum fw_caps_config_toe { + FW_CAPS_CONFIG_TOE = 0x00000001, +}; + +enum fw_caps_config_rdma { + FW_CAPS_CONFIG_RDMA_RDDP = 0x00000001, + FW_CAPS_CONFIG_RDMA_RDMAC = 0x00000002, +}; + +enum fw_caps_config_iscsi { + FW_CAPS_CONFIG_ISCSI_INITIATOR_PDU = 0x00000001, + FW_CAPS_CONFIG_ISCSI_TARGET_PDU = 0x00000002, + FW_CAPS_CONFIG_ISCSI_INITIATOR_CNXOFLD = 0x00000004, + FW_CAPS_CONFIG_ISCSI_TARGET_CNXOFLD = 0x00000008, + FW_CAPS_CONFIG_ISCSI_INITIATOR_SSNOFLD = 0x00000010, + FW_CAPS_CONFIG_ISCSI_TARGET_SSNOFLD = 0x00000020, +}; + +enum fw_caps_config_fcoe { + FW_CAPS_CONFIG_FCOE_INITIATOR = 0x00000001, + FW_CAPS_CONFIG_FCOE_TARGET = 0x00000002, + FW_CAPS_CONFIG_FCOE_CTRL_OFLD = 0x00000004, + FW_CAPS_CONFIG_POFCOE_INITIATOR = 0x00000008, + FW_CAPS_CONFIG_POFCOE_TARGET = 0x00000010, +}; + +enum fw_memtype_cf { + FW_MEMTYPE_CF_EDC0 = FW_MEMTYPE_EDC0, + FW_MEMTYPE_CF_EDC1 = FW_MEMTYPE_EDC1, + FW_MEMTYPE_CF_EXTMEM = FW_MEMTYPE_EXTMEM, + FW_MEMTYPE_CF_FLASH = FW_MEMTYPE_FLASH, + FW_MEMTYPE_CF_INTERNAL = FW_MEMTYPE_INTERNAL, + FW_MEMTYPE_CF_EXTMEM1 = FW_MEMTYPE_EXTMEM1, +}; + +struct fw_caps_config_cmd { + __be32 op_to_write; + __be32 cfvalid_to_len16; + __be32 r2; + __be32 hwmbitmap; + __be16 nbmcaps; + __be16 linkcaps; + __be16 switchcaps; + __be16 r3; + __be16 niccaps; + __be16 toecaps; + __be16 rdmacaps; + __be16 r4; + __be16 iscsicaps; + __be16 fcoecaps; + __be32 cfcsum; + __be32 finiver; + __be32 finicsum; +}; + +#define S_FW_CAPS_CONFIG_CMD_CFVALID 27 +#define M_FW_CAPS_CONFIG_CMD_CFVALID 0x1 +#define V_FW_CAPS_CONFIG_CMD_CFVALID(x) ((x) << S_FW_CAPS_CONFIG_CMD_CFVALID) +#define G_FW_CAPS_CONFIG_CMD_CFVALID(x) \ + (((x) >> S_FW_CAPS_CONFIG_CMD_CFVALID) & M_FW_CAPS_CONFIG_CMD_CFVALID) +#define F_FW_CAPS_CONFIG_CMD_CFVALID V_FW_CAPS_CONFIG_CMD_CFVALID(1U) + +#define S_FW_CAPS_CONFIG_CMD_MEMTYPE_CF 24 +#define M_FW_CAPS_CONFIG_CMD_MEMTYPE_CF 0x7 +#define V_FW_CAPS_CONFIG_CMD_MEMTYPE_CF(x) \ + ((x) << S_FW_CAPS_CONFIG_CMD_MEMTYPE_CF) +#define G_FW_CAPS_CONFIG_CMD_MEMTYPE_CF(x) \ + (((x) >> S_FW_CAPS_CONFIG_CMD_MEMTYPE_CF) & \ + M_FW_CAPS_CONFIG_CMD_MEMTYPE_CF) + +#define S_FW_CAPS_CONFIG_CMD_MEMADDR64K_CF 16 +#define M_FW_CAPS_CONFIG_CMD_MEMADDR64K_CF 0xff +#define V_FW_CAPS_CONFIG_CMD_MEMADDR64K_CF(x) \ + ((x) << S_FW_CAPS_CONFIG_CMD_MEMADDR64K_CF) +#define G_FW_CAPS_CONFIG_CMD_MEMADDR64K_CF(x) \ + (((x) >> S_FW_CAPS_CONFIG_CMD_MEMADDR64K_CF) & \ + M_FW_CAPS_CONFIG_CMD_MEMADDR64K_CF) + +/* + * params command mnemonics + */ +enum fw_params_mnem { + FW_PARAMS_MNEM_DEV = 1, /* device params */ + FW_PARAMS_MNEM_PFVF = 2, /* function params */ + FW_PARAMS_MNEM_REG = 3, /* limited register access */ + FW_PARAMS_MNEM_DMAQ = 4, /* dma queue params */ + FW_PARAMS_MNEM_LAST +}; + +/* + * device parameters + */ +enum fw_params_param_dev { + FW_PARAMS_PARAM_DEV_CCLK = 0x00, /* chip core clock in khz */ + FW_PARAMS_PARAM_DEV_PORTVEC = 0x01, /* the port vector */ + FW_PARAMS_PARAM_DEV_NTID = 0x02, /* reads the number of TIDs + * allocated by the device's + * Lookup Engine + */ + FW_PARAMS_PARAM_DEV_FLOWC_BUFFIFO_SZ = 0x03, + FW_PARAMS_PARAM_DEV_INTFVER_NIC = 0x04, + FW_PARAMS_PARAM_DEV_INTFVER_VNIC = 0x05, + FW_PARAMS_PARAM_DEV_INTFVER_OFLD = 0x06, + FW_PARAMS_PARAM_DEV_INTFVER_RI = 0x07, + FW_PARAMS_PARAM_DEV_INTFVER_ISCSIPDU = 0x08, + FW_PARAMS_PARAM_DEV_INTFVER_ISCSI = 0x09, + FW_PARAMS_PARAM_DEV_INTFVER_FCOE = 0x0A, + FW_PARAMS_PARAM_DEV_FWREV = 0x0B, + FW_PARAMS_PARAM_DEV_TPREV = 0x0C, + FW_PARAMS_PARAM_DEV_CF = 0x0D, + FW_PARAMS_PARAM_DEV_BYPASS = 0x0E, + FW_PARAMS_PARAM_DEV_PHYFW = 0x0F, + FW_PARAMS_PARAM_DEV_LOAD = 0x10, + FW_PARAMS_PARAM_DEV_DIAG = 0x11, + FW_PARAMS_PARAM_DEV_UCLK = 0x12, /* uP clock in khz */ + FW_PARAMS_PARAM_DEV_MAXORDIRD_QP = 0x13, /* max supported QP IRD/ORD + */ + FW_PARAMS_PARAM_DEV_MAXIRD_ADAPTER= 0x14,/* max supported ADAPTER IRD + */ + FW_PARAMS_PARAM_DEV_INTFVER_FCOEPDU = 0x15, + FW_PARAMS_PARAM_DEV_MCINIT = 0x16, + FW_PARAMS_PARAM_DEV_ULPTX_MEMWRITE_DSGL = 0x17, +}; + +/* + * physical and virtual function parameters + */ +enum fw_params_param_pfvf { + FW_PARAMS_PARAM_PFVF_RWXCAPS = 0x00, + FW_PARAMS_PARAM_PFVF_ROUTE_START = 0x01, + FW_PARAMS_PARAM_PFVF_ROUTE_END = 0x02, + FW_PARAMS_PARAM_PFVF_CLIP_START = 0x03, + FW_PARAMS_PARAM_PFVF_CLIP_END = 0x04, + FW_PARAMS_PARAM_PFVF_FILTER_START = 0x05, + FW_PARAMS_PARAM_PFVF_FILTER_END = 0x06, + FW_PARAMS_PARAM_PFVF_SERVER_START = 0x07, + FW_PARAMS_PARAM_PFVF_SERVER_END = 0x08, + FW_PARAMS_PARAM_PFVF_TDDP_START = 0x09, + FW_PARAMS_PARAM_PFVF_TDDP_END = 0x0A, + FW_PARAMS_PARAM_PFVF_ISCSI_START = 0x0B, + FW_PARAMS_PARAM_PFVF_ISCSI_END = 0x0C, + FW_PARAMS_PARAM_PFVF_STAG_START = 0x0D, + FW_PARAMS_PARAM_PFVF_STAG_END = 0x0E, + FW_PARAMS_PARAM_PFVF_RQ_START = 0x1F, + FW_PARAMS_PARAM_PFVF_RQ_END = 0x10, + FW_PARAMS_PARAM_PFVF_PBL_START = 0x11, + FW_PARAMS_PARAM_PFVF_PBL_END = 0x12, + FW_PARAMS_PARAM_PFVF_L2T_START = 0x13, + FW_PARAMS_PARAM_PFVF_L2T_END = 0x14, + FW_PARAMS_PARAM_PFVF_SQRQ_START = 0x15, + FW_PARAMS_PARAM_PFVF_SQRQ_END = 0x16, + FW_PARAMS_PARAM_PFVF_CQ_START = 0x17, + FW_PARAMS_PARAM_PFVF_CQ_END = 0x18, + FW_PARAMS_PARAM_PFVF_SCHEDCLASS_ETH = 0x20, + FW_PARAMS_PARAM_PFVF_VIID = 0x24, + FW_PARAMS_PARAM_PFVF_CPMASK = 0x25, + FW_PARAMS_PARAM_PFVF_OCQ_START = 0x26, + FW_PARAMS_PARAM_PFVF_OCQ_END = 0x27, + FW_PARAMS_PARAM_PFVF_CONM_MAP = 0x28, + FW_PARAMS_PARAM_PFVF_IQFLINT_START = 0x29, + FW_PARAMS_PARAM_PFVF_IQFLINT_END = 0x2A, + FW_PARAMS_PARAM_PFVF_EQ_START = 0x2B, + FW_PARAMS_PARAM_PFVF_EQ_END = 0x2C, + FW_PARAMS_PARAM_PFVF_ACTIVE_FILTER_START = 0x2D, + FW_PARAMS_PARAM_PFVF_ACTIVE_FILTER_END = 0x2E, + FW_PARAMS_PARAM_PFVF_ETHOFLD_START = 0x2F, + FW_PARAMS_PARAM_PFVF_ETHOFLD_END = 0x30, + FW_PARAMS_PARAM_PFVF_CPLFW4MSG_ENCAP = 0x31 +}; + +/* + * dma queue parameters + */ +enum fw_params_param_dmaq { + FW_PARAMS_PARAM_DMAQ_IQ_DCAEN_DCACPU = 0x00, + FW_PARAMS_PARAM_DMAQ_IQ_INTCNTTHRESH = 0x01, + FW_PARAMS_PARAM_DMAQ_IQ_INTIDX = 0x02, + FW_PARAMS_PARAM_DMAQ_EQ_CMPLIQID_MNGT = 0x10, + FW_PARAMS_PARAM_DMAQ_EQ_CMPLIQID_CTRL = 0x11, + FW_PARAMS_PARAM_DMAQ_EQ_SCHEDCLASS_ETH = 0x12, + FW_PARAMS_PARAM_DMAQ_EQ_DCBPRIO_ETH = 0x13, + FW_PARAMS_PARAM_DMAQ_CONM_CTXT = 0x20, +}; + +/* + * dev bypass parameters; actions and modes + */ +enum fw_params_param_dev_bypass { + + /* actions + */ + FW_PARAMS_PARAM_DEV_BYPASS_PFAIL = 0x00, + FW_PARAMS_PARAM_DEV_BYPASS_CURRENT = 0x01, + + /* modes + */ + FW_PARAMS_PARAM_DEV_BYPASS_NORMAL = 0x00, + FW_PARAMS_PARAM_DEV_BYPASS_DROP = 0x1, + FW_PARAMS_PARAM_DEV_BYPASS_BYPASS = 0x2, +}; + +enum fw_params_phyfw_actions { + FW_PARAMS_PARAM_PHYFW_DOWNLOAD = 0x00, + FW_PARAMS_PARAM_PHYFW_VERSION = 0x01, +}; + +enum fw_params_param_dev_diag { + FW_PARAM_DEV_DIAG_TMP = 0x00, + FW_PARAM_DEV_DIAG_VDD = 0x01, +}; + +#define S_FW_PARAMS_MNEM 24 +#define M_FW_PARAMS_MNEM 0xff +#define V_FW_PARAMS_MNEM(x) ((x) << S_FW_PARAMS_MNEM) +#define G_FW_PARAMS_MNEM(x) \ + (((x) >> S_FW_PARAMS_MNEM) & M_FW_PARAMS_MNEM) + +#define S_FW_PARAMS_PARAM_X 16 +#define M_FW_PARAMS_PARAM_X 0xff +#define V_FW_PARAMS_PARAM_X(x) ((x) << S_FW_PARAMS_PARAM_X) +#define G_FW_PARAMS_PARAM_X(x) \ + (((x) >> S_FW_PARAMS_PARAM_X) & M_FW_PARAMS_PARAM_X) + +#define S_FW_PARAMS_PARAM_Y 8 +#define M_FW_PARAMS_PARAM_Y 0xff +#define V_FW_PARAMS_PARAM_Y(x) ((x) << S_FW_PARAMS_PARAM_Y) +#define G_FW_PARAMS_PARAM_Y(x) \ + (((x) >> S_FW_PARAMS_PARAM_Y) & M_FW_PARAMS_PARAM_Y) + +#define S_FW_PARAMS_PARAM_Z 0 +#define M_FW_PARAMS_PARAM_Z 0xff +#define V_FW_PARAMS_PARAM_Z(x) ((x) << S_FW_PARAMS_PARAM_Z) +#define G_FW_PARAMS_PARAM_Z(x) \ + (((x) >> S_FW_PARAMS_PARAM_Z) & M_FW_PARAMS_PARAM_Z) + +#define S_FW_PARAMS_PARAM_XYZ 0 +#define M_FW_PARAMS_PARAM_XYZ 0xffffff +#define V_FW_PARAMS_PARAM_XYZ(x) ((x) << S_FW_PARAMS_PARAM_XYZ) +#define G_FW_PARAMS_PARAM_XYZ(x) \ + (((x) >> S_FW_PARAMS_PARAM_XYZ) & M_FW_PARAMS_PARAM_XYZ) + +#define S_FW_PARAMS_PARAM_YZ 0 +#define M_FW_PARAMS_PARAM_YZ 0xffff +#define V_FW_PARAMS_PARAM_YZ(x) ((x) << S_FW_PARAMS_PARAM_YZ) +#define G_FW_PARAMS_PARAM_YZ(x) \ + (((x) >> S_FW_PARAMS_PARAM_YZ) & M_FW_PARAMS_PARAM_YZ) + +struct fw_params_cmd { + __be32 op_to_vfn; + __be32 retval_len16; + struct fw_params_param { + __be32 mnem; + __be32 val; + } param[7]; +}; + +#define S_FW_PARAMS_CMD_PFN 8 +#define M_FW_PARAMS_CMD_PFN 0x7 +#define V_FW_PARAMS_CMD_PFN(x) ((x) << S_FW_PARAMS_CMD_PFN) +#define G_FW_PARAMS_CMD_PFN(x) \ + (((x) >> S_FW_PARAMS_CMD_PFN) & M_FW_PARAMS_CMD_PFN) + +#define S_FW_PARAMS_CMD_VFN 0 +#define M_FW_PARAMS_CMD_VFN 0xff +#define V_FW_PARAMS_CMD_VFN(x) ((x) << S_FW_PARAMS_CMD_VFN) +#define G_FW_PARAMS_CMD_VFN(x) \ + (((x) >> S_FW_PARAMS_CMD_VFN) & M_FW_PARAMS_CMD_VFN) + +struct fw_pfvf_cmd { + __be32 op_to_vfn; + __be32 retval_len16; + __be32 niqflint_niq; + __be32 type_to_neq; + __be32 tc_to_nexactf; + __be32 r_caps_to_nethctrl; + __be16 nricq; + __be16 nriqp; + __be32 r4; +}; + +#define S_FW_PFVF_CMD_PFN 8 +#define M_FW_PFVF_CMD_PFN 0x7 +#define V_FW_PFVF_CMD_PFN(x) ((x) << S_FW_PFVF_CMD_PFN) +#define G_FW_PFVF_CMD_PFN(x) \ + (((x) >> S_FW_PFVF_CMD_PFN) & M_FW_PFVF_CMD_PFN) + +#define S_FW_PFVF_CMD_VFN 0 +#define M_FW_PFVF_CMD_VFN 0xff +#define V_FW_PFVF_CMD_VFN(x) ((x) << S_FW_PFVF_CMD_VFN) +#define G_FW_PFVF_CMD_VFN(x) \ + (((x) >> S_FW_PFVF_CMD_VFN) & M_FW_PFVF_CMD_VFN) + +#define S_FW_PFVF_CMD_NIQFLINT 20 +#define M_FW_PFVF_CMD_NIQFLINT 0xfff +#define V_FW_PFVF_CMD_NIQFLINT(x) ((x) << S_FW_PFVF_CMD_NIQFLINT) +#define G_FW_PFVF_CMD_NIQFLINT(x) \ + (((x) >> S_FW_PFVF_CMD_NIQFLINT) & M_FW_PFVF_CMD_NIQFLINT) + +#define S_FW_PFVF_CMD_NIQ 0 +#define M_FW_PFVF_CMD_NIQ 0xfffff +#define V_FW_PFVF_CMD_NIQ(x) ((x) << S_FW_PFVF_CMD_NIQ) +#define G_FW_PFVF_CMD_NIQ(x) \ + (((x) >> S_FW_PFVF_CMD_NIQ) & M_FW_PFVF_CMD_NIQ) + +#define S_FW_PFVF_CMD_TYPE 31 +#define M_FW_PFVF_CMD_TYPE 0x1 +#define V_FW_PFVF_CMD_TYPE(x) ((x) << S_FW_PFVF_CMD_TYPE) +#define G_FW_PFVF_CMD_TYPE(x) \ + (((x) >> S_FW_PFVF_CMD_TYPE) & M_FW_PFVF_CMD_TYPE) +#define F_FW_PFVF_CMD_TYPE V_FW_PFVF_CMD_TYPE(1U) + +#define S_FW_PFVF_CMD_CMASK 24 +#define M_FW_PFVF_CMD_CMASK 0xf +#define V_FW_PFVF_CMD_CMASK(x) ((x) << S_FW_PFVF_CMD_CMASK) +#define G_FW_PFVF_CMD_CMASK(x) \ + (((x) >> S_FW_PFVF_CMD_CMASK) & M_FW_PFVF_CMD_CMASK) + +#define S_FW_PFVF_CMD_PMASK 20 +#define M_FW_PFVF_CMD_PMASK 0xf +#define V_FW_PFVF_CMD_PMASK(x) ((x) << S_FW_PFVF_CMD_PMASK) +#define G_FW_PFVF_CMD_PMASK(x) \ + (((x) >> S_FW_PFVF_CMD_PMASK) & M_FW_PFVF_CMD_PMASK) + +#define S_FW_PFVF_CMD_NEQ 0 +#define M_FW_PFVF_CMD_NEQ 0xfffff +#define V_FW_PFVF_CMD_NEQ(x) ((x) << S_FW_PFVF_CMD_NEQ) +#define G_FW_PFVF_CMD_NEQ(x) \ + (((x) >> S_FW_PFVF_CMD_NEQ) & M_FW_PFVF_CMD_NEQ) + +#define S_FW_PFVF_CMD_TC 24 +#define M_FW_PFVF_CMD_TC 0xff +#define V_FW_PFVF_CMD_TC(x) ((x) << S_FW_PFVF_CMD_TC) +#define G_FW_PFVF_CMD_TC(x) (((x) >> S_FW_PFVF_CMD_TC) & M_FW_PFVF_CMD_TC) + +#define S_FW_PFVF_CMD_NVI 16 +#define M_FW_PFVF_CMD_NVI 0xff +#define V_FW_PFVF_CMD_NVI(x) ((x) << S_FW_PFVF_CMD_NVI) +#define G_FW_PFVF_CMD_NVI(x) \ + (((x) >> S_FW_PFVF_CMD_NVI) & M_FW_PFVF_CMD_NVI) + +#define S_FW_PFVF_CMD_NEXACTF 0 +#define M_FW_PFVF_CMD_NEXACTF 0xffff +#define V_FW_PFVF_CMD_NEXACTF(x) ((x) << S_FW_PFVF_CMD_NEXACTF) +#define G_FW_PFVF_CMD_NEXACTF(x) \ + (((x) >> S_FW_PFVF_CMD_NEXACTF) & M_FW_PFVF_CMD_NEXACTF) + +#define S_FW_PFVF_CMD_R_CAPS 24 +#define M_FW_PFVF_CMD_R_CAPS 0xff +#define V_FW_PFVF_CMD_R_CAPS(x) ((x) << S_FW_PFVF_CMD_R_CAPS) +#define G_FW_PFVF_CMD_R_CAPS(x) \ + (((x) >> S_FW_PFVF_CMD_R_CAPS) & M_FW_PFVF_CMD_R_CAPS) + +#define S_FW_PFVF_CMD_WX_CAPS 16 +#define M_FW_PFVF_CMD_WX_CAPS 0xff +#define V_FW_PFVF_CMD_WX_CAPS(x) ((x) << S_FW_PFVF_CMD_WX_CAPS) +#define G_FW_PFVF_CMD_WX_CAPS(x) \ + (((x) >> S_FW_PFVF_CMD_WX_CAPS) & M_FW_PFVF_CMD_WX_CAPS) + +#define S_FW_PFVF_CMD_NETHCTRL 0 +#define M_FW_PFVF_CMD_NETHCTRL 0xffff +#define V_FW_PFVF_CMD_NETHCTRL(x) ((x) << S_FW_PFVF_CMD_NETHCTRL) +#define G_FW_PFVF_CMD_NETHCTRL(x) \ + (((x) >> S_FW_PFVF_CMD_NETHCTRL) & M_FW_PFVF_CMD_NETHCTRL) + +/* + * ingress queue type; the first 1K ingress queues can have associated 0, + * 1 or 2 free lists and an interrupt, all other ingress queues lack these + * capabilities + */ +enum fw_iq_type { + FW_IQ_TYPE_FL_INT_CAP, + FW_IQ_TYPE_NO_FL_INT_CAP +}; + +struct fw_iq_cmd { + __be32 op_to_vfn; + __be32 alloc_to_len16; + __be16 physiqid; + __be16 iqid; + __be16 fl0id; + __be16 fl1id; + __be32 type_to_iqandstindex; + __be16 iqdroprss_to_iqesize; + __be16 iqsize; + __be64 iqaddr; + __be32 iqns_to_fl0congen; + __be16 fl0dcaen_to_fl0cidxfthresh; + __be16 fl0size; + __be64 fl0addr; + __be32 fl1cngchmap_to_fl1congen; + __be16 fl1dcaen_to_fl1cidxfthresh; + __be16 fl1size; + __be64 fl1addr; +}; + +#define S_FW_IQ_CMD_PFN 8 +#define M_FW_IQ_CMD_PFN 0x7 +#define V_FW_IQ_CMD_PFN(x) ((x) << S_FW_IQ_CMD_PFN) +#define G_FW_IQ_CMD_PFN(x) (((x) >> S_FW_IQ_CMD_PFN) & M_FW_IQ_CMD_PFN) + +#define S_FW_IQ_CMD_VFN 0 +#define M_FW_IQ_CMD_VFN 0xff +#define V_FW_IQ_CMD_VFN(x) ((x) << S_FW_IQ_CMD_VFN) +#define G_FW_IQ_CMD_VFN(x) (((x) >> S_FW_IQ_CMD_VFN) & M_FW_IQ_CMD_VFN) + +#define S_FW_IQ_CMD_ALLOC 31 +#define M_FW_IQ_CMD_ALLOC 0x1 +#define V_FW_IQ_CMD_ALLOC(x) ((x) << S_FW_IQ_CMD_ALLOC) +#define G_FW_IQ_CMD_ALLOC(x) \ + (((x) >> S_FW_IQ_CMD_ALLOC) & M_FW_IQ_CMD_ALLOC) +#define F_FW_IQ_CMD_ALLOC V_FW_IQ_CMD_ALLOC(1U) + +#define S_FW_IQ_CMD_FREE 30 +#define M_FW_IQ_CMD_FREE 0x1 +#define V_FW_IQ_CMD_FREE(x) ((x) << S_FW_IQ_CMD_FREE) +#define G_FW_IQ_CMD_FREE(x) (((x) >> S_FW_IQ_CMD_FREE) & M_FW_IQ_CMD_FREE) +#define F_FW_IQ_CMD_FREE V_FW_IQ_CMD_FREE(1U) + +#define S_FW_IQ_CMD_MODIFY 29 +#define M_FW_IQ_CMD_MODIFY 0x1 +#define V_FW_IQ_CMD_MODIFY(x) ((x) << S_FW_IQ_CMD_MODIFY) +#define G_FW_IQ_CMD_MODIFY(x) \ + (((x) >> S_FW_IQ_CMD_MODIFY) & M_FW_IQ_CMD_MODIFY) +#define F_FW_IQ_CMD_MODIFY V_FW_IQ_CMD_MODIFY(1U) + +#define S_FW_IQ_CMD_IQSTART 28 +#define M_FW_IQ_CMD_IQSTART 0x1 +#define V_FW_IQ_CMD_IQSTART(x) ((x) << S_FW_IQ_CMD_IQSTART) +#define G_FW_IQ_CMD_IQSTART(x) \ + (((x) >> S_FW_IQ_CMD_IQSTART) & M_FW_IQ_CMD_IQSTART) +#define F_FW_IQ_CMD_IQSTART V_FW_IQ_CMD_IQSTART(1U) + +#define S_FW_IQ_CMD_IQSTOP 27 +#define M_FW_IQ_CMD_IQSTOP 0x1 +#define V_FW_IQ_CMD_IQSTOP(x) ((x) << S_FW_IQ_CMD_IQSTOP) +#define G_FW_IQ_CMD_IQSTOP(x) \ + (((x) >> S_FW_IQ_CMD_IQSTOP) & M_FW_IQ_CMD_IQSTOP) +#define F_FW_IQ_CMD_IQSTOP V_FW_IQ_CMD_IQSTOP(1U) + +#define S_FW_IQ_CMD_TYPE 29 +#define M_FW_IQ_CMD_TYPE 0x7 +#define V_FW_IQ_CMD_TYPE(x) ((x) << S_FW_IQ_CMD_TYPE) +#define G_FW_IQ_CMD_TYPE(x) (((x) >> S_FW_IQ_CMD_TYPE) & M_FW_IQ_CMD_TYPE) + +#define S_FW_IQ_CMD_IQASYNCH 28 +#define M_FW_IQ_CMD_IQASYNCH 0x1 +#define V_FW_IQ_CMD_IQASYNCH(x) ((x) << S_FW_IQ_CMD_IQASYNCH) +#define G_FW_IQ_CMD_IQASYNCH(x) \ + (((x) >> S_FW_IQ_CMD_IQASYNCH) & M_FW_IQ_CMD_IQASYNCH) +#define F_FW_IQ_CMD_IQASYNCH V_FW_IQ_CMD_IQASYNCH(1U) + +#define S_FW_IQ_CMD_VIID 16 +#define M_FW_IQ_CMD_VIID 0xfff +#define V_FW_IQ_CMD_VIID(x) ((x) << S_FW_IQ_CMD_VIID) +#define G_FW_IQ_CMD_VIID(x) (((x) >> S_FW_IQ_CMD_VIID) & M_FW_IQ_CMD_VIID) + +#define S_FW_IQ_CMD_IQANDST 15 +#define M_FW_IQ_CMD_IQANDST 0x1 +#define V_FW_IQ_CMD_IQANDST(x) ((x) << S_FW_IQ_CMD_IQANDST) +#define G_FW_IQ_CMD_IQANDST(x) \ + (((x) >> S_FW_IQ_CMD_IQANDST) & M_FW_IQ_CMD_IQANDST) +#define F_FW_IQ_CMD_IQANDST V_FW_IQ_CMD_IQANDST(1U) + +#define S_FW_IQ_CMD_IQANUS 14 +#define M_FW_IQ_CMD_IQANUS 0x1 +#define V_FW_IQ_CMD_IQANUS(x) ((x) << S_FW_IQ_CMD_IQANUS) +#define G_FW_IQ_CMD_IQANUS(x) \ + (((x) >> S_FW_IQ_CMD_IQANUS) & M_FW_IQ_CMD_IQANUS) +#define F_FW_IQ_CMD_IQANUS V_FW_IQ_CMD_IQANUS(1U) + +#define S_FW_IQ_CMD_IQANUD 12 +#define M_FW_IQ_CMD_IQANUD 0x3 +#define V_FW_IQ_CMD_IQANUD(x) ((x) << S_FW_IQ_CMD_IQANUD) +#define G_FW_IQ_CMD_IQANUD(x) \ + (((x) >> S_FW_IQ_CMD_IQANUD) & M_FW_IQ_CMD_IQANUD) + +#define S_FW_IQ_CMD_IQANDSTINDEX 0 +#define M_FW_IQ_CMD_IQANDSTINDEX 0xfff +#define V_FW_IQ_CMD_IQANDSTINDEX(x) ((x) << S_FW_IQ_CMD_IQANDSTINDEX) +#define G_FW_IQ_CMD_IQANDSTINDEX(x) \ + (((x) >> S_FW_IQ_CMD_IQANDSTINDEX) & M_FW_IQ_CMD_IQANDSTINDEX) + +#define S_FW_IQ_CMD_IQDROPRSS 15 +#define M_FW_IQ_CMD_IQDROPRSS 0x1 +#define V_FW_IQ_CMD_IQDROPRSS(x) ((x) << S_FW_IQ_CMD_IQDROPRSS) +#define G_FW_IQ_CMD_IQDROPRSS(x) \ + (((x) >> S_FW_IQ_CMD_IQDROPRSS) & M_FW_IQ_CMD_IQDROPRSS) +#define F_FW_IQ_CMD_IQDROPRSS V_FW_IQ_CMD_IQDROPRSS(1U) + +#define S_FW_IQ_CMD_IQGTSMODE 14 +#define M_FW_IQ_CMD_IQGTSMODE 0x1 +#define V_FW_IQ_CMD_IQGTSMODE(x) ((x) << S_FW_IQ_CMD_IQGTSMODE) +#define G_FW_IQ_CMD_IQGTSMODE(x) \ + (((x) >> S_FW_IQ_CMD_IQGTSMODE) & M_FW_IQ_CMD_IQGTSMODE) +#define F_FW_IQ_CMD_IQGTSMODE V_FW_IQ_CMD_IQGTSMODE(1U) + +#define S_FW_IQ_CMD_IQPCIECH 12 +#define M_FW_IQ_CMD_IQPCIECH 0x3 +#define V_FW_IQ_CMD_IQPCIECH(x) ((x) << S_FW_IQ_CMD_IQPCIECH) +#define G_FW_IQ_CMD_IQPCIECH(x) \ + (((x) >> S_FW_IQ_CMD_IQPCIECH) & M_FW_IQ_CMD_IQPCIECH) + +#define S_FW_IQ_CMD_IQDCAEN 11 +#define M_FW_IQ_CMD_IQDCAEN 0x1 +#define V_FW_IQ_CMD_IQDCAEN(x) ((x) << S_FW_IQ_CMD_IQDCAEN) +#define G_FW_IQ_CMD_IQDCAEN(x) \ + (((x) >> S_FW_IQ_CMD_IQDCAEN) & M_FW_IQ_CMD_IQDCAEN) +#define F_FW_IQ_CMD_IQDCAEN V_FW_IQ_CMD_IQDCAEN(1U) + +#define S_FW_IQ_CMD_IQDCACPU 6 +#define M_FW_IQ_CMD_IQDCACPU 0x1f +#define V_FW_IQ_CMD_IQDCACPU(x) ((x) << S_FW_IQ_CMD_IQDCACPU) +#define G_FW_IQ_CMD_IQDCACPU(x) \ + (((x) >> S_FW_IQ_CMD_IQDCACPU) & M_FW_IQ_CMD_IQDCACPU) + +#define S_FW_IQ_CMD_IQINTCNTTHRESH 4 +#define M_FW_IQ_CMD_IQINTCNTTHRESH 0x3 +#define V_FW_IQ_CMD_IQINTCNTTHRESH(x) ((x) << S_FW_IQ_CMD_IQINTCNTTHRESH) +#define G_FW_IQ_CMD_IQINTCNTTHRESH(x) \ + (((x) >> S_FW_IQ_CMD_IQINTCNTTHRESH) & M_FW_IQ_CMD_IQINTCNTTHRESH) + +#define S_FW_IQ_CMD_IQO 3 +#define M_FW_IQ_CMD_IQO 0x1 +#define V_FW_IQ_CMD_IQO(x) ((x) << S_FW_IQ_CMD_IQO) +#define G_FW_IQ_CMD_IQO(x) (((x) >> S_FW_IQ_CMD_IQO) & M_FW_IQ_CMD_IQO) +#define F_FW_IQ_CMD_IQO V_FW_IQ_CMD_IQO(1U) + +#define S_FW_IQ_CMD_IQCPRIO 2 +#define M_FW_IQ_CMD_IQCPRIO 0x1 +#define V_FW_IQ_CMD_IQCPRIO(x) ((x) << S_FW_IQ_CMD_IQCPRIO) +#define G_FW_IQ_CMD_IQCPRIO(x) \ + (((x) >> S_FW_IQ_CMD_IQCPRIO) & M_FW_IQ_CMD_IQCPRIO) +#define F_FW_IQ_CMD_IQCPRIO V_FW_IQ_CMD_IQCPRIO(1U) + +#define S_FW_IQ_CMD_IQESIZE 0 +#define M_FW_IQ_CMD_IQESIZE 0x3 +#define V_FW_IQ_CMD_IQESIZE(x) ((x) << S_FW_IQ_CMD_IQESIZE) +#define G_FW_IQ_CMD_IQESIZE(x) \ + (((x) >> S_FW_IQ_CMD_IQESIZE) & M_FW_IQ_CMD_IQESIZE) + +#define S_FW_IQ_CMD_IQNS 31 +#define M_FW_IQ_CMD_IQNS 0x1 +#define V_FW_IQ_CMD_IQNS(x) ((x) << S_FW_IQ_CMD_IQNS) +#define G_FW_IQ_CMD_IQNS(x) (((x) >> S_FW_IQ_CMD_IQNS) & M_FW_IQ_CMD_IQNS) +#define F_FW_IQ_CMD_IQNS V_FW_IQ_CMD_IQNS(1U) + +#define S_FW_IQ_CMD_IQRO 30 +#define M_FW_IQ_CMD_IQRO 0x1 +#define V_FW_IQ_CMD_IQRO(x) ((x) << S_FW_IQ_CMD_IQRO) +#define G_FW_IQ_CMD_IQRO(x) (((x) >> S_FW_IQ_CMD_IQRO) & M_FW_IQ_CMD_IQRO) +#define F_FW_IQ_CMD_IQRO V_FW_IQ_CMD_IQRO(1U) + +#define S_FW_IQ_CMD_IQFLINTIQHSEN 28 +#define M_FW_IQ_CMD_IQFLINTIQHSEN 0x3 +#define V_FW_IQ_CMD_IQFLINTIQHSEN(x) ((x) << S_FW_IQ_CMD_IQFLINTIQHSEN) +#define G_FW_IQ_CMD_IQFLINTIQHSEN(x) \ + (((x) >> S_FW_IQ_CMD_IQFLINTIQHSEN) & M_FW_IQ_CMD_IQFLINTIQHSEN) + +#define S_FW_IQ_CMD_IQFLINTCONGEN 27 +#define M_FW_IQ_CMD_IQFLINTCONGEN 0x1 +#define V_FW_IQ_CMD_IQFLINTCONGEN(x) ((x) << S_FW_IQ_CMD_IQFLINTCONGEN) +#define G_FW_IQ_CMD_IQFLINTCONGEN(x) \ + (((x) >> S_FW_IQ_CMD_IQFLINTCONGEN) & M_FW_IQ_CMD_IQFLINTCONGEN) +#define F_FW_IQ_CMD_IQFLINTCONGEN V_FW_IQ_CMD_IQFLINTCONGEN(1U) + +#define S_FW_IQ_CMD_IQFLINTISCSIC 26 +#define M_FW_IQ_CMD_IQFLINTISCSIC 0x1 +#define V_FW_IQ_CMD_IQFLINTISCSIC(x) ((x) << S_FW_IQ_CMD_IQFLINTISCSIC) +#define G_FW_IQ_CMD_IQFLINTISCSIC(x) \ + (((x) >> S_FW_IQ_CMD_IQFLINTISCSIC) & M_FW_IQ_CMD_IQFLINTISCSIC) +#define F_FW_IQ_CMD_IQFLINTISCSIC V_FW_IQ_CMD_IQFLINTISCSIC(1U) + +#define S_FW_IQ_CMD_FL0CNGCHMAP 20 +#define M_FW_IQ_CMD_FL0CNGCHMAP 0xf +#define V_FW_IQ_CMD_FL0CNGCHMAP(x) ((x) << S_FW_IQ_CMD_FL0CNGCHMAP) +#define G_FW_IQ_CMD_FL0CNGCHMAP(x) \ + (((x) >> S_FW_IQ_CMD_FL0CNGCHMAP) & M_FW_IQ_CMD_FL0CNGCHMAP) + +#define S_FW_IQ_CMD_FL0CACHELOCK 15 +#define M_FW_IQ_CMD_FL0CACHELOCK 0x1 +#define V_FW_IQ_CMD_FL0CACHELOCK(x) ((x) << S_FW_IQ_CMD_FL0CACHELOCK) +#define G_FW_IQ_CMD_FL0CACHELOCK(x) \ + (((x) >> S_FW_IQ_CMD_FL0CACHELOCK) & M_FW_IQ_CMD_FL0CACHELOCK) +#define F_FW_IQ_CMD_FL0CACHELOCK V_FW_IQ_CMD_FL0CACHELOCK(1U) + +#define S_FW_IQ_CMD_FL0DBP 14 +#define M_FW_IQ_CMD_FL0DBP 0x1 +#define V_FW_IQ_CMD_FL0DBP(x) ((x) << S_FW_IQ_CMD_FL0DBP) +#define G_FW_IQ_CMD_FL0DBP(x) \ + (((x) >> S_FW_IQ_CMD_FL0DBP) & M_FW_IQ_CMD_FL0DBP) +#define F_FW_IQ_CMD_FL0DBP V_FW_IQ_CMD_FL0DBP(1U) + +#define S_FW_IQ_CMD_FL0DATANS 13 +#define M_FW_IQ_CMD_FL0DATANS 0x1 +#define V_FW_IQ_CMD_FL0DATANS(x) ((x) << S_FW_IQ_CMD_FL0DATANS) +#define G_FW_IQ_CMD_FL0DATANS(x) \ + (((x) >> S_FW_IQ_CMD_FL0DATANS) & M_FW_IQ_CMD_FL0DATANS) +#define F_FW_IQ_CMD_FL0DATANS V_FW_IQ_CMD_FL0DATANS(1U) + +#define S_FW_IQ_CMD_FL0DATARO 12 +#define M_FW_IQ_CMD_FL0DATARO 0x1 +#define V_FW_IQ_CMD_FL0DATARO(x) ((x) << S_FW_IQ_CMD_FL0DATARO) +#define G_FW_IQ_CMD_FL0DATARO(x) \ + (((x) >> S_FW_IQ_CMD_FL0DATARO) & M_FW_IQ_CMD_FL0DATARO) +#define F_FW_IQ_CMD_FL0DATARO V_FW_IQ_CMD_FL0DATARO(1U) + +#define S_FW_IQ_CMD_FL0CONGCIF 11 +#define M_FW_IQ_CMD_FL0CONGCIF 0x1 +#define V_FW_IQ_CMD_FL0CONGCIF(x) ((x) << S_FW_IQ_CMD_FL0CONGCIF) +#define G_FW_IQ_CMD_FL0CONGCIF(x) \ + (((x) >> S_FW_IQ_CMD_FL0CONGCIF) & M_FW_IQ_CMD_FL0CONGCIF) +#define F_FW_IQ_CMD_FL0CONGCIF V_FW_IQ_CMD_FL0CONGCIF(1U) + +#define S_FW_IQ_CMD_FL0ONCHIP 10 +#define M_FW_IQ_CMD_FL0ONCHIP 0x1 +#define V_FW_IQ_CMD_FL0ONCHIP(x) ((x) << S_FW_IQ_CMD_FL0ONCHIP) +#define G_FW_IQ_CMD_FL0ONCHIP(x) \ + (((x) >> S_FW_IQ_CMD_FL0ONCHIP) & M_FW_IQ_CMD_FL0ONCHIP) +#define F_FW_IQ_CMD_FL0ONCHIP V_FW_IQ_CMD_FL0ONCHIP(1U) + +#define S_FW_IQ_CMD_FL0STATUSPGNS 9 +#define M_FW_IQ_CMD_FL0STATUSPGNS 0x1 +#define V_FW_IQ_CMD_FL0STATUSPGNS(x) ((x) << S_FW_IQ_CMD_FL0STATUSPGNS) +#define G_FW_IQ_CMD_FL0STATUSPGNS(x) \ + (((x) >> S_FW_IQ_CMD_FL0STATUSPGNS) & M_FW_IQ_CMD_FL0STATUSPGNS) +#define F_FW_IQ_CMD_FL0STATUSPGNS V_FW_IQ_CMD_FL0STATUSPGNS(1U) + +#define S_FW_IQ_CMD_FL0STATUSPGRO 8 +#define M_FW_IQ_CMD_FL0STATUSPGRO 0x1 +#define V_FW_IQ_CMD_FL0STATUSPGRO(x) ((x) << S_FW_IQ_CMD_FL0STATUSPGRO) +#define G_FW_IQ_CMD_FL0STATUSPGRO(x) \ + (((x) >> S_FW_IQ_CMD_FL0STATUSPGRO) & M_FW_IQ_CMD_FL0STATUSPGRO) +#define F_FW_IQ_CMD_FL0STATUSPGRO V_FW_IQ_CMD_FL0STATUSPGRO(1U) + +#define S_FW_IQ_CMD_FL0FETCHNS 7 +#define M_FW_IQ_CMD_FL0FETCHNS 0x1 +#define V_FW_IQ_CMD_FL0FETCHNS(x) ((x) << S_FW_IQ_CMD_FL0FETCHNS) +#define G_FW_IQ_CMD_FL0FETCHNS(x) \ + (((x) >> S_FW_IQ_CMD_FL0FETCHNS) & M_FW_IQ_CMD_FL0FETCHNS) +#define F_FW_IQ_CMD_FL0FETCHNS V_FW_IQ_CMD_FL0FETCHNS(1U) + +#define S_FW_IQ_CMD_FL0FETCHRO 6 +#define M_FW_IQ_CMD_FL0FETCHRO 0x1 +#define V_FW_IQ_CMD_FL0FETCHRO(x) ((x) << S_FW_IQ_CMD_FL0FETCHRO) +#define G_FW_IQ_CMD_FL0FETCHRO(x) \ + (((x) >> S_FW_IQ_CMD_FL0FETCHRO) & M_FW_IQ_CMD_FL0FETCHRO) +#define F_FW_IQ_CMD_FL0FETCHRO V_FW_IQ_CMD_FL0FETCHRO(1U) + +#define S_FW_IQ_CMD_FL0HOSTFCMODE 4 +#define M_FW_IQ_CMD_FL0HOSTFCMODE 0x3 +#define V_FW_IQ_CMD_FL0HOSTFCMODE(x) ((x) << S_FW_IQ_CMD_FL0HOSTFCMODE) +#define G_FW_IQ_CMD_FL0HOSTFCMODE(x) \ + (((x) >> S_FW_IQ_CMD_FL0HOSTFCMODE) & M_FW_IQ_CMD_FL0HOSTFCMODE) + +#define S_FW_IQ_CMD_FL0CPRIO 3 +#define M_FW_IQ_CMD_FL0CPRIO 0x1 +#define V_FW_IQ_CMD_FL0CPRIO(x) ((x) << S_FW_IQ_CMD_FL0CPRIO) +#define G_FW_IQ_CMD_FL0CPRIO(x) \ + (((x) >> S_FW_IQ_CMD_FL0CPRIO) & M_FW_IQ_CMD_FL0CPRIO) +#define F_FW_IQ_CMD_FL0CPRIO V_FW_IQ_CMD_FL0CPRIO(1U) + +#define S_FW_IQ_CMD_FL0PADEN 2 +#define M_FW_IQ_CMD_FL0PADEN 0x1 +#define V_FW_IQ_CMD_FL0PADEN(x) ((x) << S_FW_IQ_CMD_FL0PADEN) +#define G_FW_IQ_CMD_FL0PADEN(x) \ + (((x) >> S_FW_IQ_CMD_FL0PADEN) & M_FW_IQ_CMD_FL0PADEN) +#define F_FW_IQ_CMD_FL0PADEN V_FW_IQ_CMD_FL0PADEN(1U) + +#define S_FW_IQ_CMD_FL0PACKEN 1 +#define M_FW_IQ_CMD_FL0PACKEN 0x1 +#define V_FW_IQ_CMD_FL0PACKEN(x) ((x) << S_FW_IQ_CMD_FL0PACKEN) +#define G_FW_IQ_CMD_FL0PACKEN(x) \ + (((x) >> S_FW_IQ_CMD_FL0PACKEN) & M_FW_IQ_CMD_FL0PACKEN) +#define F_FW_IQ_CMD_FL0PACKEN V_FW_IQ_CMD_FL0PACKEN(1U) + +#define S_FW_IQ_CMD_FL0CONGEN 0 +#define M_FW_IQ_CMD_FL0CONGEN 0x1 +#define V_FW_IQ_CMD_FL0CONGEN(x) ((x) << S_FW_IQ_CMD_FL0CONGEN) +#define G_FW_IQ_CMD_FL0CONGEN(x) \ + (((x) >> S_FW_IQ_CMD_FL0CONGEN) & M_FW_IQ_CMD_FL0CONGEN) +#define F_FW_IQ_CMD_FL0CONGEN V_FW_IQ_CMD_FL0CONGEN(1U) + +#define S_FW_IQ_CMD_FL0DCAEN 15 +#define M_FW_IQ_CMD_FL0DCAEN 0x1 +#define V_FW_IQ_CMD_FL0DCAEN(x) ((x) << S_FW_IQ_CMD_FL0DCAEN) +#define G_FW_IQ_CMD_FL0DCAEN(x) \ + (((x) >> S_FW_IQ_CMD_FL0DCAEN) & M_FW_IQ_CMD_FL0DCAEN) +#define F_FW_IQ_CMD_FL0DCAEN V_FW_IQ_CMD_FL0DCAEN(1U) + +#define S_FW_IQ_CMD_FL0DCACPU 10 +#define M_FW_IQ_CMD_FL0DCACPU 0x1f +#define V_FW_IQ_CMD_FL0DCACPU(x) ((x) << S_FW_IQ_CMD_FL0DCACPU) +#define G_FW_IQ_CMD_FL0DCACPU(x) \ + (((x) >> S_FW_IQ_CMD_FL0DCACPU) & M_FW_IQ_CMD_FL0DCACPU) + +#define S_FW_IQ_CMD_FL0FBMIN 7 +#define M_FW_IQ_CMD_FL0FBMIN 0x7 +#define V_FW_IQ_CMD_FL0FBMIN(x) ((x) << S_FW_IQ_CMD_FL0FBMIN) +#define G_FW_IQ_CMD_FL0FBMIN(x) \ + (((x) >> S_FW_IQ_CMD_FL0FBMIN) & M_FW_IQ_CMD_FL0FBMIN) + +#define S_FW_IQ_CMD_FL0FBMAX 4 +#define M_FW_IQ_CMD_FL0FBMAX 0x7 +#define V_FW_IQ_CMD_FL0FBMAX(x) ((x) << S_FW_IQ_CMD_FL0FBMAX) +#define G_FW_IQ_CMD_FL0FBMAX(x) \ + (((x) >> S_FW_IQ_CMD_FL0FBMAX) & M_FW_IQ_CMD_FL0FBMAX) + +#define S_FW_IQ_CMD_FL0CIDXFTHRESHO 3 +#define M_FW_IQ_CMD_FL0CIDXFTHRESHO 0x1 +#define V_FW_IQ_CMD_FL0CIDXFTHRESHO(x) ((x) << S_FW_IQ_CMD_FL0CIDXFTHRESHO) +#define G_FW_IQ_CMD_FL0CIDXFTHRESHO(x) \ + (((x) >> S_FW_IQ_CMD_FL0CIDXFTHRESHO) & M_FW_IQ_CMD_FL0CIDXFTHRESHO) +#define F_FW_IQ_CMD_FL0CIDXFTHRESHO V_FW_IQ_CMD_FL0CIDXFTHRESHO(1U) + +#define S_FW_IQ_CMD_FL0CIDXFTHRESH 0 +#define M_FW_IQ_CMD_FL0CIDXFTHRESH 0x7 +#define V_FW_IQ_CMD_FL0CIDXFTHRESH(x) ((x) << S_FW_IQ_CMD_FL0CIDXFTHRESH) +#define G_FW_IQ_CMD_FL0CIDXFTHRESH(x) \ + (((x) >> S_FW_IQ_CMD_FL0CIDXFTHRESH) & M_FW_IQ_CMD_FL0CIDXFTHRESH) + +#define S_FW_IQ_CMD_FL1CNGCHMAP 20 +#define M_FW_IQ_CMD_FL1CNGCHMAP 0xf +#define V_FW_IQ_CMD_FL1CNGCHMAP(x) ((x) << S_FW_IQ_CMD_FL1CNGCHMAP) +#define G_FW_IQ_CMD_FL1CNGCHMAP(x) \ + (((x) >> S_FW_IQ_CMD_FL1CNGCHMAP) & M_FW_IQ_CMD_FL1CNGCHMAP) + +#define S_FW_IQ_CMD_FL1CACHELOCK 15 +#define M_FW_IQ_CMD_FL1CACHELOCK 0x1 +#define V_FW_IQ_CMD_FL1CACHELOCK(x) ((x) << S_FW_IQ_CMD_FL1CACHELOCK) +#define G_FW_IQ_CMD_FL1CACHELOCK(x) \ + (((x) >> S_FW_IQ_CMD_FL1CACHELOCK) & M_FW_IQ_CMD_FL1CACHELOCK) +#define F_FW_IQ_CMD_FL1CACHELOCK V_FW_IQ_CMD_FL1CACHELOCK(1U) + +#define S_FW_IQ_CMD_FL1DBP 14 +#define M_FW_IQ_CMD_FL1DBP 0x1 +#define V_FW_IQ_CMD_FL1DBP(x) ((x) << S_FW_IQ_CMD_FL1DBP) +#define G_FW_IQ_CMD_FL1DBP(x) \ + (((x) >> S_FW_IQ_CMD_FL1DBP) & M_FW_IQ_CMD_FL1DBP) +#define F_FW_IQ_CMD_FL1DBP V_FW_IQ_CMD_FL1DBP(1U) + +#define S_FW_IQ_CMD_FL1DATANS 13 +#define M_FW_IQ_CMD_FL1DATANS 0x1 +#define V_FW_IQ_CMD_FL1DATANS(x) ((x) << S_FW_IQ_CMD_FL1DATANS) +#define G_FW_IQ_CMD_FL1DATANS(x) \ + (((x) >> S_FW_IQ_CMD_FL1DATANS) & M_FW_IQ_CMD_FL1DATANS) +#define F_FW_IQ_CMD_FL1DATANS V_FW_IQ_CMD_FL1DATANS(1U) + +#define S_FW_IQ_CMD_FL1DATARO 12 +#define M_FW_IQ_CMD_FL1DATARO 0x1 +#define V_FW_IQ_CMD_FL1DATARO(x) ((x) << S_FW_IQ_CMD_FL1DATARO) +#define G_FW_IQ_CMD_FL1DATARO(x) \ + (((x) >> S_FW_IQ_CMD_FL1DATARO) & M_FW_IQ_CMD_FL1DATARO) +#define F_FW_IQ_CMD_FL1DATARO V_FW_IQ_CMD_FL1DATARO(1U) + +#define S_FW_IQ_CMD_FL1CONGCIF 11 +#define M_FW_IQ_CMD_FL1CONGCIF 0x1 +#define V_FW_IQ_CMD_FL1CONGCIF(x) ((x) << S_FW_IQ_CMD_FL1CONGCIF) +#define G_FW_IQ_CMD_FL1CONGCIF(x) \ + (((x) >> S_FW_IQ_CMD_FL1CONGCIF) & M_FW_IQ_CMD_FL1CONGCIF) +#define F_FW_IQ_CMD_FL1CONGCIF V_FW_IQ_CMD_FL1CONGCIF(1U) + +#define S_FW_IQ_CMD_FL1ONCHIP 10 +#define M_FW_IQ_CMD_FL1ONCHIP 0x1 +#define V_FW_IQ_CMD_FL1ONCHIP(x) ((x) << S_FW_IQ_CMD_FL1ONCHIP) +#define G_FW_IQ_CMD_FL1ONCHIP(x) \ + (((x) >> S_FW_IQ_CMD_FL1ONCHIP) & M_FW_IQ_CMD_FL1ONCHIP) +#define F_FW_IQ_CMD_FL1ONCHIP V_FW_IQ_CMD_FL1ONCHIP(1U) + +#define S_FW_IQ_CMD_FL1STATUSPGNS 9 +#define M_FW_IQ_CMD_FL1STATUSPGNS 0x1 +#define V_FW_IQ_CMD_FL1STATUSPGNS(x) ((x) << S_FW_IQ_CMD_FL1STATUSPGNS) +#define G_FW_IQ_CMD_FL1STATUSPGNS(x) \ + (((x) >> S_FW_IQ_CMD_FL1STATUSPGNS) & M_FW_IQ_CMD_FL1STATUSPGNS) +#define F_FW_IQ_CMD_FL1STATUSPGNS V_FW_IQ_CMD_FL1STATUSPGNS(1U) + +#define S_FW_IQ_CMD_FL1STATUSPGRO 8 +#define M_FW_IQ_CMD_FL1STATUSPGRO 0x1 +#define V_FW_IQ_CMD_FL1STATUSPGRO(x) ((x) << S_FW_IQ_CMD_FL1STATUSPGRO) +#define G_FW_IQ_CMD_FL1STATUSPGRO(x) \ + (((x) >> S_FW_IQ_CMD_FL1STATUSPGRO) & M_FW_IQ_CMD_FL1STATUSPGRO) +#define F_FW_IQ_CMD_FL1STATUSPGRO V_FW_IQ_CMD_FL1STATUSPGRO(1U) + +#define S_FW_IQ_CMD_FL1FETCHNS 7 +#define M_FW_IQ_CMD_FL1FETCHNS 0x1 +#define V_FW_IQ_CMD_FL1FETCHNS(x) ((x) << S_FW_IQ_CMD_FL1FETCHNS) +#define G_FW_IQ_CMD_FL1FETCHNS(x) \ + (((x) >> S_FW_IQ_CMD_FL1FETCHNS) & M_FW_IQ_CMD_FL1FETCHNS) +#define F_FW_IQ_CMD_FL1FETCHNS V_FW_IQ_CMD_FL1FETCHNS(1U) + +#define S_FW_IQ_CMD_FL1FETCHRO 6 +#define M_FW_IQ_CMD_FL1FETCHRO 0x1 +#define V_FW_IQ_CMD_FL1FETCHRO(x) ((x) << S_FW_IQ_CMD_FL1FETCHRO) +#define G_FW_IQ_CMD_FL1FETCHRO(x) \ + (((x) >> S_FW_IQ_CMD_FL1FETCHRO) & M_FW_IQ_CMD_FL1FETCHRO) +#define F_FW_IQ_CMD_FL1FETCHRO V_FW_IQ_CMD_FL1FETCHRO(1U) + +#define S_FW_IQ_CMD_FL1HOSTFCMODE 4 +#define M_FW_IQ_CMD_FL1HOSTFCMODE 0x3 +#define V_FW_IQ_CMD_FL1HOSTFCMODE(x) ((x) << S_FW_IQ_CMD_FL1HOSTFCMODE) +#define G_FW_IQ_CMD_FL1HOSTFCMODE(x) \ + (((x) >> S_FW_IQ_CMD_FL1HOSTFCMODE) & M_FW_IQ_CMD_FL1HOSTFCMODE) + +#define S_FW_IQ_CMD_FL1CPRIO 3 +#define M_FW_IQ_CMD_FL1CPRIO 0x1 +#define V_FW_IQ_CMD_FL1CPRIO(x) ((x) << S_FW_IQ_CMD_FL1CPRIO) +#define G_FW_IQ_CMD_FL1CPRIO(x) \ + (((x) >> S_FW_IQ_CMD_FL1CPRIO) & M_FW_IQ_CMD_FL1CPRIO) +#define F_FW_IQ_CMD_FL1CPRIO V_FW_IQ_CMD_FL1CPRIO(1U) + +#define S_FW_IQ_CMD_FL1PADEN 2 +#define M_FW_IQ_CMD_FL1PADEN 0x1 +#define V_FW_IQ_CMD_FL1PADEN(x) ((x) << S_FW_IQ_CMD_FL1PADEN) +#define G_FW_IQ_CMD_FL1PADEN(x) \ + (((x) >> S_FW_IQ_CMD_FL1PADEN) & M_FW_IQ_CMD_FL1PADEN) +#define F_FW_IQ_CMD_FL1PADEN V_FW_IQ_CMD_FL1PADEN(1U) + +#define S_FW_IQ_CMD_FL1PACKEN 1 +#define M_FW_IQ_CMD_FL1PACKEN 0x1 +#define V_FW_IQ_CMD_FL1PACKEN(x) ((x) << S_FW_IQ_CMD_FL1PACKEN) +#define G_FW_IQ_CMD_FL1PACKEN(x) \ + (((x) >> S_FW_IQ_CMD_FL1PACKEN) & M_FW_IQ_CMD_FL1PACKEN) +#define F_FW_IQ_CMD_FL1PACKEN V_FW_IQ_CMD_FL1PACKEN(1U) + +#define S_FW_IQ_CMD_FL1CONGEN 0 +#define M_FW_IQ_CMD_FL1CONGEN 0x1 +#define V_FW_IQ_CMD_FL1CONGEN(x) ((x) << S_FW_IQ_CMD_FL1CONGEN) +#define G_FW_IQ_CMD_FL1CONGEN(x) \ + (((x) >> S_FW_IQ_CMD_FL1CONGEN) & M_FW_IQ_CMD_FL1CONGEN) +#define F_FW_IQ_CMD_FL1CONGEN V_FW_IQ_CMD_FL1CONGEN(1U) + +#define S_FW_IQ_CMD_FL1DCAEN 15 +#define M_FW_IQ_CMD_FL1DCAEN 0x1 +#define V_FW_IQ_CMD_FL1DCAEN(x) ((x) << S_FW_IQ_CMD_FL1DCAEN) +#define G_FW_IQ_CMD_FL1DCAEN(x) \ + (((x) >> S_FW_IQ_CMD_FL1DCAEN) & M_FW_IQ_CMD_FL1DCAEN) +#define F_FW_IQ_CMD_FL1DCAEN V_FW_IQ_CMD_FL1DCAEN(1U) + +#define S_FW_IQ_CMD_FL1DCACPU 10 +#define M_FW_IQ_CMD_FL1DCACPU 0x1f +#define V_FW_IQ_CMD_FL1DCACPU(x) ((x) << S_FW_IQ_CMD_FL1DCACPU) +#define G_FW_IQ_CMD_FL1DCACPU(x) \ + (((x) >> S_FW_IQ_CMD_FL1DCACPU) & M_FW_IQ_CMD_FL1DCACPU) + +#define S_FW_IQ_CMD_FL1FBMIN 7 +#define M_FW_IQ_CMD_FL1FBMIN 0x7 +#define V_FW_IQ_CMD_FL1FBMIN(x) ((x) << S_FW_IQ_CMD_FL1FBMIN) +#define G_FW_IQ_CMD_FL1FBMIN(x) \ + (((x) >> S_FW_IQ_CMD_FL1FBMIN) & M_FW_IQ_CMD_FL1FBMIN) + +#define S_FW_IQ_CMD_FL1FBMAX 4 +#define M_FW_IQ_CMD_FL1FBMAX 0x7 +#define V_FW_IQ_CMD_FL1FBMAX(x) ((x) << S_FW_IQ_CMD_FL1FBMAX) +#define G_FW_IQ_CMD_FL1FBMAX(x) \ + (((x) >> S_FW_IQ_CMD_FL1FBMAX) & M_FW_IQ_CMD_FL1FBMAX) + +#define S_FW_IQ_CMD_FL1CIDXFTHRESHO 3 +#define M_FW_IQ_CMD_FL1CIDXFTHRESHO 0x1 +#define V_FW_IQ_CMD_FL1CIDXFTHRESHO(x) ((x) << S_FW_IQ_CMD_FL1CIDXFTHRESHO) +#define G_FW_IQ_CMD_FL1CIDXFTHRESHO(x) \ + (((x) >> S_FW_IQ_CMD_FL1CIDXFTHRESHO) & M_FW_IQ_CMD_FL1CIDXFTHRESHO) +#define F_FW_IQ_CMD_FL1CIDXFTHRESHO V_FW_IQ_CMD_FL1CIDXFTHRESHO(1U) + +#define S_FW_IQ_CMD_FL1CIDXFTHRESH 0 +#define M_FW_IQ_CMD_FL1CIDXFTHRESH 0x7 +#define V_FW_IQ_CMD_FL1CIDXFTHRESH(x) ((x) << S_FW_IQ_CMD_FL1CIDXFTHRESH) +#define G_FW_IQ_CMD_FL1CIDXFTHRESH(x) \ + (((x) >> S_FW_IQ_CMD_FL1CIDXFTHRESH) & M_FW_IQ_CMD_FL1CIDXFTHRESH) + +struct fw_eq_mngt_cmd { + __be32 op_to_vfn; + __be32 alloc_to_len16; + __be32 cmpliqid_eqid; + __be32 physeqid_pkd; + __be32 fetchszm_to_iqid; + __be32 dcaen_to_eqsize; + __be64 eqaddr; +}; + +#define S_FW_EQ_MNGT_CMD_PFN 8 +#define M_FW_EQ_MNGT_CMD_PFN 0x7 +#define V_FW_EQ_MNGT_CMD_PFN(x) ((x) << S_FW_EQ_MNGT_CMD_PFN) +#define G_FW_EQ_MNGT_CMD_PFN(x) \ + (((x) >> S_FW_EQ_MNGT_CMD_PFN) & M_FW_EQ_MNGT_CMD_PFN) + +#define S_FW_EQ_MNGT_CMD_VFN 0 +#define M_FW_EQ_MNGT_CMD_VFN 0xff +#define V_FW_EQ_MNGT_CMD_VFN(x) ((x) << S_FW_EQ_MNGT_CMD_VFN) +#define G_FW_EQ_MNGT_CMD_VFN(x) \ + (((x) >> S_FW_EQ_MNGT_CMD_VFN) & M_FW_EQ_MNGT_CMD_VFN) + +#define S_FW_EQ_MNGT_CMD_ALLOC 31 +#define M_FW_EQ_MNGT_CMD_ALLOC 0x1 +#define V_FW_EQ_MNGT_CMD_ALLOC(x) ((x) << S_FW_EQ_MNGT_CMD_ALLOC) +#define G_FW_EQ_MNGT_CMD_ALLOC(x) \ + (((x) >> S_FW_EQ_MNGT_CMD_ALLOC) & M_FW_EQ_MNGT_CMD_ALLOC) +#define F_FW_EQ_MNGT_CMD_ALLOC V_FW_EQ_MNGT_CMD_ALLOC(1U) + +#define S_FW_EQ_MNGT_CMD_FREE 30 +#define M_FW_EQ_MNGT_CMD_FREE 0x1 +#define V_FW_EQ_MNGT_CMD_FREE(x) ((x) << S_FW_EQ_MNGT_CMD_FREE) +#define G_FW_EQ_MNGT_CMD_FREE(x) \ + (((x) >> S_FW_EQ_MNGT_CMD_FREE) & M_FW_EQ_MNGT_CMD_FREE) +#define F_FW_EQ_MNGT_CMD_FREE V_FW_EQ_MNGT_CMD_FREE(1U) + +#define S_FW_EQ_MNGT_CMD_MODIFY 29 +#define M_FW_EQ_MNGT_CMD_MODIFY 0x1 +#define V_FW_EQ_MNGT_CMD_MODIFY(x) ((x) << S_FW_EQ_MNGT_CMD_MODIFY) +#define G_FW_EQ_MNGT_CMD_MODIFY(x) \ + (((x) >> S_FW_EQ_MNGT_CMD_MODIFY) & M_FW_EQ_MNGT_CMD_MODIFY) +#define F_FW_EQ_MNGT_CMD_MODIFY V_FW_EQ_MNGT_CMD_MODIFY(1U) + +#define S_FW_EQ_MNGT_CMD_EQSTART 28 +#define M_FW_EQ_MNGT_CMD_EQSTART 0x1 +#define V_FW_EQ_MNGT_CMD_EQSTART(x) ((x) << S_FW_EQ_MNGT_CMD_EQSTART) +#define G_FW_EQ_MNGT_CMD_EQSTART(x) \ + (((x) >> S_FW_EQ_MNGT_CMD_EQSTART) & M_FW_EQ_MNGT_CMD_EQSTART) +#define F_FW_EQ_MNGT_CMD_EQSTART V_FW_EQ_MNGT_CMD_EQSTART(1U) + +#define S_FW_EQ_MNGT_CMD_EQSTOP 27 +#define M_FW_EQ_MNGT_CMD_EQSTOP 0x1 +#define V_FW_EQ_MNGT_CMD_EQSTOP(x) ((x) << S_FW_EQ_MNGT_CMD_EQSTOP) +#define G_FW_EQ_MNGT_CMD_EQSTOP(x) \ + (((x) >> S_FW_EQ_MNGT_CMD_EQSTOP) & M_FW_EQ_MNGT_CMD_EQSTOP) +#define F_FW_EQ_MNGT_CMD_EQSTOP V_FW_EQ_MNGT_CMD_EQSTOP(1U) + +#define S_FW_EQ_MNGT_CMD_CMPLIQID 20 +#define M_FW_EQ_MNGT_CMD_CMPLIQID 0xfff +#define V_FW_EQ_MNGT_CMD_CMPLIQID(x) ((x) << S_FW_EQ_MNGT_CMD_CMPLIQID) +#define G_FW_EQ_MNGT_CMD_CMPLIQID(x) \ + (((x) >> S_FW_EQ_MNGT_CMD_CMPLIQID) & M_FW_EQ_MNGT_CMD_CMPLIQID) + +#define S_FW_EQ_MNGT_CMD_EQID 0 +#define M_FW_EQ_MNGT_CMD_EQID 0xfffff +#define V_FW_EQ_MNGT_CMD_EQID(x) ((x) << S_FW_EQ_MNGT_CMD_EQID) +#define G_FW_EQ_MNGT_CMD_EQID(x) \ + (((x) >> S_FW_EQ_MNGT_CMD_EQID) & M_FW_EQ_MNGT_CMD_EQID) + +#define S_FW_EQ_MNGT_CMD_PHYSEQID 0 +#define M_FW_EQ_MNGT_CMD_PHYSEQID 0xfffff +#define V_FW_EQ_MNGT_CMD_PHYSEQID(x) ((x) << S_FW_EQ_MNGT_CMD_PHYSEQID) +#define G_FW_EQ_MNGT_CMD_PHYSEQID(x) \ + (((x) >> S_FW_EQ_MNGT_CMD_PHYSEQID) & M_FW_EQ_MNGT_CMD_PHYSEQID) + +#define S_FW_EQ_MNGT_CMD_FETCHSZM 26 +#define M_FW_EQ_MNGT_CMD_FETCHSZM 0x1 +#define V_FW_EQ_MNGT_CMD_FETCHSZM(x) ((x) << S_FW_EQ_MNGT_CMD_FETCHSZM) +#define G_FW_EQ_MNGT_CMD_FETCHSZM(x) \ + (((x) >> S_FW_EQ_MNGT_CMD_FETCHSZM) & M_FW_EQ_MNGT_CMD_FETCHSZM) +#define F_FW_EQ_MNGT_CMD_FETCHSZM V_FW_EQ_MNGT_CMD_FETCHSZM(1U) + +#define S_FW_EQ_MNGT_CMD_STATUSPGNS 25 +#define M_FW_EQ_MNGT_CMD_STATUSPGNS 0x1 +#define V_FW_EQ_MNGT_CMD_STATUSPGNS(x) ((x) << S_FW_EQ_MNGT_CMD_STATUSPGNS) +#define G_FW_EQ_MNGT_CMD_STATUSPGNS(x) \ + (((x) >> S_FW_EQ_MNGT_CMD_STATUSPGNS) & M_FW_EQ_MNGT_CMD_STATUSPGNS) +#define F_FW_EQ_MNGT_CMD_STATUSPGNS V_FW_EQ_MNGT_CMD_STATUSPGNS(1U) + +#define S_FW_EQ_MNGT_CMD_STATUSPGRO 24 +#define M_FW_EQ_MNGT_CMD_STATUSPGRO 0x1 +#define V_FW_EQ_MNGT_CMD_STATUSPGRO(x) ((x) << S_FW_EQ_MNGT_CMD_STATUSPGRO) +#define G_FW_EQ_MNGT_CMD_STATUSPGRO(x) \ + (((x) >> S_FW_EQ_MNGT_CMD_STATUSPGRO) & M_FW_EQ_MNGT_CMD_STATUSPGRO) +#define F_FW_EQ_MNGT_CMD_STATUSPGRO V_FW_EQ_MNGT_CMD_STATUSPGRO(1U) + +#define S_FW_EQ_MNGT_CMD_FETCHNS 23 +#define M_FW_EQ_MNGT_CMD_FETCHNS 0x1 +#define V_FW_EQ_MNGT_CMD_FETCHNS(x) ((x) << S_FW_EQ_MNGT_CMD_FETCHNS) +#define G_FW_EQ_MNGT_CMD_FETCHNS(x) \ + (((x) >> S_FW_EQ_MNGT_CMD_FETCHNS) & M_FW_EQ_MNGT_CMD_FETCHNS) +#define F_FW_EQ_MNGT_CMD_FETCHNS V_FW_EQ_MNGT_CMD_FETCHNS(1U) + +#define S_FW_EQ_MNGT_CMD_FETCHRO 22 +#define M_FW_EQ_MNGT_CMD_FETCHRO 0x1 +#define V_FW_EQ_MNGT_CMD_FETCHRO(x) ((x) << S_FW_EQ_MNGT_CMD_FETCHRO) +#define G_FW_EQ_MNGT_CMD_FETCHRO(x) \ + (((x) >> S_FW_EQ_MNGT_CMD_FETCHRO) & M_FW_EQ_MNGT_CMD_FETCHRO) +#define F_FW_EQ_MNGT_CMD_FETCHRO V_FW_EQ_MNGT_CMD_FETCHRO(1U) + +#define S_FW_EQ_MNGT_CMD_HOSTFCMODE 20 +#define M_FW_EQ_MNGT_CMD_HOSTFCMODE 0x3 +#define V_FW_EQ_MNGT_CMD_HOSTFCMODE(x) ((x) << S_FW_EQ_MNGT_CMD_HOSTFCMODE) +#define G_FW_EQ_MNGT_CMD_HOSTFCMODE(x) \ + (((x) >> S_FW_EQ_MNGT_CMD_HOSTFCMODE) & M_FW_EQ_MNGT_CMD_HOSTFCMODE) + +#define S_FW_EQ_MNGT_CMD_CPRIO 19 +#define M_FW_EQ_MNGT_CMD_CPRIO 0x1 +#define V_FW_EQ_MNGT_CMD_CPRIO(x) ((x) << S_FW_EQ_MNGT_CMD_CPRIO) +#define G_FW_EQ_MNGT_CMD_CPRIO(x) \ + (((x) >> S_FW_EQ_MNGT_CMD_CPRIO) & M_FW_EQ_MNGT_CMD_CPRIO) +#define F_FW_EQ_MNGT_CMD_CPRIO V_FW_EQ_MNGT_CMD_CPRIO(1U) + +#define S_FW_EQ_MNGT_CMD_ONCHIP 18 +#define M_FW_EQ_MNGT_CMD_ONCHIP 0x1 +#define V_FW_EQ_MNGT_CMD_ONCHIP(x) ((x) << S_FW_EQ_MNGT_CMD_ONCHIP) +#define G_FW_EQ_MNGT_CMD_ONCHIP(x) \ + (((x) >> S_FW_EQ_MNGT_CMD_ONCHIP) & M_FW_EQ_MNGT_CMD_ONCHIP) +#define F_FW_EQ_MNGT_CMD_ONCHIP V_FW_EQ_MNGT_CMD_ONCHIP(1U) + +#define S_FW_EQ_MNGT_CMD_PCIECHN 16 +#define M_FW_EQ_MNGT_CMD_PCIECHN 0x3 +#define V_FW_EQ_MNGT_CMD_PCIECHN(x) ((x) << S_FW_EQ_MNGT_CMD_PCIECHN) +#define G_FW_EQ_MNGT_CMD_PCIECHN(x) \ + (((x) >> S_FW_EQ_MNGT_CMD_PCIECHN) & M_FW_EQ_MNGT_CMD_PCIECHN) + +#define S_FW_EQ_MNGT_CMD_IQID 0 +#define M_FW_EQ_MNGT_CMD_IQID 0xffff +#define V_FW_EQ_MNGT_CMD_IQID(x) ((x) << S_FW_EQ_MNGT_CMD_IQID) +#define G_FW_EQ_MNGT_CMD_IQID(x) \ + (((x) >> S_FW_EQ_MNGT_CMD_IQID) & M_FW_EQ_MNGT_CMD_IQID) + +#define S_FW_EQ_MNGT_CMD_DCAEN 31 +#define M_FW_EQ_MNGT_CMD_DCAEN 0x1 +#define V_FW_EQ_MNGT_CMD_DCAEN(x) ((x) << S_FW_EQ_MNGT_CMD_DCAEN) +#define G_FW_EQ_MNGT_CMD_DCAEN(x) \ + (((x) >> S_FW_EQ_MNGT_CMD_DCAEN) & M_FW_EQ_MNGT_CMD_DCAEN) +#define F_FW_EQ_MNGT_CMD_DCAEN V_FW_EQ_MNGT_CMD_DCAEN(1U) + +#define S_FW_EQ_MNGT_CMD_DCACPU 26 +#define M_FW_EQ_MNGT_CMD_DCACPU 0x1f +#define V_FW_EQ_MNGT_CMD_DCACPU(x) ((x) << S_FW_EQ_MNGT_CMD_DCACPU) +#define G_FW_EQ_MNGT_CMD_DCACPU(x) \ + (((x) >> S_FW_EQ_MNGT_CMD_DCACPU) & M_FW_EQ_MNGT_CMD_DCACPU) + +#define S_FW_EQ_MNGT_CMD_FBMIN 23 +#define M_FW_EQ_MNGT_CMD_FBMIN 0x7 +#define V_FW_EQ_MNGT_CMD_FBMIN(x) ((x) << S_FW_EQ_MNGT_CMD_FBMIN) +#define G_FW_EQ_MNGT_CMD_FBMIN(x) \ + (((x) >> S_FW_EQ_MNGT_CMD_FBMIN) & M_FW_EQ_MNGT_CMD_FBMIN) + +#define S_FW_EQ_MNGT_CMD_FBMAX 20 +#define M_FW_EQ_MNGT_CMD_FBMAX 0x7 +#define V_FW_EQ_MNGT_CMD_FBMAX(x) ((x) << S_FW_EQ_MNGT_CMD_FBMAX) +#define G_FW_EQ_MNGT_CMD_FBMAX(x) \ + (((x) >> S_FW_EQ_MNGT_CMD_FBMAX) & M_FW_EQ_MNGT_CMD_FBMAX) + +#define S_FW_EQ_MNGT_CMD_CIDXFTHRESHO 19 +#define M_FW_EQ_MNGT_CMD_CIDXFTHRESHO 0x1 +#define V_FW_EQ_MNGT_CMD_CIDXFTHRESHO(x) \ + ((x) << S_FW_EQ_MNGT_CMD_CIDXFTHRESHO) +#define G_FW_EQ_MNGT_CMD_CIDXFTHRESHO(x) \ + (((x) >> S_FW_EQ_MNGT_CMD_CIDXFTHRESHO) & M_FW_EQ_MNGT_CMD_CIDXFTHRESHO) +#define F_FW_EQ_MNGT_CMD_CIDXFTHRESHO V_FW_EQ_MNGT_CMD_CIDXFTHRESHO(1U) + +#define S_FW_EQ_MNGT_CMD_CIDXFTHRESH 16 +#define M_FW_EQ_MNGT_CMD_CIDXFTHRESH 0x7 +#define V_FW_EQ_MNGT_CMD_CIDXFTHRESH(x) ((x) << S_FW_EQ_MNGT_CMD_CIDXFTHRESH) +#define G_FW_EQ_MNGT_CMD_CIDXFTHRESH(x) \ + (((x) >> S_FW_EQ_MNGT_CMD_CIDXFTHRESH) & M_FW_EQ_MNGT_CMD_CIDXFTHRESH) + +#define S_FW_EQ_MNGT_CMD_EQSIZE 0 +#define M_FW_EQ_MNGT_CMD_EQSIZE 0xffff +#define V_FW_EQ_MNGT_CMD_EQSIZE(x) ((x) << S_FW_EQ_MNGT_CMD_EQSIZE) +#define G_FW_EQ_MNGT_CMD_EQSIZE(x) \ + (((x) >> S_FW_EQ_MNGT_CMD_EQSIZE) & M_FW_EQ_MNGT_CMD_EQSIZE) + +struct fw_eq_eth_cmd { + __be32 op_to_vfn; + __be32 alloc_to_len16; + __be32 eqid_pkd; + __be32 physeqid_pkd; + __be32 fetchszm_to_iqid; + __be32 dcaen_to_eqsize; + __be64 eqaddr; + __be32 viid_pkd; + __be32 r8_lo; + __be64 r9; +}; + +#define S_FW_EQ_ETH_CMD_PFN 8 +#define M_FW_EQ_ETH_CMD_PFN 0x7 +#define V_FW_EQ_ETH_CMD_PFN(x) ((x) << S_FW_EQ_ETH_CMD_PFN) +#define G_FW_EQ_ETH_CMD_PFN(x) \ + (((x) >> S_FW_EQ_ETH_CMD_PFN) & M_FW_EQ_ETH_CMD_PFN) + +#define S_FW_EQ_ETH_CMD_VFN 0 +#define M_FW_EQ_ETH_CMD_VFN 0xff +#define V_FW_EQ_ETH_CMD_VFN(x) ((x) << S_FW_EQ_ETH_CMD_VFN) +#define G_FW_EQ_ETH_CMD_VFN(x) \ + (((x) >> S_FW_EQ_ETH_CMD_VFN) & M_FW_EQ_ETH_CMD_VFN) + +#define S_FW_EQ_ETH_CMD_ALLOC 31 +#define M_FW_EQ_ETH_CMD_ALLOC 0x1 +#define V_FW_EQ_ETH_CMD_ALLOC(x) ((x) << S_FW_EQ_ETH_CMD_ALLOC) +#define G_FW_EQ_ETH_CMD_ALLOC(x) \ + (((x) >> S_FW_EQ_ETH_CMD_ALLOC) & M_FW_EQ_ETH_CMD_ALLOC) +#define F_FW_EQ_ETH_CMD_ALLOC V_FW_EQ_ETH_CMD_ALLOC(1U) + +#define S_FW_EQ_ETH_CMD_FREE 30 +#define M_FW_EQ_ETH_CMD_FREE 0x1 +#define V_FW_EQ_ETH_CMD_FREE(x) ((x) << S_FW_EQ_ETH_CMD_FREE) +#define G_FW_EQ_ETH_CMD_FREE(x) \ + (((x) >> S_FW_EQ_ETH_CMD_FREE) & M_FW_EQ_ETH_CMD_FREE) +#define F_FW_EQ_ETH_CMD_FREE V_FW_EQ_ETH_CMD_FREE(1U) + +#define S_FW_EQ_ETH_CMD_MODIFY 29 +#define M_FW_EQ_ETH_CMD_MODIFY 0x1 +#define V_FW_EQ_ETH_CMD_MODIFY(x) ((x) << S_FW_EQ_ETH_CMD_MODIFY) +#define G_FW_EQ_ETH_CMD_MODIFY(x) \ + (((x) >> S_FW_EQ_ETH_CMD_MODIFY) & M_FW_EQ_ETH_CMD_MODIFY) +#define F_FW_EQ_ETH_CMD_MODIFY V_FW_EQ_ETH_CMD_MODIFY(1U) + +#define S_FW_EQ_ETH_CMD_EQSTART 28 +#define M_FW_EQ_ETH_CMD_EQSTART 0x1 +#define V_FW_EQ_ETH_CMD_EQSTART(x) ((x) << S_FW_EQ_ETH_CMD_EQSTART) +#define G_FW_EQ_ETH_CMD_EQSTART(x) \ + (((x) >> S_FW_EQ_ETH_CMD_EQSTART) & M_FW_EQ_ETH_CMD_EQSTART) +#define F_FW_EQ_ETH_CMD_EQSTART V_FW_EQ_ETH_CMD_EQSTART(1U) + +#define S_FW_EQ_ETH_CMD_EQSTOP 27 +#define M_FW_EQ_ETH_CMD_EQSTOP 0x1 +#define V_FW_EQ_ETH_CMD_EQSTOP(x) ((x) << S_FW_EQ_ETH_CMD_EQSTOP) +#define G_FW_EQ_ETH_CMD_EQSTOP(x) \ + (((x) >> S_FW_EQ_ETH_CMD_EQSTOP) & M_FW_EQ_ETH_CMD_EQSTOP) +#define F_FW_EQ_ETH_CMD_EQSTOP V_FW_EQ_ETH_CMD_EQSTOP(1U) + +#define S_FW_EQ_ETH_CMD_EQID 0 +#define M_FW_EQ_ETH_CMD_EQID 0xfffff +#define V_FW_EQ_ETH_CMD_EQID(x) ((x) << S_FW_EQ_ETH_CMD_EQID) +#define G_FW_EQ_ETH_CMD_EQID(x) \ + (((x) >> S_FW_EQ_ETH_CMD_EQID) & M_FW_EQ_ETH_CMD_EQID) + +#define S_FW_EQ_ETH_CMD_PHYSEQID 0 +#define M_FW_EQ_ETH_CMD_PHYSEQID 0xfffff +#define V_FW_EQ_ETH_CMD_PHYSEQID(x) ((x) << S_FW_EQ_ETH_CMD_PHYSEQID) +#define G_FW_EQ_ETH_CMD_PHYSEQID(x) \ + (((x) >> S_FW_EQ_ETH_CMD_PHYSEQID) & M_FW_EQ_ETH_CMD_PHYSEQID) + +#define S_FW_EQ_ETH_CMD_FETCHSZM 26 +#define M_FW_EQ_ETH_CMD_FETCHSZM 0x1 +#define V_FW_EQ_ETH_CMD_FETCHSZM(x) ((x) << S_FW_EQ_ETH_CMD_FETCHSZM) +#define G_FW_EQ_ETH_CMD_FETCHSZM(x) \ + (((x) >> S_FW_EQ_ETH_CMD_FETCHSZM) & M_FW_EQ_ETH_CMD_FETCHSZM) +#define F_FW_EQ_ETH_CMD_FETCHSZM V_FW_EQ_ETH_CMD_FETCHSZM(1U) + +#define S_FW_EQ_ETH_CMD_STATUSPGNS 25 +#define M_FW_EQ_ETH_CMD_STATUSPGNS 0x1 +#define V_FW_EQ_ETH_CMD_STATUSPGNS(x) ((x) << S_FW_EQ_ETH_CMD_STATUSPGNS) +#define G_FW_EQ_ETH_CMD_STATUSPGNS(x) \ + (((x) >> S_FW_EQ_ETH_CMD_STATUSPGNS) & M_FW_EQ_ETH_CMD_STATUSPGNS) +#define F_FW_EQ_ETH_CMD_STATUSPGNS V_FW_EQ_ETH_CMD_STATUSPGNS(1U) + +#define S_FW_EQ_ETH_CMD_STATUSPGRO 24 +#define M_FW_EQ_ETH_CMD_STATUSPGRO 0x1 +#define V_FW_EQ_ETH_CMD_STATUSPGRO(x) ((x) << S_FW_EQ_ETH_CMD_STATUSPGRO) +#define G_FW_EQ_ETH_CMD_STATUSPGRO(x) \ + (((x) >> S_FW_EQ_ETH_CMD_STATUSPGRO) & M_FW_EQ_ETH_CMD_STATUSPGRO) +#define F_FW_EQ_ETH_CMD_STATUSPGRO V_FW_EQ_ETH_CMD_STATUSPGRO(1U) + +#define S_FW_EQ_ETH_CMD_FETCHNS 23 +#define M_FW_EQ_ETH_CMD_FETCHNS 0x1 +#define V_FW_EQ_ETH_CMD_FETCHNS(x) ((x) << S_FW_EQ_ETH_CMD_FETCHNS) +#define G_FW_EQ_ETH_CMD_FETCHNS(x) \ + (((x) >> S_FW_EQ_ETH_CMD_FETCHNS) & M_FW_EQ_ETH_CMD_FETCHNS) +#define F_FW_EQ_ETH_CMD_FETCHNS V_FW_EQ_ETH_CMD_FETCHNS(1U) + +#define S_FW_EQ_ETH_CMD_FETCHRO 22 +#define M_FW_EQ_ETH_CMD_FETCHRO 0x1 +#define V_FW_EQ_ETH_CMD_FETCHRO(x) ((x) << S_FW_EQ_ETH_CMD_FETCHRO) +#define G_FW_EQ_ETH_CMD_FETCHRO(x) \ + (((x) >> S_FW_EQ_ETH_CMD_FETCHRO) & M_FW_EQ_ETH_CMD_FETCHRO) +#define F_FW_EQ_ETH_CMD_FETCHRO V_FW_EQ_ETH_CMD_FETCHRO(1U) + +#define S_FW_EQ_ETH_CMD_HOSTFCMODE 20 +#define M_FW_EQ_ETH_CMD_HOSTFCMODE 0x3 +#define V_FW_EQ_ETH_CMD_HOSTFCMODE(x) ((x) << S_FW_EQ_ETH_CMD_HOSTFCMODE) +#define G_FW_EQ_ETH_CMD_HOSTFCMODE(x) \ + (((x) >> S_FW_EQ_ETH_CMD_HOSTFCMODE) & M_FW_EQ_ETH_CMD_HOSTFCMODE) + +#define S_FW_EQ_ETH_CMD_CPRIO 19 +#define M_FW_EQ_ETH_CMD_CPRIO 0x1 +#define V_FW_EQ_ETH_CMD_CPRIO(x) ((x) << S_FW_EQ_ETH_CMD_CPRIO) +#define G_FW_EQ_ETH_CMD_CPRIO(x) \ + (((x) >> S_FW_EQ_ETH_CMD_CPRIO) & M_FW_EQ_ETH_CMD_CPRIO) +#define F_FW_EQ_ETH_CMD_CPRIO V_FW_EQ_ETH_CMD_CPRIO(1U) + +#define S_FW_EQ_ETH_CMD_ONCHIP 18 +#define M_FW_EQ_ETH_CMD_ONCHIP 0x1 +#define V_FW_EQ_ETH_CMD_ONCHIP(x) ((x) << S_FW_EQ_ETH_CMD_ONCHIP) +#define G_FW_EQ_ETH_CMD_ONCHIP(x) \ + (((x) >> S_FW_EQ_ETH_CMD_ONCHIP) & M_FW_EQ_ETH_CMD_ONCHIP) +#define F_FW_EQ_ETH_CMD_ONCHIP V_FW_EQ_ETH_CMD_ONCHIP(1U) + +#define S_FW_EQ_ETH_CMD_PCIECHN 16 +#define M_FW_EQ_ETH_CMD_PCIECHN 0x3 +#define V_FW_EQ_ETH_CMD_PCIECHN(x) ((x) << S_FW_EQ_ETH_CMD_PCIECHN) +#define G_FW_EQ_ETH_CMD_PCIECHN(x) \ + (((x) >> S_FW_EQ_ETH_CMD_PCIECHN) & M_FW_EQ_ETH_CMD_PCIECHN) + +#define S_FW_EQ_ETH_CMD_IQID 0 +#define M_FW_EQ_ETH_CMD_IQID 0xffff +#define V_FW_EQ_ETH_CMD_IQID(x) ((x) << S_FW_EQ_ETH_CMD_IQID) +#define G_FW_EQ_ETH_CMD_IQID(x) \ + (((x) >> S_FW_EQ_ETH_CMD_IQID) & M_FW_EQ_ETH_CMD_IQID) + +#define S_FW_EQ_ETH_CMD_DCAEN 31 +#define M_FW_EQ_ETH_CMD_DCAEN 0x1 +#define V_FW_EQ_ETH_CMD_DCAEN(x) ((x) << S_FW_EQ_ETH_CMD_DCAEN) +#define G_FW_EQ_ETH_CMD_DCAEN(x) \ + (((x) >> S_FW_EQ_ETH_CMD_DCAEN) & M_FW_EQ_ETH_CMD_DCAEN) +#define F_FW_EQ_ETH_CMD_DCAEN V_FW_EQ_ETH_CMD_DCAEN(1U) + +#define S_FW_EQ_ETH_CMD_DCACPU 26 +#define M_FW_EQ_ETH_CMD_DCACPU 0x1f +#define V_FW_EQ_ETH_CMD_DCACPU(x) ((x) << S_FW_EQ_ETH_CMD_DCACPU) +#define G_FW_EQ_ETH_CMD_DCACPU(x) \ + (((x) >> S_FW_EQ_ETH_CMD_DCACPU) & M_FW_EQ_ETH_CMD_DCACPU) + +#define S_FW_EQ_ETH_CMD_FBMIN 23 +#define M_FW_EQ_ETH_CMD_FBMIN 0x7 +#define V_FW_EQ_ETH_CMD_FBMIN(x) ((x) << S_FW_EQ_ETH_CMD_FBMIN) +#define G_FW_EQ_ETH_CMD_FBMIN(x) \ + (((x) >> S_FW_EQ_ETH_CMD_FBMIN) & M_FW_EQ_ETH_CMD_FBMIN) + +#define S_FW_EQ_ETH_CMD_FBMAX 20 +#define M_FW_EQ_ETH_CMD_FBMAX 0x7 +#define V_FW_EQ_ETH_CMD_FBMAX(x) ((x) << S_FW_EQ_ETH_CMD_FBMAX) +#define G_FW_EQ_ETH_CMD_FBMAX(x) \ + (((x) >> S_FW_EQ_ETH_CMD_FBMAX) & M_FW_EQ_ETH_CMD_FBMAX) + +#define S_FW_EQ_ETH_CMD_CIDXFTHRESHO 19 +#define M_FW_EQ_ETH_CMD_CIDXFTHRESHO 0x1 +#define V_FW_EQ_ETH_CMD_CIDXFTHRESHO(x) ((x) << S_FW_EQ_ETH_CMD_CIDXFTHRESHO) +#define G_FW_EQ_ETH_CMD_CIDXFTHRESHO(x) \ + (((x) >> S_FW_EQ_ETH_CMD_CIDXFTHRESHO) & M_FW_EQ_ETH_CMD_CIDXFTHRESHO) +#define F_FW_EQ_ETH_CMD_CIDXFTHRESHO V_FW_EQ_ETH_CMD_CIDXFTHRESHO(1U) + +#define S_FW_EQ_ETH_CMD_CIDXFTHRESH 16 +#define M_FW_EQ_ETH_CMD_CIDXFTHRESH 0x7 +#define V_FW_EQ_ETH_CMD_CIDXFTHRESH(x) ((x) << S_FW_EQ_ETH_CMD_CIDXFTHRESH) +#define G_FW_EQ_ETH_CMD_CIDXFTHRESH(x) \ + (((x) >> S_FW_EQ_ETH_CMD_CIDXFTHRESH) & M_FW_EQ_ETH_CMD_CIDXFTHRESH) + +#define S_FW_EQ_ETH_CMD_EQSIZE 0 +#define M_FW_EQ_ETH_CMD_EQSIZE 0xffff +#define V_FW_EQ_ETH_CMD_EQSIZE(x) ((x) << S_FW_EQ_ETH_CMD_EQSIZE) +#define G_FW_EQ_ETH_CMD_EQSIZE(x) \ + (((x) >> S_FW_EQ_ETH_CMD_EQSIZE) & M_FW_EQ_ETH_CMD_EQSIZE) + +#define S_FW_EQ_ETH_CMD_VIID 16 +#define M_FW_EQ_ETH_CMD_VIID 0xfff +#define V_FW_EQ_ETH_CMD_VIID(x) ((x) << S_FW_EQ_ETH_CMD_VIID) +#define G_FW_EQ_ETH_CMD_VIID(x) \ + (((x) >> S_FW_EQ_ETH_CMD_VIID) & M_FW_EQ_ETH_CMD_VIID) + +struct fw_eq_ctrl_cmd { + __be32 op_to_vfn; + __be32 alloc_to_len16; + __be32 cmpliqid_eqid; + __be32 physeqid_pkd; + __be32 fetchszm_to_iqid; + __be32 dcaen_to_eqsize; + __be64 eqaddr; +}; + +#define S_FW_EQ_CTRL_CMD_PFN 8 +#define M_FW_EQ_CTRL_CMD_PFN 0x7 +#define V_FW_EQ_CTRL_CMD_PFN(x) ((x) << S_FW_EQ_CTRL_CMD_PFN) +#define G_FW_EQ_CTRL_CMD_PFN(x) \ + (((x) >> S_FW_EQ_CTRL_CMD_PFN) & M_FW_EQ_CTRL_CMD_PFN) + +#define S_FW_EQ_CTRL_CMD_VFN 0 +#define M_FW_EQ_CTRL_CMD_VFN 0xff +#define V_FW_EQ_CTRL_CMD_VFN(x) ((x) << S_FW_EQ_CTRL_CMD_VFN) +#define G_FW_EQ_CTRL_CMD_VFN(x) \ + (((x) >> S_FW_EQ_CTRL_CMD_VFN) & M_FW_EQ_CTRL_CMD_VFN) + +#define S_FW_EQ_CTRL_CMD_ALLOC 31 +#define M_FW_EQ_CTRL_CMD_ALLOC 0x1 +#define V_FW_EQ_CTRL_CMD_ALLOC(x) ((x) << S_FW_EQ_CTRL_CMD_ALLOC) +#define G_FW_EQ_CTRL_CMD_ALLOC(x) \ + (((x) >> S_FW_EQ_CTRL_CMD_ALLOC) & M_FW_EQ_CTRL_CMD_ALLOC) +#define F_FW_EQ_CTRL_CMD_ALLOC V_FW_EQ_CTRL_CMD_ALLOC(1U) + +#define S_FW_EQ_CTRL_CMD_FREE 30 +#define M_FW_EQ_CTRL_CMD_FREE 0x1 +#define V_FW_EQ_CTRL_CMD_FREE(x) ((x) << S_FW_EQ_CTRL_CMD_FREE) +#define G_FW_EQ_CTRL_CMD_FREE(x) \ + (((x) >> S_FW_EQ_CTRL_CMD_FREE) & M_FW_EQ_CTRL_CMD_FREE) +#define F_FW_EQ_CTRL_CMD_FREE V_FW_EQ_CTRL_CMD_FREE(1U) + +#define S_FW_EQ_CTRL_CMD_MODIFY 29 +#define M_FW_EQ_CTRL_CMD_MODIFY 0x1 +#define V_FW_EQ_CTRL_CMD_MODIFY(x) ((x) << S_FW_EQ_CTRL_CMD_MODIFY) +#define G_FW_EQ_CTRL_CMD_MODIFY(x) \ + (((x) >> S_FW_EQ_CTRL_CMD_MODIFY) & M_FW_EQ_CTRL_CMD_MODIFY) +#define F_FW_EQ_CTRL_CMD_MODIFY V_FW_EQ_CTRL_CMD_MODIFY(1U) + +#define S_FW_EQ_CTRL_CMD_EQSTART 28 +#define M_FW_EQ_CTRL_CMD_EQSTART 0x1 +#define V_FW_EQ_CTRL_CMD_EQSTART(x) ((x) << S_FW_EQ_CTRL_CMD_EQSTART) +#define G_FW_EQ_CTRL_CMD_EQSTART(x) \ + (((x) >> S_FW_EQ_CTRL_CMD_EQSTART) & M_FW_EQ_CTRL_CMD_EQSTART) +#define F_FW_EQ_CTRL_CMD_EQSTART V_FW_EQ_CTRL_CMD_EQSTART(1U) + +#define S_FW_EQ_CTRL_CMD_EQSTOP 27 +#define M_FW_EQ_CTRL_CMD_EQSTOP 0x1 +#define V_FW_EQ_CTRL_CMD_EQSTOP(x) ((x) << S_FW_EQ_CTRL_CMD_EQSTOP) +#define G_FW_EQ_CTRL_CMD_EQSTOP(x) \ + (((x) >> S_FW_EQ_CTRL_CMD_EQSTOP) & M_FW_EQ_CTRL_CMD_EQSTOP) +#define F_FW_EQ_CTRL_CMD_EQSTOP V_FW_EQ_CTRL_CMD_EQSTOP(1U) + +#define S_FW_EQ_CTRL_CMD_CMPLIQID 20 +#define M_FW_EQ_CTRL_CMD_CMPLIQID 0xfff +#define V_FW_EQ_CTRL_CMD_CMPLIQID(x) ((x) << S_FW_EQ_CTRL_CMD_CMPLIQID) +#define G_FW_EQ_CTRL_CMD_CMPLIQID(x) \ + (((x) >> S_FW_EQ_CTRL_CMD_CMPLIQID) & M_FW_EQ_CTRL_CMD_CMPLIQID) + +#define S_FW_EQ_CTRL_CMD_EQID 0 +#define M_FW_EQ_CTRL_CMD_EQID 0xfffff +#define V_FW_EQ_CTRL_CMD_EQID(x) ((x) << S_FW_EQ_CTRL_CMD_EQID) +#define G_FW_EQ_CTRL_CMD_EQID(x) \ + (((x) >> S_FW_EQ_CTRL_CMD_EQID) & M_FW_EQ_CTRL_CMD_EQID) + +#define S_FW_EQ_CTRL_CMD_PHYSEQID 0 +#define M_FW_EQ_CTRL_CMD_PHYSEQID 0xfffff +#define V_FW_EQ_CTRL_CMD_PHYSEQID(x) ((x) << S_FW_EQ_CTRL_CMD_PHYSEQID) +#define G_FW_EQ_CTRL_CMD_PHYSEQID(x) \ + (((x) >> S_FW_EQ_CTRL_CMD_PHYSEQID) & M_FW_EQ_CTRL_CMD_PHYSEQID) + +#define S_FW_EQ_CTRL_CMD_FETCHSZM 26 +#define M_FW_EQ_CTRL_CMD_FETCHSZM 0x1 +#define V_FW_EQ_CTRL_CMD_FETCHSZM(x) ((x) << S_FW_EQ_CTRL_CMD_FETCHSZM) +#define G_FW_EQ_CTRL_CMD_FETCHSZM(x) \ + (((x) >> S_FW_EQ_CTRL_CMD_FETCHSZM) & M_FW_EQ_CTRL_CMD_FETCHSZM) +#define F_FW_EQ_CTRL_CMD_FETCHSZM V_FW_EQ_CTRL_CMD_FETCHSZM(1U) + +#define S_FW_EQ_CTRL_CMD_STATUSPGNS 25 +#define M_FW_EQ_CTRL_CMD_STATUSPGNS 0x1 +#define V_FW_EQ_CTRL_CMD_STATUSPGNS(x) ((x) << S_FW_EQ_CTRL_CMD_STATUSPGNS) +#define G_FW_EQ_CTRL_CMD_STATUSPGNS(x) \ + (((x) >> S_FW_EQ_CTRL_CMD_STATUSPGNS) & M_FW_EQ_CTRL_CMD_STATUSPGNS) +#define F_FW_EQ_CTRL_CMD_STATUSPGNS V_FW_EQ_CTRL_CMD_STATUSPGNS(1U) + +#define S_FW_EQ_CTRL_CMD_STATUSPGRO 24 +#define M_FW_EQ_CTRL_CMD_STATUSPGRO 0x1 +#define V_FW_EQ_CTRL_CMD_STATUSPGRO(x) ((x) << S_FW_EQ_CTRL_CMD_STATUSPGRO) +#define G_FW_EQ_CTRL_CMD_STATUSPGRO(x) \ + (((x) >> S_FW_EQ_CTRL_CMD_STATUSPGRO) & M_FW_EQ_CTRL_CMD_STATUSPGRO) +#define F_FW_EQ_CTRL_CMD_STATUSPGRO V_FW_EQ_CTRL_CMD_STATUSPGRO(1U) + +#define S_FW_EQ_CTRL_CMD_FETCHNS 23 +#define M_FW_EQ_CTRL_CMD_FETCHNS 0x1 +#define V_FW_EQ_CTRL_CMD_FETCHNS(x) ((x) << S_FW_EQ_CTRL_CMD_FETCHNS) +#define G_FW_EQ_CTRL_CMD_FETCHNS(x) \ + (((x) >> S_FW_EQ_CTRL_CMD_FETCHNS) & M_FW_EQ_CTRL_CMD_FETCHNS) +#define F_FW_EQ_CTRL_CMD_FETCHNS V_FW_EQ_CTRL_CMD_FETCHNS(1U) + +#define S_FW_EQ_CTRL_CMD_FETCHRO 22 +#define M_FW_EQ_CTRL_CMD_FETCHRO 0x1 +#define V_FW_EQ_CTRL_CMD_FETCHRO(x) ((x) << S_FW_EQ_CTRL_CMD_FETCHRO) +#define G_FW_EQ_CTRL_CMD_FETCHRO(x) \ + (((x) >> S_FW_EQ_CTRL_CMD_FETCHRO) & M_FW_EQ_CTRL_CMD_FETCHRO) +#define F_FW_EQ_CTRL_CMD_FETCHRO V_FW_EQ_CTRL_CMD_FETCHRO(1U) + +#define S_FW_EQ_CTRL_CMD_HOSTFCMODE 20 +#define M_FW_EQ_CTRL_CMD_HOSTFCMODE 0x3 +#define V_FW_EQ_CTRL_CMD_HOSTFCMODE(x) ((x) << S_FW_EQ_CTRL_CMD_HOSTFCMODE) +#define G_FW_EQ_CTRL_CMD_HOSTFCMODE(x) \ + (((x) >> S_FW_EQ_CTRL_CMD_HOSTFCMODE) & M_FW_EQ_CTRL_CMD_HOSTFCMODE) + +#define S_FW_EQ_CTRL_CMD_CPRIO 19 +#define M_FW_EQ_CTRL_CMD_CPRIO 0x1 +#define V_FW_EQ_CTRL_CMD_CPRIO(x) ((x) << S_FW_EQ_CTRL_CMD_CPRIO) +#define G_FW_EQ_CTRL_CMD_CPRIO(x) \ + (((x) >> S_FW_EQ_CTRL_CMD_CPRIO) & M_FW_EQ_CTRL_CMD_CPRIO) +#define F_FW_EQ_CTRL_CMD_CPRIO V_FW_EQ_CTRL_CMD_CPRIO(1U) + +#define S_FW_EQ_CTRL_CMD_ONCHIP 18 +#define M_FW_EQ_CTRL_CMD_ONCHIP 0x1 +#define V_FW_EQ_CTRL_CMD_ONCHIP(x) ((x) << S_FW_EQ_CTRL_CMD_ONCHIP) +#define G_FW_EQ_CTRL_CMD_ONCHIP(x) \ + (((x) >> S_FW_EQ_CTRL_CMD_ONCHIP) & M_FW_EQ_CTRL_CMD_ONCHIP) +#define F_FW_EQ_CTRL_CMD_ONCHIP V_FW_EQ_CTRL_CMD_ONCHIP(1U) + +#define S_FW_EQ_CTRL_CMD_PCIECHN 16 +#define M_FW_EQ_CTRL_CMD_PCIECHN 0x3 +#define V_FW_EQ_CTRL_CMD_PCIECHN(x) ((x) << S_FW_EQ_CTRL_CMD_PCIECHN) +#define G_FW_EQ_CTRL_CMD_PCIECHN(x) \ + (((x) >> S_FW_EQ_CTRL_CMD_PCIECHN) & M_FW_EQ_CTRL_CMD_PCIECHN) + +#define S_FW_EQ_CTRL_CMD_IQID 0 +#define M_FW_EQ_CTRL_CMD_IQID 0xffff +#define V_FW_EQ_CTRL_CMD_IQID(x) ((x) << S_FW_EQ_CTRL_CMD_IQID) +#define G_FW_EQ_CTRL_CMD_IQID(x) \ + (((x) >> S_FW_EQ_CTRL_CMD_IQID) & M_FW_EQ_CTRL_CMD_IQID) + +#define S_FW_EQ_CTRL_CMD_DCAEN 31 +#define M_FW_EQ_CTRL_CMD_DCAEN 0x1 +#define V_FW_EQ_CTRL_CMD_DCAEN(x) ((x) << S_FW_EQ_CTRL_CMD_DCAEN) +#define G_FW_EQ_CTRL_CMD_DCAEN(x) \ + (((x) >> S_FW_EQ_CTRL_CMD_DCAEN) & M_FW_EQ_CTRL_CMD_DCAEN) +#define F_FW_EQ_CTRL_CMD_DCAEN V_FW_EQ_CTRL_CMD_DCAEN(1U) + +#define S_FW_EQ_CTRL_CMD_DCACPU 26 +#define M_FW_EQ_CTRL_CMD_DCACPU 0x1f +#define V_FW_EQ_CTRL_CMD_DCACPU(x) ((x) << S_FW_EQ_CTRL_CMD_DCACPU) +#define G_FW_EQ_CTRL_CMD_DCACPU(x) \ + (((x) >> S_FW_EQ_CTRL_CMD_DCACPU) & M_FW_EQ_CTRL_CMD_DCACPU) + +#define S_FW_EQ_CTRL_CMD_FBMIN 23 +#define M_FW_EQ_CTRL_CMD_FBMIN 0x7 +#define V_FW_EQ_CTRL_CMD_FBMIN(x) ((x) << S_FW_EQ_CTRL_CMD_FBMIN) +#define G_FW_EQ_CTRL_CMD_FBMIN(x) \ + (((x) >> S_FW_EQ_CTRL_CMD_FBMIN) & M_FW_EQ_CTRL_CMD_FBMIN) + +#define S_FW_EQ_CTRL_CMD_FBMAX 20 +#define M_FW_EQ_CTRL_CMD_FBMAX 0x7 +#define V_FW_EQ_CTRL_CMD_FBMAX(x) ((x) << S_FW_EQ_CTRL_CMD_FBMAX) +#define G_FW_EQ_CTRL_CMD_FBMAX(x) \ + (((x) >> S_FW_EQ_CTRL_CMD_FBMAX) & M_FW_EQ_CTRL_CMD_FBMAX) + +#define S_FW_EQ_CTRL_CMD_CIDXFTHRESHO 19 +#define M_FW_EQ_CTRL_CMD_CIDXFTHRESHO 0x1 +#define V_FW_EQ_CTRL_CMD_CIDXFTHRESHO(x) \ + ((x) << S_FW_EQ_CTRL_CMD_CIDXFTHRESHO) +#define G_FW_EQ_CTRL_CMD_CIDXFTHRESHO(x) \ + (((x) >> S_FW_EQ_CTRL_CMD_CIDXFTHRESHO) & M_FW_EQ_CTRL_CMD_CIDXFTHRESHO) +#define F_FW_EQ_CTRL_CMD_CIDXFTHRESHO V_FW_EQ_CTRL_CMD_CIDXFTHRESHO(1U) + +#define S_FW_EQ_CTRL_CMD_CIDXFTHRESH 16 +#define M_FW_EQ_CTRL_CMD_CIDXFTHRESH 0x7 +#define V_FW_EQ_CTRL_CMD_CIDXFTHRESH(x) ((x) << S_FW_EQ_CTRL_CMD_CIDXFTHRESH) +#define G_FW_EQ_CTRL_CMD_CIDXFTHRESH(x) \ + (((x) >> S_FW_EQ_CTRL_CMD_CIDXFTHRESH) & M_FW_EQ_CTRL_CMD_CIDXFTHRESH) + +#define S_FW_EQ_CTRL_CMD_EQSIZE 0 +#define M_FW_EQ_CTRL_CMD_EQSIZE 0xffff +#define V_FW_EQ_CTRL_CMD_EQSIZE(x) ((x) << S_FW_EQ_CTRL_CMD_EQSIZE) +#define G_FW_EQ_CTRL_CMD_EQSIZE(x) \ + (((x) >> S_FW_EQ_CTRL_CMD_EQSIZE) & M_FW_EQ_CTRL_CMD_EQSIZE) + +struct fw_eq_ofld_cmd { + __be32 op_to_vfn; + __be32 alloc_to_len16; + __be32 eqid_pkd; + __be32 physeqid_pkd; + __be32 fetchszm_to_iqid; + __be32 dcaen_to_eqsize; + __be64 eqaddr; +}; + +#define S_FW_EQ_OFLD_CMD_PFN 8 +#define M_FW_EQ_OFLD_CMD_PFN 0x7 +#define V_FW_EQ_OFLD_CMD_PFN(x) ((x) << S_FW_EQ_OFLD_CMD_PFN) +#define G_FW_EQ_OFLD_CMD_PFN(x) \ + (((x) >> S_FW_EQ_OFLD_CMD_PFN) & M_FW_EQ_OFLD_CMD_PFN) + +#define S_FW_EQ_OFLD_CMD_VFN 0 +#define M_FW_EQ_OFLD_CMD_VFN 0xff +#define V_FW_EQ_OFLD_CMD_VFN(x) ((x) << S_FW_EQ_OFLD_CMD_VFN) +#define G_FW_EQ_OFLD_CMD_VFN(x) \ + (((x) >> S_FW_EQ_OFLD_CMD_VFN) & M_FW_EQ_OFLD_CMD_VFN) + +#define S_FW_EQ_OFLD_CMD_ALLOC 31 +#define M_FW_EQ_OFLD_CMD_ALLOC 0x1 +#define V_FW_EQ_OFLD_CMD_ALLOC(x) ((x) << S_FW_EQ_OFLD_CMD_ALLOC) +#define G_FW_EQ_OFLD_CMD_ALLOC(x) \ + (((x) >> S_FW_EQ_OFLD_CMD_ALLOC) & M_FW_EQ_OFLD_CMD_ALLOC) +#define F_FW_EQ_OFLD_CMD_ALLOC V_FW_EQ_OFLD_CMD_ALLOC(1U) + +#define S_FW_EQ_OFLD_CMD_FREE 30 +#define M_FW_EQ_OFLD_CMD_FREE 0x1 +#define V_FW_EQ_OFLD_CMD_FREE(x) ((x) << S_FW_EQ_OFLD_CMD_FREE) +#define G_FW_EQ_OFLD_CMD_FREE(x) \ + (((x) >> S_FW_EQ_OFLD_CMD_FREE) & M_FW_EQ_OFLD_CMD_FREE) +#define F_FW_EQ_OFLD_CMD_FREE V_FW_EQ_OFLD_CMD_FREE(1U) + +#define S_FW_EQ_OFLD_CMD_MODIFY 29 +#define M_FW_EQ_OFLD_CMD_MODIFY 0x1 +#define V_FW_EQ_OFLD_CMD_MODIFY(x) ((x) << S_FW_EQ_OFLD_CMD_MODIFY) +#define G_FW_EQ_OFLD_CMD_MODIFY(x) \ + (((x) >> S_FW_EQ_OFLD_CMD_MODIFY) & M_FW_EQ_OFLD_CMD_MODIFY) +#define F_FW_EQ_OFLD_CMD_MODIFY V_FW_EQ_OFLD_CMD_MODIFY(1U) + +#define S_FW_EQ_OFLD_CMD_EQSTART 28 +#define M_FW_EQ_OFLD_CMD_EQSTART 0x1 +#define V_FW_EQ_OFLD_CMD_EQSTART(x) ((x) << S_FW_EQ_OFLD_CMD_EQSTART) +#define G_FW_EQ_OFLD_CMD_EQSTART(x) \ + (((x) >> S_FW_EQ_OFLD_CMD_EQSTART) & M_FW_EQ_OFLD_CMD_EQSTART) +#define F_FW_EQ_OFLD_CMD_EQSTART V_FW_EQ_OFLD_CMD_EQSTART(1U) + +#define S_FW_EQ_OFLD_CMD_EQSTOP 27 +#define M_FW_EQ_OFLD_CMD_EQSTOP 0x1 +#define V_FW_EQ_OFLD_CMD_EQSTOP(x) ((x) << S_FW_EQ_OFLD_CMD_EQSTOP) +#define G_FW_EQ_OFLD_CMD_EQSTOP(x) \ + (((x) >> S_FW_EQ_OFLD_CMD_EQSTOP) & M_FW_EQ_OFLD_CMD_EQSTOP) +#define F_FW_EQ_OFLD_CMD_EQSTOP V_FW_EQ_OFLD_CMD_EQSTOP(1U) + +#define S_FW_EQ_OFLD_CMD_EQID 0 +#define M_FW_EQ_OFLD_CMD_EQID 0xfffff +#define V_FW_EQ_OFLD_CMD_EQID(x) ((x) << S_FW_EQ_OFLD_CMD_EQID) +#define G_FW_EQ_OFLD_CMD_EQID(x) \ + (((x) >> S_FW_EQ_OFLD_CMD_EQID) & M_FW_EQ_OFLD_CMD_EQID) + +#define S_FW_EQ_OFLD_CMD_PHYSEQID 0 +#define M_FW_EQ_OFLD_CMD_PHYSEQID 0xfffff +#define V_FW_EQ_OFLD_CMD_PHYSEQID(x) ((x) << S_FW_EQ_OFLD_CMD_PHYSEQID) +#define G_FW_EQ_OFLD_CMD_PHYSEQID(x) \ + (((x) >> S_FW_EQ_OFLD_CMD_PHYSEQID) & M_FW_EQ_OFLD_CMD_PHYSEQID) + +#define S_FW_EQ_OFLD_CMD_FETCHSZM 26 +#define M_FW_EQ_OFLD_CMD_FETCHSZM 0x1 +#define V_FW_EQ_OFLD_CMD_FETCHSZM(x) ((x) << S_FW_EQ_OFLD_CMD_FETCHSZM) +#define G_FW_EQ_OFLD_CMD_FETCHSZM(x) \ + (((x) >> S_FW_EQ_OFLD_CMD_FETCHSZM) & M_FW_EQ_OFLD_CMD_FETCHSZM) +#define F_FW_EQ_OFLD_CMD_FETCHSZM V_FW_EQ_OFLD_CMD_FETCHSZM(1U) + +#define S_FW_EQ_OFLD_CMD_STATUSPGNS 25 +#define M_FW_EQ_OFLD_CMD_STATUSPGNS 0x1 +#define V_FW_EQ_OFLD_CMD_STATUSPGNS(x) ((x) << S_FW_EQ_OFLD_CMD_STATUSPGNS) +#define G_FW_EQ_OFLD_CMD_STATUSPGNS(x) \ + (((x) >> S_FW_EQ_OFLD_CMD_STATUSPGNS) & M_FW_EQ_OFLD_CMD_STATUSPGNS) +#define F_FW_EQ_OFLD_CMD_STATUSPGNS V_FW_EQ_OFLD_CMD_STATUSPGNS(1U) + +#define S_FW_EQ_OFLD_CMD_STATUSPGRO 24 +#define M_FW_EQ_OFLD_CMD_STATUSPGRO 0x1 +#define V_FW_EQ_OFLD_CMD_STATUSPGRO(x) ((x) << S_FW_EQ_OFLD_CMD_STATUSPGRO) +#define G_FW_EQ_OFLD_CMD_STATUSPGRO(x) \ + (((x) >> S_FW_EQ_OFLD_CMD_STATUSPGRO) & M_FW_EQ_OFLD_CMD_STATUSPGRO) +#define F_FW_EQ_OFLD_CMD_STATUSPGRO V_FW_EQ_OFLD_CMD_STATUSPGRO(1U) + +#define S_FW_EQ_OFLD_CMD_FETCHNS 23 +#define M_FW_EQ_OFLD_CMD_FETCHNS 0x1 +#define V_FW_EQ_OFLD_CMD_FETCHNS(x) ((x) << S_FW_EQ_OFLD_CMD_FETCHNS) +#define G_FW_EQ_OFLD_CMD_FETCHNS(x) \ + (((x) >> S_FW_EQ_OFLD_CMD_FETCHNS) & M_FW_EQ_OFLD_CMD_FETCHNS) +#define F_FW_EQ_OFLD_CMD_FETCHNS V_FW_EQ_OFLD_CMD_FETCHNS(1U) + +#define S_FW_EQ_OFLD_CMD_FETCHRO 22 +#define M_FW_EQ_OFLD_CMD_FETCHRO 0x1 +#define V_FW_EQ_OFLD_CMD_FETCHRO(x) ((x) << S_FW_EQ_OFLD_CMD_FETCHRO) +#define G_FW_EQ_OFLD_CMD_FETCHRO(x) \ + (((x) >> S_FW_EQ_OFLD_CMD_FETCHRO) & M_FW_EQ_OFLD_CMD_FETCHRO) +#define F_FW_EQ_OFLD_CMD_FETCHRO V_FW_EQ_OFLD_CMD_FETCHRO(1U) + +#define S_FW_EQ_OFLD_CMD_HOSTFCMODE 20 +#define M_FW_EQ_OFLD_CMD_HOSTFCMODE 0x3 +#define V_FW_EQ_OFLD_CMD_HOSTFCMODE(x) ((x) << S_FW_EQ_OFLD_CMD_HOSTFCMODE) +#define G_FW_EQ_OFLD_CMD_HOSTFCMODE(x) \ + (((x) >> S_FW_EQ_OFLD_CMD_HOSTFCMODE) & M_FW_EQ_OFLD_CMD_HOSTFCMODE) + +#define S_FW_EQ_OFLD_CMD_CPRIO 19 +#define M_FW_EQ_OFLD_CMD_CPRIO 0x1 +#define V_FW_EQ_OFLD_CMD_CPRIO(x) ((x) << S_FW_EQ_OFLD_CMD_CPRIO) +#define G_FW_EQ_OFLD_CMD_CPRIO(x) \ + (((x) >> S_FW_EQ_OFLD_CMD_CPRIO) & M_FW_EQ_OFLD_CMD_CPRIO) +#define F_FW_EQ_OFLD_CMD_CPRIO V_FW_EQ_OFLD_CMD_CPRIO(1U) + +#define S_FW_EQ_OFLD_CMD_ONCHIP 18 +#define M_FW_EQ_OFLD_CMD_ONCHIP 0x1 +#define V_FW_EQ_OFLD_CMD_ONCHIP(x) ((x) << S_FW_EQ_OFLD_CMD_ONCHIP) +#define G_FW_EQ_OFLD_CMD_ONCHIP(x) \ + (((x) >> S_FW_EQ_OFLD_CMD_ONCHIP) & M_FW_EQ_OFLD_CMD_ONCHIP) +#define F_FW_EQ_OFLD_CMD_ONCHIP V_FW_EQ_OFLD_CMD_ONCHIP(1U) + +#define S_FW_EQ_OFLD_CMD_PCIECHN 16 +#define M_FW_EQ_OFLD_CMD_PCIECHN 0x3 +#define V_FW_EQ_OFLD_CMD_PCIECHN(x) ((x) << S_FW_EQ_OFLD_CMD_PCIECHN) +#define G_FW_EQ_OFLD_CMD_PCIECHN(x) \ + (((x) >> S_FW_EQ_OFLD_CMD_PCIECHN) & M_FW_EQ_OFLD_CMD_PCIECHN) + +#define S_FW_EQ_OFLD_CMD_IQID 0 +#define M_FW_EQ_OFLD_CMD_IQID 0xffff +#define V_FW_EQ_OFLD_CMD_IQID(x) ((x) << S_FW_EQ_OFLD_CMD_IQID) +#define G_FW_EQ_OFLD_CMD_IQID(x) \ + (((x) >> S_FW_EQ_OFLD_CMD_IQID) & M_FW_EQ_OFLD_CMD_IQID) + +#define S_FW_EQ_OFLD_CMD_DCAEN 31 +#define M_FW_EQ_OFLD_CMD_DCAEN 0x1 +#define V_FW_EQ_OFLD_CMD_DCAEN(x) ((x) << S_FW_EQ_OFLD_CMD_DCAEN) +#define G_FW_EQ_OFLD_CMD_DCAEN(x) \ + (((x) >> S_FW_EQ_OFLD_CMD_DCAEN) & M_FW_EQ_OFLD_CMD_DCAEN) +#define F_FW_EQ_OFLD_CMD_DCAEN V_FW_EQ_OFLD_CMD_DCAEN(1U) + +#define S_FW_EQ_OFLD_CMD_DCACPU 26 +#define M_FW_EQ_OFLD_CMD_DCACPU 0x1f +#define V_FW_EQ_OFLD_CMD_DCACPU(x) ((x) << S_FW_EQ_OFLD_CMD_DCACPU) +#define G_FW_EQ_OFLD_CMD_DCACPU(x) \ + (((x) >> S_FW_EQ_OFLD_CMD_DCACPU) & M_FW_EQ_OFLD_CMD_DCACPU) + +#define S_FW_EQ_OFLD_CMD_FBMIN 23 +#define M_FW_EQ_OFLD_CMD_FBMIN 0x7 +#define V_FW_EQ_OFLD_CMD_FBMIN(x) ((x) << S_FW_EQ_OFLD_CMD_FBMIN) +#define G_FW_EQ_OFLD_CMD_FBMIN(x) \ + (((x) >> S_FW_EQ_OFLD_CMD_FBMIN) & M_FW_EQ_OFLD_CMD_FBMIN) + +#define S_FW_EQ_OFLD_CMD_FBMAX 20 +#define M_FW_EQ_OFLD_CMD_FBMAX 0x7 +#define V_FW_EQ_OFLD_CMD_FBMAX(x) ((x) << S_FW_EQ_OFLD_CMD_FBMAX) +#define G_FW_EQ_OFLD_CMD_FBMAX(x) \ + (((x) >> S_FW_EQ_OFLD_CMD_FBMAX) & M_FW_EQ_OFLD_CMD_FBMAX) + +#define S_FW_EQ_OFLD_CMD_CIDXFTHRESHO 19 +#define M_FW_EQ_OFLD_CMD_CIDXFTHRESHO 0x1 +#define V_FW_EQ_OFLD_CMD_CIDXFTHRESHO(x) \ + ((x) << S_FW_EQ_OFLD_CMD_CIDXFTHRESHO) +#define G_FW_EQ_OFLD_CMD_CIDXFTHRESHO(x) \ + (((x) >> S_FW_EQ_OFLD_CMD_CIDXFTHRESHO) & M_FW_EQ_OFLD_CMD_CIDXFTHRESHO) +#define F_FW_EQ_OFLD_CMD_CIDXFTHRESHO V_FW_EQ_OFLD_CMD_CIDXFTHRESHO(1U) + +#define S_FW_EQ_OFLD_CMD_CIDXFTHRESH 16 +#define M_FW_EQ_OFLD_CMD_CIDXFTHRESH 0x7 +#define V_FW_EQ_OFLD_CMD_CIDXFTHRESH(x) ((x) << S_FW_EQ_OFLD_CMD_CIDXFTHRESH) +#define G_FW_EQ_OFLD_CMD_CIDXFTHRESH(x) \ + (((x) >> S_FW_EQ_OFLD_CMD_CIDXFTHRESH) & M_FW_EQ_OFLD_CMD_CIDXFTHRESH) + +#define S_FW_EQ_OFLD_CMD_EQSIZE 0 +#define M_FW_EQ_OFLD_CMD_EQSIZE 0xffff +#define V_FW_EQ_OFLD_CMD_EQSIZE(x) ((x) << S_FW_EQ_OFLD_CMD_EQSIZE) +#define G_FW_EQ_OFLD_CMD_EQSIZE(x) \ + (((x) >> S_FW_EQ_OFLD_CMD_EQSIZE) & M_FW_EQ_OFLD_CMD_EQSIZE) + +/* Macros for VIID parsing: + VIID - [10:8] PFN, [7] VI Valid, [6:0] VI number */ +#define S_FW_VIID_PFN 8 +#define M_FW_VIID_PFN 0x7 +#define V_FW_VIID_PFN(x) ((x) << S_FW_VIID_PFN) +#define G_FW_VIID_PFN(x) (((x) >> S_FW_VIID_PFN) & M_FW_VIID_PFN) + +#define S_FW_VIID_VIVLD 7 +#define M_FW_VIID_VIVLD 0x1 +#define V_FW_VIID_VIVLD(x) ((x) << S_FW_VIID_VIVLD) +#define G_FW_VIID_VIVLD(x) (((x) >> S_FW_VIID_VIVLD) & M_FW_VIID_VIVLD) + +#define S_FW_VIID_VIN 0 +#define M_FW_VIID_VIN 0x7F +#define V_FW_VIID_VIN(x) ((x) << S_FW_VIID_VIN) +#define G_FW_VIID_VIN(x) (((x) >> S_FW_VIID_VIN) & M_FW_VIID_VIN) + +enum fw_vi_func { + FW_VI_FUNC_ETH, + FW_VI_FUNC_OFLD, + FW_VI_FUNC_IWARP, + FW_VI_FUNC_OPENISCSI, + FW_VI_FUNC_OPENFCOE, + FW_VI_FUNC_FOISCSI, + FW_VI_FUNC_FOFCOE, + FW_VI_FUNC_FW, +}; + +struct fw_vi_cmd { + __be32 op_to_vfn; + __be32 alloc_to_len16; + __be16 type_to_viid; + __u8 mac[6]; + __u8 portid_pkd; + __u8 nmac; + __u8 nmac0[6]; + __be16 norss_rsssize; + __u8 nmac1[6]; + __be16 idsiiq_pkd; + __u8 nmac2[6]; + __be16 idseiq_pkd; + __u8 nmac3[6]; + __be64 r9; + __be64 r10; +}; + +#define S_FW_VI_CMD_PFN 8 +#define M_FW_VI_CMD_PFN 0x7 +#define V_FW_VI_CMD_PFN(x) ((x) << S_FW_VI_CMD_PFN) +#define G_FW_VI_CMD_PFN(x) (((x) >> S_FW_VI_CMD_PFN) & M_FW_VI_CMD_PFN) + +#define S_FW_VI_CMD_VFN 0 +#define M_FW_VI_CMD_VFN 0xff +#define V_FW_VI_CMD_VFN(x) ((x) << S_FW_VI_CMD_VFN) +#define G_FW_VI_CMD_VFN(x) (((x) >> S_FW_VI_CMD_VFN) & M_FW_VI_CMD_VFN) + +#define S_FW_VI_CMD_ALLOC 31 +#define M_FW_VI_CMD_ALLOC 0x1 +#define V_FW_VI_CMD_ALLOC(x) ((x) << S_FW_VI_CMD_ALLOC) +#define G_FW_VI_CMD_ALLOC(x) \ + (((x) >> S_FW_VI_CMD_ALLOC) & M_FW_VI_CMD_ALLOC) +#define F_FW_VI_CMD_ALLOC V_FW_VI_CMD_ALLOC(1U) + +#define S_FW_VI_CMD_FREE 30 +#define M_FW_VI_CMD_FREE 0x1 +#define V_FW_VI_CMD_FREE(x) ((x) << S_FW_VI_CMD_FREE) +#define G_FW_VI_CMD_FREE(x) (((x) >> S_FW_VI_CMD_FREE) & M_FW_VI_CMD_FREE) +#define F_FW_VI_CMD_FREE V_FW_VI_CMD_FREE(1U) + +#define S_FW_VI_CMD_TYPE 15 +#define M_FW_VI_CMD_TYPE 0x1 +#define V_FW_VI_CMD_TYPE(x) ((x) << S_FW_VI_CMD_TYPE) +#define G_FW_VI_CMD_TYPE(x) (((x) >> S_FW_VI_CMD_TYPE) & M_FW_VI_CMD_TYPE) +#define F_FW_VI_CMD_TYPE V_FW_VI_CMD_TYPE(1U) + +#define S_FW_VI_CMD_FUNC 12 +#define M_FW_VI_CMD_FUNC 0x7 +#define V_FW_VI_CMD_FUNC(x) ((x) << S_FW_VI_CMD_FUNC) +#define G_FW_VI_CMD_FUNC(x) (((x) >> S_FW_VI_CMD_FUNC) & M_FW_VI_CMD_FUNC) + +#define S_FW_VI_CMD_VIID 0 +#define M_FW_VI_CMD_VIID 0xfff +#define V_FW_VI_CMD_VIID(x) ((x) << S_FW_VI_CMD_VIID) +#define G_FW_VI_CMD_VIID(x) (((x) >> S_FW_VI_CMD_VIID) & M_FW_VI_CMD_VIID) + +#define S_FW_VI_CMD_PORTID 4 +#define M_FW_VI_CMD_PORTID 0xf +#define V_FW_VI_CMD_PORTID(x) ((x) << S_FW_VI_CMD_PORTID) +#define G_FW_VI_CMD_PORTID(x) \ + (((x) >> S_FW_VI_CMD_PORTID) & M_FW_VI_CMD_PORTID) + +#define S_FW_VI_CMD_NORSS 11 +#define M_FW_VI_CMD_NORSS 0x1 +#define V_FW_VI_CMD_NORSS(x) ((x) << S_FW_VI_CMD_NORSS) +#define G_FW_VI_CMD_NORSS(x) \ + (((x) >> S_FW_VI_CMD_NORSS) & M_FW_VI_CMD_NORSS) +#define F_FW_VI_CMD_NORSS V_FW_VI_CMD_NORSS(1U) + +#define S_FW_VI_CMD_RSSSIZE 0 +#define M_FW_VI_CMD_RSSSIZE 0x7ff +#define V_FW_VI_CMD_RSSSIZE(x) ((x) << S_FW_VI_CMD_RSSSIZE) +#define G_FW_VI_CMD_RSSSIZE(x) \ + (((x) >> S_FW_VI_CMD_RSSSIZE) & M_FW_VI_CMD_RSSSIZE) + +#define S_FW_VI_CMD_IDSIIQ 0 +#define M_FW_VI_CMD_IDSIIQ 0x3ff +#define V_FW_VI_CMD_IDSIIQ(x) ((x) << S_FW_VI_CMD_IDSIIQ) +#define G_FW_VI_CMD_IDSIIQ(x) \ + (((x) >> S_FW_VI_CMD_IDSIIQ) & M_FW_VI_CMD_IDSIIQ) + +#define S_FW_VI_CMD_IDSEIQ 0 +#define M_FW_VI_CMD_IDSEIQ 0x3ff +#define V_FW_VI_CMD_IDSEIQ(x) ((x) << S_FW_VI_CMD_IDSEIQ) +#define G_FW_VI_CMD_IDSEIQ(x) \ + (((x) >> S_FW_VI_CMD_IDSEIQ) & M_FW_VI_CMD_IDSEIQ) + +/* Special VI_MAC command index ids */ +#define FW_VI_MAC_ADD_MAC 0x3FF +#define FW_VI_MAC_ADD_PERSIST_MAC 0x3FE +#define FW_VI_MAC_MAC_BASED_FREE 0x3FD + +enum fw_vi_mac_smac { + FW_VI_MAC_MPS_TCAM_ENTRY, + FW_VI_MAC_MPS_TCAM_ONLY, + FW_VI_MAC_SMT_ONLY, + FW_VI_MAC_SMT_AND_MPSTCAM +}; + +enum fw_vi_mac_result { + FW_VI_MAC_R_SUCCESS, + FW_VI_MAC_R_F_NONEXISTENT_NOMEM, + FW_VI_MAC_R_SMAC_FAIL, + FW_VI_MAC_R_F_ACL_CHECK +}; + +struct fw_vi_mac_cmd { + __be32 op_to_viid; + __be32 freemacs_to_len16; + union fw_vi_mac { + struct fw_vi_mac_exact { + __be16 valid_to_idx; + __u8 macaddr[6]; + } exact[7]; + struct fw_vi_mac_hash { + __be64 hashvec; + } hash; + } u; +}; + +#define S_FW_VI_MAC_CMD_VIID 0 +#define M_FW_VI_MAC_CMD_VIID 0xfff +#define V_FW_VI_MAC_CMD_VIID(x) ((x) << S_FW_VI_MAC_CMD_VIID) +#define G_FW_VI_MAC_CMD_VIID(x) \ + (((x) >> S_FW_VI_MAC_CMD_VIID) & M_FW_VI_MAC_CMD_VIID) + +#define S_FW_VI_MAC_CMD_FREEMACS 31 +#define M_FW_VI_MAC_CMD_FREEMACS 0x1 +#define V_FW_VI_MAC_CMD_FREEMACS(x) ((x) << S_FW_VI_MAC_CMD_FREEMACS) +#define G_FW_VI_MAC_CMD_FREEMACS(x) \ + (((x) >> S_FW_VI_MAC_CMD_FREEMACS) & M_FW_VI_MAC_CMD_FREEMACS) +#define F_FW_VI_MAC_CMD_FREEMACS V_FW_VI_MAC_CMD_FREEMACS(1U) + +#define S_FW_VI_MAC_CMD_HASHVECEN 23 +#define M_FW_VI_MAC_CMD_HASHVECEN 0x1 +#define V_FW_VI_MAC_CMD_HASHVECEN(x) ((x) << S_FW_VI_MAC_CMD_HASHVECEN) +#define G_FW_VI_MAC_CMD_HASHVECEN(x) \ + (((x) >> S_FW_VI_MAC_CMD_HASHVECEN) & M_FW_VI_MAC_CMD_HASHVECEN) +#define F_FW_VI_MAC_CMD_HASHVECEN V_FW_VI_MAC_CMD_HASHVECEN(1U) + +#define S_FW_VI_MAC_CMD_HASHUNIEN 22 +#define M_FW_VI_MAC_CMD_HASHUNIEN 0x1 +#define V_FW_VI_MAC_CMD_HASHUNIEN(x) ((x) << S_FW_VI_MAC_CMD_HASHUNIEN) +#define G_FW_VI_MAC_CMD_HASHUNIEN(x) \ + (((x) >> S_FW_VI_MAC_CMD_HASHUNIEN) & M_FW_VI_MAC_CMD_HASHUNIEN) +#define F_FW_VI_MAC_CMD_HASHUNIEN V_FW_VI_MAC_CMD_HASHUNIEN(1U) + +#define S_FW_VI_MAC_CMD_VALID 15 +#define M_FW_VI_MAC_CMD_VALID 0x1 +#define V_FW_VI_MAC_CMD_VALID(x) ((x) << S_FW_VI_MAC_CMD_VALID) +#define G_FW_VI_MAC_CMD_VALID(x) \ + (((x) >> S_FW_VI_MAC_CMD_VALID) & M_FW_VI_MAC_CMD_VALID) +#define F_FW_VI_MAC_CMD_VALID V_FW_VI_MAC_CMD_VALID(1U) + +#define S_FW_VI_MAC_CMD_PRIO 12 +#define M_FW_VI_MAC_CMD_PRIO 0x7 +#define V_FW_VI_MAC_CMD_PRIO(x) ((x) << S_FW_VI_MAC_CMD_PRIO) +#define G_FW_VI_MAC_CMD_PRIO(x) \ + (((x) >> S_FW_VI_MAC_CMD_PRIO) & M_FW_VI_MAC_CMD_PRIO) + +#define S_FW_VI_MAC_CMD_SMAC_RESULT 10 +#define M_FW_VI_MAC_CMD_SMAC_RESULT 0x3 +#define V_FW_VI_MAC_CMD_SMAC_RESULT(x) ((x) << S_FW_VI_MAC_CMD_SMAC_RESULT) +#define G_FW_VI_MAC_CMD_SMAC_RESULT(x) \ + (((x) >> S_FW_VI_MAC_CMD_SMAC_RESULT) & M_FW_VI_MAC_CMD_SMAC_RESULT) + +#define S_FW_VI_MAC_CMD_IDX 0 +#define M_FW_VI_MAC_CMD_IDX 0x3ff +#define V_FW_VI_MAC_CMD_IDX(x) ((x) << S_FW_VI_MAC_CMD_IDX) +#define G_FW_VI_MAC_CMD_IDX(x) \ + (((x) >> S_FW_VI_MAC_CMD_IDX) & M_FW_VI_MAC_CMD_IDX) + +/* T4 max MTU supported */ +#define T4_MAX_MTU_SUPPORTED 9600 +#define FW_RXMODE_MTU_NO_CHG 65535 + +struct fw_vi_rxmode_cmd { + __be32 op_to_viid; + __be32 retval_len16; + __be32 mtu_to_vlanexen; + __be32 r4_lo; +}; + +#define S_FW_VI_RXMODE_CMD_VIID 0 +#define M_FW_VI_RXMODE_CMD_VIID 0xfff +#define V_FW_VI_RXMODE_CMD_VIID(x) ((x) << S_FW_VI_RXMODE_CMD_VIID) +#define G_FW_VI_RXMODE_CMD_VIID(x) \ + (((x) >> S_FW_VI_RXMODE_CMD_VIID) & M_FW_VI_RXMODE_CMD_VIID) + +#define S_FW_VI_RXMODE_CMD_MTU 16 +#define M_FW_VI_RXMODE_CMD_MTU 0xffff +#define V_FW_VI_RXMODE_CMD_MTU(x) ((x) << S_FW_VI_RXMODE_CMD_MTU) +#define G_FW_VI_RXMODE_CMD_MTU(x) \ + (((x) >> S_FW_VI_RXMODE_CMD_MTU) & M_FW_VI_RXMODE_CMD_MTU) + +#define S_FW_VI_RXMODE_CMD_PROMISCEN 14 +#define M_FW_VI_RXMODE_CMD_PROMISCEN 0x3 +#define V_FW_VI_RXMODE_CMD_PROMISCEN(x) ((x) << S_FW_VI_RXMODE_CMD_PROMISCEN) +#define G_FW_VI_RXMODE_CMD_PROMISCEN(x) \ + (((x) >> S_FW_VI_RXMODE_CMD_PROMISCEN) & M_FW_VI_RXMODE_CMD_PROMISCEN) + +#define S_FW_VI_RXMODE_CMD_ALLMULTIEN 12 +#define M_FW_VI_RXMODE_CMD_ALLMULTIEN 0x3 +#define V_FW_VI_RXMODE_CMD_ALLMULTIEN(x) \ + ((x) << S_FW_VI_RXMODE_CMD_ALLMULTIEN) +#define G_FW_VI_RXMODE_CMD_ALLMULTIEN(x) \ + (((x) >> S_FW_VI_RXMODE_CMD_ALLMULTIEN) & M_FW_VI_RXMODE_CMD_ALLMULTIEN) + +#define S_FW_VI_RXMODE_CMD_BROADCASTEN 10 +#define M_FW_VI_RXMODE_CMD_BROADCASTEN 0x3 +#define V_FW_VI_RXMODE_CMD_BROADCASTEN(x) \ + ((x) << S_FW_VI_RXMODE_CMD_BROADCASTEN) +#define G_FW_VI_RXMODE_CMD_BROADCASTEN(x) \ + (((x) >> S_FW_VI_RXMODE_CMD_BROADCASTEN) & M_FW_VI_RXMODE_CMD_BROADCASTEN) + +#define S_FW_VI_RXMODE_CMD_VLANEXEN 8 +#define M_FW_VI_RXMODE_CMD_VLANEXEN 0x3 +#define V_FW_VI_RXMODE_CMD_VLANEXEN(x) ((x) << S_FW_VI_RXMODE_CMD_VLANEXEN) +#define G_FW_VI_RXMODE_CMD_VLANEXEN(x) \ + (((x) >> S_FW_VI_RXMODE_CMD_VLANEXEN) & M_FW_VI_RXMODE_CMD_VLANEXEN) + +struct fw_vi_enable_cmd { + __be32 op_to_viid; + __be32 ien_to_len16; + __be16 blinkdur; + __be16 r3; + __be32 r4; +}; + +#define S_FW_VI_ENABLE_CMD_VIID 0 +#define M_FW_VI_ENABLE_CMD_VIID 0xfff +#define V_FW_VI_ENABLE_CMD_VIID(x) ((x) << S_FW_VI_ENABLE_CMD_VIID) +#define G_FW_VI_ENABLE_CMD_VIID(x) \ + (((x) >> S_FW_VI_ENABLE_CMD_VIID) & M_FW_VI_ENABLE_CMD_VIID) + +#define S_FW_VI_ENABLE_CMD_IEN 31 +#define M_FW_VI_ENABLE_CMD_IEN 0x1 +#define V_FW_VI_ENABLE_CMD_IEN(x) ((x) << S_FW_VI_ENABLE_CMD_IEN) +#define G_FW_VI_ENABLE_CMD_IEN(x) \ + (((x) >> S_FW_VI_ENABLE_CMD_IEN) & M_FW_VI_ENABLE_CMD_IEN) +#define F_FW_VI_ENABLE_CMD_IEN V_FW_VI_ENABLE_CMD_IEN(1U) + +#define S_FW_VI_ENABLE_CMD_EEN 30 +#define M_FW_VI_ENABLE_CMD_EEN 0x1 +#define V_FW_VI_ENABLE_CMD_EEN(x) ((x) << S_FW_VI_ENABLE_CMD_EEN) +#define G_FW_VI_ENABLE_CMD_EEN(x) \ + (((x) >> S_FW_VI_ENABLE_CMD_EEN) & M_FW_VI_ENABLE_CMD_EEN) +#define F_FW_VI_ENABLE_CMD_EEN V_FW_VI_ENABLE_CMD_EEN(1U) + +#define S_FW_VI_ENABLE_CMD_LED 29 +#define M_FW_VI_ENABLE_CMD_LED 0x1 +#define V_FW_VI_ENABLE_CMD_LED(x) ((x) << S_FW_VI_ENABLE_CMD_LED) +#define G_FW_VI_ENABLE_CMD_LED(x) \ + (((x) >> S_FW_VI_ENABLE_CMD_LED) & M_FW_VI_ENABLE_CMD_LED) +#define F_FW_VI_ENABLE_CMD_LED V_FW_VI_ENABLE_CMD_LED(1U) + +#define S_FW_VI_ENABLE_CMD_DCB_INFO 28 +#define M_FW_VI_ENABLE_CMD_DCB_INFO 0x1 +#define V_FW_VI_ENABLE_CMD_DCB_INFO(x) ((x) << S_FW_VI_ENABLE_CMD_DCB_INFO) +#define G_FW_VI_ENABLE_CMD_DCB_INFO(x) \ + (((x) >> S_FW_VI_ENABLE_CMD_DCB_INFO) & M_FW_VI_ENABLE_CMD_DCB_INFO) +#define F_FW_VI_ENABLE_CMD_DCB_INFO V_FW_VI_ENABLE_CMD_DCB_INFO(1U) + +/* VI VF stats offset definitions */ +#define VI_VF_NUM_STATS 16 +enum fw_vi_stats_vf_index { + FW_VI_VF_STAT_TX_BCAST_BYTES_IX, + FW_VI_VF_STAT_TX_BCAST_FRAMES_IX, + FW_VI_VF_STAT_TX_MCAST_BYTES_IX, + FW_VI_VF_STAT_TX_MCAST_FRAMES_IX, + FW_VI_VF_STAT_TX_UCAST_BYTES_IX, + FW_VI_VF_STAT_TX_UCAST_FRAMES_IX, + FW_VI_VF_STAT_TX_DROP_FRAMES_IX, + FW_VI_VF_STAT_TX_OFLD_BYTES_IX, + FW_VI_VF_STAT_TX_OFLD_FRAMES_IX, + FW_VI_VF_STAT_RX_BCAST_BYTES_IX, + FW_VI_VF_STAT_RX_BCAST_FRAMES_IX, + FW_VI_VF_STAT_RX_MCAST_BYTES_IX, + FW_VI_VF_STAT_RX_MCAST_FRAMES_IX, + FW_VI_VF_STAT_RX_UCAST_BYTES_IX, + FW_VI_VF_STAT_RX_UCAST_FRAMES_IX, + FW_VI_VF_STAT_RX_ERR_FRAMES_IX +}; + +/* VI PF stats offset definitions */ +#define VI_PF_NUM_STATS 17 +enum fw_vi_stats_pf_index { + FW_VI_PF_STAT_TX_BCAST_BYTES_IX, + FW_VI_PF_STAT_TX_BCAST_FRAMES_IX, + FW_VI_PF_STAT_TX_MCAST_BYTES_IX, + FW_VI_PF_STAT_TX_MCAST_FRAMES_IX, + FW_VI_PF_STAT_TX_UCAST_BYTES_IX, + FW_VI_PF_STAT_TX_UCAST_FRAMES_IX, + FW_VI_PF_STAT_TX_OFLD_BYTES_IX, + FW_VI_PF_STAT_TX_OFLD_FRAMES_IX, + FW_VI_PF_STAT_RX_BYTES_IX, + FW_VI_PF_STAT_RX_FRAMES_IX, + FW_VI_PF_STAT_RX_BCAST_BYTES_IX, + FW_VI_PF_STAT_RX_BCAST_FRAMES_IX, + FW_VI_PF_STAT_RX_MCAST_BYTES_IX, + FW_VI_PF_STAT_RX_MCAST_FRAMES_IX, + FW_VI_PF_STAT_RX_UCAST_BYTES_IX, + FW_VI_PF_STAT_RX_UCAST_FRAMES_IX, + FW_VI_PF_STAT_RX_ERR_FRAMES_IX +}; + +struct fw_vi_stats_cmd { + __be32 op_to_viid; + __be32 retval_len16; + union fw_vi_stats { + struct fw_vi_stats_ctl { + __be16 nstats_ix; + __be16 r6; + __be32 r7; + __be64 stat0; + __be64 stat1; + __be64 stat2; + __be64 stat3; + __be64 stat4; + __be64 stat5; + } ctl; + struct fw_vi_stats_pf { + __be64 tx_bcast_bytes; + __be64 tx_bcast_frames; + __be64 tx_mcast_bytes; + __be64 tx_mcast_frames; + __be64 tx_ucast_bytes; + __be64 tx_ucast_frames; + __be64 tx_offload_bytes; + __be64 tx_offload_frames; + __be64 rx_pf_bytes; + __be64 rx_pf_frames; + __be64 rx_bcast_bytes; + __be64 rx_bcast_frames; + __be64 rx_mcast_bytes; + __be64 rx_mcast_frames; + __be64 rx_ucast_bytes; + __be64 rx_ucast_frames; + __be64 rx_err_frames; + } pf; + struct fw_vi_stats_vf { + __be64 tx_bcast_bytes; + __be64 tx_bcast_frames; + __be64 tx_mcast_bytes; + __be64 tx_mcast_frames; + __be64 tx_ucast_bytes; + __be64 tx_ucast_frames; + __be64 tx_drop_frames; + __be64 tx_offload_bytes; + __be64 tx_offload_frames; + __be64 rx_bcast_bytes; + __be64 rx_bcast_frames; + __be64 rx_mcast_bytes; + __be64 rx_mcast_frames; + __be64 rx_ucast_bytes; + __be64 rx_ucast_frames; + __be64 rx_err_frames; + } vf; + } u; +}; + +#define S_FW_VI_STATS_CMD_VIID 0 +#define M_FW_VI_STATS_CMD_VIID 0xfff +#define V_FW_VI_STATS_CMD_VIID(x) ((x) << S_FW_VI_STATS_CMD_VIID) +#define G_FW_VI_STATS_CMD_VIID(x) \ + (((x) >> S_FW_VI_STATS_CMD_VIID) & M_FW_VI_STATS_CMD_VIID) + +#define S_FW_VI_STATS_CMD_NSTATS 12 +#define M_FW_VI_STATS_CMD_NSTATS 0x7 +#define V_FW_VI_STATS_CMD_NSTATS(x) ((x) << S_FW_VI_STATS_CMD_NSTATS) +#define G_FW_VI_STATS_CMD_NSTATS(x) \ + (((x) >> S_FW_VI_STATS_CMD_NSTATS) & M_FW_VI_STATS_CMD_NSTATS) + +#define S_FW_VI_STATS_CMD_IX 0 +#define M_FW_VI_STATS_CMD_IX 0x1f +#define V_FW_VI_STATS_CMD_IX(x) ((x) << S_FW_VI_STATS_CMD_IX) +#define G_FW_VI_STATS_CMD_IX(x) \ + (((x) >> S_FW_VI_STATS_CMD_IX) & M_FW_VI_STATS_CMD_IX) + +struct fw_acl_mac_cmd { + __be32 op_to_vfn; + __be32 en_to_len16; + __u8 nmac; + __u8 r3[7]; + __be16 r4; + __u8 macaddr0[6]; + __be16 r5; + __u8 macaddr1[6]; + __be16 r6; + __u8 macaddr2[6]; + __be16 r7; + __u8 macaddr3[6]; +}; + +#define S_FW_ACL_MAC_CMD_PFN 8 +#define M_FW_ACL_MAC_CMD_PFN 0x7 +#define V_FW_ACL_MAC_CMD_PFN(x) ((x) << S_FW_ACL_MAC_CMD_PFN) +#define G_FW_ACL_MAC_CMD_PFN(x) \ + (((x) >> S_FW_ACL_MAC_CMD_PFN) & M_FW_ACL_MAC_CMD_PFN) + +#define S_FW_ACL_MAC_CMD_VFN 0 +#define M_FW_ACL_MAC_CMD_VFN 0xff +#define V_FW_ACL_MAC_CMD_VFN(x) ((x) << S_FW_ACL_MAC_CMD_VFN) +#define G_FW_ACL_MAC_CMD_VFN(x) \ + (((x) >> S_FW_ACL_MAC_CMD_VFN) & M_FW_ACL_MAC_CMD_VFN) + +#define S_FW_ACL_MAC_CMD_EN 31 +#define M_FW_ACL_MAC_CMD_EN 0x1 +#define V_FW_ACL_MAC_CMD_EN(x) ((x) << S_FW_ACL_MAC_CMD_EN) +#define G_FW_ACL_MAC_CMD_EN(x) \ + (((x) >> S_FW_ACL_MAC_CMD_EN) & M_FW_ACL_MAC_CMD_EN) +#define F_FW_ACL_MAC_CMD_EN V_FW_ACL_MAC_CMD_EN(1U) + +struct fw_acl_vlan_cmd { + __be32 op_to_vfn; + __be32 en_to_len16; + __u8 nvlan; + __u8 dropnovlan_fm; + __u8 r3_lo[6]; + __be16 vlanid[16]; +}; + +#define S_FW_ACL_VLAN_CMD_PFN 8 +#define M_FW_ACL_VLAN_CMD_PFN 0x7 +#define V_FW_ACL_VLAN_CMD_PFN(x) ((x) << S_FW_ACL_VLAN_CMD_PFN) +#define G_FW_ACL_VLAN_CMD_PFN(x) \ + (((x) >> S_FW_ACL_VLAN_CMD_PFN) & M_FW_ACL_VLAN_CMD_PFN) + +#define S_FW_ACL_VLAN_CMD_VFN 0 +#define M_FW_ACL_VLAN_CMD_VFN 0xff +#define V_FW_ACL_VLAN_CMD_VFN(x) ((x) << S_FW_ACL_VLAN_CMD_VFN) +#define G_FW_ACL_VLAN_CMD_VFN(x) \ + (((x) >> S_FW_ACL_VLAN_CMD_VFN) & M_FW_ACL_VLAN_CMD_VFN) + +#define S_FW_ACL_VLAN_CMD_EN 31 +#define M_FW_ACL_VLAN_CMD_EN 0x1 +#define V_FW_ACL_VLAN_CMD_EN(x) ((x) << S_FW_ACL_VLAN_CMD_EN) +#define G_FW_ACL_VLAN_CMD_EN(x) \ + (((x) >> S_FW_ACL_VLAN_CMD_EN) & M_FW_ACL_VLAN_CMD_EN) +#define F_FW_ACL_VLAN_CMD_EN V_FW_ACL_VLAN_CMD_EN(1U) + +#define S_FW_ACL_VLAN_CMD_DROPNOVLAN 7 +#define M_FW_ACL_VLAN_CMD_DROPNOVLAN 0x1 +#define V_FW_ACL_VLAN_CMD_DROPNOVLAN(x) ((x) << S_FW_ACL_VLAN_CMD_DROPNOVLAN) +#define G_FW_ACL_VLAN_CMD_DROPNOVLAN(x) \ + (((x) >> S_FW_ACL_VLAN_CMD_DROPNOVLAN) & M_FW_ACL_VLAN_CMD_DROPNOVLAN) +#define F_FW_ACL_VLAN_CMD_DROPNOVLAN V_FW_ACL_VLAN_CMD_DROPNOVLAN(1U) + +#define S_FW_ACL_VLAN_CMD_FM 6 +#define M_FW_ACL_VLAN_CMD_FM 0x1 +#define V_FW_ACL_VLAN_CMD_FM(x) ((x) << S_FW_ACL_VLAN_CMD_FM) +#define G_FW_ACL_VLAN_CMD_FM(x) \ + (((x) >> S_FW_ACL_VLAN_CMD_FM) & M_FW_ACL_VLAN_CMD_FM) +#define F_FW_ACL_VLAN_CMD_FM V_FW_ACL_VLAN_CMD_FM(1U) + +/* port capabilities bitmap */ +enum fw_port_cap { + FW_PORT_CAP_SPEED_100M = 0x0001, + FW_PORT_CAP_SPEED_1G = 0x0002, + FW_PORT_CAP_SPEED_2_5G = 0x0004, + FW_PORT_CAP_SPEED_10G = 0x0008, + FW_PORT_CAP_SPEED_40G = 0x0010, + FW_PORT_CAP_SPEED_100G = 0x0020, + FW_PORT_CAP_FC_RX = 0x0040, + FW_PORT_CAP_FC_TX = 0x0080, + FW_PORT_CAP_ANEG = 0x0100, + FW_PORT_CAP_MDIX = 0x0200, + FW_PORT_CAP_MDIAUTO = 0x0400, + FW_PORT_CAP_FEC = 0x0800, + FW_PORT_CAP_TECHKR = 0x1000, + FW_PORT_CAP_TECHKX4 = 0x2000, +}; + +#define S_FW_PORT_AUXLINFO_MDI 3 +#define M_FW_PORT_AUXLINFO_MDI 0x3 +#define V_FW_PORT_AUXLINFO_MDI(x) ((x) << S_FW_PORT_AUXLINFO_MDI) +#define G_FW_PORT_AUXLINFO_MDI(x) \ + (((x) >> S_FW_PORT_AUXLINFO_MDI) & M_FW_PORT_AUXLINFO_MDI) + +#define S_FW_PORT_AUXLINFO_KX4 2 +#define M_FW_PORT_AUXLINFO_KX4 0x1 +#define V_FW_PORT_AUXLINFO_KX4(x) ((x) << S_FW_PORT_AUXLINFO_KX4) +#define G_FW_PORT_AUXLINFO_KX4(x) \ + (((x) >> S_FW_PORT_AUXLINFO_KX4) & M_FW_PORT_AUXLINFO_KX4) +#define F_FW_PORT_AUXLINFO_KX4 V_FW_PORT_AUXLINFO_KX4(1U) + +#define S_FW_PORT_AUXLINFO_KR 1 +#define M_FW_PORT_AUXLINFO_KR 0x1 +#define V_FW_PORT_AUXLINFO_KR(x) ((x) << S_FW_PORT_AUXLINFO_KR) +#define G_FW_PORT_AUXLINFO_KR(x) \ + (((x) >> S_FW_PORT_AUXLINFO_KR) & M_FW_PORT_AUXLINFO_KR) +#define F_FW_PORT_AUXLINFO_KR V_FW_PORT_AUXLINFO_KR(1U) + +#define S_FW_PORT_AUXLINFO_FEC 0 +#define M_FW_PORT_AUXLINFO_FEC 0x1 +#define V_FW_PORT_AUXLINFO_FEC(x) ((x) << S_FW_PORT_AUXLINFO_FEC) +#define G_FW_PORT_AUXLINFO_FEC(x) \ + (((x) >> S_FW_PORT_AUXLINFO_FEC) & M_FW_PORT_AUXLINFO_FEC) +#define F_FW_PORT_AUXLINFO_FEC V_FW_PORT_AUXLINFO_FEC(1U) + +#define S_FW_PORT_RCAP_AUX 11 +#define M_FW_PORT_RCAP_AUX 0x7 +#define V_FW_PORT_RCAP_AUX(x) ((x) << S_FW_PORT_RCAP_AUX) +#define G_FW_PORT_RCAP_AUX(x) \ + (((x) >> S_FW_PORT_RCAP_AUX) & M_FW_PORT_RCAP_AUX) + +#define S_FW_PORT_CAP_SPEED 0 +#define M_FW_PORT_CAP_SPEED 0x3f +#define V_FW_PORT_CAP_SPEED(x) ((x) << S_FW_PORT_CAP_SPEED) +#define G_FW_PORT_CAP_SPEED(x) \ + (((x) >> S_FW_PORT_CAP_SPEED) & M_FW_PORT_CAP_SPEED) + +#define S_FW_PORT_CAP_FC 6 +#define M_FW_PORT_CAP_FC 0x3 +#define V_FW_PORT_CAP_FC(x) ((x) << S_FW_PORT_CAP_FC) +#define G_FW_PORT_CAP_FC(x) \ + (((x) >> S_FW_PORT_CAP_FC) & M_FW_PORT_CAP_FC) + +#define S_FW_PORT_CAP_ANEG 8 +#define M_FW_PORT_CAP_ANEG 0x1 +#define V_FW_PORT_CAP_ANEG(x) ((x) << S_FW_PORT_CAP_ANEG) +#define G_FW_PORT_CAP_ANEG(x) \ + (((x) >> S_FW_PORT_CAP_ANEG) & M_FW_PORT_CAP_ANEG) + +enum fw_port_mdi { + FW_PORT_CAP_MDI_UNCHANGED, + FW_PORT_CAP_MDI_AUTO, + FW_PORT_CAP_MDI_F_STRAIGHT, + FW_PORT_CAP_MDI_F_CROSSOVER +}; + +#define S_FW_PORT_CAP_MDI 9 +#define M_FW_PORT_CAP_MDI 3 +#define V_FW_PORT_CAP_MDI(x) ((x) << S_FW_PORT_CAP_MDI) +#define G_FW_PORT_CAP_MDI(x) (((x) >> S_FW_PORT_CAP_MDI) & M_FW_PORT_CAP_MDI) + +enum fw_port_action { + FW_PORT_ACTION_L1_CFG = 0x0001, + FW_PORT_ACTION_L2_CFG = 0x0002, + FW_PORT_ACTION_GET_PORT_INFO = 0x0003, + FW_PORT_ACTION_L2_PPP_CFG = 0x0004, + FW_PORT_ACTION_L2_DCB_CFG = 0x0005, + FW_PORT_ACTION_DCB_READ_TRANS = 0x0006, + FW_PORT_ACTION_DCB_READ_RECV = 0x0007, + FW_PORT_ACTION_DCB_READ_DET = 0x0008, + FW_PORT_ACTION_LOW_PWR_TO_NORMAL = 0x0010, + FW_PORT_ACTION_L1_LOW_PWR_EN = 0x0011, + FW_PORT_ACTION_L2_WOL_MODE_EN = 0x0012, + FW_PORT_ACTION_LPBK_TO_NORMAL = 0x0020, + FW_PORT_ACTION_LPBK_SS_ASIC = 0x0022, + FW_PORT_ACTION_LPBK_WS_ASIC = 0x0023, + FW_PORT_ACTION_LPBK_WS_EXT_PHY = 0x0025, + FW_PORT_ACTION_LPBK_SS_EXT = 0x0026, + FW_PORT_ACTION_DIAGNOSTICS = 0x0027, + FW_PORT_ACTION_LPBK_SS_EXT_PHY = 0x0028, + FW_PORT_ACTION_PHY_RESET = 0x0040, + FW_PORT_ACTION_PMA_RESET = 0x0041, + FW_PORT_ACTION_PCS_RESET = 0x0042, + FW_PORT_ACTION_PHYXS_RESET = 0x0043, + FW_PORT_ACTION_DTEXS_REEST = 0x0044, + FW_PORT_ACTION_AN_RESET = 0x0045, + +}; + +enum fw_port_l2cfg_ctlbf { + FW_PORT_L2_CTLBF_OVLAN0 = 0x01, + FW_PORT_L2_CTLBF_OVLAN1 = 0x02, + FW_PORT_L2_CTLBF_OVLAN2 = 0x04, + FW_PORT_L2_CTLBF_OVLAN3 = 0x08, + FW_PORT_L2_CTLBF_IVLAN = 0x10, + FW_PORT_L2_CTLBF_TXIPG = 0x20, + FW_PORT_L2_CTLBF_MTU = 0x40 +}; + +enum fw_dcb_app_tlv_sf { + FW_DCB_APP_SF_ETHERTYPE, + FW_DCB_APP_SF_SOCKET_TCP, + FW_DCB_APP_SF_SOCKET_UDP, + FW_DCB_APP_SF_SOCKET_ALL, +}; + +enum fw_port_dcb_versions { + FW_PORT_DCB_VER_CEE1D0, + FW_PORT_DCB_VER_CEE1D01, + FW_PORT_DCB_VER_IEEE, + FW_PORT_DCB_VER_UNKNOWN=7 +}; + +enum fw_port_dcb_cfg { + FW_PORT_DCB_CFG_PG = 0x01, + FW_PORT_DCB_CFG_PFC = 0x02, + FW_PORT_DCB_CFG_APPL = 0x04 +}; + +enum fw_port_dcb_cfg_rc { + FW_PORT_DCB_CFG_SUCCESS = 0x0, + FW_PORT_DCB_CFG_ERROR = 0x1 +}; + +enum fw_port_dcb_type { + FW_PORT_DCB_TYPE_PGID = 0x00, + FW_PORT_DCB_TYPE_PGRATE = 0x01, + FW_PORT_DCB_TYPE_PRIORATE = 0x02, + FW_PORT_DCB_TYPE_PFC = 0x03, + FW_PORT_DCB_TYPE_APP_ID = 0x04, + FW_PORT_DCB_TYPE_CONTROL = 0x05, +}; + +enum fw_port_dcb_feature_state { + FW_PORT_DCB_FEATURE_STATE_PENDING = 0x0, + FW_PORT_DCB_FEATURE_STATE_SUCCESS = 0x1, + FW_PORT_DCB_FEATURE_STATE_ERROR = 0x2, + FW_PORT_DCB_FEATURE_STATE_TIMEOUT = 0x3, +}; + +enum fw_port_diag_ops { + FW_PORT_DIAGS_TEMP = 0x00, + FW_PORT_DIAGS_TX_POWER = 0x01, + FW_PORT_DIAGS_RX_POWER = 0x02, +}; + +struct fw_port_cmd { + __be32 op_to_portid; + __be32 action_to_len16; + union fw_port { + struct fw_port_l1cfg { + __be32 rcap; + __be32 r; + } l1cfg; + struct fw_port_l2cfg { + __u8 ctlbf; + __u8 ovlan3_to_ivlan0; + __be16 ivlantype; + __be16 txipg_force_pinfo; + __be16 mtu; + __be16 ovlan0mask; + __be16 ovlan0type; + __be16 ovlan1mask; + __be16 ovlan1type; + __be16 ovlan2mask; + __be16 ovlan2type; + __be16 ovlan3mask; + __be16 ovlan3type; + } l2cfg; + struct fw_port_info { + __be32 lstatus_to_modtype; + __be16 pcap; + __be16 acap; + __be16 mtu; + __u8 cbllen; + __u8 auxlinfo; + __u8 dcbxdis_pkd; + __u8 r8_lo[3]; + __be64 r9; + } info; + struct fw_port_diags { + __u8 diagop; + __u8 r[3]; + __be32 diagval; + } diags; + union fw_port_dcb { + struct fw_port_dcb_pgid { + __u8 type; + __u8 apply_pkd; + __u8 r10_lo[2]; + __be32 pgid; + __be64 r11; + } pgid; + struct fw_port_dcb_pgrate { + __u8 type; + __u8 apply_pkd; + __u8 r10_lo[5]; + __u8 num_tcs_supported; + __u8 pgrate[8]; + } pgrate; + struct fw_port_dcb_priorate { + __u8 type; + __u8 apply_pkd; + __u8 r10_lo[6]; + __u8 strict_priorate[8]; + } priorate; + struct fw_port_dcb_pfc { + __u8 type; + __u8 pfcen; + __be16 r10[3]; + __be64 r11; + } pfc; + struct fw_port_app_priority { + __u8 type; + __u8 r10[2]; + __u8 idx; + __u8 user_prio_map; + __u8 sel_field; + __be16 protocolid; + __be64 r12; + } app_priority; + struct fw_port_dcb_control { + __u8 type; + __u8 all_syncd_pkd; + __be16 pfc_state_to_app_state; + __be32 r11; + __be64 r12; + } control; + } dcb; + } u; +}; + +#define S_FW_PORT_CMD_READ 22 +#define M_FW_PORT_CMD_READ 0x1 +#define V_FW_PORT_CMD_READ(x) ((x) << S_FW_PORT_CMD_READ) +#define G_FW_PORT_CMD_READ(x) \ + (((x) >> S_FW_PORT_CMD_READ) & M_FW_PORT_CMD_READ) +#define F_FW_PORT_CMD_READ V_FW_PORT_CMD_READ(1U) + +#define S_FW_PORT_CMD_PORTID 0 +#define M_FW_PORT_CMD_PORTID 0xf +#define V_FW_PORT_CMD_PORTID(x) ((x) << S_FW_PORT_CMD_PORTID) +#define G_FW_PORT_CMD_PORTID(x) \ + (((x) >> S_FW_PORT_CMD_PORTID) & M_FW_PORT_CMD_PORTID) + +#define S_FW_PORT_CMD_ACTION 16 +#define M_FW_PORT_CMD_ACTION 0xffff +#define V_FW_PORT_CMD_ACTION(x) ((x) << S_FW_PORT_CMD_ACTION) +#define G_FW_PORT_CMD_ACTION(x) \ + (((x) >> S_FW_PORT_CMD_ACTION) & M_FW_PORT_CMD_ACTION) + +#define S_FW_PORT_CMD_OVLAN3 7 +#define M_FW_PORT_CMD_OVLAN3 0x1 +#define V_FW_PORT_CMD_OVLAN3(x) ((x) << S_FW_PORT_CMD_OVLAN3) +#define G_FW_PORT_CMD_OVLAN3(x) \ + (((x) >> S_FW_PORT_CMD_OVLAN3) & M_FW_PORT_CMD_OVLAN3) +#define F_FW_PORT_CMD_OVLAN3 V_FW_PORT_CMD_OVLAN3(1U) + +#define S_FW_PORT_CMD_OVLAN2 6 +#define M_FW_PORT_CMD_OVLAN2 0x1 +#define V_FW_PORT_CMD_OVLAN2(x) ((x) << S_FW_PORT_CMD_OVLAN2) +#define G_FW_PORT_CMD_OVLAN2(x) \ + (((x) >> S_FW_PORT_CMD_OVLAN2) & M_FW_PORT_CMD_OVLAN2) +#define F_FW_PORT_CMD_OVLAN2 V_FW_PORT_CMD_OVLAN2(1U) + +#define S_FW_PORT_CMD_OVLAN1 5 +#define M_FW_PORT_CMD_OVLAN1 0x1 +#define V_FW_PORT_CMD_OVLAN1(x) ((x) << S_FW_PORT_CMD_OVLAN1) +#define G_FW_PORT_CMD_OVLAN1(x) \ + (((x) >> S_FW_PORT_CMD_OVLAN1) & M_FW_PORT_CMD_OVLAN1) +#define F_FW_PORT_CMD_OVLAN1 V_FW_PORT_CMD_OVLAN1(1U) + +#define S_FW_PORT_CMD_OVLAN0 4 +#define M_FW_PORT_CMD_OVLAN0 0x1 +#define V_FW_PORT_CMD_OVLAN0(x) ((x) << S_FW_PORT_CMD_OVLAN0) +#define G_FW_PORT_CMD_OVLAN0(x) \ + (((x) >> S_FW_PORT_CMD_OVLAN0) & M_FW_PORT_CMD_OVLAN0) +#define F_FW_PORT_CMD_OVLAN0 V_FW_PORT_CMD_OVLAN0(1U) + +#define S_FW_PORT_CMD_IVLAN0 3 +#define M_FW_PORT_CMD_IVLAN0 0x1 +#define V_FW_PORT_CMD_IVLAN0(x) ((x) << S_FW_PORT_CMD_IVLAN0) +#define G_FW_PORT_CMD_IVLAN0(x) \ + (((x) >> S_FW_PORT_CMD_IVLAN0) & M_FW_PORT_CMD_IVLAN0) +#define F_FW_PORT_CMD_IVLAN0 V_FW_PORT_CMD_IVLAN0(1U) + +#define S_FW_PORT_CMD_TXIPG 3 +#define M_FW_PORT_CMD_TXIPG 0x1fff +#define V_FW_PORT_CMD_TXIPG(x) ((x) << S_FW_PORT_CMD_TXIPG) +#define G_FW_PORT_CMD_TXIPG(x) \ + (((x) >> S_FW_PORT_CMD_TXIPG) & M_FW_PORT_CMD_TXIPG) + +#define S_FW_PORT_CMD_FORCE_PINFO 0 +#define M_FW_PORT_CMD_FORCE_PINFO 0x1 +#define V_FW_PORT_CMD_FORCE_PINFO(x) ((x) << S_FW_PORT_CMD_FORCE_PINFO) +#define G_FW_PORT_CMD_FORCE_PINFO(x) \ + (((x) >> S_FW_PORT_CMD_FORCE_PINFO) & M_FW_PORT_CMD_FORCE_PINFO) +#define F_FW_PORT_CMD_FORCE_PINFO V_FW_PORT_CMD_FORCE_PINFO(1U) + +#define S_FW_PORT_CMD_LSTATUS 31 +#define M_FW_PORT_CMD_LSTATUS 0x1 +#define V_FW_PORT_CMD_LSTATUS(x) ((x) << S_FW_PORT_CMD_LSTATUS) +#define G_FW_PORT_CMD_LSTATUS(x) \ + (((x) >> S_FW_PORT_CMD_LSTATUS) & M_FW_PORT_CMD_LSTATUS) +#define F_FW_PORT_CMD_LSTATUS V_FW_PORT_CMD_LSTATUS(1U) + +#define S_FW_PORT_CMD_LSPEED 24 +#define M_FW_PORT_CMD_LSPEED 0x3f +#define V_FW_PORT_CMD_LSPEED(x) ((x) << S_FW_PORT_CMD_LSPEED) +#define G_FW_PORT_CMD_LSPEED(x) \ + (((x) >> S_FW_PORT_CMD_LSPEED) & M_FW_PORT_CMD_LSPEED) + +#define S_FW_PORT_CMD_TXPAUSE 23 +#define M_FW_PORT_CMD_TXPAUSE 0x1 +#define V_FW_PORT_CMD_TXPAUSE(x) ((x) << S_FW_PORT_CMD_TXPAUSE) +#define G_FW_PORT_CMD_TXPAUSE(x) \ + (((x) >> S_FW_PORT_CMD_TXPAUSE) & M_FW_PORT_CMD_TXPAUSE) +#define F_FW_PORT_CMD_TXPAUSE V_FW_PORT_CMD_TXPAUSE(1U) + +#define S_FW_PORT_CMD_RXPAUSE 22 +#define M_FW_PORT_CMD_RXPAUSE 0x1 +#define V_FW_PORT_CMD_RXPAUSE(x) ((x) << S_FW_PORT_CMD_RXPAUSE) +#define G_FW_PORT_CMD_RXPAUSE(x) \ + (((x) >> S_FW_PORT_CMD_RXPAUSE) & M_FW_PORT_CMD_RXPAUSE) +#define F_FW_PORT_CMD_RXPAUSE V_FW_PORT_CMD_RXPAUSE(1U) + +#define S_FW_PORT_CMD_MDIOCAP 21 +#define M_FW_PORT_CMD_MDIOCAP 0x1 +#define V_FW_PORT_CMD_MDIOCAP(x) ((x) << S_FW_PORT_CMD_MDIOCAP) +#define G_FW_PORT_CMD_MDIOCAP(x) \ + (((x) >> S_FW_PORT_CMD_MDIOCAP) & M_FW_PORT_CMD_MDIOCAP) +#define F_FW_PORT_CMD_MDIOCAP V_FW_PORT_CMD_MDIOCAP(1U) + +#define S_FW_PORT_CMD_MDIOADDR 16 +#define M_FW_PORT_CMD_MDIOADDR 0x1f +#define V_FW_PORT_CMD_MDIOADDR(x) ((x) << S_FW_PORT_CMD_MDIOADDR) +#define G_FW_PORT_CMD_MDIOADDR(x) \ + (((x) >> S_FW_PORT_CMD_MDIOADDR) & M_FW_PORT_CMD_MDIOADDR) + +#define S_FW_PORT_CMD_LPTXPAUSE 15 +#define M_FW_PORT_CMD_LPTXPAUSE 0x1 +#define V_FW_PORT_CMD_LPTXPAUSE(x) ((x) << S_FW_PORT_CMD_LPTXPAUSE) +#define G_FW_PORT_CMD_LPTXPAUSE(x) \ + (((x) >> S_FW_PORT_CMD_LPTXPAUSE) & M_FW_PORT_CMD_LPTXPAUSE) +#define F_FW_PORT_CMD_LPTXPAUSE V_FW_PORT_CMD_LPTXPAUSE(1U) + +#define S_FW_PORT_CMD_LPRXPAUSE 14 +#define M_FW_PORT_CMD_LPRXPAUSE 0x1 +#define V_FW_PORT_CMD_LPRXPAUSE(x) ((x) << S_FW_PORT_CMD_LPRXPAUSE) +#define G_FW_PORT_CMD_LPRXPAUSE(x) \ + (((x) >> S_FW_PORT_CMD_LPRXPAUSE) & M_FW_PORT_CMD_LPRXPAUSE) +#define F_FW_PORT_CMD_LPRXPAUSE V_FW_PORT_CMD_LPRXPAUSE(1U) + +#define S_FW_PORT_CMD_PTYPE 8 +#define M_FW_PORT_CMD_PTYPE 0x1f +#define V_FW_PORT_CMD_PTYPE(x) ((x) << S_FW_PORT_CMD_PTYPE) +#define G_FW_PORT_CMD_PTYPE(x) \ + (((x) >> S_FW_PORT_CMD_PTYPE) & M_FW_PORT_CMD_PTYPE) + +#define S_FW_PORT_CMD_LINKDNRC 5 +#define M_FW_PORT_CMD_LINKDNRC 0x7 +#define V_FW_PORT_CMD_LINKDNRC(x) ((x) << S_FW_PORT_CMD_LINKDNRC) +#define G_FW_PORT_CMD_LINKDNRC(x) \ + (((x) >> S_FW_PORT_CMD_LINKDNRC) & M_FW_PORT_CMD_LINKDNRC) + +#define S_FW_PORT_CMD_MODTYPE 0 +#define M_FW_PORT_CMD_MODTYPE 0x1f +#define V_FW_PORT_CMD_MODTYPE(x) ((x) << S_FW_PORT_CMD_MODTYPE) +#define G_FW_PORT_CMD_MODTYPE(x) \ + (((x) >> S_FW_PORT_CMD_MODTYPE) & M_FW_PORT_CMD_MODTYPE) + +#define S_FW_PORT_CMD_DCBXDIS 7 +#define M_FW_PORT_CMD_DCBXDIS 0x1 +#define V_FW_PORT_CMD_DCBXDIS(x) ((x) << S_FW_PORT_CMD_DCBXDIS) +#define G_FW_PORT_CMD_DCBXDIS(x) \ + (((x) >> S_FW_PORT_CMD_DCBXDIS) & M_FW_PORT_CMD_DCBXDIS) +#define F_FW_PORT_CMD_DCBXDIS V_FW_PORT_CMD_DCBXDIS(1U) + +#define S_FW_PORT_CMD_APPLY 7 +#define M_FW_PORT_CMD_APPLY 0x1 +#define V_FW_PORT_CMD_APPLY(x) ((x) << S_FW_PORT_CMD_APPLY) +#define G_FW_PORT_CMD_APPLY(x) \ + (((x) >> S_FW_PORT_CMD_APPLY) & M_FW_PORT_CMD_APPLY) +#define F_FW_PORT_CMD_APPLY V_FW_PORT_CMD_APPLY(1U) + +#define S_FW_PORT_CMD_ALL_SYNCD 7 +#define M_FW_PORT_CMD_ALL_SYNCD 0x1 +#define V_FW_PORT_CMD_ALL_SYNCD(x) ((x) << S_FW_PORT_CMD_ALL_SYNCD) +#define G_FW_PORT_CMD_ALL_SYNCD(x) \ + (((x) >> S_FW_PORT_CMD_ALL_SYNCD) & M_FW_PORT_CMD_ALL_SYNCD) +#define F_FW_PORT_CMD_ALL_SYNCD V_FW_PORT_CMD_ALL_SYNCD(1U) + +#define S_FW_PORT_CMD_PFC_STATE 8 +#define M_FW_PORT_CMD_PFC_STATE 0xf +#define V_FW_PORT_CMD_PFC_STATE(x) ((x) << S_FW_PORT_CMD_PFC_STATE) +#define G_FW_PORT_CMD_PFC_STATE(x) \ + (((x) >> S_FW_PORT_CMD_PFC_STATE) & M_FW_PORT_CMD_PFC_STATE) + +#define S_FW_PORT_CMD_ETS_STATE 4 +#define M_FW_PORT_CMD_ETS_STATE 0xf +#define V_FW_PORT_CMD_ETS_STATE(x) ((x) << S_FW_PORT_CMD_ETS_STATE) +#define G_FW_PORT_CMD_ETS_STATE(x) \ + (((x) >> S_FW_PORT_CMD_ETS_STATE) & M_FW_PORT_CMD_ETS_STATE) + +#define S_FW_PORT_CMD_APP_STATE 0 +#define M_FW_PORT_CMD_APP_STATE 0xf +#define V_FW_PORT_CMD_APP_STATE(x) ((x) << S_FW_PORT_CMD_APP_STATE) +#define G_FW_PORT_CMD_APP_STATE(x) \ + (((x) >> S_FW_PORT_CMD_APP_STATE) & M_FW_PORT_CMD_APP_STATE) + +/* + * These are configured into the VPD and hence tools that generate + * VPD may use this enumeration. + * extPHY #lanes T4_I2C extI2C BP_Eq BP_ANEG Speed + * + * REMEMBER: + * Update the Common Code t4_hw.c:t4_get_port_type_description() + * with any new Firmware Port Technology Types! + */ +enum fw_port_type { + FW_PORT_TYPE_FIBER_XFI = 0, /* Y, 1, N, Y, N, N, 10G */ + FW_PORT_TYPE_FIBER_XAUI = 1, /* Y, 4, N, Y, N, N, 10G */ + FW_PORT_TYPE_BT_SGMII = 2, /* Y, 1, No, No, No, No, 1G/100M */ + FW_PORT_TYPE_BT_XFI = 3, /* Y, 1, No, No, No, No, 10G */ + FW_PORT_TYPE_BT_XAUI = 4, /* Y, 4, No, No, No, No, 10G/1G/100M? */ + FW_PORT_TYPE_KX4 = 5, /* No, 4, No, No, Yes, Yes, 10G */ + FW_PORT_TYPE_CX4 = 6, /* No, 4, No, No, No, No, 10G */ + FW_PORT_TYPE_KX = 7, /* No, 1, No, No, Yes, No, 1G */ + FW_PORT_TYPE_KR = 8, /* No, 1, No, No, Yes, Yes, 10G */ + FW_PORT_TYPE_SFP = 9, /* No, 1, Yes, No, No, No, 10G */ + FW_PORT_TYPE_BP_AP = 10, /* No, 1, No, No, Yes, Yes, 10G, BP ANGE */ + FW_PORT_TYPE_BP4_AP = 11, /* No, 4, No, No, Yes, Yes, 10G, BP ANGE */ + FW_PORT_TYPE_QSFP_10G = 12, /* No, 1, Yes, No, No, No, 10G */ + FW_PORT_TYPE_QSFP = 14, /* No, 4, Yes, No, No, No, 40G */ + FW_PORT_TYPE_BP40_BA = 15, /* No, 4, No, No, Yes, Yes, 40G/10G/1G, BP ANGE */ + + FW_PORT_TYPE_NONE = M_FW_PORT_CMD_PTYPE +}; + +/* These are read from module's EEPROM and determined once the + module is inserted. */ +enum fw_port_module_type { + FW_PORT_MOD_TYPE_NA = 0x0, + FW_PORT_MOD_TYPE_LR = 0x1, + FW_PORT_MOD_TYPE_SR = 0x2, + FW_PORT_MOD_TYPE_ER = 0x3, + FW_PORT_MOD_TYPE_TWINAX_PASSIVE = 0x4, + FW_PORT_MOD_TYPE_TWINAX_ACTIVE = 0x5, + FW_PORT_MOD_TYPE_LRM = 0x6, + FW_PORT_MOD_TYPE_ERROR = M_FW_PORT_CMD_MODTYPE - 3, + FW_PORT_MOD_TYPE_UNKNOWN = M_FW_PORT_CMD_MODTYPE - 2, + FW_PORT_MOD_TYPE_NOTSUPPORTED = M_FW_PORT_CMD_MODTYPE - 1, + FW_PORT_MOD_TYPE_NONE = M_FW_PORT_CMD_MODTYPE +}; + +/* used by FW and tools may use this to generate VPD */ +enum fw_port_mod_sub_type { + FW_PORT_MOD_SUB_TYPE_NA, + FW_PORT_MOD_SUB_TYPE_MV88E114X=0x1, + FW_PORT_MOD_SUB_TYPE_TN8022=0x2, + FW_PORT_MOD_SUB_TYPE_AQ1202=0x3, + FW_PORT_MOD_SUB_TYPE_88x3120=0x4, + FW_PORT_MOD_SUB_TYPE_BCM84834=0x5, + FW_PORT_MOD_SUB_TYPE_BCM5482=0x6, + FW_PORT_MOD_SUB_TYPE_BT_VSC8634=0x8, + + /* + * The following will never been in the VPD. They are TWINAX cable + * lengths decoded from SFP+ module i2c PROMs. These should almost + * certainly go somewhere else ... + */ + FW_PORT_MOD_SUB_TYPE_TWINAX_1=0x9, + FW_PORT_MOD_SUB_TYPE_TWINAX_3=0xA, + FW_PORT_MOD_SUB_TYPE_TWINAX_5=0xB, + FW_PORT_MOD_SUB_TYPE_TWINAX_7=0xC, +}; + +/* link down reason codes (3b) */ +enum fw_port_link_dn_rc { + FW_PORT_LINK_DN_RC_NONE, + FW_PORT_LINK_DN_RC_REMFLT, /* Remote fault detected */ + FW_PORT_LINK_DN_ANEG_F, /* Auto-negotiation fault */ + FW_PORT_LINK_DN_RESERVED3, + FW_PORT_LINK_DN_OVERHEAT, /* Port overheated */ + FW_PORT_LINK_DN_UNKNOWN, /* Unable to determine reason */ + FW_PORT_LINK_DN_RX_LOS, /* No RX signal detected */ + FW_PORT_LINK_DN_RESERVED7 +}; + +/* port stats */ +#define FW_NUM_PORT_STATS 50 +#define FW_NUM_PORT_TX_STATS 23 +#define FW_NUM_PORT_RX_STATS 27 + +enum fw_port_stats_tx_index { + FW_STAT_TX_PORT_BYTES_IX, + FW_STAT_TX_PORT_FRAMES_IX, + FW_STAT_TX_PORT_BCAST_IX, + FW_STAT_TX_PORT_MCAST_IX, + FW_STAT_TX_PORT_UCAST_IX, + FW_STAT_TX_PORT_ERROR_IX, + FW_STAT_TX_PORT_64B_IX, + FW_STAT_TX_PORT_65B_127B_IX, + FW_STAT_TX_PORT_128B_255B_IX, + FW_STAT_TX_PORT_256B_511B_IX, + FW_STAT_TX_PORT_512B_1023B_IX, + FW_STAT_TX_PORT_1024B_1518B_IX, + FW_STAT_TX_PORT_1519B_MAX_IX, + FW_STAT_TX_PORT_DROP_IX, + FW_STAT_TX_PORT_PAUSE_IX, + FW_STAT_TX_PORT_PPP0_IX, + FW_STAT_TX_PORT_PPP1_IX, + FW_STAT_TX_PORT_PPP2_IX, + FW_STAT_TX_PORT_PPP3_IX, + FW_STAT_TX_PORT_PPP4_IX, + FW_STAT_TX_PORT_PPP5_IX, + FW_STAT_TX_PORT_PPP6_IX, + FW_STAT_TX_PORT_PPP7_IX +}; + +enum fw_port_stat_rx_index { + FW_STAT_RX_PORT_BYTES_IX, + FW_STAT_RX_PORT_FRAMES_IX, + FW_STAT_RX_PORT_BCAST_IX, + FW_STAT_RX_PORT_MCAST_IX, + FW_STAT_RX_PORT_UCAST_IX, + FW_STAT_RX_PORT_MTU_ERROR_IX, + FW_STAT_RX_PORT_MTU_CRC_ERROR_IX, + FW_STAT_RX_PORT_CRC_ERROR_IX, + FW_STAT_RX_PORT_LEN_ERROR_IX, + FW_STAT_RX_PORT_SYM_ERROR_IX, + FW_STAT_RX_PORT_64B_IX, + FW_STAT_RX_PORT_65B_127B_IX, + FW_STAT_RX_PORT_128B_255B_IX, + FW_STAT_RX_PORT_256B_511B_IX, + FW_STAT_RX_PORT_512B_1023B_IX, + FW_STAT_RX_PORT_1024B_1518B_IX, + FW_STAT_RX_PORT_1519B_MAX_IX, + FW_STAT_RX_PORT_PAUSE_IX, + FW_STAT_RX_PORT_PPP0_IX, + FW_STAT_RX_PORT_PPP1_IX, + FW_STAT_RX_PORT_PPP2_IX, + FW_STAT_RX_PORT_PPP3_IX, + FW_STAT_RX_PORT_PPP4_IX, + FW_STAT_RX_PORT_PPP5_IX, + FW_STAT_RX_PORT_PPP6_IX, + FW_STAT_RX_PORT_PPP7_IX, + FW_STAT_RX_PORT_LESS_64B_IX +}; + +struct fw_port_stats_cmd { + __be32 op_to_portid; + __be32 retval_len16; + union fw_port_stats { + struct fw_port_stats_ctl { + __u8 nstats_bg_bm; + __u8 tx_ix; + __be16 r6; + __be32 r7; + __be64 stat0; + __be64 stat1; + __be64 stat2; + __be64 stat3; + __be64 stat4; + __be64 stat5; + } ctl; + struct fw_port_stats_all { + __be64 tx_bytes; + __be64 tx_frames; + __be64 tx_bcast; + __be64 tx_mcast; + __be64 tx_ucast; + __be64 tx_error; + __be64 tx_64b; + __be64 tx_65b_127b; + __be64 tx_128b_255b; + __be64 tx_256b_511b; + __be64 tx_512b_1023b; + __be64 tx_1024b_1518b; + __be64 tx_1519b_max; + __be64 tx_drop; + __be64 tx_pause; + __be64 tx_ppp0; + __be64 tx_ppp1; + __be64 tx_ppp2; + __be64 tx_ppp3; + __be64 tx_ppp4; + __be64 tx_ppp5; + __be64 tx_ppp6; + __be64 tx_ppp7; + __be64 rx_bytes; + __be64 rx_frames; + __be64 rx_bcast; + __be64 rx_mcast; + __be64 rx_ucast; + __be64 rx_mtu_error; + __be64 rx_mtu_crc_error; + __be64 rx_crc_error; + __be64 rx_len_error; + __be64 rx_sym_error; + __be64 rx_64b; + __be64 rx_65b_127b; + __be64 rx_128b_255b; + __be64 rx_256b_511b; + __be64 rx_512b_1023b; + __be64 rx_1024b_1518b; + __be64 rx_1519b_max; + __be64 rx_pause; + __be64 rx_ppp0; + __be64 rx_ppp1; + __be64 rx_ppp2; + __be64 rx_ppp3; + __be64 rx_ppp4; + __be64 rx_ppp5; + __be64 rx_ppp6; + __be64 rx_ppp7; + __be64 rx_less_64b; + __be64 rx_bg_drop; + __be64 rx_bg_trunc; + } all; + } u; +}; + +#define S_FW_PORT_STATS_CMD_NSTATS 4 +#define M_FW_PORT_STATS_CMD_NSTATS 0x7 +#define V_FW_PORT_STATS_CMD_NSTATS(x) ((x) << S_FW_PORT_STATS_CMD_NSTATS) +#define G_FW_PORT_STATS_CMD_NSTATS(x) \ + (((x) >> S_FW_PORT_STATS_CMD_NSTATS) & M_FW_PORT_STATS_CMD_NSTATS) + +#define S_FW_PORT_STATS_CMD_BG_BM 0 +#define M_FW_PORT_STATS_CMD_BG_BM 0x3 +#define V_FW_PORT_STATS_CMD_BG_BM(x) ((x) << S_FW_PORT_STATS_CMD_BG_BM) +#define G_FW_PORT_STATS_CMD_BG_BM(x) \ + (((x) >> S_FW_PORT_STATS_CMD_BG_BM) & M_FW_PORT_STATS_CMD_BG_BM) + +#define S_FW_PORT_STATS_CMD_TX 7 +#define M_FW_PORT_STATS_CMD_TX 0x1 +#define V_FW_PORT_STATS_CMD_TX(x) ((x) << S_FW_PORT_STATS_CMD_TX) +#define G_FW_PORT_STATS_CMD_TX(x) \ + (((x) >> S_FW_PORT_STATS_CMD_TX) & M_FW_PORT_STATS_CMD_TX) +#define F_FW_PORT_STATS_CMD_TX V_FW_PORT_STATS_CMD_TX(1U) + +#define S_FW_PORT_STATS_CMD_IX 0 +#define M_FW_PORT_STATS_CMD_IX 0x3f +#define V_FW_PORT_STATS_CMD_IX(x) ((x) << S_FW_PORT_STATS_CMD_IX) +#define G_FW_PORT_STATS_CMD_IX(x) \ + (((x) >> S_FW_PORT_STATS_CMD_IX) & M_FW_PORT_STATS_CMD_IX) + +/* port loopback stats */ +#define FW_NUM_LB_STATS 14 +enum fw_port_lb_stats_index { + FW_STAT_LB_PORT_BYTES_IX, + FW_STAT_LB_PORT_FRAMES_IX, + FW_STAT_LB_PORT_BCAST_IX, + FW_STAT_LB_PORT_MCAST_IX, + FW_STAT_LB_PORT_UCAST_IX, + FW_STAT_LB_PORT_ERROR_IX, + FW_STAT_LB_PORT_64B_IX, + FW_STAT_LB_PORT_65B_127B_IX, + FW_STAT_LB_PORT_128B_255B_IX, + FW_STAT_LB_PORT_256B_511B_IX, + FW_STAT_LB_PORT_512B_1023B_IX, + FW_STAT_LB_PORT_1024B_1518B_IX, + FW_STAT_LB_PORT_1519B_MAX_IX, + FW_STAT_LB_PORT_DROP_FRAMES_IX +}; + +struct fw_port_lb_stats_cmd { + __be32 op_to_lbport; + __be32 retval_len16; + union fw_port_lb_stats { + struct fw_port_lb_stats_ctl { + __u8 nstats_bg_bm; + __u8 ix_pkd; + __be16 r6; + __be32 r7; + __be64 stat0; + __be64 stat1; + __be64 stat2; + __be64 stat3; + __be64 stat4; + __be64 stat5; + } ctl; + struct fw_port_lb_stats_all { + __be64 tx_bytes; + __be64 tx_frames; + __be64 tx_bcast; + __be64 tx_mcast; + __be64 tx_ucast; + __be64 tx_error; + __be64 tx_64b; + __be64 tx_65b_127b; + __be64 tx_128b_255b; + __be64 tx_256b_511b; + __be64 tx_512b_1023b; + __be64 tx_1024b_1518b; + __be64 tx_1519b_max; + __be64 rx_lb_drop; + __be64 rx_lb_trunc; + } all; + } u; +}; + +#define S_FW_PORT_LB_STATS_CMD_LBPORT 0 +#define M_FW_PORT_LB_STATS_CMD_LBPORT 0xf +#define V_FW_PORT_LB_STATS_CMD_LBPORT(x) \ + ((x) << S_FW_PORT_LB_STATS_CMD_LBPORT) +#define G_FW_PORT_LB_STATS_CMD_LBPORT(x) \ + (((x) >> S_FW_PORT_LB_STATS_CMD_LBPORT) & M_FW_PORT_LB_STATS_CMD_LBPORT) + +#define S_FW_PORT_LB_STATS_CMD_NSTATS 4 +#define M_FW_PORT_LB_STATS_CMD_NSTATS 0x7 +#define V_FW_PORT_LB_STATS_CMD_NSTATS(x) \ + ((x) << S_FW_PORT_LB_STATS_CMD_NSTATS) +#define G_FW_PORT_LB_STATS_CMD_NSTATS(x) \ + (((x) >> S_FW_PORT_LB_STATS_CMD_NSTATS) & M_FW_PORT_LB_STATS_CMD_NSTATS) + +#define S_FW_PORT_LB_STATS_CMD_BG_BM 0 +#define M_FW_PORT_LB_STATS_CMD_BG_BM 0x3 +#define V_FW_PORT_LB_STATS_CMD_BG_BM(x) ((x) << S_FW_PORT_LB_STATS_CMD_BG_BM) +#define G_FW_PORT_LB_STATS_CMD_BG_BM(x) \ + (((x) >> S_FW_PORT_LB_STATS_CMD_BG_BM) & M_FW_PORT_LB_STATS_CMD_BG_BM) + +#define S_FW_PORT_LB_STATS_CMD_IX 0 +#define M_FW_PORT_LB_STATS_CMD_IX 0xf +#define V_FW_PORT_LB_STATS_CMD_IX(x) ((x) << S_FW_PORT_LB_STATS_CMD_IX) +#define G_FW_PORT_LB_STATS_CMD_IX(x) \ + (((x) >> S_FW_PORT_LB_STATS_CMD_IX) & M_FW_PORT_LB_STATS_CMD_IX) + +/* Trace related defines */ +#define FW_TRACE_CAPTURE_MAX_SINGLE_FLT_MODE 10240 +#define FW_TRACE_CAPTURE_MAX_MULTI_FLT_MODE 2560 + +struct fw_port_trace_cmd { + __be32 op_to_portid; + __be32 retval_len16; + __be16 traceen_to_pciech; + __be16 qnum; + __be32 r5; +}; + +#define S_FW_PORT_TRACE_CMD_PORTID 0 +#define M_FW_PORT_TRACE_CMD_PORTID 0xf +#define V_FW_PORT_TRACE_CMD_PORTID(x) ((x) << S_FW_PORT_TRACE_CMD_PORTID) +#define G_FW_PORT_TRACE_CMD_PORTID(x) \ + (((x) >> S_FW_PORT_TRACE_CMD_PORTID) & M_FW_PORT_TRACE_CMD_PORTID) + +#define S_FW_PORT_TRACE_CMD_TRACEEN 15 +#define M_FW_PORT_TRACE_CMD_TRACEEN 0x1 +#define V_FW_PORT_TRACE_CMD_TRACEEN(x) ((x) << S_FW_PORT_TRACE_CMD_TRACEEN) +#define G_FW_PORT_TRACE_CMD_TRACEEN(x) \ + (((x) >> S_FW_PORT_TRACE_CMD_TRACEEN) & M_FW_PORT_TRACE_CMD_TRACEEN) +#define F_FW_PORT_TRACE_CMD_TRACEEN V_FW_PORT_TRACE_CMD_TRACEEN(1U) + +#define S_FW_PORT_TRACE_CMD_FLTMODE 14 +#define M_FW_PORT_TRACE_CMD_FLTMODE 0x1 +#define V_FW_PORT_TRACE_CMD_FLTMODE(x) ((x) << S_FW_PORT_TRACE_CMD_FLTMODE) +#define G_FW_PORT_TRACE_CMD_FLTMODE(x) \ + (((x) >> S_FW_PORT_TRACE_CMD_FLTMODE) & M_FW_PORT_TRACE_CMD_FLTMODE) +#define F_FW_PORT_TRACE_CMD_FLTMODE V_FW_PORT_TRACE_CMD_FLTMODE(1U) + +#define S_FW_PORT_TRACE_CMD_DUPLEN 13 +#define M_FW_PORT_TRACE_CMD_DUPLEN 0x1 +#define V_FW_PORT_TRACE_CMD_DUPLEN(x) ((x) << S_FW_PORT_TRACE_CMD_DUPLEN) +#define G_FW_PORT_TRACE_CMD_DUPLEN(x) \ + (((x) >> S_FW_PORT_TRACE_CMD_DUPLEN) & M_FW_PORT_TRACE_CMD_DUPLEN) +#define F_FW_PORT_TRACE_CMD_DUPLEN V_FW_PORT_TRACE_CMD_DUPLEN(1U) + +#define S_FW_PORT_TRACE_CMD_RUNTFLTSIZE 8 +#define M_FW_PORT_TRACE_CMD_RUNTFLTSIZE 0x1f +#define V_FW_PORT_TRACE_CMD_RUNTFLTSIZE(x) \ + ((x) << S_FW_PORT_TRACE_CMD_RUNTFLTSIZE) +#define G_FW_PORT_TRACE_CMD_RUNTFLTSIZE(x) \ + (((x) >> S_FW_PORT_TRACE_CMD_RUNTFLTSIZE) & \ + M_FW_PORT_TRACE_CMD_RUNTFLTSIZE) + +#define S_FW_PORT_TRACE_CMD_PCIECH 6 +#define M_FW_PORT_TRACE_CMD_PCIECH 0x3 +#define V_FW_PORT_TRACE_CMD_PCIECH(x) ((x) << S_FW_PORT_TRACE_CMD_PCIECH) +#define G_FW_PORT_TRACE_CMD_PCIECH(x) \ + (((x) >> S_FW_PORT_TRACE_CMD_PCIECH) & M_FW_PORT_TRACE_CMD_PCIECH) + +struct fw_port_trace_mmap_cmd { + __be32 op_to_portid; + __be32 retval_len16; + __be32 fid_to_skipoffset; + __be32 minpktsize_capturemax; + __u8 map[224]; +}; + +#define S_FW_PORT_TRACE_MMAP_CMD_PORTID 0 +#define M_FW_PORT_TRACE_MMAP_CMD_PORTID 0xf +#define V_FW_PORT_TRACE_MMAP_CMD_PORTID(x) \ + ((x) << S_FW_PORT_TRACE_MMAP_CMD_PORTID) +#define G_FW_PORT_TRACE_MMAP_CMD_PORTID(x) \ + (((x) >> S_FW_PORT_TRACE_MMAP_CMD_PORTID) & \ + M_FW_PORT_TRACE_MMAP_CMD_PORTID) + +#define S_FW_PORT_TRACE_MMAP_CMD_FID 30 +#define M_FW_PORT_TRACE_MMAP_CMD_FID 0x3 +#define V_FW_PORT_TRACE_MMAP_CMD_FID(x) ((x) << S_FW_PORT_TRACE_MMAP_CMD_FID) +#define G_FW_PORT_TRACE_MMAP_CMD_FID(x) \ + (((x) >> S_FW_PORT_TRACE_MMAP_CMD_FID) & M_FW_PORT_TRACE_MMAP_CMD_FID) + +#define S_FW_PORT_TRACE_MMAP_CMD_MMAPEN 29 +#define M_FW_PORT_TRACE_MMAP_CMD_MMAPEN 0x1 +#define V_FW_PORT_TRACE_MMAP_CMD_MMAPEN(x) \ + ((x) << S_FW_PORT_TRACE_MMAP_CMD_MMAPEN) +#define G_FW_PORT_TRACE_MMAP_CMD_MMAPEN(x) \ + (((x) >> S_FW_PORT_TRACE_MMAP_CMD_MMAPEN) & \ + M_FW_PORT_TRACE_MMAP_CMD_MMAPEN) +#define F_FW_PORT_TRACE_MMAP_CMD_MMAPEN V_FW_PORT_TRACE_MMAP_CMD_MMAPEN(1U) + +#define S_FW_PORT_TRACE_MMAP_CMD_DCMAPEN 28 +#define M_FW_PORT_TRACE_MMAP_CMD_DCMAPEN 0x1 +#define V_FW_PORT_TRACE_MMAP_CMD_DCMAPEN(x) \ + ((x) << S_FW_PORT_TRACE_MMAP_CMD_DCMAPEN) +#define G_FW_PORT_TRACE_MMAP_CMD_DCMAPEN(x) \ + (((x) >> S_FW_PORT_TRACE_MMAP_CMD_DCMAPEN) & \ + M_FW_PORT_TRACE_MMAP_CMD_DCMAPEN) +#define F_FW_PORT_TRACE_MMAP_CMD_DCMAPEN \ + V_FW_PORT_TRACE_MMAP_CMD_DCMAPEN(1U) + +#define S_FW_PORT_TRACE_MMAP_CMD_SKIPLENGTH 8 +#define M_FW_PORT_TRACE_MMAP_CMD_SKIPLENGTH 0x1f +#define V_FW_PORT_TRACE_MMAP_CMD_SKIPLENGTH(x) \ + ((x) << S_FW_PORT_TRACE_MMAP_CMD_SKIPLENGTH) +#define G_FW_PORT_TRACE_MMAP_CMD_SKIPLENGTH(x) \ + (((x) >> S_FW_PORT_TRACE_MMAP_CMD_SKIPLENGTH) & \ + M_FW_PORT_TRACE_MMAP_CMD_SKIPLENGTH) + +#define S_FW_PORT_TRACE_MMAP_CMD_SKIPOFFSET 0 +#define M_FW_PORT_TRACE_MMAP_CMD_SKIPOFFSET 0x1f +#define V_FW_PORT_TRACE_MMAP_CMD_SKIPOFFSET(x) \ + ((x) << S_FW_PORT_TRACE_MMAP_CMD_SKIPOFFSET) +#define G_FW_PORT_TRACE_MMAP_CMD_SKIPOFFSET(x) \ + (((x) >> S_FW_PORT_TRACE_MMAP_CMD_SKIPOFFSET) & \ + M_FW_PORT_TRACE_MMAP_CMD_SKIPOFFSET) + +#define S_FW_PORT_TRACE_MMAP_CMD_MINPKTSIZE 18 +#define M_FW_PORT_TRACE_MMAP_CMD_MINPKTSIZE 0x3fff +#define V_FW_PORT_TRACE_MMAP_CMD_MINPKTSIZE(x) \ + ((x) << S_FW_PORT_TRACE_MMAP_CMD_MINPKTSIZE) +#define G_FW_PORT_TRACE_MMAP_CMD_MINPKTSIZE(x) \ + (((x) >> S_FW_PORT_TRACE_MMAP_CMD_MINPKTSIZE) & \ + M_FW_PORT_TRACE_MMAP_CMD_MINPKTSIZE) + +#define S_FW_PORT_TRACE_MMAP_CMD_CAPTUREMAX 0 +#define M_FW_PORT_TRACE_MMAP_CMD_CAPTUREMAX 0x3fff +#define V_FW_PORT_TRACE_MMAP_CMD_CAPTUREMAX(x) \ + ((x) << S_FW_PORT_TRACE_MMAP_CMD_CAPTUREMAX) +#define G_FW_PORT_TRACE_MMAP_CMD_CAPTUREMAX(x) \ + (((x) >> S_FW_PORT_TRACE_MMAP_CMD_CAPTUREMAX) & \ + M_FW_PORT_TRACE_MMAP_CMD_CAPTUREMAX) + +struct fw_rss_ind_tbl_cmd { + __be32 op_to_viid; + __be32 retval_len16; + __be16 niqid; + __be16 startidx; + __be32 r3; + __be32 iq0_to_iq2; + __be32 iq3_to_iq5; + __be32 iq6_to_iq8; + __be32 iq9_to_iq11; + __be32 iq12_to_iq14; + __be32 iq15_to_iq17; + __be32 iq18_to_iq20; + __be32 iq21_to_iq23; + __be32 iq24_to_iq26; + __be32 iq27_to_iq29; + __be32 iq30_iq31; + __be32 r15_lo; +}; + +#define S_FW_RSS_IND_TBL_CMD_VIID 0 +#define M_FW_RSS_IND_TBL_CMD_VIID 0xfff +#define V_FW_RSS_IND_TBL_CMD_VIID(x) ((x) << S_FW_RSS_IND_TBL_CMD_VIID) +#define G_FW_RSS_IND_TBL_CMD_VIID(x) \ + (((x) >> S_FW_RSS_IND_TBL_CMD_VIID) & M_FW_RSS_IND_TBL_CMD_VIID) + +#define S_FW_RSS_IND_TBL_CMD_IQ0 20 +#define M_FW_RSS_IND_TBL_CMD_IQ0 0x3ff +#define V_FW_RSS_IND_TBL_CMD_IQ0(x) ((x) << S_FW_RSS_IND_TBL_CMD_IQ0) +#define G_FW_RSS_IND_TBL_CMD_IQ0(x) \ + (((x) >> S_FW_RSS_IND_TBL_CMD_IQ0) & M_FW_RSS_IND_TBL_CMD_IQ0) + +#define S_FW_RSS_IND_TBL_CMD_IQ1 10 +#define M_FW_RSS_IND_TBL_CMD_IQ1 0x3ff +#define V_FW_RSS_IND_TBL_CMD_IQ1(x) ((x) << S_FW_RSS_IND_TBL_CMD_IQ1) +#define G_FW_RSS_IND_TBL_CMD_IQ1(x) \ + (((x) >> S_FW_RSS_IND_TBL_CMD_IQ1) & M_FW_RSS_IND_TBL_CMD_IQ1) + +#define S_FW_RSS_IND_TBL_CMD_IQ2 0 +#define M_FW_RSS_IND_TBL_CMD_IQ2 0x3ff +#define V_FW_RSS_IND_TBL_CMD_IQ2(x) ((x) << S_FW_RSS_IND_TBL_CMD_IQ2) +#define G_FW_RSS_IND_TBL_CMD_IQ2(x) \ + (((x) >> S_FW_RSS_IND_TBL_CMD_IQ2) & M_FW_RSS_IND_TBL_CMD_IQ2) + +#define S_FW_RSS_IND_TBL_CMD_IQ3 20 +#define M_FW_RSS_IND_TBL_CMD_IQ3 0x3ff +#define V_FW_RSS_IND_TBL_CMD_IQ3(x) ((x) << S_FW_RSS_IND_TBL_CMD_IQ3) +#define G_FW_RSS_IND_TBL_CMD_IQ3(x) \ + (((x) >> S_FW_RSS_IND_TBL_CMD_IQ3) & M_FW_RSS_IND_TBL_CMD_IQ3) + +#define S_FW_RSS_IND_TBL_CMD_IQ4 10 +#define M_FW_RSS_IND_TBL_CMD_IQ4 0x3ff +#define V_FW_RSS_IND_TBL_CMD_IQ4(x) ((x) << S_FW_RSS_IND_TBL_CMD_IQ4) +#define G_FW_RSS_IND_TBL_CMD_IQ4(x) \ + (((x) >> S_FW_RSS_IND_TBL_CMD_IQ4) & M_FW_RSS_IND_TBL_CMD_IQ4) + +#define S_FW_RSS_IND_TBL_CMD_IQ5 0 +#define M_FW_RSS_IND_TBL_CMD_IQ5 0x3ff +#define V_FW_RSS_IND_TBL_CMD_IQ5(x) ((x) << S_FW_RSS_IND_TBL_CMD_IQ5) +#define G_FW_RSS_IND_TBL_CMD_IQ5(x) \ + (((x) >> S_FW_RSS_IND_TBL_CMD_IQ5) & M_FW_RSS_IND_TBL_CMD_IQ5) + +#define S_FW_RSS_IND_TBL_CMD_IQ6 20 +#define M_FW_RSS_IND_TBL_CMD_IQ6 0x3ff +#define V_FW_RSS_IND_TBL_CMD_IQ6(x) ((x) << S_FW_RSS_IND_TBL_CMD_IQ6) +#define G_FW_RSS_IND_TBL_CMD_IQ6(x) \ + (((x) >> S_FW_RSS_IND_TBL_CMD_IQ6) & M_FW_RSS_IND_TBL_CMD_IQ6) + +#define S_FW_RSS_IND_TBL_CMD_IQ7 10 +#define M_FW_RSS_IND_TBL_CMD_IQ7 0x3ff +#define V_FW_RSS_IND_TBL_CMD_IQ7(x) ((x) << S_FW_RSS_IND_TBL_CMD_IQ7) +#define G_FW_RSS_IND_TBL_CMD_IQ7(x) \ + (((x) >> S_FW_RSS_IND_TBL_CMD_IQ7) & M_FW_RSS_IND_TBL_CMD_IQ7) + +#define S_FW_RSS_IND_TBL_CMD_IQ8 0 +#define M_FW_RSS_IND_TBL_CMD_IQ8 0x3ff +#define V_FW_RSS_IND_TBL_CMD_IQ8(x) ((x) << S_FW_RSS_IND_TBL_CMD_IQ8) +#define G_FW_RSS_IND_TBL_CMD_IQ8(x) \ + (((x) >> S_FW_RSS_IND_TBL_CMD_IQ8) & M_FW_RSS_IND_TBL_CMD_IQ8) + +#define S_FW_RSS_IND_TBL_CMD_IQ9 20 +#define M_FW_RSS_IND_TBL_CMD_IQ9 0x3ff +#define V_FW_RSS_IND_TBL_CMD_IQ9(x) ((x) << S_FW_RSS_IND_TBL_CMD_IQ9) +#define G_FW_RSS_IND_TBL_CMD_IQ9(x) \ + (((x) >> S_FW_RSS_IND_TBL_CMD_IQ9) & M_FW_RSS_IND_TBL_CMD_IQ9) + +#define S_FW_RSS_IND_TBL_CMD_IQ10 10 +#define M_FW_RSS_IND_TBL_CMD_IQ10 0x3ff +#define V_FW_RSS_IND_TBL_CMD_IQ10(x) ((x) << S_FW_RSS_IND_TBL_CMD_IQ10) +#define G_FW_RSS_IND_TBL_CMD_IQ10(x) \ + (((x) >> S_FW_RSS_IND_TBL_CMD_IQ10) & M_FW_RSS_IND_TBL_CMD_IQ10) + +#define S_FW_RSS_IND_TBL_CMD_IQ11 0 +#define M_FW_RSS_IND_TBL_CMD_IQ11 0x3ff +#define V_FW_RSS_IND_TBL_CMD_IQ11(x) ((x) << S_FW_RSS_IND_TBL_CMD_IQ11) +#define G_FW_RSS_IND_TBL_CMD_IQ11(x) \ + (((x) >> S_FW_RSS_IND_TBL_CMD_IQ11) & M_FW_RSS_IND_TBL_CMD_IQ11) + +#define S_FW_RSS_IND_TBL_CMD_IQ12 20 +#define M_FW_RSS_IND_TBL_CMD_IQ12 0x3ff +#define V_FW_RSS_IND_TBL_CMD_IQ12(x) ((x) << S_FW_RSS_IND_TBL_CMD_IQ12) +#define G_FW_RSS_IND_TBL_CMD_IQ12(x) \ + (((x) >> S_FW_RSS_IND_TBL_CMD_IQ12) & M_FW_RSS_IND_TBL_CMD_IQ12) + +#define S_FW_RSS_IND_TBL_CMD_IQ13 10 +#define M_FW_RSS_IND_TBL_CMD_IQ13 0x3ff +#define V_FW_RSS_IND_TBL_CMD_IQ13(x) ((x) << S_FW_RSS_IND_TBL_CMD_IQ13) +#define G_FW_RSS_IND_TBL_CMD_IQ13(x) \ + (((x) >> S_FW_RSS_IND_TBL_CMD_IQ13) & M_FW_RSS_IND_TBL_CMD_IQ13) + +#define S_FW_RSS_IND_TBL_CMD_IQ14 0 +#define M_FW_RSS_IND_TBL_CMD_IQ14 0x3ff +#define V_FW_RSS_IND_TBL_CMD_IQ14(x) ((x) << S_FW_RSS_IND_TBL_CMD_IQ14) +#define G_FW_RSS_IND_TBL_CMD_IQ14(x) \ + (((x) >> S_FW_RSS_IND_TBL_CMD_IQ14) & M_FW_RSS_IND_TBL_CMD_IQ14) + +#define S_FW_RSS_IND_TBL_CMD_IQ15 20 +#define M_FW_RSS_IND_TBL_CMD_IQ15 0x3ff +#define V_FW_RSS_IND_TBL_CMD_IQ15(x) ((x) << S_FW_RSS_IND_TBL_CMD_IQ15) +#define G_FW_RSS_IND_TBL_CMD_IQ15(x) \ + (((x) >> S_FW_RSS_IND_TBL_CMD_IQ15) & M_FW_RSS_IND_TBL_CMD_IQ15) + +#define S_FW_RSS_IND_TBL_CMD_IQ16 10 +#define M_FW_RSS_IND_TBL_CMD_IQ16 0x3ff +#define V_FW_RSS_IND_TBL_CMD_IQ16(x) ((x) << S_FW_RSS_IND_TBL_CMD_IQ16) +#define G_FW_RSS_IND_TBL_CMD_IQ16(x) \ + (((x) >> S_FW_RSS_IND_TBL_CMD_IQ16) & M_FW_RSS_IND_TBL_CMD_IQ16) + +#define S_FW_RSS_IND_TBL_CMD_IQ17 0 +#define M_FW_RSS_IND_TBL_CMD_IQ17 0x3ff +#define V_FW_RSS_IND_TBL_CMD_IQ17(x) ((x) << S_FW_RSS_IND_TBL_CMD_IQ17) +#define G_FW_RSS_IND_TBL_CMD_IQ17(x) \ + (((x) >> S_FW_RSS_IND_TBL_CMD_IQ17) & M_FW_RSS_IND_TBL_CMD_IQ17) + +#define S_FW_RSS_IND_TBL_CMD_IQ18 20 +#define M_FW_RSS_IND_TBL_CMD_IQ18 0x3ff +#define V_FW_RSS_IND_TBL_CMD_IQ18(x) ((x) << S_FW_RSS_IND_TBL_CMD_IQ18) +#define G_FW_RSS_IND_TBL_CMD_IQ18(x) \ + (((x) >> S_FW_RSS_IND_TBL_CMD_IQ18) & M_FW_RSS_IND_TBL_CMD_IQ18) + +#define S_FW_RSS_IND_TBL_CMD_IQ19 10 +#define M_FW_RSS_IND_TBL_CMD_IQ19 0x3ff +#define V_FW_RSS_IND_TBL_CMD_IQ19(x) ((x) << S_FW_RSS_IND_TBL_CMD_IQ19) +#define G_FW_RSS_IND_TBL_CMD_IQ19(x) \ + (((x) >> S_FW_RSS_IND_TBL_CMD_IQ19) & M_FW_RSS_IND_TBL_CMD_IQ19) + +#define S_FW_RSS_IND_TBL_CMD_IQ20 0 +#define M_FW_RSS_IND_TBL_CMD_IQ20 0x3ff +#define V_FW_RSS_IND_TBL_CMD_IQ20(x) ((x) << S_FW_RSS_IND_TBL_CMD_IQ20) +#define G_FW_RSS_IND_TBL_CMD_IQ20(x) \ + (((x) >> S_FW_RSS_IND_TBL_CMD_IQ20) & M_FW_RSS_IND_TBL_CMD_IQ20) + +#define S_FW_RSS_IND_TBL_CMD_IQ21 20 +#define M_FW_RSS_IND_TBL_CMD_IQ21 0x3ff +#define V_FW_RSS_IND_TBL_CMD_IQ21(x) ((x) << S_FW_RSS_IND_TBL_CMD_IQ21) +#define G_FW_RSS_IND_TBL_CMD_IQ21(x) \ + (((x) >> S_FW_RSS_IND_TBL_CMD_IQ21) & M_FW_RSS_IND_TBL_CMD_IQ21) + +#define S_FW_RSS_IND_TBL_CMD_IQ22 10 +#define M_FW_RSS_IND_TBL_CMD_IQ22 0x3ff +#define V_FW_RSS_IND_TBL_CMD_IQ22(x) ((x) << S_FW_RSS_IND_TBL_CMD_IQ22) +#define G_FW_RSS_IND_TBL_CMD_IQ22(x) \ + (((x) >> S_FW_RSS_IND_TBL_CMD_IQ22) & M_FW_RSS_IND_TBL_CMD_IQ22) + +#define S_FW_RSS_IND_TBL_CMD_IQ23 0 +#define M_FW_RSS_IND_TBL_CMD_IQ23 0x3ff +#define V_FW_RSS_IND_TBL_CMD_IQ23(x) ((x) << S_FW_RSS_IND_TBL_CMD_IQ23) +#define G_FW_RSS_IND_TBL_CMD_IQ23(x) \ + (((x) >> S_FW_RSS_IND_TBL_CMD_IQ23) & M_FW_RSS_IND_TBL_CMD_IQ23) + +#define S_FW_RSS_IND_TBL_CMD_IQ24 20 +#define M_FW_RSS_IND_TBL_CMD_IQ24 0x3ff +#define V_FW_RSS_IND_TBL_CMD_IQ24(x) ((x) << S_FW_RSS_IND_TBL_CMD_IQ24) +#define G_FW_RSS_IND_TBL_CMD_IQ24(x) \ + (((x) >> S_FW_RSS_IND_TBL_CMD_IQ24) & M_FW_RSS_IND_TBL_CMD_IQ24) + +#define S_FW_RSS_IND_TBL_CMD_IQ25 10 +#define M_FW_RSS_IND_TBL_CMD_IQ25 0x3ff +#define V_FW_RSS_IND_TBL_CMD_IQ25(x) ((x) << S_FW_RSS_IND_TBL_CMD_IQ25) +#define G_FW_RSS_IND_TBL_CMD_IQ25(x) \ + (((x) >> S_FW_RSS_IND_TBL_CMD_IQ25) & M_FW_RSS_IND_TBL_CMD_IQ25) + +#define S_FW_RSS_IND_TBL_CMD_IQ26 0 +#define M_FW_RSS_IND_TBL_CMD_IQ26 0x3ff +#define V_FW_RSS_IND_TBL_CMD_IQ26(x) ((x) << S_FW_RSS_IND_TBL_CMD_IQ26) +#define G_FW_RSS_IND_TBL_CMD_IQ26(x) \ + (((x) >> S_FW_RSS_IND_TBL_CMD_IQ26) & M_FW_RSS_IND_TBL_CMD_IQ26) + +#define S_FW_RSS_IND_TBL_CMD_IQ27 20 +#define M_FW_RSS_IND_TBL_CMD_IQ27 0x3ff +#define V_FW_RSS_IND_TBL_CMD_IQ27(x) ((x) << S_FW_RSS_IND_TBL_CMD_IQ27) +#define G_FW_RSS_IND_TBL_CMD_IQ27(x) \ + (((x) >> S_FW_RSS_IND_TBL_CMD_IQ27) & M_FW_RSS_IND_TBL_CMD_IQ27) + +#define S_FW_RSS_IND_TBL_CMD_IQ28 10 +#define M_FW_RSS_IND_TBL_CMD_IQ28 0x3ff +#define V_FW_RSS_IND_TBL_CMD_IQ28(x) ((x) << S_FW_RSS_IND_TBL_CMD_IQ28) +#define G_FW_RSS_IND_TBL_CMD_IQ28(x) \ + (((x) >> S_FW_RSS_IND_TBL_CMD_IQ28) & M_FW_RSS_IND_TBL_CMD_IQ28) + +#define S_FW_RSS_IND_TBL_CMD_IQ29 0 +#define M_FW_RSS_IND_TBL_CMD_IQ29 0x3ff +#define V_FW_RSS_IND_TBL_CMD_IQ29(x) ((x) << S_FW_RSS_IND_TBL_CMD_IQ29) +#define G_FW_RSS_IND_TBL_CMD_IQ29(x) \ + (((x) >> S_FW_RSS_IND_TBL_CMD_IQ29) & M_FW_RSS_IND_TBL_CMD_IQ29) + +#define S_FW_RSS_IND_TBL_CMD_IQ30 20 +#define M_FW_RSS_IND_TBL_CMD_IQ30 0x3ff +#define V_FW_RSS_IND_TBL_CMD_IQ30(x) ((x) << S_FW_RSS_IND_TBL_CMD_IQ30) +#define G_FW_RSS_IND_TBL_CMD_IQ30(x) \ + (((x) >> S_FW_RSS_IND_TBL_CMD_IQ30) & M_FW_RSS_IND_TBL_CMD_IQ30) + +#define S_FW_RSS_IND_TBL_CMD_IQ31 10 +#define M_FW_RSS_IND_TBL_CMD_IQ31 0x3ff +#define V_FW_RSS_IND_TBL_CMD_IQ31(x) ((x) << S_FW_RSS_IND_TBL_CMD_IQ31) +#define G_FW_RSS_IND_TBL_CMD_IQ31(x) \ + (((x) >> S_FW_RSS_IND_TBL_CMD_IQ31) & M_FW_RSS_IND_TBL_CMD_IQ31) + +struct fw_rss_glb_config_cmd { + __be32 op_to_write; + __be32 retval_len16; + union fw_rss_glb_config { + struct fw_rss_glb_config_manual { + __be32 mode_pkd; + __be32 r3; + __be64 r4; + __be64 r5; + } manual; + struct fw_rss_glb_config_basicvirtual { + __be32 mode_pkd; + __be32 synmapen_to_hashtoeplitz; + __be64 r8; + __be64 r9; + } basicvirtual; + } u; +}; + +#define S_FW_RSS_GLB_CONFIG_CMD_MODE 28 +#define M_FW_RSS_GLB_CONFIG_CMD_MODE 0xf +#define V_FW_RSS_GLB_CONFIG_CMD_MODE(x) ((x) << S_FW_RSS_GLB_CONFIG_CMD_MODE) +#define G_FW_RSS_GLB_CONFIG_CMD_MODE(x) \ + (((x) >> S_FW_RSS_GLB_CONFIG_CMD_MODE) & M_FW_RSS_GLB_CONFIG_CMD_MODE) + +#define FW_RSS_GLB_CONFIG_CMD_MODE_MANUAL 0 +#define FW_RSS_GLB_CONFIG_CMD_MODE_BASICVIRTUAL 1 +#define FW_RSS_GLB_CONFIG_CMD_MODE_MAX 1 + +#define S_FW_RSS_GLB_CONFIG_CMD_SYNMAPEN 8 +#define M_FW_RSS_GLB_CONFIG_CMD_SYNMAPEN 0x1 +#define V_FW_RSS_GLB_CONFIG_CMD_SYNMAPEN(x) \ + ((x) << S_FW_RSS_GLB_CONFIG_CMD_SYNMAPEN) +#define G_FW_RSS_GLB_CONFIG_CMD_SYNMAPEN(x) \ + (((x) >> S_FW_RSS_GLB_CONFIG_CMD_SYNMAPEN) & \ + M_FW_RSS_GLB_CONFIG_CMD_SYNMAPEN) +#define F_FW_RSS_GLB_CONFIG_CMD_SYNMAPEN \ + V_FW_RSS_GLB_CONFIG_CMD_SYNMAPEN(1U) + +#define S_FW_RSS_GLB_CONFIG_CMD_SYN4TUPENIPV6 7 +#define M_FW_RSS_GLB_CONFIG_CMD_SYN4TUPENIPV6 0x1 +#define V_FW_RSS_GLB_CONFIG_CMD_SYN4TUPENIPV6(x) \ + ((x) << S_FW_RSS_GLB_CONFIG_CMD_SYN4TUPENIPV6) +#define G_FW_RSS_GLB_CONFIG_CMD_SYN4TUPENIPV6(x) \ + (((x) >> S_FW_RSS_GLB_CONFIG_CMD_SYN4TUPENIPV6) & \ + M_FW_RSS_GLB_CONFIG_CMD_SYN4TUPENIPV6) +#define F_FW_RSS_GLB_CONFIG_CMD_SYN4TUPENIPV6 \ + V_FW_RSS_GLB_CONFIG_CMD_SYN4TUPENIPV6(1U) + +#define S_FW_RSS_GLB_CONFIG_CMD_SYN2TUPENIPV6 6 +#define M_FW_RSS_GLB_CONFIG_CMD_SYN2TUPENIPV6 0x1 +#define V_FW_RSS_GLB_CONFIG_CMD_SYN2TUPENIPV6(x) \ + ((x) << S_FW_RSS_GLB_CONFIG_CMD_SYN2TUPENIPV6) +#define G_FW_RSS_GLB_CONFIG_CMD_SYN2TUPENIPV6(x) \ + (((x) >> S_FW_RSS_GLB_CONFIG_CMD_SYN2TUPENIPV6) & \ + M_FW_RSS_GLB_CONFIG_CMD_SYN2TUPENIPV6) +#define F_FW_RSS_GLB_CONFIG_CMD_SYN2TUPENIPV6 \ + V_FW_RSS_GLB_CONFIG_CMD_SYN2TUPENIPV6(1U) + +#define S_FW_RSS_GLB_CONFIG_CMD_SYN4TUPENIPV4 5 +#define M_FW_RSS_GLB_CONFIG_CMD_SYN4TUPENIPV4 0x1 +#define V_FW_RSS_GLB_CONFIG_CMD_SYN4TUPENIPV4(x) \ + ((x) << S_FW_RSS_GLB_CONFIG_CMD_SYN4TUPENIPV4) +#define G_FW_RSS_GLB_CONFIG_CMD_SYN4TUPENIPV4(x) \ + (((x) >> S_FW_RSS_GLB_CONFIG_CMD_SYN4TUPENIPV4) & \ + M_FW_RSS_GLB_CONFIG_CMD_SYN4TUPENIPV4) +#define F_FW_RSS_GLB_CONFIG_CMD_SYN4TUPENIPV4 \ + V_FW_RSS_GLB_CONFIG_CMD_SYN4TUPENIPV4(1U) + +#define S_FW_RSS_GLB_CONFIG_CMD_SYN2TUPENIPV4 4 +#define M_FW_RSS_GLB_CONFIG_CMD_SYN2TUPENIPV4 0x1 +#define V_FW_RSS_GLB_CONFIG_CMD_SYN2TUPENIPV4(x) \ + ((x) << S_FW_RSS_GLB_CONFIG_CMD_SYN2TUPENIPV4) +#define G_FW_RSS_GLB_CONFIG_CMD_SYN2TUPENIPV4(x) \ + (((x) >> S_FW_RSS_GLB_CONFIG_CMD_SYN2TUPENIPV4) & \ + M_FW_RSS_GLB_CONFIG_CMD_SYN2TUPENIPV4) +#define F_FW_RSS_GLB_CONFIG_CMD_SYN2TUPENIPV4 \ + V_FW_RSS_GLB_CONFIG_CMD_SYN2TUPENIPV4(1U) + +#define S_FW_RSS_GLB_CONFIG_CMD_OFDMAPEN 3 +#define M_FW_RSS_GLB_CONFIG_CMD_OFDMAPEN 0x1 +#define V_FW_RSS_GLB_CONFIG_CMD_OFDMAPEN(x) \ + ((x) << S_FW_RSS_GLB_CONFIG_CMD_OFDMAPEN) +#define G_FW_RSS_GLB_CONFIG_CMD_OFDMAPEN(x) \ + (((x) >> S_FW_RSS_GLB_CONFIG_CMD_OFDMAPEN) & \ + M_FW_RSS_GLB_CONFIG_CMD_OFDMAPEN) +#define F_FW_RSS_GLB_CONFIG_CMD_OFDMAPEN \ + V_FW_RSS_GLB_CONFIG_CMD_OFDMAPEN(1U) + +#define S_FW_RSS_GLB_CONFIG_CMD_TNLMAPEN 2 +#define M_FW_RSS_GLB_CONFIG_CMD_TNLMAPEN 0x1 +#define V_FW_RSS_GLB_CONFIG_CMD_TNLMAPEN(x) \ + ((x) << S_FW_RSS_GLB_CONFIG_CMD_TNLMAPEN) +#define G_FW_RSS_GLB_CONFIG_CMD_TNLMAPEN(x) \ + (((x) >> S_FW_RSS_GLB_CONFIG_CMD_TNLMAPEN) & \ + M_FW_RSS_GLB_CONFIG_CMD_TNLMAPEN) +#define F_FW_RSS_GLB_CONFIG_CMD_TNLMAPEN \ + V_FW_RSS_GLB_CONFIG_CMD_TNLMAPEN(1U) + +#define S_FW_RSS_GLB_CONFIG_CMD_TNLALLLKP 1 +#define M_FW_RSS_GLB_CONFIG_CMD_TNLALLLKP 0x1 +#define V_FW_RSS_GLB_CONFIG_CMD_TNLALLLKP(x) \ + ((x) << S_FW_RSS_GLB_CONFIG_CMD_TNLALLLKP) +#define G_FW_RSS_GLB_CONFIG_CMD_TNLALLLKP(x) \ + (((x) >> S_FW_RSS_GLB_CONFIG_CMD_TNLALLLKP) & \ + M_FW_RSS_GLB_CONFIG_CMD_TNLALLLKP) +#define F_FW_RSS_GLB_CONFIG_CMD_TNLALLLKP \ + V_FW_RSS_GLB_CONFIG_CMD_TNLALLLKP(1U) + +#define S_FW_RSS_GLB_CONFIG_CMD_HASHTOEPLITZ 0 +#define M_FW_RSS_GLB_CONFIG_CMD_HASHTOEPLITZ 0x1 +#define V_FW_RSS_GLB_CONFIG_CMD_HASHTOEPLITZ(x) \ + ((x) << S_FW_RSS_GLB_CONFIG_CMD_HASHTOEPLITZ) +#define G_FW_RSS_GLB_CONFIG_CMD_HASHTOEPLITZ(x) \ + (((x) >> S_FW_RSS_GLB_CONFIG_CMD_HASHTOEPLITZ) & \ + M_FW_RSS_GLB_CONFIG_CMD_HASHTOEPLITZ) +#define F_FW_RSS_GLB_CONFIG_CMD_HASHTOEPLITZ \ + V_FW_RSS_GLB_CONFIG_CMD_HASHTOEPLITZ(1U) + +struct fw_rss_vi_config_cmd { + __be32 op_to_viid; + __be32 retval_len16; + union fw_rss_vi_config { + struct fw_rss_vi_config_manual { + __be64 r3; + __be64 r4; + __be64 r5; + } manual; + struct fw_rss_vi_config_basicvirtual { + __be32 r6; + __be32 defaultq_to_udpen; + __be64 r9; + __be64 r10; + } basicvirtual; + } u; +}; + +#define S_FW_RSS_VI_CONFIG_CMD_VIID 0 +#define M_FW_RSS_VI_CONFIG_CMD_VIID 0xfff +#define V_FW_RSS_VI_CONFIG_CMD_VIID(x) ((x) << S_FW_RSS_VI_CONFIG_CMD_VIID) +#define G_FW_RSS_VI_CONFIG_CMD_VIID(x) \ + (((x) >> S_FW_RSS_VI_CONFIG_CMD_VIID) & M_FW_RSS_VI_CONFIG_CMD_VIID) + +#define S_FW_RSS_VI_CONFIG_CMD_DEFAULTQ 16 +#define M_FW_RSS_VI_CONFIG_CMD_DEFAULTQ 0x3ff +#define V_FW_RSS_VI_CONFIG_CMD_DEFAULTQ(x) \ + ((x) << S_FW_RSS_VI_CONFIG_CMD_DEFAULTQ) +#define G_FW_RSS_VI_CONFIG_CMD_DEFAULTQ(x) \ + (((x) >> S_FW_RSS_VI_CONFIG_CMD_DEFAULTQ) & \ + M_FW_RSS_VI_CONFIG_CMD_DEFAULTQ) + +#define S_FW_RSS_VI_CONFIG_CMD_IP6FOURTUPEN 4 +#define M_FW_RSS_VI_CONFIG_CMD_IP6FOURTUPEN 0x1 +#define V_FW_RSS_VI_CONFIG_CMD_IP6FOURTUPEN(x) \ + ((x) << S_FW_RSS_VI_CONFIG_CMD_IP6FOURTUPEN) +#define G_FW_RSS_VI_CONFIG_CMD_IP6FOURTUPEN(x) \ + (((x) >> S_FW_RSS_VI_CONFIG_CMD_IP6FOURTUPEN) & \ + M_FW_RSS_VI_CONFIG_CMD_IP6FOURTUPEN) +#define F_FW_RSS_VI_CONFIG_CMD_IP6FOURTUPEN \ + V_FW_RSS_VI_CONFIG_CMD_IP6FOURTUPEN(1U) + +#define S_FW_RSS_VI_CONFIG_CMD_IP6TWOTUPEN 3 +#define M_FW_RSS_VI_CONFIG_CMD_IP6TWOTUPEN 0x1 +#define V_FW_RSS_VI_CONFIG_CMD_IP6TWOTUPEN(x) \ + ((x) << S_FW_RSS_VI_CONFIG_CMD_IP6TWOTUPEN) +#define G_FW_RSS_VI_CONFIG_CMD_IP6TWOTUPEN(x) \ + (((x) >> S_FW_RSS_VI_CONFIG_CMD_IP6TWOTUPEN) & \ + M_FW_RSS_VI_CONFIG_CMD_IP6TWOTUPEN) +#define F_FW_RSS_VI_CONFIG_CMD_IP6TWOTUPEN \ + V_FW_RSS_VI_CONFIG_CMD_IP6TWOTUPEN(1U) + +#define S_FW_RSS_VI_CONFIG_CMD_IP4FOURTUPEN 2 +#define M_FW_RSS_VI_CONFIG_CMD_IP4FOURTUPEN 0x1 +#define V_FW_RSS_VI_CONFIG_CMD_IP4FOURTUPEN(x) \ + ((x) << S_FW_RSS_VI_CONFIG_CMD_IP4FOURTUPEN) +#define G_FW_RSS_VI_CONFIG_CMD_IP4FOURTUPEN(x) \ + (((x) >> S_FW_RSS_VI_CONFIG_CMD_IP4FOURTUPEN) & \ + M_FW_RSS_VI_CONFIG_CMD_IP4FOURTUPEN) +#define F_FW_RSS_VI_CONFIG_CMD_IP4FOURTUPEN \ + V_FW_RSS_VI_CONFIG_CMD_IP4FOURTUPEN(1U) + +#define S_FW_RSS_VI_CONFIG_CMD_IP4TWOTUPEN 1 +#define M_FW_RSS_VI_CONFIG_CMD_IP4TWOTUPEN 0x1 +#define V_FW_RSS_VI_CONFIG_CMD_IP4TWOTUPEN(x) \ + ((x) << S_FW_RSS_VI_CONFIG_CMD_IP4TWOTUPEN) +#define G_FW_RSS_VI_CONFIG_CMD_IP4TWOTUPEN(x) \ + (((x) >> S_FW_RSS_VI_CONFIG_CMD_IP4TWOTUPEN) & \ + M_FW_RSS_VI_CONFIG_CMD_IP4TWOTUPEN) +#define F_FW_RSS_VI_CONFIG_CMD_IP4TWOTUPEN \ + V_FW_RSS_VI_CONFIG_CMD_IP4TWOTUPEN(1U) + +#define S_FW_RSS_VI_CONFIG_CMD_UDPEN 0 +#define M_FW_RSS_VI_CONFIG_CMD_UDPEN 0x1 +#define V_FW_RSS_VI_CONFIG_CMD_UDPEN(x) ((x) << S_FW_RSS_VI_CONFIG_CMD_UDPEN) +#define G_FW_RSS_VI_CONFIG_CMD_UDPEN(x) \ + (((x) >> S_FW_RSS_VI_CONFIG_CMD_UDPEN) & M_FW_RSS_VI_CONFIG_CMD_UDPEN) +#define F_FW_RSS_VI_CONFIG_CMD_UDPEN V_FW_RSS_VI_CONFIG_CMD_UDPEN(1U) + +enum fw_sched_sc { + FW_SCHED_SC_CONFIG = 0, + FW_SCHED_SC_PARAMS = 1, +}; + +enum fw_sched_type { + FW_SCHED_TYPE_PKTSCHED = 0, + FW_SCHED_TYPE_STREAMSCHED = 1, +}; + +enum fw_sched_params_level { + FW_SCHED_PARAMS_LEVEL_CL_RL = 0, + FW_SCHED_PARAMS_LEVEL_CL_WRR = 1, + FW_SCHED_PARAMS_LEVEL_CH_RL = 2, +}; + +enum fw_sched_params_mode { + FW_SCHED_PARAMS_MODE_CLASS = 0, + FW_SCHED_PARAMS_MODE_FLOW = 1, +}; + +enum fw_sched_params_unit { + FW_SCHED_PARAMS_UNIT_BITRATE = 0, + FW_SCHED_PARAMS_UNIT_PKTRATE = 1, +}; + +enum fw_sched_params_rate { + FW_SCHED_PARAMS_RATE_REL = 0, + FW_SCHED_PARAMS_RATE_ABS = 1, +}; + +struct fw_sched_cmd { + __be32 op_to_write; + __be32 retval_len16; + union fw_sched { + struct fw_sched_config { + __u8 sc; + __u8 type; + __u8 minmaxen; + __u8 r3[5]; + __u8 nclasses[4]; + __be32 r4; + } config; + struct fw_sched_params { + __u8 sc; + __u8 type; + __u8 level; + __u8 mode; + __u8 unit; + __u8 rate; + __u8 ch; + __u8 cl; + __be32 min; + __be32 max; + __be16 weight; + __be16 pktsize; + __be16 burstsize; + __be16 r4; + } params; + } u; +}; + +/* + * length of the formatting string + */ +#define FW_DEVLOG_FMT_LEN 192 + +/* + * maximum number of the formatting string parameters + */ +#define FW_DEVLOG_FMT_PARAMS_NUM 8 + +/* + * priority levels + */ +enum fw_devlog_level { + FW_DEVLOG_LEVEL_EMERG = 0x0, + FW_DEVLOG_LEVEL_CRIT = 0x1, + FW_DEVLOG_LEVEL_ERR = 0x2, + FW_DEVLOG_LEVEL_NOTICE = 0x3, + FW_DEVLOG_LEVEL_INFO = 0x4, + FW_DEVLOG_LEVEL_DEBUG = 0x5, + FW_DEVLOG_LEVEL_MAX = 0x5, +}; + +/* + * facilities that may send a log message + */ +enum fw_devlog_facility { + FW_DEVLOG_FACILITY_CORE = 0x00, + FW_DEVLOG_FACILITY_CF = 0x01, + FW_DEVLOG_FACILITY_SCHED = 0x02, + FW_DEVLOG_FACILITY_TIMER = 0x04, + FW_DEVLOG_FACILITY_RES = 0x06, + FW_DEVLOG_FACILITY_HW = 0x08, + FW_DEVLOG_FACILITY_FLR = 0x10, + FW_DEVLOG_FACILITY_DMAQ = 0x12, + FW_DEVLOG_FACILITY_PHY = 0x14, + FW_DEVLOG_FACILITY_MAC = 0x16, + FW_DEVLOG_FACILITY_PORT = 0x18, + FW_DEVLOG_FACILITY_VI = 0x1A, + FW_DEVLOG_FACILITY_FILTER = 0x1C, + FW_DEVLOG_FACILITY_ACL = 0x1E, + FW_DEVLOG_FACILITY_TM = 0x20, + FW_DEVLOG_FACILITY_QFC = 0x22, + FW_DEVLOG_FACILITY_DCB = 0x24, + FW_DEVLOG_FACILITY_ETH = 0x26, + FW_DEVLOG_FACILITY_OFLD = 0x28, + FW_DEVLOG_FACILITY_RI = 0x2A, + FW_DEVLOG_FACILITY_ISCSI = 0x2C, + FW_DEVLOG_FACILITY_FCOE = 0x2E, + FW_DEVLOG_FACILITY_FOISCSI = 0x30, + FW_DEVLOG_FACILITY_FOFCOE = 0x32, + FW_DEVLOG_FACILITY_MAX = 0x32, +}; + +/* + * log message format + */ +struct fw_devlog_e { + __be64 timestamp; + __be32 seqno; + __be16 reserved1; + __u8 level; + __u8 facility; + __u8 fmt[FW_DEVLOG_FMT_LEN]; + __be32 params[FW_DEVLOG_FMT_PARAMS_NUM]; + __be32 reserved3[4]; +}; + +struct fw_devlog_cmd { + __be32 op_to_write; + __be32 retval_len16; + __u8 level; + __u8 r2[7]; + __be32 memtype_devlog_memaddr16_devlog; + __be32 memsize_devlog; + __be32 r3[2]; +}; + +#define S_FW_DEVLOG_CMD_MEMTYPE_DEVLOG 28 +#define M_FW_DEVLOG_CMD_MEMTYPE_DEVLOG 0xf +#define V_FW_DEVLOG_CMD_MEMTYPE_DEVLOG(x) \ + ((x) << S_FW_DEVLOG_CMD_MEMTYPE_DEVLOG) +#define G_FW_DEVLOG_CMD_MEMTYPE_DEVLOG(x) \ + (((x) >> S_FW_DEVLOG_CMD_MEMTYPE_DEVLOG) & M_FW_DEVLOG_CMD_MEMTYPE_DEVLOG) + +#define S_FW_DEVLOG_CMD_MEMADDR16_DEVLOG 0 +#define M_FW_DEVLOG_CMD_MEMADDR16_DEVLOG 0xfffffff +#define V_FW_DEVLOG_CMD_MEMADDR16_DEVLOG(x) \ + ((x) << S_FW_DEVLOG_CMD_MEMADDR16_DEVLOG) +#define G_FW_DEVLOG_CMD_MEMADDR16_DEVLOG(x) \ + (((x) >> S_FW_DEVLOG_CMD_MEMADDR16_DEVLOG) & \ + M_FW_DEVLOG_CMD_MEMADDR16_DEVLOG) + +enum fw_watchdog_actions { + FW_WATCHDOG_ACTION_SHUTDOWN = 0, + FW_WATCHDOG_ACTION_FLR = 1, + FW_WATCHDOG_ACTION_BYPASS = 2, + FW_WATCHDOG_ACTION_TMPCHK = 3, + + FW_WATCHDOG_ACTION_MAX = 4, +}; + +#define FW_WATCHDOG_MAX_TIMEOUT_SECS 60 + +struct fw_watchdog_cmd { + __be32 op_to_vfn; + __be32 retval_len16; + __be32 timeout; + __be32 action; +}; + +#define S_FW_WATCHDOG_CMD_PFN 8 +#define M_FW_WATCHDOG_CMD_PFN 0x7 +#define V_FW_WATCHDOG_CMD_PFN(x) ((x) << S_FW_WATCHDOG_CMD_PFN) +#define G_FW_WATCHDOG_CMD_PFN(x) \ + (((x) >> S_FW_WATCHDOG_CMD_PFN) & M_FW_WATCHDOG_CMD_PFN) + +#define S_FW_WATCHDOG_CMD_VFN 0 +#define M_FW_WATCHDOG_CMD_VFN 0xff +#define V_FW_WATCHDOG_CMD_VFN(x) ((x) << S_FW_WATCHDOG_CMD_VFN) +#define G_FW_WATCHDOG_CMD_VFN(x) \ + (((x) >> S_FW_WATCHDOG_CMD_VFN) & M_FW_WATCHDOG_CMD_VFN) + +struct fw_clip_cmd { + __be32 op_to_write; + __be32 alloc_to_len16; + __be64 ip_hi; + __be64 ip_lo; + __be32 r4[2]; +}; + +#define S_FW_CLIP_CMD_ALLOC 31 +#define M_FW_CLIP_CMD_ALLOC 0x1 +#define V_FW_CLIP_CMD_ALLOC(x) ((x) << S_FW_CLIP_CMD_ALLOC) +#define G_FW_CLIP_CMD_ALLOC(x) \ + (((x) >> S_FW_CLIP_CMD_ALLOC) & M_FW_CLIP_CMD_ALLOC) +#define F_FW_CLIP_CMD_ALLOC V_FW_CLIP_CMD_ALLOC(1U) + +#define S_FW_CLIP_CMD_FREE 30 +#define M_FW_CLIP_CMD_FREE 0x1 +#define V_FW_CLIP_CMD_FREE(x) ((x) << S_FW_CLIP_CMD_FREE) +#define G_FW_CLIP_CMD_FREE(x) \ + (((x) >> S_FW_CLIP_CMD_FREE) & M_FW_CLIP_CMD_FREE) +#define F_FW_CLIP_CMD_FREE V_FW_CLIP_CMD_FREE(1U) + +/****************************************************************************** + * F O i S C S I C O M M A N D s + **************************************/ + +#define FW_CHNET_IFACE_ADDR_MAX 3 + +enum fw_chnet_iface_cmd_subop { + FW_CHNET_IFACE_CMD_SUBOP_NOOP = 0, + + FW_CHNET_IFACE_CMD_SUBOP_LINK_UP, + FW_CHNET_IFACE_CMD_SUBOP_LINK_DOWN, + + FW_CHNET_IFACE_CMD_SUBOP_MTU_SET, + FW_CHNET_IFACE_CMD_SUBOP_MTU_GET, + + FW_CHNET_IFACE_CMD_SUBOP_MAX, +}; + +struct fw_chnet_iface_cmd { + __be32 op_to_portid; + __be32 retval_len16; + __u8 subop; + __u8 r2[3]; + __be32 ifid_ifstate; + __be16 mtu; + __be16 vlanid; + __be32 r3; + __be16 r4; + __u8 mac[6]; +}; + +#define S_FW_CHNET_IFACE_CMD_PORTID 0 +#define M_FW_CHNET_IFACE_CMD_PORTID 0xf +#define V_FW_CHNET_IFACE_CMD_PORTID(x) ((x) << S_FW_CHNET_IFACE_CMD_PORTID) +#define G_FW_CHNET_IFACE_CMD_PORTID(x) \ + (((x) >> S_FW_CHNET_IFACE_CMD_PORTID) & M_FW_CHNET_IFACE_CMD_PORTID) + +#define S_FW_CHNET_IFACE_CMD_IFID 8 +#define M_FW_CHNET_IFACE_CMD_IFID 0xffffff +#define V_FW_CHNET_IFACE_CMD_IFID(x) ((x) << S_FW_CHNET_IFACE_CMD_IFID) +#define G_FW_CHNET_IFACE_CMD_IFID(x) \ + (((x) >> S_FW_CHNET_IFACE_CMD_IFID) & M_FW_CHNET_IFACE_CMD_IFID) + +#define S_FW_CHNET_IFACE_CMD_IFSTATE 0 +#define M_FW_CHNET_IFACE_CMD_IFSTATE 0xff +#define V_FW_CHNET_IFACE_CMD_IFSTATE(x) ((x) << S_FW_CHNET_IFACE_CMD_IFSTATE) +#define G_FW_CHNET_IFACE_CMD_IFSTATE(x) \ + (((x) >> S_FW_CHNET_IFACE_CMD_IFSTATE) & M_FW_CHNET_IFACE_CMD_IFSTATE) + +/****************************************************************************** + * F O F C O E C O M M A N D s + ************************************/ + +struct fw_fcoe_res_info_cmd { + __be32 op_to_read; + __be32 retval_len16; + __be16 e_d_tov; + __be16 r_a_tov_seq; + __be16 r_a_tov_els; + __be16 r_r_tov; + __be32 max_xchgs; + __be32 max_ssns; + __be32 used_xchgs; + __be32 used_ssns; + __be32 max_fcfs; + __be32 max_vnps; + __be32 used_fcfs; + __be32 used_vnps; +}; + +struct fw_fcoe_link_cmd { + __be32 op_to_portid; + __be32 retval_len16; + __be32 sub_opcode_fcfi; + __u8 r3; + __u8 lstatus; + __be16 flags; + __u8 r4; + __u8 set_vlan; + __be16 vlan_id; + __be32 vnpi_pkd; + __be16 r6; + __u8 phy_mac[6]; + __u8 vnport_wwnn[8]; + __u8 vnport_wwpn[8]; +}; + +#define S_FW_FCOE_LINK_CMD_PORTID 0 +#define M_FW_FCOE_LINK_CMD_PORTID 0xf +#define V_FW_FCOE_LINK_CMD_PORTID(x) ((x) << S_FW_FCOE_LINK_CMD_PORTID) +#define G_FW_FCOE_LINK_CMD_PORTID(x) \ + (((x) >> S_FW_FCOE_LINK_CMD_PORTID) & M_FW_FCOE_LINK_CMD_PORTID) + +#define S_FW_FCOE_LINK_CMD_SUB_OPCODE 24 +#define M_FW_FCOE_LINK_CMD_SUB_OPCODE 0xff +#define V_FW_FCOE_LINK_CMD_SUB_OPCODE(x) \ + ((x) << S_FW_FCOE_LINK_CMD_SUB_OPCODE) +#define G_FW_FCOE_LINK_CMD_SUB_OPCODE(x) \ + (((x) >> S_FW_FCOE_LINK_CMD_SUB_OPCODE) & M_FW_FCOE_LINK_CMD_SUB_OPCODE) + +#define S_FW_FCOE_LINK_CMD_FCFI 0 +#define M_FW_FCOE_LINK_CMD_FCFI 0xffffff +#define V_FW_FCOE_LINK_CMD_FCFI(x) ((x) << S_FW_FCOE_LINK_CMD_FCFI) +#define G_FW_FCOE_LINK_CMD_FCFI(x) \ + (((x) >> S_FW_FCOE_LINK_CMD_FCFI) & M_FW_FCOE_LINK_CMD_FCFI) + +#define S_FW_FCOE_LINK_CMD_VNPI 0 +#define M_FW_FCOE_LINK_CMD_VNPI 0xfffff +#define V_FW_FCOE_LINK_CMD_VNPI(x) ((x) << S_FW_FCOE_LINK_CMD_VNPI) +#define G_FW_FCOE_LINK_CMD_VNPI(x) \ + (((x) >> S_FW_FCOE_LINK_CMD_VNPI) & M_FW_FCOE_LINK_CMD_VNPI) + +struct fw_fcoe_vnp_cmd { + __be32 op_to_fcfi; + __be32 alloc_to_len16; + __be32 gen_wwn_to_vnpi; + __be32 vf_id; + __be16 iqid; + __u8 vnport_mac[6]; + __u8 vnport_wwnn[8]; + __u8 vnport_wwpn[8]; + __u8 cmn_srv_parms[16]; + __u8 clsp_word_0_1[8]; +}; + +#define S_FW_FCOE_VNP_CMD_FCFI 0 +#define M_FW_FCOE_VNP_CMD_FCFI 0xfffff +#define V_FW_FCOE_VNP_CMD_FCFI(x) ((x) << S_FW_FCOE_VNP_CMD_FCFI) +#define G_FW_FCOE_VNP_CMD_FCFI(x) \ + (((x) >> S_FW_FCOE_VNP_CMD_FCFI) & M_FW_FCOE_VNP_CMD_FCFI) + +#define S_FW_FCOE_VNP_CMD_ALLOC 31 +#define M_FW_FCOE_VNP_CMD_ALLOC 0x1 +#define V_FW_FCOE_VNP_CMD_ALLOC(x) ((x) << S_FW_FCOE_VNP_CMD_ALLOC) +#define G_FW_FCOE_VNP_CMD_ALLOC(x) \ + (((x) >> S_FW_FCOE_VNP_CMD_ALLOC) & M_FW_FCOE_VNP_CMD_ALLOC) +#define F_FW_FCOE_VNP_CMD_ALLOC V_FW_FCOE_VNP_CMD_ALLOC(1U) + +#define S_FW_FCOE_VNP_CMD_FREE 30 +#define M_FW_FCOE_VNP_CMD_FREE 0x1 +#define V_FW_FCOE_VNP_CMD_FREE(x) ((x) << S_FW_FCOE_VNP_CMD_FREE) +#define G_FW_FCOE_VNP_CMD_FREE(x) \ + (((x) >> S_FW_FCOE_VNP_CMD_FREE) & M_FW_FCOE_VNP_CMD_FREE) +#define F_FW_FCOE_VNP_CMD_FREE V_FW_FCOE_VNP_CMD_FREE(1U) + +#define S_FW_FCOE_VNP_CMD_MODIFY 29 +#define M_FW_FCOE_VNP_CMD_MODIFY 0x1 +#define V_FW_FCOE_VNP_CMD_MODIFY(x) ((x) << S_FW_FCOE_VNP_CMD_MODIFY) +#define G_FW_FCOE_VNP_CMD_MODIFY(x) \ + (((x) >> S_FW_FCOE_VNP_CMD_MODIFY) & M_FW_FCOE_VNP_CMD_MODIFY) +#define F_FW_FCOE_VNP_CMD_MODIFY V_FW_FCOE_VNP_CMD_MODIFY(1U) + +#define S_FW_FCOE_VNP_CMD_GEN_WWN 22 +#define M_FW_FCOE_VNP_CMD_GEN_WWN 0x1 +#define V_FW_FCOE_VNP_CMD_GEN_WWN(x) ((x) << S_FW_FCOE_VNP_CMD_GEN_WWN) +#define G_FW_FCOE_VNP_CMD_GEN_WWN(x) \ + (((x) >> S_FW_FCOE_VNP_CMD_GEN_WWN) & M_FW_FCOE_VNP_CMD_GEN_WWN) +#define F_FW_FCOE_VNP_CMD_GEN_WWN V_FW_FCOE_VNP_CMD_GEN_WWN(1U) + +#define S_FW_FCOE_VNP_CMD_PERSIST 21 +#define M_FW_FCOE_VNP_CMD_PERSIST 0x1 +#define V_FW_FCOE_VNP_CMD_PERSIST(x) ((x) << S_FW_FCOE_VNP_CMD_PERSIST) +#define G_FW_FCOE_VNP_CMD_PERSIST(x) \ + (((x) >> S_FW_FCOE_VNP_CMD_PERSIST) & M_FW_FCOE_VNP_CMD_PERSIST) +#define F_FW_FCOE_VNP_CMD_PERSIST V_FW_FCOE_VNP_CMD_PERSIST(1U) + +#define S_FW_FCOE_VNP_CMD_VFID_EN 20 +#define M_FW_FCOE_VNP_CMD_VFID_EN 0x1 +#define V_FW_FCOE_VNP_CMD_VFID_EN(x) ((x) << S_FW_FCOE_VNP_CMD_VFID_EN) +#define G_FW_FCOE_VNP_CMD_VFID_EN(x) \ + (((x) >> S_FW_FCOE_VNP_CMD_VFID_EN) & M_FW_FCOE_VNP_CMD_VFID_EN) +#define F_FW_FCOE_VNP_CMD_VFID_EN V_FW_FCOE_VNP_CMD_VFID_EN(1U) + +#define S_FW_FCOE_VNP_CMD_VNPI 0 +#define M_FW_FCOE_VNP_CMD_VNPI 0xfffff +#define V_FW_FCOE_VNP_CMD_VNPI(x) ((x) << S_FW_FCOE_VNP_CMD_VNPI) +#define G_FW_FCOE_VNP_CMD_VNPI(x) \ + (((x) >> S_FW_FCOE_VNP_CMD_VNPI) & M_FW_FCOE_VNP_CMD_VNPI) + +struct fw_fcoe_sparams_cmd { + __be32 op_to_portid; + __be32 retval_len16; + __u8 r3[7]; + __u8 cos; + __u8 lport_wwnn[8]; + __u8 lport_wwpn[8]; + __u8 cmn_srv_parms[16]; + __u8 cls_srv_parms[16]; +}; + +#define S_FW_FCOE_SPARAMS_CMD_PORTID 0 +#define M_FW_FCOE_SPARAMS_CMD_PORTID 0xf +#define V_FW_FCOE_SPARAMS_CMD_PORTID(x) ((x) << S_FW_FCOE_SPARAMS_CMD_PORTID) +#define G_FW_FCOE_SPARAMS_CMD_PORTID(x) \ + (((x) >> S_FW_FCOE_SPARAMS_CMD_PORTID) & M_FW_FCOE_SPARAMS_CMD_PORTID) + +struct fw_fcoe_stats_cmd { + __be32 op_to_flowid; + __be32 free_to_len16; + union fw_fcoe_stats { + struct fw_fcoe_stats_ctl { + __u8 nstats_port; + __u8 port_valid_ix; + __be16 r6; + __be32 r7; + __be64 stat0; + __be64 stat1; + __be64 stat2; + __be64 stat3; + __be64 stat4; + __be64 stat5; + } ctl; + struct fw_fcoe_port_stats { + __be64 tx_bcast_bytes; + __be64 tx_bcast_frames; + __be64 tx_mcast_bytes; + __be64 tx_mcast_frames; + __be64 tx_ucast_bytes; + __be64 tx_ucast_frames; + __be64 tx_drop_frames; + __be64 tx_offload_bytes; + __be64 tx_offload_frames; + __be64 rx_bcast_bytes; + __be64 rx_bcast_frames; + __be64 rx_mcast_bytes; + __be64 rx_mcast_frames; + __be64 rx_ucast_bytes; + __be64 rx_ucast_frames; + __be64 rx_err_frames; + } port_stats; + struct fw_fcoe_fcf_stats { + __be32 fip_tx_bytes; + __be32 fip_tx_fr; + __be64 fcf_ka; + __be64 mcast_adv_rcvd; + __be16 ucast_adv_rcvd; + __be16 sol_sent; + __be16 vlan_req; + __be16 vlan_rpl; + __be16 clr_vlink; + __be16 link_down; + __be16 link_up; + __be16 logo; + __be16 flogi_req; + __be16 flogi_rpl; + __be16 fdisc_req; + __be16 fdisc_rpl; + __be16 fka_prd_chg; + __be16 fc_map_chg; + __be16 vfid_chg; + __u8 no_fka_req; + __u8 no_vnp; + } fcf_stats; + struct fw_fcoe_pcb_stats { + __be64 tx_bytes; + __be64 tx_frames; + __be64 rx_bytes; + __be64 rx_frames; + __be32 vnp_ka; + __be32 unsol_els_rcvd; + __be64 unsol_cmd_rcvd; + __be16 implicit_logo; + __be16 flogi_inv_sparm; + __be16 fdisc_inv_sparm; + __be16 flogi_rjt; + __be16 fdisc_rjt; + __be16 no_ssn; + __be16 mac_flt_fail; + __be16 inv_fr_rcvd; + } pcb_stats; + struct fw_fcoe_scb_stats { + __be64 tx_bytes; + __be64 tx_frames; + __be64 rx_bytes; + __be64 rx_frames; + __be32 host_abrt_req; + __be32 adap_auto_abrt; + __be32 adap_abrt_rsp; + __be32 host_ios_req; + __be16 ssn_offl_ios; + __be16 ssn_not_rdy_ios; + __u8 rx_data_ddp_err; + __u8 ddp_flt_set_err; + __be16 rx_data_fr_err; + __u8 bad_st_abrt_req; + __u8 no_io_abrt_req; + __u8 abort_tmo; + __u8 abort_tmo_2; + __be32 abort_req; + __u8 no_ppod_res_tmo; + __u8 bp_tmo; + __u8 adap_auto_cls; + __u8 no_io_cls_req; + __be32 host_cls_req; + __be64 unsol_cmd_rcvd; + __be32 plogi_req_rcvd; + __be32 prli_req_rcvd; + __be16 logo_req_rcvd; + __be16 prlo_req_rcvd; + __be16 plogi_rjt_rcvd; + __be16 prli_rjt_rcvd; + __be32 adisc_req_rcvd; + __be32 rscn_rcvd; + __be32 rrq_req_rcvd; + __be32 unsol_els_rcvd; + __u8 adisc_rjt_rcvd; + __u8 scr_rjt; + __u8 ct_rjt; + __u8 inval_bls_rcvd; + __be32 ba_rjt_rcvd; + } scb_stats; + } u; +}; + +#define S_FW_FCOE_STATS_CMD_FLOWID 0 +#define M_FW_FCOE_STATS_CMD_FLOWID 0xfffff +#define V_FW_FCOE_STATS_CMD_FLOWID(x) ((x) << S_FW_FCOE_STATS_CMD_FLOWID) +#define G_FW_FCOE_STATS_CMD_FLOWID(x) \ + (((x) >> S_FW_FCOE_STATS_CMD_FLOWID) & M_FW_FCOE_STATS_CMD_FLOWID) + +#define S_FW_FCOE_STATS_CMD_FREE 30 +#define M_FW_FCOE_STATS_CMD_FREE 0x1 +#define V_FW_FCOE_STATS_CMD_FREE(x) ((x) << S_FW_FCOE_STATS_CMD_FREE) +#define G_FW_FCOE_STATS_CMD_FREE(x) \ + (((x) >> S_FW_FCOE_STATS_CMD_FREE) & M_FW_FCOE_STATS_CMD_FREE) +#define F_FW_FCOE_STATS_CMD_FREE V_FW_FCOE_STATS_CMD_FREE(1U) + +#define S_FW_FCOE_STATS_CMD_NSTATS 4 +#define M_FW_FCOE_STATS_CMD_NSTATS 0x7 +#define V_FW_FCOE_STATS_CMD_NSTATS(x) ((x) << S_FW_FCOE_STATS_CMD_NSTATS) +#define G_FW_FCOE_STATS_CMD_NSTATS(x) \ + (((x) >> S_FW_FCOE_STATS_CMD_NSTATS) & M_FW_FCOE_STATS_CMD_NSTATS) + +#define S_FW_FCOE_STATS_CMD_PORT 0 +#define M_FW_FCOE_STATS_CMD_PORT 0x3 +#define V_FW_FCOE_STATS_CMD_PORT(x) ((x) << S_FW_FCOE_STATS_CMD_PORT) +#define G_FW_FCOE_STATS_CMD_PORT(x) \ + (((x) >> S_FW_FCOE_STATS_CMD_PORT) & M_FW_FCOE_STATS_CMD_PORT) + +#define S_FW_FCOE_STATS_CMD_PORT_VALID 7 +#define M_FW_FCOE_STATS_CMD_PORT_VALID 0x1 +#define V_FW_FCOE_STATS_CMD_PORT_VALID(x) \ + ((x) << S_FW_FCOE_STATS_CMD_PORT_VALID) +#define G_FW_FCOE_STATS_CMD_PORT_VALID(x) \ + (((x) >> S_FW_FCOE_STATS_CMD_PORT_VALID) & M_FW_FCOE_STATS_CMD_PORT_VALID) +#define F_FW_FCOE_STATS_CMD_PORT_VALID V_FW_FCOE_STATS_CMD_PORT_VALID(1U) + +#define S_FW_FCOE_STATS_CMD_IX 0 +#define M_FW_FCOE_STATS_CMD_IX 0x3f +#define V_FW_FCOE_STATS_CMD_IX(x) ((x) << S_FW_FCOE_STATS_CMD_IX) +#define G_FW_FCOE_STATS_CMD_IX(x) \ + (((x) >> S_FW_FCOE_STATS_CMD_IX) & M_FW_FCOE_STATS_CMD_IX) + +struct fw_fcoe_fcf_cmd { + __be32 op_to_fcfi; + __be32 retval_len16; + __be16 priority_pkd; + __u8 mac[6]; + __u8 name_id[8]; + __u8 fabric[8]; + __be16 vf_id; + __be16 max_fcoe_size; + __u8 vlan_id; + __u8 fc_map[3]; + __be32 fka_adv; + __be32 r6; + __u8 r7_hi; + __u8 fpma_to_portid; + __u8 spma_mac[6]; + __be64 r8; +}; + +#define S_FW_FCOE_FCF_CMD_FCFI 0 +#define M_FW_FCOE_FCF_CMD_FCFI 0xfffff +#define V_FW_FCOE_FCF_CMD_FCFI(x) ((x) << S_FW_FCOE_FCF_CMD_FCFI) +#define G_FW_FCOE_FCF_CMD_FCFI(x) \ + (((x) >> S_FW_FCOE_FCF_CMD_FCFI) & M_FW_FCOE_FCF_CMD_FCFI) + +#define S_FW_FCOE_FCF_CMD_PRIORITY 0 +#define M_FW_FCOE_FCF_CMD_PRIORITY 0xff +#define V_FW_FCOE_FCF_CMD_PRIORITY(x) ((x) << S_FW_FCOE_FCF_CMD_PRIORITY) +#define G_FW_FCOE_FCF_CMD_PRIORITY(x) \ + (((x) >> S_FW_FCOE_FCF_CMD_PRIORITY) & M_FW_FCOE_FCF_CMD_PRIORITY) + +#define S_FW_FCOE_FCF_CMD_FPMA 6 +#define M_FW_FCOE_FCF_CMD_FPMA 0x1 +#define V_FW_FCOE_FCF_CMD_FPMA(x) ((x) << S_FW_FCOE_FCF_CMD_FPMA) +#define G_FW_FCOE_FCF_CMD_FPMA(x) \ + (((x) >> S_FW_FCOE_FCF_CMD_FPMA) & M_FW_FCOE_FCF_CMD_FPMA) +#define F_FW_FCOE_FCF_CMD_FPMA V_FW_FCOE_FCF_CMD_FPMA(1U) + +#define S_FW_FCOE_FCF_CMD_SPMA 5 +#define M_FW_FCOE_FCF_CMD_SPMA 0x1 +#define V_FW_FCOE_FCF_CMD_SPMA(x) ((x) << S_FW_FCOE_FCF_CMD_SPMA) +#define G_FW_FCOE_FCF_CMD_SPMA(x) \ + (((x) >> S_FW_FCOE_FCF_CMD_SPMA) & M_FW_FCOE_FCF_CMD_SPMA) +#define F_FW_FCOE_FCF_CMD_SPMA V_FW_FCOE_FCF_CMD_SPMA(1U) + +#define S_FW_FCOE_FCF_CMD_LOGIN 4 +#define M_FW_FCOE_FCF_CMD_LOGIN 0x1 +#define V_FW_FCOE_FCF_CMD_LOGIN(x) ((x) << S_FW_FCOE_FCF_CMD_LOGIN) +#define G_FW_FCOE_FCF_CMD_LOGIN(x) \ + (((x) >> S_FW_FCOE_FCF_CMD_LOGIN) & M_FW_FCOE_FCF_CMD_LOGIN) +#define F_FW_FCOE_FCF_CMD_LOGIN V_FW_FCOE_FCF_CMD_LOGIN(1U) + +#define S_FW_FCOE_FCF_CMD_PORTID 0 +#define M_FW_FCOE_FCF_CMD_PORTID 0xf +#define V_FW_FCOE_FCF_CMD_PORTID(x) ((x) << S_FW_FCOE_FCF_CMD_PORTID) +#define G_FW_FCOE_FCF_CMD_PORTID(x) \ + (((x) >> S_FW_FCOE_FCF_CMD_PORTID) & M_FW_FCOE_FCF_CMD_PORTID) + +/****************************************************************************** + * E R R O R a n d D E B U G C O M M A N D s + ******************************************************/ + +enum fw_error_type { + FW_ERROR_TYPE_EXCEPTION = 0x0, + FW_ERROR_TYPE_HWMODULE = 0x1, + FW_ERROR_TYPE_WR = 0x2, + FW_ERROR_TYPE_ACL = 0x3, +}; + +struct fw_error_cmd { + __be32 op_to_type; + __be32 len16_pkd; + union fw_error { + struct fw_error_exception { + __be32 info[6]; + } exception; + struct fw_error_hwmodule { + __be32 regaddr; + __be32 regval; + } hwmodule; + struct fw_error_wr { + __be16 cidx; + __be16 pfn_vfn; + __be32 eqid; + __u8 wrhdr[16]; + } wr; + struct fw_error_acl { + __be16 cidx; + __be16 pfn_vfn; + __be32 eqid; + __be16 mv_pkd; + __u8 val[6]; + __be64 r4; + } acl; + } u; +}; + +#define S_FW_ERROR_CMD_FATAL 4 +#define M_FW_ERROR_CMD_FATAL 0x1 +#define V_FW_ERROR_CMD_FATAL(x) ((x) << S_FW_ERROR_CMD_FATAL) +#define G_FW_ERROR_CMD_FATAL(x) \ + (((x) >> S_FW_ERROR_CMD_FATAL) & M_FW_ERROR_CMD_FATAL) +#define F_FW_ERROR_CMD_FATAL V_FW_ERROR_CMD_FATAL(1U) + +#define S_FW_ERROR_CMD_TYPE 0 +#define M_FW_ERROR_CMD_TYPE 0xf +#define V_FW_ERROR_CMD_TYPE(x) ((x) << S_FW_ERROR_CMD_TYPE) +#define G_FW_ERROR_CMD_TYPE(x) \ + (((x) >> S_FW_ERROR_CMD_TYPE) & M_FW_ERROR_CMD_TYPE) + +#define S_FW_ERROR_CMD_PFN 8 +#define M_FW_ERROR_CMD_PFN 0x7 +#define V_FW_ERROR_CMD_PFN(x) ((x) << S_FW_ERROR_CMD_PFN) +#define G_FW_ERROR_CMD_PFN(x) \ + (((x) >> S_FW_ERROR_CMD_PFN) & M_FW_ERROR_CMD_PFN) + +#define S_FW_ERROR_CMD_VFN 0 +#define M_FW_ERROR_CMD_VFN 0xff +#define V_FW_ERROR_CMD_VFN(x) ((x) << S_FW_ERROR_CMD_VFN) +#define G_FW_ERROR_CMD_VFN(x) \ + (((x) >> S_FW_ERROR_CMD_VFN) & M_FW_ERROR_CMD_VFN) + +#define S_FW_ERROR_CMD_PFN 8 +#define M_FW_ERROR_CMD_PFN 0x7 +#define V_FW_ERROR_CMD_PFN(x) ((x) << S_FW_ERROR_CMD_PFN) +#define G_FW_ERROR_CMD_PFN(x) \ + (((x) >> S_FW_ERROR_CMD_PFN) & M_FW_ERROR_CMD_PFN) + +#define S_FW_ERROR_CMD_VFN 0 +#define M_FW_ERROR_CMD_VFN 0xff +#define V_FW_ERROR_CMD_VFN(x) ((x) << S_FW_ERROR_CMD_VFN) +#define G_FW_ERROR_CMD_VFN(x) \ + (((x) >> S_FW_ERROR_CMD_VFN) & M_FW_ERROR_CMD_VFN) + +#define S_FW_ERROR_CMD_MV 15 +#define M_FW_ERROR_CMD_MV 0x1 +#define V_FW_ERROR_CMD_MV(x) ((x) << S_FW_ERROR_CMD_MV) +#define G_FW_ERROR_CMD_MV(x) \ + (((x) >> S_FW_ERROR_CMD_MV) & M_FW_ERROR_CMD_MV) +#define F_FW_ERROR_CMD_MV V_FW_ERROR_CMD_MV(1U) + +struct fw_debug_cmd { + __be32 op_type; + __be32 len16_pkd; + union fw_debug { + struct fw_debug_assert { + __be32 fcid; + __be32 line; + __be32 x; + __be32 y; + __u8 filename_0_7[8]; + __u8 filename_8_15[8]; + __be64 r3; + } assert; + struct fw_debug_prt { + __be16 dprtstridx; + __be16 r3[3]; + __be32 dprtstrparam0; + __be32 dprtstrparam1; + __be32 dprtstrparam2; + __be32 dprtstrparam3; + } prt; + } u; +}; + +#define S_FW_DEBUG_CMD_TYPE 0 +#define M_FW_DEBUG_CMD_TYPE 0xff +#define V_FW_DEBUG_CMD_TYPE(x) ((x) << S_FW_DEBUG_CMD_TYPE) +#define G_FW_DEBUG_CMD_TYPE(x) \ + (((x) >> S_FW_DEBUG_CMD_TYPE) & M_FW_DEBUG_CMD_TYPE) + +/****************************************************************************** + * P C I E F W R E G I S T E R + **************************************/ + +enum pcie_fw_eval { + PCIE_FW_EVAL_CRASH = 0, + PCIE_FW_EVAL_PREP = 1, + PCIE_FW_EVAL_CONF = 2, + PCIE_FW_EVAL_INIT = 3, + PCIE_FW_EVAL_UNEXPECTEDEVENT = 4, + PCIE_FW_EVAL_OVERHEAT = 5, + PCIE_FW_EVAL_DEVICESHUTDOWN = 6, +}; + +/** + * Register definitions for the PCIE_FW register which the firmware uses + * to retain status across RESETs. This register should be considered + * as a READ-ONLY register for Host Software and only to be used to + * track firmware initialization/error state, etc. + */ +#define S_PCIE_FW_ERR 31 +#define M_PCIE_FW_ERR 0x1 +#define V_PCIE_FW_ERR(x) ((x) << S_PCIE_FW_ERR) +#define G_PCIE_FW_ERR(x) (((x) >> S_PCIE_FW_ERR) & M_PCIE_FW_ERR) +#define F_PCIE_FW_ERR V_PCIE_FW_ERR(1U) + +#define S_PCIE_FW_INIT 30 +#define M_PCIE_FW_INIT 0x1 +#define V_PCIE_FW_INIT(x) ((x) << S_PCIE_FW_INIT) +#define G_PCIE_FW_INIT(x) (((x) >> S_PCIE_FW_INIT) & M_PCIE_FW_INIT) +#define F_PCIE_FW_INIT V_PCIE_FW_INIT(1U) + +#define S_PCIE_FW_HALT 29 +#define M_PCIE_FW_HALT 0x1 +#define V_PCIE_FW_HALT(x) ((x) << S_PCIE_FW_HALT) +#define G_PCIE_FW_HALT(x) (((x) >> S_PCIE_FW_HALT) & M_PCIE_FW_HALT) +#define F_PCIE_FW_HALT V_PCIE_FW_HALT(1U) + +#define S_PCIE_FW_EVAL 24 +#define M_PCIE_FW_EVAL 0x7 +#define V_PCIE_FW_EVAL(x) ((x) << S_PCIE_FW_EVAL) +#define G_PCIE_FW_EVAL(x) (((x) >> S_PCIE_FW_EVAL) & M_PCIE_FW_EVAL) + +#define S_PCIE_FW_STAGE 21 +#define M_PCIE_FW_STAGE 0x7 +#define V_PCIE_FW_STAGE(x) ((x) << S_PCIE_FW_STAGE) +#define G_PCIE_FW_STAGE(x) (((x) >> S_PCIE_FW_STAGE) & M_PCIE_FW_STAGE) + +#define S_PCIE_FW_ASYNCNOT_VLD 20 +#define M_PCIE_FW_ASYNCNOT_VLD 0x1 +#define V_PCIE_FW_ASYNCNOT_VLD(x) \ + ((x) << S_PCIE_FW_ASYNCNOT_VLD) +#define G_PCIE_FW_ASYNCNOT_VLD(x) \ + (((x) >> S_PCIE_FW_ASYNCNOT_VLD) & M_PCIE_FW_ASYNCNOT_VLD) +#define F_PCIE_FW_ASYNCNOT_VLD V_PCIE_FW_ASYNCNOT_VLD(1U) + +#define S_PCIE_FW_ASYNCNOTINT 19 +#define M_PCIE_FW_ASYNCNOTINT 0x1 +#define V_PCIE_FW_ASYNCNOTINT(x) \ + ((x) << S_PCIE_FW_ASYNCNOTINT) +#define G_PCIE_FW_ASYNCNOTINT(x) \ + (((x) >> S_PCIE_FW_ASYNCNOTINT) & M_PCIE_FW_ASYNCNOTINT) +#define F_PCIE_FW_ASYNCNOTINT V_PCIE_FW_ASYNCNOTINT(1U) + +#define S_PCIE_FW_ASYNCNOT 16 +#define M_PCIE_FW_ASYNCNOT 0x7 +#define V_PCIE_FW_ASYNCNOT(x) ((x) << S_PCIE_FW_ASYNCNOT) +#define G_PCIE_FW_ASYNCNOT(x) \ + (((x) >> S_PCIE_FW_ASYNCNOT) & M_PCIE_FW_ASYNCNOT) + +#define S_PCIE_FW_MASTER_VLD 15 +#define M_PCIE_FW_MASTER_VLD 0x1 +#define V_PCIE_FW_MASTER_VLD(x) ((x) << S_PCIE_FW_MASTER_VLD) +#define G_PCIE_FW_MASTER_VLD(x) \ + (((x) >> S_PCIE_FW_MASTER_VLD) & M_PCIE_FW_MASTER_VLD) +#define F_PCIE_FW_MASTER_VLD V_PCIE_FW_MASTER_VLD(1U) + +#define S_PCIE_FW_MASTER 12 +#define M_PCIE_FW_MASTER 0x7 +#define V_PCIE_FW_MASTER(x) ((x) << S_PCIE_FW_MASTER) +#define G_PCIE_FW_MASTER(x) (((x) >> S_PCIE_FW_MASTER) & M_PCIE_FW_MASTER) + +#define S_PCIE_FW_RESET_VLD 11 +#define M_PCIE_FW_RESET_VLD 0x1 +#define V_PCIE_FW_RESET_VLD(x) ((x) << S_PCIE_FW_RESET_VLD) +#define G_PCIE_FW_RESET_VLD(x) \ + (((x) >> S_PCIE_FW_RESET_VLD) & M_PCIE_FW_RESET_VLD) +#define F_PCIE_FW_RESET_VLD V_PCIE_FW_RESET_VLD(1U) + +#define S_PCIE_FW_RESET 8 +#define M_PCIE_FW_RESET 0x7 +#define V_PCIE_FW_RESET(x) ((x) << S_PCIE_FW_RESET) +#define G_PCIE_FW_RESET(x) \ + (((x) >> S_PCIE_FW_RESET) & M_PCIE_FW_RESET) + +#define S_PCIE_FW_REGISTERED 0 +#define M_PCIE_FW_REGISTERED 0xff +#define V_PCIE_FW_REGISTERED(x) ((x) << S_PCIE_FW_REGISTERED) +#define G_PCIE_FW_REGISTERED(x) \ + (((x) >> S_PCIE_FW_REGISTERED) & M_PCIE_FW_REGISTERED) + + +/****************************************************************************** + * P C I E F W P F 0 R E G I S T E R + **********************************************/ + +/* + * this register is available as 32-bit of persistent storage (accross + * PL_RST based chip-reset) for boot drivers (i.e. firmware and driver + * will not write it) + */ + + +/****************************************************************************** + * B I N A R Y H E A D E R F O R M A T + **********************************************/ + +/* + * firmware binary header format + */ +struct fw_hdr { + __u8 ver; + __u8 chip; /* terminator chip family */ + __be16 len512; /* bin length in units of 512-bytes */ + __be32 fw_ver; /* firmware version */ + __be32 tp_microcode_ver; /* tcp processor microcode version */ + __u8 intfver_nic; + __u8 intfver_vnic; + __u8 intfver_ofld; + __u8 intfver_ri; + __u8 intfver_iscsipdu; + __u8 intfver_iscsi; + __u8 intfver_fcoepdu; + __u8 intfver_fcoe; + __u32 reserved2; + __u32 reserved3; + __u32 magic; /* runtime or bootstrap fw */ + __be32 flags; + __be32 reserved6[23]; +}; + +enum fw_hdr_chip { + FW_HDR_CHIP_T4, + FW_HDR_CHIP_T5 +}; + +#define S_FW_HDR_FW_VER_MAJOR 24 +#define M_FW_HDR_FW_VER_MAJOR 0xff +#define V_FW_HDR_FW_VER_MAJOR(x) \ + ((x) << S_FW_HDR_FW_VER_MAJOR) +#define G_FW_HDR_FW_VER_MAJOR(x) \ + (((x) >> S_FW_HDR_FW_VER_MAJOR) & M_FW_HDR_FW_VER_MAJOR) + +#define S_FW_HDR_FW_VER_MINOR 16 +#define M_FW_HDR_FW_VER_MINOR 0xff +#define V_FW_HDR_FW_VER_MINOR(x) \ + ((x) << S_FW_HDR_FW_VER_MINOR) +#define G_FW_HDR_FW_VER_MINOR(x) \ + (((x) >> S_FW_HDR_FW_VER_MINOR) & M_FW_HDR_FW_VER_MINOR) + +#define S_FW_HDR_FW_VER_MICRO 8 +#define M_FW_HDR_FW_VER_MICRO 0xff +#define V_FW_HDR_FW_VER_MICRO(x) \ + ((x) << S_FW_HDR_FW_VER_MICRO) +#define G_FW_HDR_FW_VER_MICRO(x) \ + (((x) >> S_FW_HDR_FW_VER_MICRO) & M_FW_HDR_FW_VER_MICRO) + +#define S_FW_HDR_FW_VER_BUILD 0 +#define M_FW_HDR_FW_VER_BUILD 0xff +#define V_FW_HDR_FW_VER_BUILD(x) \ + ((x) << S_FW_HDR_FW_VER_BUILD) +#define G_FW_HDR_FW_VER_BUILD(x) \ + (((x) >> S_FW_HDR_FW_VER_BUILD) & M_FW_HDR_FW_VER_BUILD) + +enum { + /* T4 + */ + FW_HDR_INTFVER_NIC = 0x00, + FW_HDR_INTFVER_VNIC = 0x00, + FW_HDR_INTFVER_OFLD = 0x00, + FW_HDR_INTFVER_RI = 0x00, + FW_HDR_INTFVER_ISCSIPDU = 0x00, + FW_HDR_INTFVER_ISCSI = 0x00, + FW_HDR_INTFVER_FCOEPDU = 0x00, + FW_HDR_INTFVER_FCOE = 0x00, + + /* T5 + */ + T5FW_HDR_INTFVER_NIC = 0x00, + T5FW_HDR_INTFVER_VNIC = 0x00, + T5FW_HDR_INTFVER_OFLD = 0x00, + T5FW_HDR_INTFVER_RI = 0x00, + T5FW_HDR_INTFVER_ISCSIPDU= 0x00, + T5FW_HDR_INTFVER_ISCSI = 0x00, + T5FW_HDR_INTFVER_FCOEPDU= 0x00, + T5FW_HDR_INTFVER_FCOE = 0x00, +}; + +enum { + FW_HDR_MAGIC_RUNTIME = 0x00000000, + FW_HDR_MAGIC_BOOTSTRAP = 0x626f6f74, +}; + +enum fw_hdr_flags { + FW_HDR_FLAGS_RESET_HALT = 0x00000001, +}; + +#endif /* _T4FW_INTERFACE_H_ */ Index: head/contrib/ofed/libcxgb4/src/verbs.c =================================================================== --- head/contrib/ofed/libcxgb4/src/verbs.c (nonexistent) +++ head/contrib/ofed/libcxgb4/src/verbs.c (revision 273806) @@ -0,0 +1,702 @@ +/* + * Copyright (c) 2006-2014 Chelsio, Inc. All rights reserved. + * + * This software is available to you under a choice of one of two + * licenses. You may choose to be licensed under the terms of the GNU + * General Public License (GPL) Version 2, available from the file + * COPYING in the main directory of this source tree, or the + * OpenIB.org BSD license below: + * + * Redistribution and use in source and binary forms, with or + * without modification, are permitted provided that the following + * conditions are met: + * + * - Redistributions of source code must retain the above + * copyright notice, this list of conditions and the following + * disclaimer. + * + * - Redistributions in binary form must reproduce the above + * copyright notice, this list of conditions and the following + * disclaimer in the documentation and/or other materials + * provided with the distribution. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, + * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF + * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND + * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS + * BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN + * ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN + * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE + * SOFTWARE. + */ +#if HAVE_CONFIG_H +# include +#endif /* HAVE_CONFIG_H */ + +#include +#include +#include +#include +#include +#include +#include +#include +#include + +#include "libcxgb4.h" +#include "cxgb4-abi.h" + +#define MASKED(x) (void *)((unsigned long)(x) & c4iw_page_mask) + +int c4iw_query_device(struct ibv_context *context, struct ibv_device_attr *attr) +{ + struct ibv_query_device cmd; + uint64_t raw_fw_ver; + unsigned major, minor, sub_minor; + int ret; + + ret = ibv_cmd_query_device(context, attr, &raw_fw_ver, &cmd, + sizeof cmd); + if (ret) + return ret; + + major = (raw_fw_ver >> 32) & 0xffff; + minor = (raw_fw_ver >> 16) & 0xffff; + sub_minor = raw_fw_ver & 0xffff; + + snprintf(attr->fw_ver, sizeof attr->fw_ver, + "%d.%d.%d", major, minor, sub_minor); + + return 0; +} + +int c4iw_query_port(struct ibv_context *context, uint8_t port, + struct ibv_port_attr *attr) +{ + struct ibv_query_port cmd; + + return ibv_cmd_query_port(context, port, attr, &cmd, sizeof cmd); +} + +struct ibv_pd *c4iw_alloc_pd(struct ibv_context *context) +{ + struct ibv_alloc_pd cmd; + struct c4iw_alloc_pd_resp resp; + struct c4iw_pd *pd; + + pd = malloc(sizeof *pd); + if (!pd) + return NULL; + + if (ibv_cmd_alloc_pd(context, &pd->ibv_pd, &cmd, sizeof cmd, + &resp.ibv_resp, sizeof resp)) { + free(pd); + return NULL; + } + + return &pd->ibv_pd; +} + +int c4iw_free_pd(struct ibv_pd *pd) +{ + int ret; + + ret = ibv_cmd_dealloc_pd(pd); + if (ret) + return ret; + + free(pd); + return 0; +} + +static struct ibv_mr *__c4iw_reg_mr(struct ibv_pd *pd, void *addr, + size_t length, uint64_t hca_va, + int access) +{ + struct c4iw_mr *mhp; + struct ibv_reg_mr cmd; + struct ibv_reg_mr_resp resp; + struct c4iw_dev *dev = to_c4iw_dev(pd->context->device); + + mhp = malloc(sizeof *mhp); + if (!mhp) + return NULL; + + if (ibv_cmd_reg_mr(pd, addr, length, hca_va, + access, &mhp->ibv_mr, &cmd, sizeof cmd, + &resp, sizeof resp)) { + free(mhp); + return NULL; + } + + mhp->va_fbo = hca_va; + mhp->len = length; + + PDBG("%s stag 0x%x va_fbo 0x%" PRIx64 " len %d\n", + __func__, mhp->ibv_mr.rkey, mhp->va_fbo, mhp->len); + + pthread_spin_lock(&dev->lock); + dev->mmid2ptr[c4iw_mmid(mhp->ibv_mr.lkey)] = mhp; + pthread_spin_unlock(&dev->lock); + INC_STAT(mr); + return &mhp->ibv_mr; +} + +struct ibv_mr *c4iw_reg_mr(struct ibv_pd *pd, void *addr, + size_t length, int access) +{ + PDBG("%s addr %p length %ld\n", __func__, addr, length); + return __c4iw_reg_mr(pd, addr, length, (uintptr_t) addr, access); +} + +int c4iw_dereg_mr(struct ibv_mr *mr) +{ + int ret; + struct c4iw_dev *dev = to_c4iw_dev(mr->pd->context->device); + + ret = ibv_cmd_dereg_mr(mr); + if (ret) + return ret; + + pthread_spin_lock(&dev->lock); + dev->mmid2ptr[c4iw_mmid(mr->lkey)] = NULL; + pthread_spin_unlock(&dev->lock); + + free(to_c4iw_mr(mr)); + + return 0; +} + +struct ibv_cq *c4iw_create_cq(struct ibv_context *context, int cqe, + struct ibv_comp_channel *channel, int comp_vector) +{ + struct ibv_create_cq cmd; + struct c4iw_create_cq_resp resp; + struct c4iw_cq *chp; + struct c4iw_dev *dev = to_c4iw_dev(context->device); + int ret; + + chp = calloc(1, sizeof *chp); + if (!chp) { + return NULL; + } + + resp.reserved = 0; + ret = ibv_cmd_create_cq(context, cqe, channel, comp_vector, + &chp->ibv_cq, &cmd, sizeof cmd, + &resp.ibv_resp, sizeof resp); + if (ret) + goto err1; + + if (resp.reserved) + PDBG("%s c4iw_create_cq_resp reserved field modified by kernel\n", + __FUNCTION__); + + pthread_spin_init(&chp->lock, PTHREAD_PROCESS_PRIVATE); +#ifdef STALL_DETECTION + gettimeofday(&chp->time, NULL); +#endif + chp->rhp = dev; + chp->cq.qid_mask = resp.qid_mask; + chp->cq.cqid = resp.cqid; + chp->cq.size = resp.size; + chp->cq.memsize = resp.memsize; + chp->cq.gen = 1; + chp->cq.queue = mmap(NULL, chp->cq.memsize, PROT_READ|PROT_WRITE, + MAP_SHARED, context->cmd_fd, resp.key); + if (chp->cq.queue == MAP_FAILED) + goto err2; + + chp->cq.ugts = mmap(NULL, c4iw_page_size, PROT_WRITE, MAP_SHARED, + context->cmd_fd, resp.gts_key); + if (chp->cq.ugts == MAP_FAILED) + goto err3; + + if (dev_is_t5(chp->rhp)) + chp->cq.ugts += 3; + else + chp->cq.ugts += 1; + chp->cq.sw_queue = calloc(chp->cq.size, sizeof *chp->cq.queue); + if (!chp->cq.sw_queue) + goto err4; + + PDBG("%s cqid 0x%x key %" PRIx64 " va %p memsize %lu gts_key %" + PRIx64 " va %p qid_mask 0x%x\n", + __func__, chp->cq.cqid, resp.key, chp->cq.queue, + chp->cq.memsize, resp.gts_key, chp->cq.ugts, chp->cq.qid_mask); + + pthread_spin_lock(&dev->lock); + dev->cqid2ptr[chp->cq.cqid] = chp; + pthread_spin_unlock(&dev->lock); + INC_STAT(cq); + return &chp->ibv_cq; +err4: + munmap(MASKED(chp->cq.ugts), c4iw_page_size); +err3: + munmap(chp->cq.queue, chp->cq.memsize); +err2: + (void)ibv_cmd_destroy_cq(&chp->ibv_cq); +err1: + free(chp); + return NULL; +} + +int c4iw_resize_cq(struct ibv_cq *ibcq, int cqe) +{ +#if 0 + int ret; + + struct ibv_resize_cq cmd; + struct ibv_resize_cq_resp resp; + ret = ibv_cmd_resize_cq(ibcq, cqe, &cmd, sizeof cmd, &resp, sizeof resp); + PDBG("%s ret %d\n", __func__, ret); + return ret; +#else + return -ENOSYS; +#endif +} + +int c4iw_destroy_cq(struct ibv_cq *ibcq) +{ + int ret; + struct c4iw_cq *chp = to_c4iw_cq(ibcq); + struct c4iw_dev *dev = to_c4iw_dev(ibcq->context->device); + + chp->cq.error = 1; + ret = ibv_cmd_destroy_cq(ibcq); + if (ret) { + return ret; + } + munmap(MASKED(chp->cq.ugts), c4iw_page_size); + munmap(chp->cq.queue, chp->cq.memsize); + + pthread_spin_lock(&dev->lock); + dev->cqid2ptr[chp->cq.cqid] = NULL; + pthread_spin_unlock(&dev->lock); + + free(chp->cq.sw_queue); + free(chp); + return 0; +} + +struct ibv_srq *c4iw_create_srq(struct ibv_pd *pd, + struct ibv_srq_init_attr *attr) +{ + return NULL; +} + +int c4iw_modify_srq(struct ibv_srq *srq, struct ibv_srq_attr *attr, + int attr_mask) +{ + return ENOSYS; +} + +int c4iw_destroy_srq(struct ibv_srq *srq) +{ + return ENOSYS; +} + +int c4iw_post_srq_recv(struct ibv_srq *ibsrq, struct ibv_recv_wr *wr, + struct ibv_recv_wr **bad_wr) +{ + return ENOSYS; +} + +static struct ibv_qp *create_qp_v0(struct ibv_pd *pd, + struct ibv_qp_init_attr *attr) +{ + struct ibv_create_qp cmd; + struct c4iw_create_qp_resp_v0 resp; + struct c4iw_qp *qhp; + struct c4iw_dev *dev = to_c4iw_dev(pd->context->device); + int ret; + void *dbva; + + PDBG("%s enter qp\n", __func__); + qhp = calloc(1, sizeof *qhp); + if (!qhp) + goto err1; + + ret = ibv_cmd_create_qp(pd, &qhp->ibv_qp, attr, &cmd, + sizeof cmd, &resp.ibv_resp, sizeof resp); + if (ret) + goto err2; + + PDBG("%s sqid 0x%x sq key %" PRIx64 " sq db/gts key %" PRIx64 + " rqid 0x%x rq key %" PRIx64 " rq db/gts key %" PRIx64 + " qid_mask 0x%x\n", + __func__, + resp.sqid, resp.sq_key, resp.sq_db_gts_key, + resp.rqid, resp.rq_key, resp.rq_db_gts_key, resp.qid_mask); + + qhp->wq.qid_mask = resp.qid_mask; + qhp->rhp = dev; + qhp->wq.sq.qid = resp.sqid; + qhp->wq.sq.size = resp.sq_size; + qhp->wq.sq.memsize = resp.sq_memsize; + qhp->wq.sq.flags = 0; + qhp->wq.rq.msn = 1; + qhp->wq.rq.qid = resp.rqid; + qhp->wq.rq.size = resp.rq_size; + qhp->wq.rq.memsize = resp.rq_memsize; + pthread_spin_init(&qhp->lock, PTHREAD_PROCESS_PRIVATE); + + dbva = mmap(NULL, c4iw_page_size, PROT_WRITE, MAP_SHARED, + pd->context->cmd_fd, resp.sq_db_gts_key); + if (dbva == MAP_FAILED) + goto err3; + + qhp->wq.sq.udb = dbva; + qhp->wq.sq.queue = mmap(NULL, qhp->wq.sq.memsize, + PROT_WRITE, MAP_SHARED, + pd->context->cmd_fd, resp.sq_key); + if (qhp->wq.sq.queue == MAP_FAILED) + goto err4; + + dbva = mmap(NULL, c4iw_page_size, PROT_WRITE, MAP_SHARED, + pd->context->cmd_fd, resp.rq_db_gts_key); + if (dbva == MAP_FAILED) + goto err5; + qhp->wq.rq.udb = dbva; + qhp->wq.rq.queue = mmap(NULL, qhp->wq.rq.memsize, + PROT_WRITE, MAP_SHARED, + pd->context->cmd_fd, resp.rq_key); + if (qhp->wq.rq.queue == MAP_FAILED) + goto err6; + + qhp->wq.sq.sw_sq = calloc(qhp->wq.sq.size, sizeof (struct t4_swsqe)); + if (!qhp->wq.sq.sw_sq) + goto err7; + + qhp->wq.rq.sw_rq = calloc(qhp->wq.rq.size, sizeof (uint64_t)); + if (!qhp->wq.rq.sw_rq) + goto err8; + + PDBG("%s sq dbva %p sq qva %p sq depth %u sq memsize %lu " + " rq dbva %p rq qva %p rq depth %u rq memsize %lu\n", + __func__, + qhp->wq.sq.udb, qhp->wq.sq.queue, + qhp->wq.sq.size, qhp->wq.sq.memsize, + qhp->wq.rq.udb, qhp->wq.rq.queue, + qhp->wq.rq.size, qhp->wq.rq.memsize); + + qhp->sq_sig_all = attr->sq_sig_all; + + pthread_spin_lock(&dev->lock); + dev->qpid2ptr[qhp->wq.sq.qid] = qhp; + pthread_spin_unlock(&dev->lock); + INC_STAT(qp); + return &qhp->ibv_qp; +err8: + free(qhp->wq.sq.sw_sq); +err7: + munmap((void *)qhp->wq.rq.queue, qhp->wq.rq.memsize); +err6: + munmap(MASKED(qhp->wq.rq.udb), c4iw_page_size); +err5: + munmap((void *)qhp->wq.sq.queue, qhp->wq.sq.memsize); +err4: + munmap(MASKED(qhp->wq.sq.udb), c4iw_page_size); +err3: + (void)ibv_cmd_destroy_qp(&qhp->ibv_qp); +err2: + free(qhp); +err1: + return NULL; +} + +static struct ibv_qp *create_qp(struct ibv_pd *pd, + struct ibv_qp_init_attr *attr) +{ + struct ibv_create_qp cmd; + struct c4iw_create_qp_resp resp; + struct c4iw_qp *qhp; + struct c4iw_dev *dev = to_c4iw_dev(pd->context->device); + struct c4iw_context *ctx = to_c4iw_context(pd->context); + int ret; + void *dbva; + + PDBG("%s enter qp\n", __func__); + qhp = calloc(1, sizeof *qhp); + if (!qhp) + goto err1; + + ret = ibv_cmd_create_qp(pd, &qhp->ibv_qp, attr, &cmd, + sizeof cmd, &resp.ibv_resp, sizeof resp); + if (ret) + goto err2; + + PDBG("%s sqid 0x%x sq key %" PRIx64 " sq db/gts key %" PRIx64 + " rqid 0x%x rq key %" PRIx64 " rq db/gts key %" PRIx64 + " qid_mask 0x%x\n", + __func__, + resp.sqid, resp.sq_key, resp.sq_db_gts_key, + resp.rqid, resp.rq_key, resp.rq_db_gts_key, resp.qid_mask); + + qhp->wq.qid_mask = resp.qid_mask; + qhp->rhp = dev; + qhp->wq.sq.qid = resp.sqid; + qhp->wq.sq.size = resp.sq_size; + qhp->wq.sq.memsize = resp.sq_memsize; + qhp->wq.sq.flags = resp.flags & C4IW_QPF_ONCHIP ? T4_SQ_ONCHIP : 0; + qhp->wq.sq.flush_cidx = -1; + qhp->wq.rq.msn = 1; + qhp->wq.rq.qid = resp.rqid; + qhp->wq.rq.size = resp.rq_size; + qhp->wq.rq.memsize = resp.rq_memsize; + if (ma_wr && resp.sq_memsize < (resp.sq_size + 1) * + sizeof *qhp->wq.sq.queue + 16*sizeof(__be64) ) { + ma_wr = 0; + fprintf(stderr, "libcxgb4 warning - downlevel iw_cxgb4 driver. " + "MA workaround disabled.\n"); + } + pthread_spin_init(&qhp->lock, PTHREAD_PROCESS_PRIVATE); + + dbva = mmap(NULL, c4iw_page_size, PROT_WRITE, MAP_SHARED, + pd->context->cmd_fd, resp.sq_db_gts_key); + if (dbva == MAP_FAILED) { + PDBG(" %s mmap for sq db failed\n", __func__); + abort(); + goto err3; + } + qhp->wq.sq.udb = dbva; + if (dev_is_t5(qhp->rhp)) { + qhp->wq.sq.udb += (128*(qhp->wq.sq.qid & qhp->wq.qid_mask))/4; + qhp->wq.sq.udb += 2; + } + + qhp->wq.sq.queue = mmap(NULL, qhp->wq.sq.memsize, + PROT_READ | PROT_WRITE, MAP_SHARED, + pd->context->cmd_fd, resp.sq_key); + if (qhp->wq.sq.queue == MAP_FAILED) { + PDBG(" %s mmap for sq q failed size is qhp->wq.sq.memsize %zu \n", __func__, qhp->wq.sq.memsize); + abort(); + goto err4; + } + + dbva = mmap(NULL, c4iw_page_size, PROT_WRITE, MAP_SHARED, + pd->context->cmd_fd, resp.rq_db_gts_key); + if (dbva == MAP_FAILED) + goto err5; + qhp->wq.rq.udb = dbva; + if (dev_is_t5(qhp->rhp)) { + qhp->wq.rq.udb += (128*(qhp->wq.rq.qid & qhp->wq.qid_mask))/4; + qhp->wq.rq.udb += 2; + } + qhp->wq.rq.queue = mmap(NULL, qhp->wq.rq.memsize, + PROT_READ | PROT_WRITE, MAP_SHARED, + pd->context->cmd_fd, resp.rq_key); + if (qhp->wq.rq.queue == MAP_FAILED) + goto err6; + + qhp->wq.sq.sw_sq = calloc(qhp->wq.sq.size, sizeof (struct t4_swsqe)); + if (!qhp->wq.sq.sw_sq) + goto err7; + + qhp->wq.rq.sw_rq = calloc(qhp->wq.rq.size, sizeof (uint64_t)); + if (!qhp->wq.rq.sw_rq) + goto err8; + + if (t4_sq_onchip(&qhp->wq)) { + qhp->wq.sq.ma_sync = mmap(NULL, c4iw_page_size, PROT_WRITE, + MAP_SHARED, pd->context->cmd_fd, + resp.ma_sync_key); + if (qhp->wq.sq.ma_sync == MAP_FAILED) + goto err9; + qhp->wq.sq.ma_sync += (A_PCIE_MA_SYNC & (c4iw_page_size - 1)); + } + + if (ctx->status_page_size) { + qhp->wq.db_offp = &ctx->status_page->db_off; + } else { + qhp->wq.db_offp = + &qhp->wq.rq.queue[qhp->wq.rq.size].status.db_off; + } + + PDBG("%s sq dbva %p sq qva %p sq depth %u sq memsize %lu " + " rq dbva %p rq qva %p rq depth %u rq memsize %lu\n", + __func__, + qhp->wq.sq.udb, qhp->wq.sq.queue, + qhp->wq.sq.size, qhp->wq.sq.memsize, + qhp->wq.rq.udb, qhp->wq.rq.queue, + qhp->wq.rq.size, qhp->wq.rq.memsize); + + qhp->sq_sig_all = attr->sq_sig_all; + + pthread_spin_lock(&dev->lock); + dev->qpid2ptr[qhp->wq.sq.qid] = qhp; + pthread_spin_unlock(&dev->lock); + INC_STAT(qp); + return &qhp->ibv_qp; +err9: + free(qhp->wq.rq.sw_rq); +err8: + free(qhp->wq.sq.sw_sq); +err7: + munmap((void *)qhp->wq.rq.queue, qhp->wq.rq.memsize); +err6: + munmap(MASKED(qhp->wq.rq.udb), c4iw_page_size); +err5: + munmap((void *)qhp->wq.sq.queue, qhp->wq.sq.memsize); +err4: + munmap(MASKED(qhp->wq.sq.udb), c4iw_page_size); +err3: + (void)ibv_cmd_destroy_qp(&qhp->ibv_qp); +err2: + free(qhp); +err1: + return NULL; +} + +struct ibv_qp *c4iw_create_qp(struct ibv_pd *pd, + struct ibv_qp_init_attr *attr) +{ + struct c4iw_dev *dev = to_c4iw_dev(pd->context->device); + + if (dev->abi_version == 0) + return create_qp_v0(pd, attr); + return create_qp(pd, attr); +} + +static void reset_qp(struct c4iw_qp *qhp) +{ + PDBG("%s enter qp %p\n", __func__, qhp); + qhp->wq.sq.cidx = 0; + qhp->wq.sq.wq_pidx = qhp->wq.sq.pidx = qhp->wq.sq.in_use = 0; + qhp->wq.rq.cidx = qhp->wq.rq.pidx = qhp->wq.rq.in_use = 0; + qhp->wq.sq.oldest_read = NULL; + memset(qhp->wq.sq.queue, 0, qhp->wq.sq.memsize); + memset(qhp->wq.rq.queue, 0, qhp->wq.rq.memsize); +} + +int c4iw_modify_qp(struct ibv_qp *ibqp, struct ibv_qp_attr *attr, + int attr_mask) +{ + struct ibv_modify_qp cmd; + struct c4iw_qp *qhp = to_c4iw_qp(ibqp); + int ret; + + PDBG("%s enter qp %p new state %d\n", __func__, ibqp, attr_mask & IBV_QP_STATE ? attr->qp_state : -1); + pthread_spin_lock(&qhp->lock); + if (t4_wq_in_error(&qhp->wq)) + c4iw_flush_qp(qhp); + ret = ibv_cmd_modify_qp(ibqp, attr, attr_mask, &cmd, sizeof cmd); + if (!ret && (attr_mask & IBV_QP_STATE) && attr->qp_state == IBV_QPS_RESET) + reset_qp(qhp); + pthread_spin_unlock(&qhp->lock); + return ret; +} + +int c4iw_destroy_qp(struct ibv_qp *ibqp) +{ + int ret; + struct c4iw_qp *qhp = to_c4iw_qp(ibqp); + struct c4iw_dev *dev = to_c4iw_dev(ibqp->context->device); + + PDBG("%s enter qp %p\n", __func__, ibqp); + pthread_spin_lock(&qhp->lock); + c4iw_flush_qp(qhp); + pthread_spin_unlock(&qhp->lock); + + ret = ibv_cmd_destroy_qp(ibqp); + if (ret) { + return ret; + } + if (t4_sq_onchip(&qhp->wq)) { + qhp->wq.sq.ma_sync -= (A_PCIE_MA_SYNC & (c4iw_page_size - 1)); + munmap((void *)qhp->wq.sq.ma_sync, c4iw_page_size); + } + munmap(MASKED(qhp->wq.sq.udb), c4iw_page_size); + munmap(MASKED(qhp->wq.rq.udb), c4iw_page_size); + munmap(qhp->wq.sq.queue, qhp->wq.sq.memsize); + munmap(qhp->wq.rq.queue, qhp->wq.rq.memsize); + + pthread_spin_lock(&dev->lock); + dev->qpid2ptr[qhp->wq.sq.qid] = NULL; + pthread_spin_unlock(&dev->lock); + + free(qhp->wq.rq.sw_rq); + free(qhp->wq.sq.sw_sq); + free(qhp); + return 0; +} + +int c4iw_query_qp(struct ibv_qp *ibqp, struct ibv_qp_attr *attr, + int attr_mask, struct ibv_qp_init_attr *init_attr) +{ + struct ibv_query_qp cmd; + struct c4iw_qp *qhp = to_c4iw_qp(ibqp); + int ret; + + pthread_spin_lock(&qhp->lock); + if (t4_wq_in_error(&qhp->wq)) + c4iw_flush_qp(qhp); + ret = ibv_cmd_query_qp(ibqp, attr, attr_mask, init_attr, &cmd, sizeof cmd); + pthread_spin_unlock(&qhp->lock); + return ret; +} + +struct ibv_ah *c4iw_create_ah(struct ibv_pd *pd, struct ibv_ah_attr *attr) +{ + return NULL; +} + +int c4iw_destroy_ah(struct ibv_ah *ah) +{ + return ENOSYS; +} + +int c4iw_attach_mcast(struct ibv_qp *ibqp, const union ibv_gid *gid, + uint16_t lid) +{ + struct c4iw_qp *qhp = to_c4iw_qp(ibqp); + int ret; + + pthread_spin_lock(&qhp->lock); + if (t4_wq_in_error(&qhp->wq)) + c4iw_flush_qp(qhp); + ret = ibv_cmd_attach_mcast(ibqp, gid, lid); + pthread_spin_unlock(&qhp->lock); + return ret; +} + +int c4iw_detach_mcast(struct ibv_qp *ibqp, const union ibv_gid *gid, + uint16_t lid) +{ + struct c4iw_qp *qhp = to_c4iw_qp(ibqp); + int ret; + + pthread_spin_lock(&qhp->lock); + if (t4_wq_in_error(&qhp->wq)) + c4iw_flush_qp(qhp); + ret = ibv_cmd_detach_mcast(ibqp, gid, lid); + pthread_spin_unlock(&qhp->lock); + return ret; +} + +void c4iw_async_event(struct ibv_async_event *event) +{ + PDBG("%s type %d obj %p\n", __func__, event->event_type, + event->element.cq); + + switch (event->event_type) { + case IBV_EVENT_CQ_ERR: + break; + case IBV_EVENT_QP_FATAL: + case IBV_EVENT_QP_REQ_ERR: + case IBV_EVENT_QP_ACCESS_ERR: + case IBV_EVENT_PATH_MIG_ERR: { + struct c4iw_qp *qhp = to_c4iw_qp(event->element.qp); + pthread_spin_lock(&qhp->lock); + c4iw_flush_qp(qhp); + pthread_spin_unlock(&qhp->lock); + break; + } + case IBV_EVENT_SQ_DRAINED: + case IBV_EVENT_PATH_MIG: + case IBV_EVENT_COMM_EST: + case IBV_EVENT_QP_LAST_WQE_REACHED: + default: + break; + } +} Index: head/contrib/ofed/usr.lib/Makefile =================================================================== --- head/contrib/ofed/usr.lib/Makefile (revision 273805) +++ head/contrib/ofed/usr.lib/Makefile (revision 273806) @@ -1,6 +1,6 @@ .include SUBDIR = libibcommon libibmad libibumad libibverbs libmlx4 libmthca -SUBDIR += libopensm libosmcomp libosmvendor libibcm librdmacm libsdp +SUBDIR += libopensm libosmcomp libosmvendor libibcm librdmacm libsdp libcxgb4 .include Index: head/contrib/ofed/usr.lib/libcxgb4/Makefile =================================================================== --- head/contrib/ofed/usr.lib/libcxgb4/Makefile (nonexistent) +++ head/contrib/ofed/usr.lib/libcxgb4/Makefile (revision 273806) @@ -0,0 +1,24 @@ +# $FreeBSD$ + +SHLIBDIR?= /usr/lib + +.include + +CXGB4DIR= ${.CURDIR}/../../libcxgb4 +IBVERBSDIR= ${.CURDIR}/../../libibverbs +CXGBSRCDIR= ${CXGB4DIR}/src + +.PATH: ${CXGBSRCDIR} + +LIB= cxgb4 +SHLIB_MAJOR= 1 +MK_PROFILE= no + +SRCS= dev.c cq.c qp.c verbs.c + +CFLAGS+= -g -DHAVE_CONFIG_H -DDEBUG +CFLAGS+= -I${.CURDIR} -I${CXGBSRCDIR} -I${IBVERBSDIR}/include + +VERSION_MAP= ${CXGBSRCDIR}/cxgb4.map + +.include Index: head/contrib/ofed/usr.lib/libcxgb4/config.h =================================================================== --- head/contrib/ofed/usr.lib/libcxgb4/config.h (nonexistent) +++ head/contrib/ofed/usr.lib/libcxgb4/config.h (revision 273806) @@ -0,0 +1,4 @@ +#define HAVE_IBV_DONTFORK_RANGE +#define HAVE_IBV_DOFORK_RANGE +#define HAVE_IBV_REGISTER_DRIVER +#define HAVE_IBV_READ_SYSFS_FILE