INFO: No output directory specified (--dir) INFO: Using directory: "template_simple_20250514_151825" INFO: Regenerating c-file: template_simple.c DEBUG: CMD: /u/data/pkwi/McXtrace/mcxtrace/3.x-dev/bin/mcxtrace -t -o ./template_simple.c template_simple.instr CFLAGS= ----------------------------------------------------------- Generating single GPU kernel or single CPU section layout: ----------------------------------------------------------- Generating GPU/CPU -DFUNNEL layout: ----------------------------------------------------------- DEBUG: CMD: /u/data/pkwi/McXtrace/mcxtrace/3.x-dev/bin/mcxtrace finished INFO: Recompiling: ./template_simple.out DEBUG: CMD: nvc -o ./template_simple.out ./template_simple.c -lm -Wl,-O2 -Wl,--sort-common -Wl,--as-needed -Wl,-z,relro -Wl,-z,now -Wl,--disable-new-dtags -Wl,--gc-sections -Wl,--allow-shlib-undefined -Wl,-rpath,/u/data/pkwi/McXtrace/mcxtrace/3.x-dev/miniconda3/lib -Wl,-rpath-link,/u/data/pkwi/McXtrace/mcxtrace/3.x-dev/miniconda3/lib -L/u/data/pkwi/McXtrace/mcxtrace/3.x-dev/miniconda3/lib -mtune=haswell -fPIC -O2 -isystem /u/data/pkwi/McXtrace/mcxtrace/3.x-dev/miniconda3/include -fast -Minfo=accel -acc=gpu -gpu=mem:managed -DOPENACC "./template_simple.c", line 85: warning: Routine "mcgenstate" will be treated as sequential because its "routine" directive doesn't specify a level of parallelism [no_routine_type] _class_particle mcgenstate(void); ^ Remark: individual warnings can be suppressed with "--diag_suppress " "./template_simple.c", line 87: warning: Routine "mcsetstate" will be treated as sequential because its "routine" directive doesn't specify a level of parallelism [no_routine_type] _class_particle mcsetstate(double x, double y, double z, double kx, double ky, double kz, ^ "./template_simple.c", line 90: warning: Routine "mcgetstate" will be treated as sequential because its "routine" directive doesn't specify a level of parallelism [no_routine_type] _class_particle mcgetstate(_class_particle mcphoton, double *x, double *y, double *z, double *kx, double *ky, double *kz, ^ "./template_simple.c", line 105: warning: Routine "particle_getvar" will be treated as sequential because its "routine" directive doesn't specify a level of parallelism [no_routine_type] double particle_getvar(_class_particle *p, char *name, int *suc); ^ "./template_simple.c", line 109: warning: Routine "str_comp" will be treated as sequential because its "routine" directive doesn't specify a level of parallelism [no_routine_type] int str_comp(char *str1, char *str2); ^ "./template_simple.c", line 138: warning: Routine "particle_getvar_void" will be treated as sequential because its "routine" directive doesn't specify a level of parallelism [no_routine_type] void* particle_getvar_void(_class_particle *p, char *name, int *suc); ^ "./template_simple.c", line 109: warning: Routine "str_comp" will be treated as sequential because its "routine" directive doesn't specify a level of parallelism [no_routine_type] int str_comp(char *str1, char *str2); ^ "./template_simple.c", line 168: warning: Routine "particle_setvar_void" will be treated as sequential because its "routine" directive doesn't specify a level of parallelism [no_routine_type] int particle_setvar_void(_class_particle *, char *, void*); ^ "./template_simple.c", line 191: warning: Routine "particle_setvar_void_array" will be treated as sequential because its "routine" directive doesn't specify a level of parallelism [no_routine_type] int particle_setvar_void_array(_class_particle *, char *, void*, int); ^ "./template_simple.c", line 202: warning: Routine "particle_restore" will be treated as sequential because its "routine" directive doesn't specify a level of parallelism [no_routine_type] void particle_restore(_class_particle *p, _class_particle *p0); ^ "./template_simple.c", line 213: warning: Routine "particle_getuservar_byid" will be treated as sequential because its "routine" directive doesn't specify a level of parallelism [no_routine_type] double particle_getuservar_byid(_class_particle *p, int id, int *suc){ ^ "./template_simple.c", line 223: warning: Routine "particle_uservar_init" will be treated as sequential because its "routine" directive doesn't specify a level of parallelism [no_routine_type] void particle_uservar_init(_class_particle *p){ ^ "./template_simple.c", line 295: warning: Routine "noprintf" will be treated as sequential because its "routine" directive doesn't specify a level of parallelism [no_routine_type] int noprintf(); ^ "./template_simple.c", line 297: warning: Routine "str_len" will be treated as sequential because its "routine" directive doesn't specify a level of parallelism [no_routine_type] size_t str_len(const char *s); ^ "./template_simple.c", line 647: warning: Routine "mcget_ncount" will be treated as sequential because its "routine" directive doesn't specify a level of parallelism [no_routine_type] unsigned long long int mcget_ncount(void); /* wrapper to set mcncount */ ^ "./template_simple.c", line 868: warning: Routine "_randnorm2" will be treated as sequential because its "routine" directive doesn't specify a level of parallelism [no_routine_type] double _randnorm2(randstate_t* state); ^ "./template_simple.c", line 885: warning: Routine "kiss_srandom" will be treated as sequential because its "routine" directive doesn't specify a level of parallelism [no_routine_type] uint64_t *kiss_srandom(uint64_t state[7], uint64_t seed); ^ "./template_simple.c", line 887: warning: Routine "kiss_random" will be treated as sequential because its "routine" directive doesn't specify a level of parallelism [no_routine_type] uint64_t kiss_random(uint64_t state[7]); ^ "./template_simple.c", line 895: warning: Routine "_rand01" will be treated as sequential because its "routine" directive doesn't specify a level of parallelism [no_routine_type] double _rand01(randstate_t* state); ^ "./template_simple.c", line 897: warning: Routine "_randpm1" will be treated as sequential because its "routine" directive doesn't specify a level of parallelism [no_routine_type] double _randpm1(randstate_t* state); ^ "./template_simple.c", line 899: warning: Routine "_rand0max" will be treated as sequential because its "routine" directive doesn't specify a level of parallelism [no_routine_type] double _rand0max(double max, randstate_t* state); ^ "./template_simple.c", line 901: warning: Routine "_randminmax" will be treated as sequential because its "routine" directive doesn't specify a level of parallelism [no_routine_type] double _randminmax(double min, double max, randstate_t* state); ^ "./template_simple.c", line 903: warning: Routine "_randtriangle" will be treated as sequential because its "routine" directive doesn't specify a level of parallelism [no_routine_type] double _randtriangle(randstate_t* state); ^ "./template_simple.c", line 999: warning: Routine "coords_set" will be treated as sequential because its "routine" directive doesn't specify a level of parallelism [no_routine_type] Coords coords_set(MCNUM x, MCNUM y, MCNUM z); ^ "./template_simple.c", line 1001: warning: Routine "coords_get" will be treated as sequential because its "routine" directive doesn't specify a level of parallelism [no_routine_type] Coords coords_get(Coords a, MCNUM *x, MCNUM *y, MCNUM *z); ^ "./template_simple.c", line 1003: warning: Routine "coords_add" will be treated as sequential because its "routine" directive doesn't specify a level of parallelism [no_routine_type] Coords coords_add(Coords a, Coords b); ^ "./template_simple.c", line 1005: warning: Routine "coords_sub" will be treated as sequential because its "routine" directive doesn't specify a level of parallelism [no_routine_type] Coords coords_sub(Coords a, Coords b); ^ "./template_simple.c", line 1007: warning: Routine "coords_neg" will be treated as sequential because its "routine" directive doesn't specify a level of parallelism [no_routine_type] Coords coords_neg(Coords a); ^ "./template_simple.c", line 1009: warning: Routine "coords_scale" will be treated as sequential because its "routine" directive doesn't specify a level of parallelism [no_routine_type] Coords coords_scale(Coords b, double scale); ^ "./template_simple.c", line 1011: warning: Routine "coords_sp" will be treated as sequential because its "routine" directive doesn't specify a level of parallelism [no_routine_type] double coords_sp(Coords a, Coords b); ^ "./template_simple.c", line 1013: warning: Routine "coords_xp" will be treated as sequential because its "routine" directive doesn't specify a level of parallelism [no_routine_type] Coords coords_xp(Coords b, Coords c); ^ "./template_simple.c", line 1015: warning: Routine "coords_len" will be treated as sequential because its "routine" directive doesn't specify a level of parallelism [no_routine_type] double coords_len(Coords a); ^ "./template_simple.c", line 4561: warning: variable "num" was declared but never referenced [declared_but_not_referenced] int num = 3; ^ "./template_simple.c", line 6262: warning: variable "status" was set but never used [set_but_not_used] int status; ^ "./template_simple.c", line 6713: warning: variable "ret" was declared but never referenced [declared_but_not_referenced] int ret=1,stat=0,plane_stat=0; ^ "./template_simple.c", line 6886: warning: variable "D" was declared but never referenced [declared_but_not_referenced] double A,B,C,D,k; ^ "./template_simple.c", line 7099: warning: variable "tc2" was set but never used [set_but_not_used] Coords tc1, tc2; ^ "./template_simple.c", line 7087: warning: variable "current_setpos_index" was declared but never referenced [declared_but_not_referenced] int current_setpos_index = 1; ^ "./template_simple.c", line 7243: warning: Routine "class_Progress_bar_trace" will be treated as sequential because its "routine" directive doesn't specify a level of parallelism [no_routine_type] void class_Progress_bar_trace(_class_Progress_bar *_comp ^ "./template_simple.c", line 7339: warning: Routine "raytrace" will be treated as sequential because its "routine" directive doesn't specify a level of parallelism [no_routine_type] int raytrace(_class_particle* _particle) { /* single event propagation, called by mccode_main for template_simple:TRACE */ ^ "./template_simple.c", line 7961: warning: variable "t" was declared but never referenced [declared_but_not_referenced] time_t t; ^ "./template_simple.c", line 7962: warning: variable "ct" was set but never used [set_but_not_used] clock_t ct; ^ "./template_simple.c", line 1498: warning: variable "mcstartdate" was set but never used [set_but_not_used] static long mcstartdate = 0; /* start simulation time */ ^ "./template_simple.c", line 2918: warning: function "strcpy_valid" was declared but never referenced [declared_but_not_referenced] static char *strcpy_valid(char *valid, char *original) ^ mcgenstate: 98, Generating acc routine seq Generating NVIDIA GPU code particle_getvar: 112, Generating acc routine seq Generating NVIDIA GPU code particle_getvar_void: 145, Generating acc routine seq Generating NVIDIA GPU code particle_setvar_void: 170, Generating acc routine seq Generating NVIDIA GPU code particle_setvar_void_array: 193, Generating acc routine seq Generating NVIDIA GPU code particle_restore: 204, Generating acc routine seq Generating NVIDIA GPU code particle_getuservar_byid: 213, Generating acc routine seq Generating NVIDIA GPU code particle_uservar_init: 223, Generating acc routine seq Generating NVIDIA GPU code noprintf: 1546, Generating acc routine seq Generating NVIDIA GPU code str_comp: 1550, Generating acc routine seq Generating NVIDIA GPU code str_len: 1559, Generating acc routine seq Generating NVIDIA GPU code mcget_ncount: 4182, Generating acc routine seq Generating NVIDIA GPU code coords_set: 4613, Generating acc routine seq Generating NVIDIA GPU code coords_get: 4624, Generating acc routine seq Generating NVIDIA GPU code coords_add: 4633, Generating acc routine seq Generating NVIDIA GPU code coords_sub: 4645, Generating acc routine seq Generating NVIDIA GPU code coords_neg: 4657, Generating acc routine seq Generating NVIDIA GPU code coords_scale: 4667, Generating acc routine seq Generating NVIDIA GPU code coords_sp: 4677, Generating acc routine seq Generating NVIDIA GPU code coords_xp: 4685, Generating acc routine seq Generating NVIDIA GPU code coords_len: 4695, Generating acc routine seq Generating NVIDIA GPU code coords_print: 4717, Generating acc routine seq Generating NVIDIA GPU code coords_norm: 4724, Generating acc routine seq Generating NVIDIA GPU code rot_set_rotation: 4770, Generating acc routine seq Generating NVIDIA GPU code rot_test_identity: 4805, Generating acc routine seq Generating NVIDIA GPU code rot_mul: 4816, Generating acc routine seq Generating NVIDIA GPU code rot_copy: 4833, Generating acc routine seq Generating NVIDIA GPU code rot_transpose: 4844, Generating acc routine seq Generating NVIDIA GPU code rot_apply: 4860, Generating acc routine seq Generating NVIDIA GPU code vec_prod_func: 4889, Generating acc routine seq Generating NVIDIA GPU code scalar_prod: 4900, Generating acc routine seq Generating NVIDIA GPU code norm_func: 4904, Generating acc routine seq Generating NVIDIA GPU code mccoordschange: 5081, Generating acc routine seq Generating NVIDIA GPU code mccoordschange_polarisation: 5112, Generating acc routine seq Generating NVIDIA GPU code normal_vec: 5129, Generating acc routine seq Generating NVIDIA GPU code solve_2nd_order: 5228, Generating acc routine seq Generating NVIDIA GPU code _randvec_target_circle: 5312, Generating acc routine seq Generating NVIDIA GPU code _randvec_target_rect_angular: 5378, Generating acc routine seq Generating NVIDIA GPU code _randvec_target_rect_real: 5455, Generating acc routine seq Generating NVIDIA GPU code kiss_srandom: 5727, Generating acc routine seq Generating NVIDIA GPU code kiss_random: 5739, Generating acc routine seq Generating NVIDIA GPU code _hash: 5771, Generating acc routine seq Generating NVIDIA GPU code _randnorm2: 5812, Generating acc routine seq Generating NVIDIA GPU code _randtriangle: 5823, Generating acc routine seq Generating NVIDIA GPU code _rand01: 5828, Generating acc routine seq Generating NVIDIA GPU code _randpm1: 5836, Generating acc routine seq Generating NVIDIA GPU code _rand0max: 5844, Generating acc routine seq Generating NVIDIA GPU code _randminmax: 5851, Generating acc routine seq Generating NVIDIA GPU code mcsetstate: 6514, Generating acc routine seq Generating NVIDIA GPU code mcgetstate: 6547, Generating acc routine seq Generating NVIDIA GPU code inside_rectangle: 6608, Generating acc routine seq Generating NVIDIA GPU code box_intersect: 6624, Generating acc routine seq Generating NVIDIA GPU code cylinder_intersect: 6710, Generating acc routine seq Generating NVIDIA GPU code sphere_intersect: 6778, Generating acc routine seq Generating NVIDIA GPU code init: 7203, Generating update device(_origin_var,_instrument_var) class_Progress_bar_trace: 7244, Generating acc routine seq Generating NVIDIA GPU code raytrace: 7339, Generating acc routine seq Generating NVIDIA GPU code raytrace_all: 7415, Generating implicit firstprivate(gpu_innerloop) Generating NVIDIA GPU code 7351, #pragma acc loop seq 7429, #pragma acc loop gang(numgangs), vector(vecsize) /* blockIdx.x threadIdx.x */ 7415, Local memory used for .inl_.inl_mcphoton_0_6230,.inl_particle_6214,particleN,.inl__particle_save_6238,.inl_.inl_.X1858_2970_6248,.inl_.inl_c_2978_6256,.inl_.inl_.inl_c_1912_2993_6269,.inl_.inl_.inl_.inl_b_1897_1918__6274,.inl_.inl_.inl_.inl_.X1874_1896__6273,.inl_.inl_.inl_b_1908_2992_6268,.inl_.inl_.inl_c_1904_2986_6262,.inl_.inl_.inl_.inl_.X1874_1896__6284,.inl_.inl_.inl_.X1874_1902_2983_6260,.inl_.inl_.inl_b_1903_2984_6261,.inl_.inl_.X1908_13_6231,.inl_.inl_.inl_b_1919_3003_6279,.inl_.inl_c_2967_6247,.inl_.inl_.inl_.inl_b_1897_1929__6285,.inl_.inl_.inl_.X1858_1907_2987_6263,.inl_.inl_a_2962_6245,.inl_.inl_.X1856_2966_6246,.inl_.inl_.X1857_2975_6252,.inl_.inl_b_2976_6255,.inl_.X1720_6232,.inl_.inl_.inl_c_1923_3004_6280 7429, Generating implicit firstprivate(seed,_particle) 7351, Complex loop carried dependence of _particle->flag_nocoordschange,_particle->x,_particle->y,_particle->z,_particle->,_particle+->,->,_particle->kz,_particle->kx,_particle->ky,_particle->Ez,_particle->Ex,_particle->Ey,_particle->_absorbed,_particle->_index prevents parallelization Scalar last value needed after loop for .inl__particle_save_6238 at line 7379 Complex loop carried dependence of _particle->phi,_particle->t,_particle->p,_particle->_restore,_particle->_scattered prevents parallelization finally: 7684, Generating update self(_origin_var,_instrument_var) mcenabletrace: 5971, Generating update device(mcdotrace) DEBUG: CMD: nvc finished INFO: ===