Lines Matching +full:1 +full:- +full:5
1 // SPDX-License-Identifier: GPL-2.0-or-later
12 * Andreas Schwab, <schwab@issan.informatik.uni-dortmund.de>
19 * length-counter instead of the length counter
20 * (%1). Thanks to Roman Hodek for pointing this out.
22 * data-registers to hold input values and one tries to
43 * is aligned on either a 2-byte or 4-byte boundary. in csum_partial()
46 "btst #1,%3\n\t" /* Check alignment */ in csum_partial()
48 "subql #2,%1\n\t" /* buff%4==2: treat first word */ in csum_partial()
49 "jgt 1f\n\t" in csum_partial()
50 "addql #2,%1\n\t" /* len was == 2, treat only rest */ in csum_partial()
52 "1:\t" in csum_partial()
58 "movel %1,%3\n\t" /* save len in tmp1 */ in csum_partial()
59 "lsrl #5,%1\n\t" /* len/32 */ in csum_partial()
61 "subql #1,%1\n" in csum_partial()
62 "1:\t" in csum_partial()
79 "dbra %1,1b\n\t" in csum_partial()
82 "clrw %1\n\t" in csum_partial()
83 "subql #1,%1\n\t" in csum_partial()
84 "jcc 1b\n" in csum_partial()
86 "movel %3,%1\n\t" /* restore len from tmp1 */ in csum_partial()
90 "subqw #1,%3\n" in csum_partial()
100 "andw #3,%1\n\t" in csum_partial()
103 "subqw #2,%1\n\t" in csum_partial()
104 "jlt 5f\n\t" in csum_partial()
107 "tstw %1\n\t" /* another byte? */ in csum_partial()
109 "5:\t" in csum_partial()
119 : "0" (sum), "1" (len), "2" (buff) in csum_partial()
143 "btst #1,%4\n\t" /* Check alignment */ in csum_and_copy_from_user()
145 "subql #2,%1\n\t" /* buff%4==2: treat first word */ in csum_and_copy_from_user()
146 "jgt 1f\n\t" in csum_and_copy_from_user()
147 "addql #2,%1\n\t" /* len was == 2, treat only rest */ in csum_and_copy_from_user()
149 "1:\n" in csum_and_copy_from_user()
158 "movel %1,%4\n\t" /* save len in tmp1 */ in csum_and_copy_from_user()
159 "lsrl #5,%1\n\t" /* len/32 */ in csum_and_copy_from_user()
161 "subql #1,%1\n" in csum_and_copy_from_user()
162 "1:\n" in csum_and_copy_from_user()
164 "movesl %2@+,%5\n\t" in csum_and_copy_from_user()
165 "addxl %5,%0\n\t" in csum_and_copy_from_user()
166 "movel %5,%3@+\n\t" in csum_and_copy_from_user()
168 "movesl %2@+,%5\n\t" in csum_and_copy_from_user()
169 "addxl %5,%0\n\t" in csum_and_copy_from_user()
170 "movel %5,%3@+\n\t" in csum_and_copy_from_user()
172 "movesl %2@+,%5\n\t" in csum_and_copy_from_user()
173 "addxl %5,%0\n\t" in csum_and_copy_from_user()
174 "movel %5,%3@+\n\t" in csum_and_copy_from_user()
176 "movesl %2@+,%5\n\t" in csum_and_copy_from_user()
177 "addxl %5,%0\n\t" in csum_and_copy_from_user()
178 "movel %5,%3@+\n\t" in csum_and_copy_from_user()
180 "movesl %2@+,%5\n\t" in csum_and_copy_from_user()
181 "addxl %5,%0\n\t" in csum_and_copy_from_user()
182 "movel %5,%3@+\n\t" in csum_and_copy_from_user()
184 "movesl %2@+,%5\n\t" in csum_and_copy_from_user()
185 "addxl %5,%0\n\t" in csum_and_copy_from_user()
186 "movel %5,%3@+\n\t" in csum_and_copy_from_user()
188 "movesl %2@+,%5\n\t" in csum_and_copy_from_user()
189 "addxl %5,%0\n\t" in csum_and_copy_from_user()
190 "movel %5,%3@+\n\t" in csum_and_copy_from_user()
192 "movesl %2@+,%5\n\t" in csum_and_copy_from_user()
193 "addxl %5,%0\n\t" in csum_and_copy_from_user()
194 "movel %5,%3@+\n\t" in csum_and_copy_from_user()
195 "dbra %1,1b\n\t" in csum_and_copy_from_user()
196 "clrl %5\n\t" in csum_and_copy_from_user()
197 "addxl %5,%0\n\t" /* add X bit */ in csum_and_copy_from_user()
198 "clrw %1\n\t" in csum_and_copy_from_user()
199 "subql #1,%1\n\t" in csum_and_copy_from_user()
200 "jcc 1b\n" in csum_and_copy_from_user()
202 "movel %4,%1\n\t" /* restore len from tmp1 */ in csum_and_copy_from_user()
206 "subqw #1,%4\n" in csum_and_copy_from_user()
210 "movesl %2@+,%5\n\t" in csum_and_copy_from_user()
211 "addxl %5,%0\n\t" in csum_and_copy_from_user()
212 "movel %5,%3@+\n\t" in csum_and_copy_from_user()
214 "clrl %5\n\t" in csum_and_copy_from_user()
215 "addxl %5,%0\n" /* add X bit */ in csum_and_copy_from_user()
218 "andw #3,%1\n\t" in csum_and_copy_from_user()
220 "clrl %5\n\t" /* clear tmp2 for rest bytes */ in csum_and_copy_from_user()
221 "subqw #2,%1\n\t" in csum_and_copy_from_user()
222 "jlt 5f\n\t" in csum_and_copy_from_user()
224 "movesw %2@+,%5\n\t" /* have rest >= 2: get word */ in csum_and_copy_from_user()
225 "movew %5,%3@+\n\t" in csum_and_copy_from_user()
226 "swap %5\n\t" /* into bits 16..31 */ in csum_and_copy_from_user()
227 "tstw %1\n\t" /* another byte? */ in csum_and_copy_from_user()
229 "5:\n" in csum_and_copy_from_user()
231 "movesb %2@,%5\n\t" /* have odd rest: get byte */ in csum_and_copy_from_user()
232 "moveb %5,%3@+\n\t" in csum_and_copy_from_user()
233 "lslw #8,%5\n\t" /* into bits 8..15; 16..31 untouched */ in csum_and_copy_from_user()
235 "addl %5,%0\n\t" /* now add rest long to sum */ in csum_and_copy_from_user()
236 "clrl %5\n\t" in csum_and_copy_from_user()
237 "addxl %5,%0\n\t" /* add X bit */ in csum_and_copy_from_user()
262 : "0" (sum), "1" (len), "2" (src), "3" (dst) in csum_and_copy_from_user()
281 "btst #1,%4\n\t" /* Check alignment */ in csum_partial_copy_nocheck()
283 "subql #2,%1\n\t" /* buff%4==2: treat first word */ in csum_partial_copy_nocheck()
284 "jgt 1f\n\t" in csum_partial_copy_nocheck()
285 "addql #2,%1\n\t" /* len was == 2, treat only rest */ in csum_partial_copy_nocheck()
287 "1:\t" in csum_partial_copy_nocheck()
295 "movel %1,%4\n\t" /* save len in tmp1 */ in csum_partial_copy_nocheck()
296 "lsrl #5,%1\n\t" /* len/32 */ in csum_partial_copy_nocheck()
298 "subql #1,%1\n" in csum_partial_copy_nocheck()
299 "1:\t" in csum_partial_copy_nocheck()
300 "movel %2@+,%5\n\t" in csum_partial_copy_nocheck()
301 "addxl %5,%0\n\t" in csum_partial_copy_nocheck()
302 "movel %5,%3@+\n\t" in csum_partial_copy_nocheck()
303 "movel %2@+,%5\n\t" in csum_partial_copy_nocheck()
304 "addxl %5,%0\n\t" in csum_partial_copy_nocheck()
305 "movel %5,%3@+\n\t" in csum_partial_copy_nocheck()
306 "movel %2@+,%5\n\t" in csum_partial_copy_nocheck()
307 "addxl %5,%0\n\t" in csum_partial_copy_nocheck()
308 "movel %5,%3@+\n\t" in csum_partial_copy_nocheck()
309 "movel %2@+,%5\n\t" in csum_partial_copy_nocheck()
310 "addxl %5,%0\n\t" in csum_partial_copy_nocheck()
311 "movel %5,%3@+\n\t" in csum_partial_copy_nocheck()
312 "movel %2@+,%5\n\t" in csum_partial_copy_nocheck()
313 "addxl %5,%0\n\t" in csum_partial_copy_nocheck()
314 "movel %5,%3@+\n\t" in csum_partial_copy_nocheck()
315 "movel %2@+,%5\n\t" in csum_partial_copy_nocheck()
316 "addxl %5,%0\n\t" in csum_partial_copy_nocheck()
317 "movel %5,%3@+\n\t" in csum_partial_copy_nocheck()
318 "movel %2@+,%5\n\t" in csum_partial_copy_nocheck()
319 "addxl %5,%0\n\t" in csum_partial_copy_nocheck()
320 "movel %5,%3@+\n\t" in csum_partial_copy_nocheck()
321 "movel %2@+,%5\n\t" in csum_partial_copy_nocheck()
322 "addxl %5,%0\n\t" in csum_partial_copy_nocheck()
323 "movel %5,%3@+\n\t" in csum_partial_copy_nocheck()
324 "dbra %1,1b\n\t" in csum_partial_copy_nocheck()
325 "clrl %5\n\t" in csum_partial_copy_nocheck()
326 "addxl %5,%0\n\t" /* add X bit */ in csum_partial_copy_nocheck()
327 "clrw %1\n\t" in csum_partial_copy_nocheck()
328 "subql #1,%1\n\t" in csum_partial_copy_nocheck()
329 "jcc 1b\n" in csum_partial_copy_nocheck()
331 "movel %4,%1\n\t" /* restore len from tmp1 */ in csum_partial_copy_nocheck()
335 "subqw #1,%4\n" in csum_partial_copy_nocheck()
338 "movel %2@+,%5\n\t" in csum_partial_copy_nocheck()
339 "addxl %5,%0\n\t" in csum_partial_copy_nocheck()
340 "movel %5,%3@+\n\t" in csum_partial_copy_nocheck()
342 "clrl %5\n\t" in csum_partial_copy_nocheck()
343 "addxl %5,%0\n" /* add X bit */ in csum_partial_copy_nocheck()
346 "andw #3,%1\n\t" in csum_partial_copy_nocheck()
348 "clrl %5\n\t" /* clear tmp2 for rest bytes */ in csum_partial_copy_nocheck()
349 "subqw #2,%1\n\t" in csum_partial_copy_nocheck()
350 "jlt 5f\n\t" in csum_partial_copy_nocheck()
351 "movew %2@+,%5\n\t" /* have rest >= 2: get word */ in csum_partial_copy_nocheck()
352 "movew %5,%3@+\n\t" in csum_partial_copy_nocheck()
353 "swap %5\n\t" /* into bits 16..31 */ in csum_partial_copy_nocheck()
354 "tstw %1\n\t" /* another byte? */ in csum_partial_copy_nocheck()
356 "5:\t" in csum_partial_copy_nocheck()
357 "moveb %2@,%5\n\t" /* have odd rest: get byte */ in csum_partial_copy_nocheck()
358 "moveb %5,%3@+\n\t" in csum_partial_copy_nocheck()
359 "lslw #8,%5\n" /* into bits 8..15; 16..31 untouched */ in csum_partial_copy_nocheck()
361 "addl %5,%0\n\t" /* now add rest long to sum */ in csum_partial_copy_nocheck()
362 "clrl %5\n\t" in csum_partial_copy_nocheck()
363 "addxl %5,%0\n" /* add X bit */ in csum_partial_copy_nocheck()
367 : "0" (sum), "1" (len), "2" (src), "3" (dst) in csum_partial_copy_nocheck()