Code/Resource
Windows Develop
Linux-Unix program
Internet-Socket-Network
Web Server
Browser Client
Ftp Server
Ftp Client
Browser Plugins
Proxy Server
Email Server
Email Client
WEB Mail
Firewall-Security
Telnet Server
Telnet Client
ICQ-IM-Chat
Search Engine
Sniffer Package capture
Remote Control
xml-soap-webservice
P2P
WEB(ASP,PHP,...)
TCP/IP Stack
SNMP
Grid Computing
SilverLight
DNS
Cluster Service
Network Security
Communication-Mobile
Game Program
Editor
Multimedia program
Graph program
Compiler program
Compress-Decompress algrithms
Crypt_Decrypt algrithms
Mathimatics-Numerical algorithms
MultiLanguage
Disk/Storage
Java Develop
assembly language
Applications
Other systems
Database system
Embeded-SCM Develop
FlashMX/Flex
source in ebook
Delphi VCL
OS Develop
MiddleWare
MPI
MacOS develop
LabView
ELanguage
Software/Tools
E-Books
Artical/Document
pixel.asm
Package: chapter15.rar [view]
Upload User: hjq518
Upload Date: 2021-12-09
Package Size: 5084k
Code Size: 19k
Category:
Audio program
Development Platform:
Visual C++
- /*****************************************************************************
- * pixel.asm: h264 encoder library
- *****************************************************************************
- * Copyright (C) 2005 Phil Jensen <philj@csufresno.edu>
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation; either version 2 of the License, or
- * (at your option) any later version.
- *
- * 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
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License
- * along with this program; if not, write to the Free Software
- * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02111, USA.
- *****************************************************************************/
- ! VIS optimized SAD for UltraSPARC
- .text
- .global x264_pixel_sad_8x8_vis
- x264_pixel_sad_8x8_vis:
- save %sp, -120, %sp
- fzero %f12
- alignaddr %i0, %g0, %l0
- ldd [%l0], %f0
- ldd [%l0+8], %f2
- faligndata %f0, %f2, %f4
- alignaddr %i2, %g0, %l2
- ldd [%l2], %f6
- ldd [%l2+8], %f8
- faligndata %f6, %f8, %f10
- add %i0, %i1, %i0
- add %i2, %i3, %i2
- pdist %f4, %f10, %f12
- alignaddr %i0, %g0, %l0
- ldd [%l0], %f0
- ldd [%l0+8], %f2
- faligndata %f0, %f2, %f4
- alignaddr %i2, %g0, %l2
- ldd [%l2], %f6
- ldd [%l2+8], %f8
- faligndata %f6, %f8, %f10
- add %i0, %i1, %i0
- add %i2, %i3, %i2
- pdist %f4, %f10, %f12
- alignaddr %i0, %g0, %l0
- ldd [%l0], %f0
- ldd [%l0+8], %f2
- faligndata %f0, %f2, %f4
- alignaddr %i2, %g0, %l2
- ldd [%l2], %f6
- ldd [%l2+8], %f8
- faligndata %f6, %f8, %f10
- add %i0, %i1, %i0
- add %i2, %i3, %i2
- pdist %f4, %f10, %f12
- alignaddr %i0, %g0, %l0
- ldd [%l0], %f0
- ldd [%l0+8], %f2
- faligndata %f0, %f2, %f4
- alignaddr %i2, %g0, %l2
- ldd [%l2], %f6
- ldd [%l2+8], %f8
- faligndata %f6, %f8, %f10
- add %i0, %i1, %i0
- add %i2, %i3, %i2
- pdist %f4, %f10, %f12
- alignaddr %i0, %g0, %l0
- ldd [%l0], %f0
- ldd [%l0+8], %f2
- faligndata %f0, %f2, %f4
- alignaddr %i2, %g0, %l2
- ldd [%l2], %f6
- ldd [%l2+8], %f8
- faligndata %f6, %f8, %f10
- add %i0, %i1, %i0
- add %i2, %i3, %i2
- pdist %f4, %f10, %f12
- alignaddr %i0, %g0, %l0
- ldd [%l0], %f0
- ldd [%l0+8], %f2
- faligndata %f0, %f2, %f4
- alignaddr %i2, %g0, %l2
- ldd [%l2], %f6
- ldd [%l2+8], %f8
- faligndata %f6, %f8, %f10
- add %i0, %i1, %i0
- add %i2, %i3, %i2
- pdist %f4, %f10, %f12
- alignaddr %i0, %g0, %l0
- ldd [%l0], %f0
- ldd [%l0+8], %f2
- faligndata %f0, %f2, %f4
- alignaddr %i2, %g0, %l2
- ldd [%l2], %f6
- ldd [%l2+8], %f8
- faligndata %f6, %f8, %f10
- add %i0, %i1, %i0
- add %i2, %i3, %i2
- pdist %f4, %f10, %f12
- alignaddr %i0, %g0, %l0
- ldd [%l0], %f0
- ldd [%l0+8], %f2
- faligndata %f0, %f2, %f4
- alignaddr %i2, %g0, %l2
- ldd [%l2], %f6
- ldd [%l2+8], %f8
- faligndata %f6, %f8, %f10
- add %i0, %i1, %i0
- add %i2, %i3, %i2
- pdist %f4, %f10, %f12
- std %f12, [%fp-24]
- ld [%fp-20], %i0
- ret
- restore
- .global x264_pixel_sad_8x16_vis
- x264_pixel_sad_8x16_vis:
- save %sp, -120, %sp
- fzero %f12
- alignaddr %i0, %g0, %l0
- ldd [%l0], %f0
- ldd [%l0+8], %f2
- faligndata %f0, %f2, %f4
- alignaddr %i2, %g0, %l2
- ldd [%l2], %f6
- ldd [%l2+8], %f8
- faligndata %f6, %f8, %f10
- add %i0, %i1, %i0
- add %i2, %i3, %i2
- pdist %f4, %f10, %f12
- alignaddr %i0, %g0, %l0
- ldd [%l0], %f0
- ldd [%l0+8], %f2
- faligndata %f0, %f2, %f4
- alignaddr %i2, %g0, %l2
- ldd [%l2], %f6
- ldd [%l2+8], %f8
- faligndata %f6, %f8, %f10
- add %i0, %i1, %i0
- add %i2, %i3, %i2
- pdist %f4, %f10, %f12
- alignaddr %i0, %g0, %l0
- ldd [%l0], %f0
- ldd [%l0+8], %f2
- faligndata %f0, %f2, %f4
- alignaddr %i2, %g0, %l2
- ldd [%l2], %f6
- ldd [%l2+8], %f8
- faligndata %f6, %f8, %f10
- add %i0, %i1, %i0
- add %i2, %i3, %i2
- pdist %f4, %f10, %f12
- alignaddr %i0, %g0, %l0
- ldd [%l0], %f0
- ldd [%l0+8], %f2
- faligndata %f0, %f2, %f4
- alignaddr %i2, %g0, %l2
- ldd [%l2], %f6
- ldd [%l2+8], %f8
- faligndata %f6, %f8, %f10
- add %i0, %i1, %i0
- add %i2, %i3, %i2
- pdist %f4, %f10, %f12
- alignaddr %i0, %g0, %l0
- ldd [%l0], %f0
- ldd [%l0+8], %f2
- faligndata %f0, %f2, %f4
- alignaddr %i2, %g0, %l2
- ldd [%l2], %f6
- ldd [%l2+8], %f8
- faligndata %f6, %f8, %f10
- add %i0, %i1, %i0
- add %i2, %i3, %i2
- pdist %f4, %f10, %f12
- alignaddr %i0, %g0, %l0
- ldd [%l0], %f0
- ldd [%l0+8], %f2
- faligndata %f0, %f2, %f4
- alignaddr %i2, %g0, %l2
- ldd [%l2], %f6
- ldd [%l2+8], %f8
- faligndata %f6, %f8, %f10
- add %i0, %i1, %i0
- add %i2, %i3, %i2
- pdist %f4, %f10, %f12
- alignaddr %i0, %g0, %l0
- ldd [%l0], %f0
- ldd [%l0+8], %f2
- faligndata %f0, %f2, %f4
- alignaddr %i2, %g0, %l2
- ldd [%l2], %f6
- ldd [%l2+8], %f8
- faligndata %f6, %f8, %f10
- add %i0, %i1, %i0
- add %i2, %i3, %i2
- pdist %f4, %f10, %f12
- alignaddr %i0, %g0, %l0
- ldd [%l0], %f0
- ldd [%l0+8], %f2
- faligndata %f0, %f2, %f4
- alignaddr %i2, %g0, %l2
- ldd [%l2], %f6
- ldd [%l2+8], %f8
- faligndata %f6, %f8, %f10
- add %i0, %i1, %i0
- add %i2, %i3, %i2
- pdist %f4, %f10, %f12
- alignaddr %i0, %g0, %l0
- ldd [%l0], %f0
- ldd [%l0+8], %f2
- faligndata %f0, %f2, %f4
- alignaddr %i2, %g0, %l2
- ldd [%l2], %f6
- ldd [%l2+8], %f8
- faligndata %f6, %f8, %f10
- add %i0, %i1, %i0
- add %i2, %i3, %i2
- pdist %f4, %f10, %f12
- alignaddr %i0, %g0, %l0
- ldd [%l0], %f0
- ldd [%l0+8], %f2
- faligndata %f0, %f2, %f4
- alignaddr %i2, %g0, %l2
- ldd [%l2], %f6
- ldd [%l2+8], %f8
- faligndata %f6, %f8, %f10
- add %i0, %i1, %i0
- add %i2, %i3, %i2
- pdist %f4, %f10, %f12
- alignaddr %i0, %g0, %l0
- ldd [%l0], %f0
- ldd [%l0+8], %f2
- faligndata %f0, %f2, %f4
- alignaddr %i2, %g0, %l2
- ldd [%l2], %f6
- ldd [%l2+8], %f8
- faligndata %f6, %f8, %f10
- add %i0, %i1, %i0
- add %i2, %i3, %i2
- pdist %f4, %f10, %f12
- alignaddr %i0, %g0, %l0
- ldd [%l0], %f0
- ldd [%l0+8], %f2
- faligndata %f0, %f2, %f4
- alignaddr %i2, %g0, %l2
- ldd [%l2], %f6
- ldd [%l2+8], %f8
- faligndata %f6, %f8, %f10
- add %i0, %i1, %i0
- add %i2, %i3, %i2
- pdist %f4, %f10, %f12
- alignaddr %i0, %g0, %l0
- ldd [%l0], %f0
- ldd [%l0+8], %f2
- faligndata %f0, %f2, %f4
- alignaddr %i2, %g0, %l2
- ldd [%l2], %f6
- ldd [%l2+8], %f8
- faligndata %f6, %f8, %f10
- add %i0, %i1, %i0
- add %i2, %i3, %i2
- pdist %f4, %f10, %f12
- alignaddr %i0, %g0, %l0
- ldd [%l0], %f0
- ldd [%l0+8], %f2
- faligndata %f0, %f2, %f4
- alignaddr %i2, %g0, %l2
- ldd [%l2], %f6
- ldd [%l2+8], %f8
- faligndata %f6, %f8, %f10
- add %i0, %i1, %i0
- add %i2, %i3, %i2
- pdist %f4, %f10, %f12
- alignaddr %i0, %g0, %l0
- ldd [%l0], %f0
- ldd [%l0+8], %f2
- faligndata %f0, %f2, %f4
- alignaddr %i2, %g0, %l2
- ldd [%l2], %f6
- ldd [%l2+8], %f8
- faligndata %f6, %f8, %f10
- add %i0, %i1, %i0
- add %i2, %i3, %i2
- pdist %f4, %f10, %f12
- alignaddr %i0, %g0, %l0
- ldd [%l0], %f0
- ldd [%l0+8], %f2
- faligndata %f0, %f2, %f4
- alignaddr %i2, %g0, %l2
- ldd [%l2], %f6
- ldd [%l2+8], %f8
- faligndata %f6, %f8, %f10
- add %i0, %i1, %i0
- add %i2, %i3, %i2
- pdist %f4, %f10, %f12
- std %f12, [%fp-24]
- ld [%fp-20], %i0
- ret
- restore
- .global x264_pixel_sad_16x8_vis
- x264_pixel_sad_16x8_vis:
- save %sp, -120, %sp
- fzero %f12 ! zero out the accumulator used for pdist
- sub %i1, 8, %i1 ! reduce stride by 8, since we are moving forward 8 each block
- sub %i3, 8, %i3 ! same here, reduce stride by 8
- alignaddr %i0, %g0, %l0
- ldd [%l0], %f0
- ldd [%l0+8], %f2
- faligndata %f0, %f2, %f4
- alignaddr %i2, %g0, %l2
- ldd [%l2], %f6
- ldd [%l2+8], %f8
- faligndata %f6, %f8, %f10
- add %i0, 8, %i0
- add %i2, 8, %i2
- pdist %f4, %f10, %f12
- alignaddr %i0, %g0, %l0
- ldd [%l0], %f0
- ldd [%l0+8], %f2
- faligndata %f0, %f2, %f4
- alignaddr %i2, %g0, %l2
- ldd [%l2], %f6
- ldd [%l2+8], %f8
- faligndata %f6, %f8, %f10
- add %i0, %i1, %i0
- add %i2, %i3, %i2
- pdist %f4, %f10, %f12
- alignaddr %i0, %g0, %l0
- ldd [%l0], %f0
- ldd [%l0+8], %f2
- faligndata %f0, %f2, %f4
- alignaddr %i2, %g0, %l2
- ldd [%l2], %f6
- ldd [%l2+8], %f8
- faligndata %f6, %f8, %f10
- add %i0, 8, %i0
- add %i2, 8, %i2
- pdist %f4, %f10, %f12
- alignaddr %i0, %g0, %l0
- ldd [%l0], %f0
- ldd [%l0+8], %f2
- faligndata %f0, %f2, %f4
- alignaddr %i2, %g0, %l2
- ldd [%l2], %f6
- ldd [%l2+8], %f8
- faligndata %f6, %f8, %f10
- add %i0, %i1, %i0
- add %i2, %i3, %i2
- pdist %f4, %f10, %f12
- alignaddr %i0, %g0, %l0
- ldd [%l0], %f0
- ldd [%l0+8], %f2
- faligndata %f0, %f2, %f4
- alignaddr %i2, %g0, %l2
- ldd [%l2], %f6
- ldd [%l2+8], %f8
- faligndata %f6, %f8, %f10
- add %i0, 8, %i0
- add %i2, 8, %i2
- pdist %f4, %f10, %f12
- alignaddr %i0, %g0, %l0
- ldd [%l0], %f0
- ldd [%l0+8], %f2
- faligndata %f0, %f2, %f4
- alignaddr %i2, %g0, %l2
- ldd [%l2], %f6
- ldd [%l2+8], %f8
- faligndata %f6, %f8, %f10
- add %i0, %i1, %i0
- add %i2, %i3, %i2
- pdist %f4, %f10, %f12
- alignaddr %i0, %g0, %l0
- ldd [%l0], %f0
- ldd [%l0+8], %f2
- faligndata %f0, %f2, %f4
- alignaddr %i2, %g0, %l2
- ldd [%l2], %f6
- ldd [%l2+8], %f8
- faligndata %f6, %f8, %f10
- add %i0, 8, %i0
- add %i2, 8, %i2
- pdist %f4, %f10, %f12
- alignaddr %i0, %g0, %l0
- ldd [%l0], %f0
- ldd [%l0+8], %f2
- faligndata %f0, %f2, %f4
- alignaddr %i2, %g0, %l2
- ldd [%l2], %f6
- ldd [%l2+8], %f8
- faligndata %f6, %f8, %f10
- add %i0, %i1, %i0
- add %i2, %i3, %i2
- pdist %f4, %f10, %f12
- alignaddr %i0, %g0, %l0
- ldd [%l0], %f0
- ldd [%l0+8], %f2
- faligndata %f0, %f2, %f4
- alignaddr %i2, %g0, %l2
- ldd [%l2], %f6
- ldd [%l2+8], %f8
- faligndata %f6, %f8, %f10
- add %i0, 8, %i0
- add %i2, 8, %i2
- pdist %f4, %f10, %f12
- alignaddr %i0, %g0, %l0
- ldd [%l0], %f0
- ldd [%l0+8], %f2
- faligndata %f0, %f2, %f4
- alignaddr %i2, %g0, %l2
- ldd [%l2], %f6
- ldd [%l2+8], %f8
- faligndata %f6, %f8, %f10
- add %i0, %i1, %i0
- add %i2, %i3, %i2
- pdist %f4, %f10, %f12
- alignaddr %i0, %g0, %l0
- ldd [%l0], %f0
- ldd [%l0+8], %f2
- faligndata %f0, %f2, %f4
- alignaddr %i2, %g0, %l2
- ldd [%l2], %f6
- ldd [%l2+8], %f8
- faligndata %f6, %f8, %f10
- add %i0, 8, %i0
- add %i2, 8, %i2
- pdist %f4, %f10, %f12
- alignaddr %i0, %g0, %l0
- ldd [%l0], %f0
- ldd [%l0+8], %f2
- faligndata %f0, %f2, %f4
- alignaddr %i2, %g0, %l2
- ldd [%l2], %f6
- ldd [%l2+8], %f8
- faligndata %f6, %f8, %f10
- add %i0, %i1, %i0
- add %i2, %i3, %i2
- pdist %f4, %f10, %f12
- alignaddr %i0, %g0, %l0
- ldd [%l0], %f0
- ldd [%l0+8], %f2
- faligndata %f0, %f2, %f4
- alignaddr %i2, %g0, %l2
- ldd [%l2], %f6
- ldd [%l2+8], %f8
- faligndata %f6, %f8, %f10
- add %i0, 8, %i0
- add %i2, 8, %i2
- pdist %f4, %f10, %f12
- alignaddr %i0, %g0, %l0
- ldd [%l0], %f0
- ldd [%l0+8], %f2
- faligndata %f0, %f2, %f4
- alignaddr %i2, %g0, %l2
- ldd [%l2], %f6
- ldd [%l2+8], %f8
- faligndata %f6, %f8, %f10
- add %i0, %i1, %i0
- add %i2, %i3, %i2
- pdist %f4, %f10, %f12
- alignaddr %i0, %g0, %l0
- ldd [%l0], %f0
- ldd [%l0+8], %f2
- faligndata %f0, %f2, %f4
- alignaddr %i2, %g0, %l2
- ldd [%l2], %f6
- ldd [%l2+8], %f8
- faligndata %f6, %f8, %f10
- add %i0, 8, %i0
- add %i2, 8, %i2
- pdist %f4, %f10, %f12
- alignaddr %i0, %g0, %l0
- ldd [%l0], %f0
- ldd [%l0+8], %f2
- faligndata %f0, %f2, %f4
- alignaddr %i2, %g0, %l2
- ldd [%l2], %f6
- ldd [%l2+8], %f8
- faligndata %f6, %f8, %f10
- add %i0, %i1, %i0
- add %i2, %i3, %i2
- pdist %f4, %f10, %f12
- std %f12, [%fp-24]
- ld [%fp-20], %i0
- ret
- restore
- .global x264_pixel_sad_16x16_vis
- x264_pixel_sad_16x16_vis:
- save %sp, -120, %sp
- fzero %f12 ! zero out the accumulator used for pdist
- sub %i1, 8, %i1 ! reduce stride by 8, since we are moving forward 8 each block
- sub %i3, 8, %i3 ! same here, reduce stride by 8
- alignaddr %i0, %g0, %l0
- ldd [%l0], %f0
- ldd [%l0+8], %f2
- faligndata %f0, %f2, %f4
- alignaddr %i2, %g0, %l2
- ldd [%l2], %f6
- ldd [%l2+8], %f8
- faligndata %f6, %f8, %f10
- add %i0, 8, %i0
- add %i2, 8, %i2
- pdist %f4, %f10, %f12
- alignaddr %i0, %g0, %l0
- ldd [%l0], %f0
- ldd [%l0+8], %f2
- faligndata %f0, %f2, %f4
- alignaddr %i2, %g0, %l2
- ldd [%l2], %f6
- ldd [%l2+8], %f8
- faligndata %f6, %f8, %f10
- add %i0, %i1, %i0
- add %i2, %i3, %i2
- pdist %f4, %f10, %f12
- alignaddr %i0, %g0, %l0
- ldd [%l0], %f0
- ldd [%l0+8], %f2
- faligndata %f0, %f2, %f4
- alignaddr %i2, %g0, %l2
- ldd [%l2], %f6
- ldd [%l2+8], %f8
- faligndata %f6, %f8, %f10
- add %i0, 8, %i0
- add %i2, 8, %i2
- pdist %f4, %f10, %f12
- alignaddr %i0, %g0, %l0
- ldd [%l0], %f0
- ldd [%l0+8], %f2
- faligndata %f0, %f2, %f4
- alignaddr %i2, %g0, %l2
- ldd [%l2], %f6
- ldd [%l2+8], %f8
- faligndata %f6, %f8, %f10
- add %i0, %i1, %i0
- add %i2, %i3, %i2
- pdist %f4, %f10, %f12
- alignaddr %i0, %g0, %l0
- ldd [%l0], %f0
- ldd [%l0+8], %f2
- faligndata %f0, %f2, %f4
- alignaddr %i2, %g0, %l2
- ldd [%l2], %f6
- ldd [%l2+8], %f8
- faligndata %f6, %f8, %f10
- add %i0, 8, %i0
- add %i2, 8, %i2
- pdist %f4, %f10, %f12
- alignaddr %i0, %g0, %l0
- ldd [%l0], %f0
- ldd [%l0+8], %f2
- faligndata %f0, %f2, %f4
- alignaddr %i2, %g0, %l2
- ldd [%l2], %f6
- ldd [%l2+8], %f8
- faligndata %f6, %f8, %f10
- add %i0, %i1, %i0
- add %i2, %i3, %i2
- pdist %f4, %f10, %f12
- alignaddr %i0, %g0, %l0
- ldd [%l0], %f0
- ldd [%l0+8], %f2
- faligndata %f0, %f2, %f4
- alignaddr %i2, %g0, %l2
- ldd [%l2], %f6
- ldd [%l2+8], %f8
- faligndata %f6, %f8, %f10
- add %i0, 8, %i0
- add %i2, 8, %i2
- pdist %f4, %f10, %f12
- alignaddr %i0, %g0, %l0
- ldd [%l0], %f0
- ldd [%l0+8], %f2
- faligndata %f0, %f2, %f4
- alignaddr %i2, %g0, %l2
- ldd [%l2], %f6
- ldd [%l2+8], %f8
- faligndata %f6, %f8, %f10
- add %i0, %i1, %i0
- add %i2, %i3, %i2
- pdist %f4, %f10, %f12
- alignaddr %i0, %g0, %l0
- ldd [%l0], %f0
- ldd [%l0+8], %f2
- faligndata %f0, %f2, %f4
- alignaddr %i2, %g0, %l2
- ldd [%l2], %f6
- ldd [%l2+8], %f8
- faligndata %f6, %f8, %f10
- add %i0, 8, %i0
- add %i2, 8, %i2
- pdist %f4, %f10, %f12
- alignaddr %i0, %g0, %l0
- ldd [%l0], %f0
- ldd [%l0+8], %f2
- faligndata %f0, %f2, %f4
- alignaddr %i2, %g0, %l2
- ldd [%l2], %f6
- ldd [%l2+8], %f8
- faligndata %f6, %f8, %f10
- add %i0, %i1, %i0
- add %i2, %i3, %i2
- pdist %f4, %f10, %f12
- alignaddr %i0, %g0, %l0
- ldd [%l0], %f0
- ldd [%l0+8], %f2
- faligndata %f0, %f2, %f4
- alignaddr %i2, %g0, %l2
- ldd [%l2], %f6
- ldd [%l2+8], %f8
- faligndata %f6, %f8, %f10
- add %i0, 8, %i0
- add %i2, 8, %i2
- pdist %f4, %f10, %f12
- alignaddr %i0, %g0, %l0
- ldd [%l0], %f0
- ldd [%l0+8], %f2
- faligndata %f0, %f2, %f4
- alignaddr %i2, %g0, %l2
- ldd [%l2], %f6
- ldd [%l2+8], %f8
- faligndata %f6, %f8, %f10
- add %i0, %i1, %i0
- add %i2, %i3, %i2
- pdist %f4, %f10, %f12
- alignaddr %i0, %g0, %l0
- ldd [%l0], %f0
- ldd [%l0+8], %f2
- faligndata %f0, %f2, %f4
- alignaddr %i2, %g0, %l2
- ldd [%l2], %f6
- ldd [%l2+8], %f8
- faligndata %f6, %f8, %f10
- add %i0, 8, %i0
- add %i2, 8, %i2
- pdist %f4, %f10, %f12
- alignaddr %i0, %g0, %l0
- ldd [%l0], %f0
- ldd [%l0+8], %f2
- faligndata %f0, %f2, %f4
- alignaddr %i2, %g0, %l2
- ldd [%l2], %f6
- ldd [%l2+8], %f8
- faligndata %f6, %f8, %f10
- add %i0, %i1, %i0
- add %i2, %i3, %i2
- pdist %f4, %f10, %f12
- alignaddr %i0, %g0, %l0
- ldd [%l0], %f0
- ldd [%l0+8], %f2
- faligndata %f0, %f2, %f4
- alignaddr %i2, %g0, %l2
- ldd [%l2], %f6
- ldd [%l2+8], %f8
- faligndata %f6, %f8, %f10
- add %i0, 8, %i0
- add %i2, 8, %i2
- pdist %f4, %f10, %f12
- alignaddr %i0, %g0, %l0
- ldd [%l0], %f0
- ldd [%l0+8], %f2
- faligndata %f0, %f2, %f4
- alignaddr %i2, %g0, %l2
- ldd [%l2], %f6
- ldd [%l2+8], %f8
- faligndata %f6, %f8, %f10
- add %i0, %i1, %i0
- add %i2, %i3, %i2
- pdist %f4, %f10, %f12
- alignaddr %i0, %g0, %l0
- ldd [%l0], %f0
- ldd [%l0+8], %f2
- faligndata %f0, %f2, %f4
- alignaddr %i2, %g0, %l2
- ldd [%l2], %f6
- ldd [%l2+8], %f8
- faligndata %f6, %f8, %f10
- add %i0, 8, %i0
- add %i2, 8, %i2
- pdist %f4, %f10, %f12
- alignaddr %i0, %g0, %l0
- ldd [%l0], %f0
- ldd [%l0+8], %f2
- faligndata %f0, %f2, %f4
- alignaddr %i2, %g0, %l2
- ldd [%l2], %f6
- ldd [%l2+8], %f8
- faligndata %f6, %f8, %f10
- add %i0, %i1, %i0
- add %i2, %i3, %i2
- pdist %f4, %f10, %f12
- alignaddr %i0, %g0, %l0
- ldd [%l0], %f0
- ldd [%l0+8], %f2
- faligndata %f0, %f2, %f4
- alignaddr %i2, %g0, %l2
- ldd [%l2], %f6
- ldd [%l2+8], %f8
- faligndata %f6, %f8, %f10
- add %i0, 8, %i0
- add %i2, 8, %i2
- pdist %f4, %f10, %f12
- alignaddr %i0, %g0, %l0
- ldd [%l0], %f0
- ldd [%l0+8], %f2
- faligndata %f0, %f2, %f4
- alignaddr %i2, %g0, %l2
- ldd [%l2], %f6
- ldd [%l2+8], %f8
- faligndata %f6, %f8, %f10
- add %i0, %i1, %i0
- add %i2, %i3, %i2
- pdist %f4, %f10, %f12
- alignaddr %i0, %g0, %l0
- ldd [%l0], %f0
- ldd [%l0+8], %f2
- faligndata %f0, %f2, %f4
- alignaddr %i2, %g0, %l2
- ldd [%l2], %f6
- ldd [%l2+8], %f8
- faligndata %f6, %f8, %f10
- add %i0, 8, %i0
- add %i2, 8, %i2
- pdist %f4, %f10, %f12
- alignaddr %i0, %g0, %l0
- ldd [%l0], %f0
- ldd [%l0+8], %f2
- faligndata %f0, %f2, %f4
- alignaddr %i2, %g0, %l2
- ldd [%l2], %f6
- ldd [%l2+8], %f8
- faligndata %f6, %f8, %f10
- add %i0, %i1, %i0
- add %i2, %i3, %i2
- pdist %f4, %f10, %f12
- alignaddr %i0, %g0, %l0
- ldd [%l0], %f0
- ldd [%l0+8], %f2
- faligndata %f0, %f2, %f4
- alignaddr %i2, %g0, %l2
- ldd [%l2], %f6
- ldd [%l2+8], %f8
- faligndata %f6, %f8, %f10
- add %i0, 8, %i0
- add %i2, 8, %i2
- pdist %f4, %f10, %f12
- alignaddr %i0, %g0, %l0
- ldd [%l0], %f0
- ldd [%l0+8], %f2
- faligndata %f0, %f2, %f4
- alignaddr %i2, %g0, %l2
- ldd [%l2], %f6
- ldd [%l2+8], %f8
- faligndata %f6, %f8, %f10
- add %i0, %i1, %i0
- add %i2, %i3, %i2
- pdist %f4, %f10, %f12
- alignaddr %i0, %g0, %l0
- ldd [%l0], %f0
- ldd [%l0+8], %f2
- faligndata %f0, %f2, %f4
- alignaddr %i2, %g0, %l2
- ldd [%l2], %f6
- ldd [%l2+8], %f8
- faligndata %f6, %f8, %f10
- add %i0, 8, %i0
- add %i2, 8, %i2
- pdist %f4, %f10, %f12
- alignaddr %i0, %g0, %l0
- ldd [%l0], %f0
- ldd [%l0+8], %f2
- faligndata %f0, %f2, %f4
- alignaddr %i2, %g0, %l2
- ldd [%l2], %f6
- ldd [%l2+8], %f8
- faligndata %f6, %f8, %f10
- add %i0, %i1, %i0
- add %i2, %i3, %i2
- pdist %f4, %f10, %f12
- alignaddr %i0, %g0, %l0
- ldd [%l0], %f0
- ldd [%l0+8], %f2
- faligndata %f0, %f2, %f4
- alignaddr %i2, %g0, %l2
- ldd [%l2], %f6
- ldd [%l2+8], %f8
- faligndata %f6, %f8, %f10
- add %i0, 8, %i0
- add %i2, 8, %i2
- pdist %f4, %f10, %f12
- alignaddr %i0, %g0, %l0
- ldd [%l0], %f0
- ldd [%l0+8], %f2
- faligndata %f0, %f2, %f4
- alignaddr %i2, %g0, %l2
- ldd [%l2], %f6
- ldd [%l2+8], %f8
- faligndata %f6, %f8, %f10
- add %i0, %i1, %i0
- add %i2, %i3, %i2
- pdist %f4, %f10, %f12
- alignaddr %i0, %g0, %l0
- ldd [%l0], %f0
- ldd [%l0+8], %f2
- faligndata %f0, %f2, %f4
- alignaddr %i2, %g0, %l2
- ldd [%l2], %f6
- ldd [%l2+8], %f8
- faligndata %f6, %f8, %f10
- add %i0, 8, %i0
- add %i2, 8, %i2
- pdist %f4, %f10, %f12
- alignaddr %i0, %g0, %l0
- ldd [%l0], %f0
- ldd [%l0+8], %f2
- faligndata %f0, %f2, %f4
- alignaddr %i2, %g0, %l2
- ldd [%l2], %f6
- ldd [%l2+8], %f8
- faligndata %f6, %f8, %f10
- add %i0, %i1, %i0
- add %i2, %i3, %i2
- pdist %f4, %f10, %f12
- alignaddr %i0, %g0, %l0
- ldd [%l0], %f0
- ldd [%l0+8], %f2
- faligndata %f0, %f2, %f4
- alignaddr %i2, %g0, %l2
- ldd [%l2], %f6
- ldd [%l2+8], %f8
- faligndata %f6, %f8, %f10
- add %i0, 8, %i0
- add %i2, 8, %i2
- pdist %f4, %f10, %f12
- alignaddr %i0, %g0, %l0
- ldd [%l0], %f0
- ldd [%l0+8], %f2
- faligndata %f0, %f2, %f4
- alignaddr %i2, %g0, %l2
- ldd [%l2], %f6
- ldd [%l2+8], %f8
- faligndata %f6, %f8, %f10
- add %i0, %i1, %i0
- add %i2, %i3, %i2
- pdist %f4, %f10, %f12
- std %f12, [%fp-24]
- ld [%fp-20], %i0
- ret
- restore