Server IP : 2a02:4780:11:1359:0:1d43:a566:2 / Your IP : 216.73.216.161 Web Server : LiteSpeed System : Linux in-mum-web1259.main-hosting.eu 4.18.0-553.37.1.lve.el8.x86_64 #1 SMP Mon Feb 10 22:45:17 UTC 2025 x86_64 User : u490972518 ( 490972518) PHP Version : 5.6.40 Disable Function : system, exec, shell_exec, passthru, mysql_list_dbs, ini_alter, dl, symlink, link, chgrp, leak, popen, apache_child_terminate, virtual, mb_send_mail MySQL : ON | cURL : ON | WGET : ON | Perl : OFF | Python : OFF Directory (0755) : /home/../opt/golang/1.19.4/test/ |
[ Home ] | [ C0mmand ] | [ Upload File ] |
---|
// +build amd64 // errorcheck -0 -d=ssa/likelyadjust/debug=1,ssa/insert_resched_checks/off // rescheduling check insertion is turned off because the inserted conditional branches perturb the errorcheck // Copyright 2016 The Go Authors. All rights reserved. // Use of this source code is governed by a BSD-style // license that can be found in the LICENSE file. // Test that branches have some prediction properties. package foo func f(x, y, z int) int { a := 0 for i := 0; i < x; i++ { // ERROR "Branch prediction rule stay in loop" for j := 0; j < y; j++ { // ERROR "Branch prediction rule stay in loop" a += j } for k := 0; k < z; k++ { // ERROR "Branch prediction rule stay in loop" a -= x + y + z } } return a } func g(x, y, z int) int { a := 0 if y == 0 { // ERROR "Branch prediction rule default < call" y = g(y, z, x) } else { y++ } if y == x { // ERROR "Branch prediction rule default < call" y = g(y, z, x) } else { } if y == 2 { // ERROR "Branch prediction rule default < call" z++ } else { y = g(z, x, y) } if y+z == 3 { // ERROR "Branch prediction rule call < exit" println("ha ha") } else { panic("help help help") } if x != 0 { // ERROR "Branch prediction rule default < ret" for i := 0; i < x; i++ { // ERROR "Branch prediction rule stay in loop" if x == 4 { // ERROR "Branch prediction rule stay in loop" return a } for j := 0; j < y; j++ { // ERROR "Branch prediction rule stay in loop" for k := 0; k < z; k++ { // ERROR "Branch prediction rule stay in loop" a -= j * i } a += j } } } return a } func h(x, y, z int) int { a := 0 for i := 0; i < x; i++ { // ERROR "Branch prediction rule stay in loop" for j := 0; j < y; j++ { // ERROR "Branch prediction rule stay in loop" a += j if i == j { // ERROR "Branch prediction rule stay in loop" break } a *= j } for k := 0; k < z; k++ { // ERROR "Branch prediction rule stay in loop" a -= k if i == k { continue } a *= k } } if a > 0 { // ERROR "Branch prediction rule default < call" a = g(x, y, z) } else { a = -a } return a }