Quellcodebibliothek Statistik Leitseite products/sources/formale Sprachen/C/Linux/arch/sparc/lib/   (Open Source Betriebssystem Version 6.17.9©)  Datei vom 24.10.2025 mit Größe 3 kB image not shown  

Quelle  GENbzero.S   Sprache: Sparc

 
/* SPDX-License-Identifier: GPL-2.0 */
/* GENbzero.S: Generic sparc64 memset/clear_user.
 *
 * Copyright (C) 2007 David S. Miller (davem@davemloft.net)
 */

#include <asm/asi.h>

#define EX_ST(x,y)  \
98: x,y;   \
 .section __ex_table,"a";\
 .align 4;  \
 .word 98b, __retl_o1_asi;\
 .text;   \
 .align 4;

 .align 32
 .text

 .globl  GENmemset
 .type  GENmemset, #function
GENmemset:  /* %o0=buf, %o1=pat, %o2=len */
 and  %o1, 0xff, %o3
 mov  %o2, %o1
 sllx  %o3, 8, %g1
 or  %g1, %o3, %o2
 sllx  %o2, 16, %g1
 or  %g1, %o2, %o2
 sllx  %o2, 32, %g1
 ba,pt  %xcc, 1f
  or  %g1, %o2, %o2

 .globl  GENbzero
 .type  GENbzero, #function
GENbzero:
 clr  %o2
1: brz,pn  %o1, GENbzero_return
  mov  %o0, %o3

 /* %o5: saved %asi, restored at GENbzero_done
 * %o4: store %asi to use
 */

 rd  %asi, %o5
 mov  ASI_P, %o4
 wr  %o4, 0x0, %asi

GENbzero_from_clear_user:
 cmp  %o1, 15
 bl,pn  %icc, GENbzero_tiny
  andcc  %o0, 0x7, %g1
 be,pt  %xcc, 2f
  mov  8, %g2
 sub  %g2, %g1, %g1
 sub  %o1, %g1, %o1
1: EX_ST(stba %o2, [%o0 + 0x00] %asi)
 subcc  %g1, 1, %g1
 bne,pt  %xcc, 1b
  add  %o0, 1, %o0
2: cmp  %o1, 128
 bl,pn  %icc, GENbzero_medium
  andcc  %o0, (64 - 1), %g1
 be,pt  %xcc, GENbzero_pre_loop
  mov  64, %g2
 sub  %g2, %g1, %g1
 sub  %o1, %g1, %o1
1: EX_ST(stxa %o2, [%o0 + 0x00] %asi)
 subcc  %g1, 8, %g1
 bne,pt  %xcc, 1b
  add  %o0, 8, %o0

GENbzero_pre_loop:
 andn  %o1, (64 - 1), %g1
 sub  %o1, %g1, %o1
GENbzero_loop:
 EX_ST(stxa %o2, [%o0 + 0x00] %asi)
 EX_ST(stxa %o2, [%o0 + 0x08] %asi)
 EX_ST(stxa %o2, [%o0 + 0x10] %asi)
 EX_ST(stxa %o2, [%o0 + 0x18] %asi)
 EX_ST(stxa %o2, [%o0 + 0x20] %asi)
 EX_ST(stxa %o2, [%o0 + 0x28] %asi)
 EX_ST(stxa %o2, [%o0 + 0x30] %asi)
 EX_ST(stxa %o2, [%o0 + 0x38] %asi)
 subcc  %g1, 64, %g1
 bne,pt  %xcc, GENbzero_loop
  add  %o0, 64, %o0

 membar  #Sync
 wr  %o4, 0x0, %asi
 brz,pn  %o1, GENbzero_done
GENbzero_medium:
  andncc  %o1, 0x7, %g1
 be,pn  %xcc, 2f
  sub  %o1, %g1, %o1
1: EX_ST(stxa %o2, [%o0 + 0x00] %asi)
 subcc  %g1, 8, %g1
 bne,pt  %xcc, 1b
  add  %o0, 8, %o0
2: brz,pt  %o1, GENbzero_done
  nop

GENbzero_tiny:
1: EX_ST(stba %o2, [%o0 + 0x00] %asi)
 subcc  %o1, 1, %o1
 bne,pt  %icc, 1b
  add  %o0, 1, %o0

 /* fallthrough */

GENbzero_done:
 wr  %o5, 0x0, %asi

GENbzero_return:
 retl
  mov  %o3, %o0
 .size  GENbzero, .-GENbzero
 .size  GENmemset, .-GENmemset

 .globl  GENclear_user
 .type  GENclear_user, #function
GENclear_user:  /* %o0=buf, %o1=len */
 rd  %asi, %o5
 brz,pn  %o1, GENbzero_done
  clr  %o3
 cmp  %o5, ASI_AIUS
 bne,pn  %icc, GENbzero
  clr  %o2
 ba,pt  %xcc, GENbzero_from_clear_user
  mov  ASI_AIUS, %o4
 .size  GENclear_user, .-GENclear_user

#define BRANCH_ALWAYS 0x10680000
#define NOP  0x01000000
#define GEN_DO_PATCH(OLD, NEW) \
 sethi %hi(NEW), %g1; \
 or %g1, %lo(NEW), %g1; \
 sethi %hi(OLD), %g2; \
 or %g2, %lo(OLD), %g2; \
 sub %g1, %g2, %g1; \
 sethi %hi(BRANCH_ALWAYS), %g3; \
 sll %g1, 11, %g1; \
 srl %g1, 11 + 2, %g1; \
 or %g3, %lo(BRANCH_ALWAYS), %g3; \
 or %g3, %g1, %g3; \
 stw %g3, [%g2]; \
 sethi %hi(NOP), %g3; \
 or %g3, %lo(NOP), %g3; \
 stw %g3, [%g2 + 0x4]; \
 flush %g2;

 .globl generic_patch_bzero
 .type generic_patch_bzero,#function
generic_patch_bzero:
 GEN_DO_PATCH(memset, GENmemset)
 GEN_DO_PATCH(__bzero, GENbzero)
 GEN_DO_PATCH(__clear_user, GENclear_user)
 retl
  nop
 .size generic_patch_bzero,.-generic_patch_bzero

Messung V0.5
C=91 H=98 G=94

¤ Dauer der Verarbeitung: 0.0 Sekunden  (vorverarbeitet)  ¤

*© Formatika GbR, Deutschland






Wurzel

Suchen

Beweissystem der NASA

Beweissystem Isabelle

NIST Cobol Testsuite

Cephes Mathematical Library

Wiener Entwicklungsmethode

Haftungshinweis

Die Informationen auf dieser Webseite wurden nach bestem Wissen sorgfältig zusammengestellt. Es wird jedoch weder Vollständigkeit, noch Richtigkeit, noch Qualität der bereit gestellten Informationen zugesichert.

Bemerkung:

Die farbliche Syntaxdarstellung und die Messung sind noch experimentell.