~louis/ubuntu/trusty/clamav/lp799623_fix_logrotate

« back to all changes in this revision

Viewing changes to libclamav/c++/llvm/test/CodeGen/X86/stack-align.ll

  • Committer: Bazaar Package Importer
  • Author(s): Scott Kitterman
  • Date: 2010-03-12 11:30:04 UTC
  • mfrom: (0.41.1 upstream)
  • Revision ID: james.westby@ubuntu.com-20100312113004-b0fop4bkycszdd0z
Tags: 0.96~rc1+dfsg-0ubuntu1
* New upstream RC - FFE (LP: #537636):
  - Add OfficialDatabaseOnly option to clamav-base.postinst.in
  - Add LocalSocketGroup option to clamav-base.postinst.in
  - Add LocalSocketMode option to clamav-base.postinst.in
  - Add CrossFilesystems option to clamav-base.postinst.in
  - Add ClamukoScannerCount option to clamav-base.postinst.in
  - Add BytecodeSecurity opiton to clamav-base.postinst.in
  - Add DetectionStatsHostID option to clamav-freshclam.postinst.in
  - Add Bytecode option to clamav-freshclam.postinst.in
  - Add MilterSocketGroup option to clamav-milter.postinst.in
  - Add MilterSocketMode option to clamav-milter.postinst.in
  - Add ReportHostname option to clamav-milter.postinst.in
  - Bump libclamav SO version to 6.1.0 in libclamav6.install
  - Drop clamdmon from clamav.examples (no longer shipped by upstream)
  - Drop libclamav.a from libclamav-dev.install (not built by upstream)
  - Update SO version for lintian override for libclamav6
  - Add new Bytecode Testing Tool, usr/bin/clambc, to clamav.install
  - Add build-depends on python and python-setuptools for new test suite
  - Update debian/copyright for the embedded copy of llvm (using the system
    llvm is not currently feasible)

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
; RUN: llc < %s -relocation-model=static -realign-stack=1 -mcpu=yonah | FileCheck %s
 
2
 
 
3
; The double argument is at 4(esp) which is 16-byte aligned, allowing us to
 
4
; fold the load into the andpd.
 
5
 
 
6
target datalayout = "e-p:32:32:32-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:32:64-f32:32:32-f64:32:64-v64:64:64-v128:128:128-a0:0:64-f80:128:128"
 
7
target triple = "i686-apple-darwin8"
 
8
@G = external global double
 
9
 
 
10
define void @test({ double, double }* byval  %z, double* %P) {
 
11
entry:
 
12
        %tmp = getelementptr { double, double }* %z, i32 0, i32 0               ; <double*> [#uses=1]
 
13
        %tmp1 = load double* %tmp, align 8              ; <double> [#uses=1]
 
14
        %tmp2 = tail call double @fabs( double %tmp1 )          ; <double> [#uses=1]
 
15
    ; CHECK: andpd{{.*}}4(%esp), %xmm
 
16
        %tmp3 = load double* @G, align 16               ; <double> [#uses=1]
 
17
        %tmp4 = tail call double @fabs( double %tmp3 )          ; <double> [#uses=1]
 
18
        %tmp6 = fadd double %tmp4, %tmp2                ; <double> [#uses=1]
 
19
        store double %tmp6, double* %P, align 8
 
20
        ret void
 
21
}
 
22
 
 
23
define void @test2() alignstack(16) {
 
24
entry:
 
25
    ; CHECK: andl{{.*}}$-16, %esp
 
26
    ret void
 
27
}
 
28
 
 
29
; Use a call to force a spill.
 
30
define <2 x double> @test3(<2 x double> %x, <2 x double> %y) alignstack(32) {
 
31
entry:
 
32
    ; CHECK: andl{{.*}}$-32, %esp
 
33
    call void @test2()
 
34
    %A = mul <2 x double> %x, %y
 
35
    ret <2 x double> %A
 
36
}
 
37
 
 
38
declare double @fabs(double)
 
39