1*4882a593Smuzhiyun /*
2*4882a593Smuzhiyun * Copyright 2019 Red Hat Inc.
3*4882a593Smuzhiyun *
4*4882a593Smuzhiyun * Permission is hereby granted, free of charge, to any person obtaining a
5*4882a593Smuzhiyun * copy of this software and associated documentation files (the "Software"),
6*4882a593Smuzhiyun * to deal in the Software without restriction, including without limitation
7*4882a593Smuzhiyun * the rights to use, copy, modify, merge, publish, distribute, sublicense,
8*4882a593Smuzhiyun * and/or sell copies of the Software, and to permit persons to whom the
9*4882a593Smuzhiyun * Software is furnished to do so, subject to the following conditions:
10*4882a593Smuzhiyun *
11*4882a593Smuzhiyun * The above copyright notice and this permission notice shall be included in
12*4882a593Smuzhiyun * all copies or substantial portions of the Software.
13*4882a593Smuzhiyun *
14*4882a593Smuzhiyun * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
15*4882a593Smuzhiyun * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
16*4882a593Smuzhiyun * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
17*4882a593Smuzhiyun * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
18*4882a593Smuzhiyun * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
19*4882a593Smuzhiyun * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
20*4882a593Smuzhiyun * OTHER DEALINGS IN THE SOFTWARE.
21*4882a593Smuzhiyun */
22*4882a593Smuzhiyun #ifndef __NVIF_PUSH_H__
23*4882a593Smuzhiyun #define __NVIF_PUSH_H__
24*4882a593Smuzhiyun #include <nvif/mem.h>
25*4882a593Smuzhiyun #include <nvif/printf.h>
26*4882a593Smuzhiyun
27*4882a593Smuzhiyun #include <nvhw/drf.h>
28*4882a593Smuzhiyun
29*4882a593Smuzhiyun struct nvif_push {
30*4882a593Smuzhiyun int (*wait)(struct nvif_push *push, u32 size);
31*4882a593Smuzhiyun void (*kick)(struct nvif_push *push);
32*4882a593Smuzhiyun
33*4882a593Smuzhiyun struct nvif_mem mem;
34*4882a593Smuzhiyun
35*4882a593Smuzhiyun u32 *bgn;
36*4882a593Smuzhiyun u32 *cur;
37*4882a593Smuzhiyun u32 *seg;
38*4882a593Smuzhiyun u32 *end;
39*4882a593Smuzhiyun };
40*4882a593Smuzhiyun
41*4882a593Smuzhiyun static inline __must_check int
PUSH_WAIT(struct nvif_push * push,u32 size)42*4882a593Smuzhiyun PUSH_WAIT(struct nvif_push *push, u32 size)
43*4882a593Smuzhiyun {
44*4882a593Smuzhiyun if (push->cur + size >= push->end) {
45*4882a593Smuzhiyun int ret = push->wait(push, size);
46*4882a593Smuzhiyun if (ret)
47*4882a593Smuzhiyun return ret;
48*4882a593Smuzhiyun }
49*4882a593Smuzhiyun #ifdef CONFIG_NOUVEAU_DEBUG_PUSH
50*4882a593Smuzhiyun push->seg = push->cur + size;
51*4882a593Smuzhiyun #endif
52*4882a593Smuzhiyun return 0;
53*4882a593Smuzhiyun }
54*4882a593Smuzhiyun
55*4882a593Smuzhiyun static inline int
PUSH_KICK(struct nvif_push * push)56*4882a593Smuzhiyun PUSH_KICK(struct nvif_push *push)
57*4882a593Smuzhiyun {
58*4882a593Smuzhiyun push->kick(push);
59*4882a593Smuzhiyun return 0;
60*4882a593Smuzhiyun }
61*4882a593Smuzhiyun
62*4882a593Smuzhiyun #ifdef CONFIG_NOUVEAU_DEBUG_PUSH
63*4882a593Smuzhiyun #define PUSH_PRINTF(p,f,a...) do { \
64*4882a593Smuzhiyun struct nvif_push *_ppp = (p); \
65*4882a593Smuzhiyun u32 __o = _ppp->cur - (u32 *)_ppp->mem.object.map.ptr; \
66*4882a593Smuzhiyun NVIF_DEBUG(&_ppp->mem.object, "%08x: "f, __o * 4, ##a); \
67*4882a593Smuzhiyun (void)__o; \
68*4882a593Smuzhiyun } while(0)
69*4882a593Smuzhiyun #define PUSH_ASSERT_ON(a,b) WARN((a), b)
70*4882a593Smuzhiyun #else
71*4882a593Smuzhiyun #define PUSH_PRINTF(p,f,a...)
72*4882a593Smuzhiyun #define PUSH_ASSERT_ON(a, b)
73*4882a593Smuzhiyun #endif
74*4882a593Smuzhiyun
75*4882a593Smuzhiyun #define PUSH_ASSERT(a,b) do { \
76*4882a593Smuzhiyun static_assert( \
77*4882a593Smuzhiyun __builtin_choose_expr(__builtin_constant_p(a), (a), 1), b \
78*4882a593Smuzhiyun ); \
79*4882a593Smuzhiyun PUSH_ASSERT_ON(!(a), b); \
80*4882a593Smuzhiyun } while(0)
81*4882a593Smuzhiyun
82*4882a593Smuzhiyun #define PUSH_DATA__(p,d,f,a...) do { \
83*4882a593Smuzhiyun struct nvif_push *_p = (p); \
84*4882a593Smuzhiyun u32 _d = (d); \
85*4882a593Smuzhiyun PUSH_ASSERT(_p->cur < _p->seg, "segment overrun"); \
86*4882a593Smuzhiyun PUSH_ASSERT(_p->cur < _p->end, "pushbuf overrun"); \
87*4882a593Smuzhiyun PUSH_PRINTF(_p, "%08x"f, _d, ##a); \
88*4882a593Smuzhiyun *_p->cur++ = _d; \
89*4882a593Smuzhiyun } while(0)
90*4882a593Smuzhiyun
91*4882a593Smuzhiyun #define PUSH_DATA_(X,p,m,i0,i1,d,s,f,a...) PUSH_DATA__((p), (d), "-> "#m f, ##a)
92*4882a593Smuzhiyun #define PUSH_DATA(p,d) PUSH_DATA__((p), (d), " data - %s", __func__)
93*4882a593Smuzhiyun
94*4882a593Smuzhiyun //XXX: error-check this against *real* pushbuffer end?
95*4882a593Smuzhiyun #define PUSH_RSVD(p,d) do { \
96*4882a593Smuzhiyun struct nvif_push *__p = (p); \
97*4882a593Smuzhiyun __p->seg++; \
98*4882a593Smuzhiyun __p->end++; \
99*4882a593Smuzhiyun d; \
100*4882a593Smuzhiyun } while(0)
101*4882a593Smuzhiyun
102*4882a593Smuzhiyun #ifdef CONFIG_NOUVEAU_DEBUG_PUSH
103*4882a593Smuzhiyun #define PUSH_DATAp(X,p,m,i,o,d,s,f,a...) do { \
104*4882a593Smuzhiyun struct nvif_push *_pp = (p); \
105*4882a593Smuzhiyun const u32 *_dd = (d); \
106*4882a593Smuzhiyun u32 _s = (s), _i = (i?PUSH_##o##_INC); \
107*4882a593Smuzhiyun if (_s--) { \
108*4882a593Smuzhiyun PUSH_DATA_(X, _pp, X##m, i0, i1, *_dd++, 1, "+0x%x", 0); \
109*4882a593Smuzhiyun while (_s--) { \
110*4882a593Smuzhiyun PUSH_DATA_(X, _pp, X##m, i0, i1, *_dd++, 1, "+0x%x", _i); \
111*4882a593Smuzhiyun _i += (0?PUSH_##o##_INC); \
112*4882a593Smuzhiyun } \
113*4882a593Smuzhiyun } \
114*4882a593Smuzhiyun } while(0)
115*4882a593Smuzhiyun #else
116*4882a593Smuzhiyun #define PUSH_DATAp(X,p,m,i,o,d,s,f,a...) do { \
117*4882a593Smuzhiyun struct nvif_push *_p = (p); \
118*4882a593Smuzhiyun u32 _s = (s); \
119*4882a593Smuzhiyun PUSH_ASSERT(_p->cur + _s <= _p->seg, "segment overrun"); \
120*4882a593Smuzhiyun PUSH_ASSERT(_p->cur + _s <= _p->end, "pushbuf overrun"); \
121*4882a593Smuzhiyun memcpy(_p->cur, (d), _s << 2); \
122*4882a593Smuzhiyun _p->cur += _s; \
123*4882a593Smuzhiyun } while(0)
124*4882a593Smuzhiyun #endif
125*4882a593Smuzhiyun
126*4882a593Smuzhiyun #define PUSH_1(X,f,ds,n,o,p,s,mA,dA) do { \
127*4882a593Smuzhiyun PUSH_##o##_HDR((p), s, mA, (ds)+(n)); \
128*4882a593Smuzhiyun PUSH_##f(X, (p), X##mA, 1, o, (dA), ds, ""); \
129*4882a593Smuzhiyun } while(0)
130*4882a593Smuzhiyun #define PUSH_2(X,f,ds,n,o,p,s,mB,dB,mA,dA,a...) do { \
131*4882a593Smuzhiyun PUSH_ASSERT((mB) - (mA) == (1?PUSH_##o##_INC), "mthd1"); \
132*4882a593Smuzhiyun PUSH_1(X, DATA_, 1, (ds) + (n), o, (p), s, X##mA, (dA), ##a); \
133*4882a593Smuzhiyun PUSH_##f(X, (p), X##mB, 0, o, (dB), ds, ""); \
134*4882a593Smuzhiyun } while(0)
135*4882a593Smuzhiyun #define PUSH_3(X,f,ds,n,o,p,s,mB,dB,mA,dA,a...) do { \
136*4882a593Smuzhiyun PUSH_ASSERT((mB) - (mA) == (0?PUSH_##o##_INC), "mthd2"); \
137*4882a593Smuzhiyun PUSH_2(X, DATA_, 1, (ds) + (n), o, (p), s, X##mA, (dA), ##a); \
138*4882a593Smuzhiyun PUSH_##f(X, (p), X##mB, 0, o, (dB), ds, ""); \
139*4882a593Smuzhiyun } while(0)
140*4882a593Smuzhiyun #define PUSH_4(X,f,ds,n,o,p,s,mB,dB,mA,dA,a...) do { \
141*4882a593Smuzhiyun PUSH_ASSERT((mB) - (mA) == (0?PUSH_##o##_INC), "mthd3"); \
142*4882a593Smuzhiyun PUSH_3(X, DATA_, 1, (ds) + (n), o, (p), s, X##mA, (dA), ##a); \
143*4882a593Smuzhiyun PUSH_##f(X, (p), X##mB, 0, o, (dB), ds, ""); \
144*4882a593Smuzhiyun } while(0)
145*4882a593Smuzhiyun #define PUSH_5(X,f,ds,n,o,p,s,mB,dB,mA,dA,a...) do { \
146*4882a593Smuzhiyun PUSH_ASSERT((mB) - (mA) == (0?PUSH_##o##_INC), "mthd4"); \
147*4882a593Smuzhiyun PUSH_4(X, DATA_, 1, (ds) + (n), o, (p), s, X##mA, (dA), ##a); \
148*4882a593Smuzhiyun PUSH_##f(X, (p), X##mB, 0, o, (dB), ds, ""); \
149*4882a593Smuzhiyun } while(0)
150*4882a593Smuzhiyun #define PUSH_6(X,f,ds,n,o,p,s,mB,dB,mA,dA,a...) do { \
151*4882a593Smuzhiyun PUSH_ASSERT((mB) - (mA) == (0?PUSH_##o##_INC), "mthd5"); \
152*4882a593Smuzhiyun PUSH_5(X, DATA_, 1, (ds) + (n), o, (p), s, X##mA, (dA), ##a); \
153*4882a593Smuzhiyun PUSH_##f(X, (p), X##mB, 0, o, (dB), ds, ""); \
154*4882a593Smuzhiyun } while(0)
155*4882a593Smuzhiyun #define PUSH_7(X,f,ds,n,o,p,s,mB,dB,mA,dA,a...) do { \
156*4882a593Smuzhiyun PUSH_ASSERT((mB) - (mA) == (0?PUSH_##o##_INC), "mthd6"); \
157*4882a593Smuzhiyun PUSH_6(X, DATA_, 1, (ds) + (n), o, (p), s, X##mA, (dA), ##a); \
158*4882a593Smuzhiyun PUSH_##f(X, (p), X##mB, 0, o, (dB), ds, ""); \
159*4882a593Smuzhiyun } while(0)
160*4882a593Smuzhiyun #define PUSH_8(X,f,ds,n,o,p,s,mB,dB,mA,dA,a...) do { \
161*4882a593Smuzhiyun PUSH_ASSERT((mB) - (mA) == (0?PUSH_##o##_INC), "mthd7"); \
162*4882a593Smuzhiyun PUSH_7(X, DATA_, 1, (ds) + (n), o, (p), s, X##mA, (dA), ##a); \
163*4882a593Smuzhiyun PUSH_##f(X, (p), X##mB, 0, o, (dB), ds, ""); \
164*4882a593Smuzhiyun } while(0)
165*4882a593Smuzhiyun #define PUSH_9(X,f,ds,n,o,p,s,mB,dB,mA,dA,a...) do { \
166*4882a593Smuzhiyun PUSH_ASSERT((mB) - (mA) == (0?PUSH_##o##_INC), "mthd8"); \
167*4882a593Smuzhiyun PUSH_8(X, DATA_, 1, (ds) + (n), o, (p), s, X##mA, (dA), ##a); \
168*4882a593Smuzhiyun PUSH_##f(X, (p), X##mB, 0, o, (dB), ds, ""); \
169*4882a593Smuzhiyun } while(0)
170*4882a593Smuzhiyun #define PUSH_10(X,f,ds,n,o,p,s,mB,dB,mA,dA,a...) do { \
171*4882a593Smuzhiyun PUSH_ASSERT((mB) - (mA) == (0?PUSH_##o##_INC), "mthd9"); \
172*4882a593Smuzhiyun PUSH_9(X, DATA_, 1, (ds) + (n), o, (p), s, X##mA, (dA), ##a); \
173*4882a593Smuzhiyun PUSH_##f(X, (p), X##mB, 0, o, (dB), ds, ""); \
174*4882a593Smuzhiyun } while(0)
175*4882a593Smuzhiyun
176*4882a593Smuzhiyun #define PUSH_1D(X,o,p,s,mA,dA) \
177*4882a593Smuzhiyun PUSH_1(X, DATA_, 1, 0, o, (p), s, X##mA, (dA))
178*4882a593Smuzhiyun #define PUSH_2D(X,o,p,s,mA,dA,mB,dB) \
179*4882a593Smuzhiyun PUSH_2(X, DATA_, 1, 0, o, (p), s, X##mB, (dB), \
180*4882a593Smuzhiyun X##mA, (dA))
181*4882a593Smuzhiyun #define PUSH_3D(X,o,p,s,mA,dA,mB,dB,mC,dC) \
182*4882a593Smuzhiyun PUSH_3(X, DATA_, 1, 0, o, (p), s, X##mC, (dC), \
183*4882a593Smuzhiyun X##mB, (dB), \
184*4882a593Smuzhiyun X##mA, (dA))
185*4882a593Smuzhiyun #define PUSH_4D(X,o,p,s,mA,dA,mB,dB,mC,dC,mD,dD) \
186*4882a593Smuzhiyun PUSH_4(X, DATA_, 1, 0, o, (p), s, X##mD, (dD), \
187*4882a593Smuzhiyun X##mC, (dC), \
188*4882a593Smuzhiyun X##mB, (dB), \
189*4882a593Smuzhiyun X##mA, (dA))
190*4882a593Smuzhiyun #define PUSH_5D(X,o,p,s,mA,dA,mB,dB,mC,dC,mD,dD,mE,dE) \
191*4882a593Smuzhiyun PUSH_5(X, DATA_, 1, 0, o, (p), s, X##mE, (dE), \
192*4882a593Smuzhiyun X##mD, (dD), \
193*4882a593Smuzhiyun X##mC, (dC), \
194*4882a593Smuzhiyun X##mB, (dB), \
195*4882a593Smuzhiyun X##mA, (dA))
196*4882a593Smuzhiyun #define PUSH_6D(X,o,p,s,mA,dA,mB,dB,mC,dC,mD,dD,mE,dE,mF,dF) \
197*4882a593Smuzhiyun PUSH_6(X, DATA_, 1, 0, o, (p), s, X##mF, (dF), \
198*4882a593Smuzhiyun X##mE, (dE), \
199*4882a593Smuzhiyun X##mD, (dD), \
200*4882a593Smuzhiyun X##mC, (dC), \
201*4882a593Smuzhiyun X##mB, (dB), \
202*4882a593Smuzhiyun X##mA, (dA))
203*4882a593Smuzhiyun #define PUSH_7D(X,o,p,s,mA,dA,mB,dB,mC,dC,mD,dD,mE,dE,mF,dF,mG,dG) \
204*4882a593Smuzhiyun PUSH_7(X, DATA_, 1, 0, o, (p), s, X##mG, (dG), \
205*4882a593Smuzhiyun X##mF, (dF), \
206*4882a593Smuzhiyun X##mE, (dE), \
207*4882a593Smuzhiyun X##mD, (dD), \
208*4882a593Smuzhiyun X##mC, (dC), \
209*4882a593Smuzhiyun X##mB, (dB), \
210*4882a593Smuzhiyun X##mA, (dA))
211*4882a593Smuzhiyun #define PUSH_8D(X,o,p,s,mA,dA,mB,dB,mC,dC,mD,dD,mE,dE,mF,dF,mG,dG,mH,dH) \
212*4882a593Smuzhiyun PUSH_8(X, DATA_, 1, 0, o, (p), s, X##mH, (dH), \
213*4882a593Smuzhiyun X##mG, (dG), \
214*4882a593Smuzhiyun X##mF, (dF), \
215*4882a593Smuzhiyun X##mE, (dE), \
216*4882a593Smuzhiyun X##mD, (dD), \
217*4882a593Smuzhiyun X##mC, (dC), \
218*4882a593Smuzhiyun X##mB, (dB), \
219*4882a593Smuzhiyun X##mA, (dA))
220*4882a593Smuzhiyun #define PUSH_9D(X,o,p,s,mA,dA,mB,dB,mC,dC,mD,dD,mE,dE,mF,dF,mG,dG,mH,dH,mI,dI) \
221*4882a593Smuzhiyun PUSH_9(X, DATA_, 1, 0, o, (p), s, X##mI, (dI), \
222*4882a593Smuzhiyun X##mH, (dH), \
223*4882a593Smuzhiyun X##mG, (dG), \
224*4882a593Smuzhiyun X##mF, (dF), \
225*4882a593Smuzhiyun X##mE, (dE), \
226*4882a593Smuzhiyun X##mD, (dD), \
227*4882a593Smuzhiyun X##mC, (dC), \
228*4882a593Smuzhiyun X##mB, (dB), \
229*4882a593Smuzhiyun X##mA, (dA))
230*4882a593Smuzhiyun #define PUSH_10D(X,o,p,s,mA,dA,mB,dB,mC,dC,mD,dD,mE,dE,mF,dF,mG,dG,mH,dH,mI,dI,mJ,dJ) \
231*4882a593Smuzhiyun PUSH_10(X, DATA_, 1, 0, o, (p), s, X##mJ, (dJ), \
232*4882a593Smuzhiyun X##mI, (dI), \
233*4882a593Smuzhiyun X##mH, (dH), \
234*4882a593Smuzhiyun X##mG, (dG), \
235*4882a593Smuzhiyun X##mF, (dF), \
236*4882a593Smuzhiyun X##mE, (dE), \
237*4882a593Smuzhiyun X##mD, (dD), \
238*4882a593Smuzhiyun X##mC, (dC), \
239*4882a593Smuzhiyun X##mB, (dB), \
240*4882a593Smuzhiyun X##mA, (dA))
241*4882a593Smuzhiyun
242*4882a593Smuzhiyun #define PUSH_1P(X,o,p,s,mA,dp,ds) \
243*4882a593Smuzhiyun PUSH_1(X, DATAp, ds, 0, o, (p), s, X##mA, (dp))
244*4882a593Smuzhiyun #define PUSH_2P(X,o,p,s,mA,dA,mB,dp,ds) \
245*4882a593Smuzhiyun PUSH_2(X, DATAp, ds, 0, o, (p), s, X##mB, (dp), \
246*4882a593Smuzhiyun X##mA, (dA))
247*4882a593Smuzhiyun #define PUSH_3P(X,o,p,s,mA,dA,mB,dB,mC,dp,ds) \
248*4882a593Smuzhiyun PUSH_3(X, DATAp, ds, 0, o, (p), s, X##mC, (dp), \
249*4882a593Smuzhiyun X##mB, (dB), \
250*4882a593Smuzhiyun X##mA, (dA))
251*4882a593Smuzhiyun
252*4882a593Smuzhiyun #define PUSH_(A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P,Q,R,S,T,U,V,W,X,IMPL,...) IMPL
253*4882a593Smuzhiyun #define PUSH(A...) PUSH_(A, PUSH_10P, PUSH_10D, \
254*4882a593Smuzhiyun PUSH_9P , PUSH_9D, \
255*4882a593Smuzhiyun PUSH_8P , PUSH_8D, \
256*4882a593Smuzhiyun PUSH_7P , PUSH_7D, \
257*4882a593Smuzhiyun PUSH_6P , PUSH_6D, \
258*4882a593Smuzhiyun PUSH_5P , PUSH_5D, \
259*4882a593Smuzhiyun PUSH_4P , PUSH_4D, \
260*4882a593Smuzhiyun PUSH_3P , PUSH_3D, \
261*4882a593Smuzhiyun PUSH_2P , PUSH_2D, \
262*4882a593Smuzhiyun PUSH_1P , PUSH_1D)(, ##A)
263*4882a593Smuzhiyun
264*4882a593Smuzhiyun #define PUSH_NVIM(p,c,m,d) do { \
265*4882a593Smuzhiyun struct nvif_push *__p = (p); \
266*4882a593Smuzhiyun u32 __d = (d); \
267*4882a593Smuzhiyun PUSH_IMMD_HDR(__p, c, m, __d); \
268*4882a593Smuzhiyun __p->cur--; \
269*4882a593Smuzhiyun PUSH_PRINTF(__p, "%08x-> "#m, __d); \
270*4882a593Smuzhiyun __p->cur++; \
271*4882a593Smuzhiyun } while(0)
272*4882a593Smuzhiyun #define PUSH_NVSQ(A...) PUSH(MTHD, ##A)
273*4882a593Smuzhiyun #define PUSH_NV1I(A...) PUSH(1INC, ##A)
274*4882a593Smuzhiyun #define PUSH_NVNI(A...) PUSH(NINC, ##A)
275*4882a593Smuzhiyun
276*4882a593Smuzhiyun
277*4882a593Smuzhiyun #define PUSH_NV_1(X,o,p,c,mA,d...) \
278*4882a593Smuzhiyun PUSH_##o(p,c,c##_##mA,d)
279*4882a593Smuzhiyun #define PUSH_NV_2(X,o,p,c,mA,dA,mB,d...) \
280*4882a593Smuzhiyun PUSH_##o(p,c,c##_##mA,dA, \
281*4882a593Smuzhiyun c##_##mB,d)
282*4882a593Smuzhiyun #define PUSH_NV_3(X,o,p,c,mA,dA,mB,dB,mC,d...) \
283*4882a593Smuzhiyun PUSH_##o(p,c,c##_##mA,dA, \
284*4882a593Smuzhiyun c##_##mB,dB, \
285*4882a593Smuzhiyun c##_##mC,d)
286*4882a593Smuzhiyun #define PUSH_NV_4(X,o,p,c,mA,dA,mB,dB,mC,dC,mD,d...) \
287*4882a593Smuzhiyun PUSH_##o(p,c,c##_##mA,dA, \
288*4882a593Smuzhiyun c##_##mB,dB, \
289*4882a593Smuzhiyun c##_##mC,dC, \
290*4882a593Smuzhiyun c##_##mD,d)
291*4882a593Smuzhiyun #define PUSH_NV_5(X,o,p,c,mA,dA,mB,dB,mC,dC,mD,dD,mE,d...) \
292*4882a593Smuzhiyun PUSH_##o(p,c,c##_##mA,dA, \
293*4882a593Smuzhiyun c##_##mB,dB, \
294*4882a593Smuzhiyun c##_##mC,dC, \
295*4882a593Smuzhiyun c##_##mD,dD, \
296*4882a593Smuzhiyun c##_##mE,d)
297*4882a593Smuzhiyun #define PUSH_NV_6(X,o,p,c,mA,dA,mB,dB,mC,dC,mD,dD,mE,dE,mF,d...) \
298*4882a593Smuzhiyun PUSH_##o(p,c,c##_##mA,dA, \
299*4882a593Smuzhiyun c##_##mB,dB, \
300*4882a593Smuzhiyun c##_##mC,dC, \
301*4882a593Smuzhiyun c##_##mD,dD, \
302*4882a593Smuzhiyun c##_##mE,dE, \
303*4882a593Smuzhiyun c##_##mF,d)
304*4882a593Smuzhiyun #define PUSH_NV_7(X,o,p,c,mA,dA,mB,dB,mC,dC,mD,dD,mE,dE,mF,dF,mG,d...) \
305*4882a593Smuzhiyun PUSH_##o(p,c,c##_##mA,dA, \
306*4882a593Smuzhiyun c##_##mB,dB, \
307*4882a593Smuzhiyun c##_##mC,dC, \
308*4882a593Smuzhiyun c##_##mD,dD, \
309*4882a593Smuzhiyun c##_##mE,dE, \
310*4882a593Smuzhiyun c##_##mF,dF, \
311*4882a593Smuzhiyun c##_##mG,d)
312*4882a593Smuzhiyun #define PUSH_NV_8(X,o,p,c,mA,dA,mB,dB,mC,dC,mD,dD,mE,dE,mF,dF,mG,dG,mH,d...) \
313*4882a593Smuzhiyun PUSH_##o(p,c,c##_##mA,dA, \
314*4882a593Smuzhiyun c##_##mB,dB, \
315*4882a593Smuzhiyun c##_##mC,dC, \
316*4882a593Smuzhiyun c##_##mD,dD, \
317*4882a593Smuzhiyun c##_##mE,dE, \
318*4882a593Smuzhiyun c##_##mF,dF, \
319*4882a593Smuzhiyun c##_##mG,dG, \
320*4882a593Smuzhiyun c##_##mH,d)
321*4882a593Smuzhiyun #define PUSH_NV_9(X,o,p,c,mA,dA,mB,dB,mC,dC,mD,dD,mE,dE,mF,dF,mG,dG,mH,dH,mI,d...) \
322*4882a593Smuzhiyun PUSH_##o(p,c,c##_##mA,dA, \
323*4882a593Smuzhiyun c##_##mB,dB, \
324*4882a593Smuzhiyun c##_##mC,dC, \
325*4882a593Smuzhiyun c##_##mD,dD, \
326*4882a593Smuzhiyun c##_##mE,dE, \
327*4882a593Smuzhiyun c##_##mF,dF, \
328*4882a593Smuzhiyun c##_##mG,dG, \
329*4882a593Smuzhiyun c##_##mH,dH, \
330*4882a593Smuzhiyun c##_##mI,d)
331*4882a593Smuzhiyun #define PUSH_NV_10(X,o,p,c,mA,dA,mB,dB,mC,dC,mD,dD,mE,dE,mF,dF,mG,dG,mH,dH,mI,dI,mJ,d...) \
332*4882a593Smuzhiyun PUSH_##o(p,c,c##_##mA,dA, \
333*4882a593Smuzhiyun c##_##mB,dB, \
334*4882a593Smuzhiyun c##_##mC,dC, \
335*4882a593Smuzhiyun c##_##mD,dD, \
336*4882a593Smuzhiyun c##_##mE,dE, \
337*4882a593Smuzhiyun c##_##mF,dF, \
338*4882a593Smuzhiyun c##_##mG,dG, \
339*4882a593Smuzhiyun c##_##mH,dH, \
340*4882a593Smuzhiyun c##_##mI,dI, \
341*4882a593Smuzhiyun c##_##mJ,d)
342*4882a593Smuzhiyun
343*4882a593Smuzhiyun #define PUSH_NV_(A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P,Q,R,S,T,U,V,W,X,IMPL,...) IMPL
344*4882a593Smuzhiyun #define PUSH_NV(A...) PUSH_NV_(A, PUSH_NV_10, PUSH_NV_10, \
345*4882a593Smuzhiyun PUSH_NV_9 , PUSH_NV_9, \
346*4882a593Smuzhiyun PUSH_NV_8 , PUSH_NV_8, \
347*4882a593Smuzhiyun PUSH_NV_7 , PUSH_NV_7, \
348*4882a593Smuzhiyun PUSH_NV_6 , PUSH_NV_6, \
349*4882a593Smuzhiyun PUSH_NV_5 , PUSH_NV_5, \
350*4882a593Smuzhiyun PUSH_NV_4 , PUSH_NV_4, \
351*4882a593Smuzhiyun PUSH_NV_3 , PUSH_NV_3, \
352*4882a593Smuzhiyun PUSH_NV_2 , PUSH_NV_2, \
353*4882a593Smuzhiyun PUSH_NV_1 , PUSH_NV_1)(, ##A)
354*4882a593Smuzhiyun
355*4882a593Smuzhiyun #define PUSH_IMMD(A...) PUSH_NV(NVIM, ##A)
356*4882a593Smuzhiyun #define PUSH_MTHD(A...) PUSH_NV(NVSQ, ##A)
357*4882a593Smuzhiyun #define PUSH_1INC(A...) PUSH_NV(NV1I, ##A)
358*4882a593Smuzhiyun #define PUSH_NINC(A...) PUSH_NV(NVNI, ##A)
359*4882a593Smuzhiyun #endif
360