1# Copyright 2010-2019 Free Software Foundation, Inc. 2 3# This program is free software; you can redistribute it and/or modify 4# it under the terms of the GNU General Public License as published by 5# the Free Software Foundation; either version 3 of the License, or 6# (at your option) any later version. 7# 8# This program is distributed in the hope that it will be useful, 9# but WITHOUT ANY WARRANTY; without even the implied warranty of 10# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 11# GNU General Public License for more details. 12# 13# You should have received a copy of the GNU General Public License 14# along with this program. If not, see <http://www.gnu.org/licenses/>. */ 15# 16# Contributed by Ken Werner <ken.werner@de.ibm.com>. 17# 18# Tests component access of OpenCL vectors. 19 20load_lib opencl.exp 21 22if { [skip_opencl_tests] } { 23 return 0 24} 25 26set testfile "vec_comps" 27set clprogram [remote_download target ${srcdir}/${subdir}/${testfile}.cl] 28 29# Compile the generic OpenCL host app 30if { [gdb_compile_opencl_hostapp "${clprogram}" "${testfile}" "" ] != "" } { 31 untested "failed to compile" 32 return -1 33} 34 35# Load the OpenCL app 36clean_restart ${testfile} 37 38# Set breakpoint at the OpenCL kernel 39gdb_test "tbreak testkernel" \ 40 "" \ 41 "Set pending breakpoint" \ 42 ".*Function \"testkernel\" not defined.*Make breakpoint pending.*y or \\\[n\\\]. $" \ 43 "y" 44 45gdb_run_cmd 46gdb_test "" ".*reakpoint.*1.*testkernel.*" "run" 47 48# Continue to the marker 49gdb_breakpoint [gdb_get_line_number "marker" "${clprogram}"] 50gdb_continue_to_breakpoint "marker" 51 52# Check if the language was switched to opencl 53gdb_test "show language" "The current source language is \"auto; currently opencl\"\." 54 55# Retrieve some information about the OpenCL version and the availability of extensions 56set opencl_version [get_integer_valueof "opencl_version" 0] 57set have_cl_khr_fp64 [get_integer_valueof "have_cl_khr_fp64" 0] 58set have_cl_khr_fp16 [get_integer_valueof "have_cl_khr_fp16" 0] 59 60# Sanity checks 61proc check_basic { name type size } { 62 gdb_test "ptype ${name}" "type = ${type}16" 63 gdb_test "p sizeof(${name})" " = [expr ${size} * 16]" 64 gdb_test "print/d ${name}" " = \\{0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15\\}" 65} 66 67proc check_type { name type alttype } { 68 gdb_test "whatis ${name}.lo" "type = ${type}8" 69 gdb_test "whatis ${name}.hi" "type = ${type}8" 70 gdb_test "whatis ${name}.even" "type = ${type}8" 71 gdb_test "whatis ${name}.odd" "type = ${type}8" 72 gdb_test "whatis ${name}.low" "Invalid OpenCL vector component accessor low" 73 gdb_test "whatis ${name}.high" "Invalid OpenCL vector component accessor high" 74 75 gdb_test "whatis ${name}.hi.even" "type = ${type}4" 76 gdb_test "whatis ${name}.odd.odd.lo" "type = ${type}2" 77 gdb_test "whatis ${name}.even.hi.lo.odd" "type = ${alttype}|${type}" 78 79 gdb_test "whatis ${name}.x" "type = ${alttype}|${type}" 80 gdb_test "whatis ${name}.y" "type = ${alttype}|${type}" 81 gdb_test "whatis ${name}.z" "type = ${alttype}|${type}" 82 gdb_test "whatis ${name}.w" "type = ${alttype}|${type}" 83 gdb_test "whatis ${name}.v" "Invalid OpenCL vector component accessor v" 84 85 gdb_test "whatis ${name}.xy" "type = ${type}2" 86 gdb_test "whatis ${name}.xx" "type = ${type}2" 87 gdb_test "whatis ${name}.wy" "type = ${type}2" 88 gdb_test "whatis ${name}.zv" "Invalid OpenCL vector component accessor zv" 89 90 gdb_test "whatis ${name}.xyz" "type = ${type}3" 91 gdb_test "whatis ${name}.yxy" "type = ${type}3" 92 gdb_test "whatis ${name}.yzx" "type = ${type}3" 93 gdb_test "whatis ${name}.yzv" "Invalid OpenCL vector component accessor yzv" 94 95 gdb_test "whatis ${name}.xywz" "type = ${type}4" 96 gdb_test "whatis ${name}.zzyy" "type = ${type}4" 97 gdb_test "whatis ${name}.wwww" "type = ${type}4" 98 gdb_test "whatis ${name}.yxwv" "Invalid OpenCL vector component accessor yxwv" 99 gdb_test "whatis ${name}.zyxwv" "Invalid OpenCL vector component accessor zyxwv" 100 101 gdb_test "whatis ${name}.xy.x" "type = ${alttype}|${type}" 102 gdb_test "whatis ${name}.wzyx.yy" "type = ${type}2" 103 gdb_test "whatis ${name}.wzyx.yx.x" "type = ${alttype}|${type}" 104 gdb_test "whatis ${name}.xyzw.w" "type = ${alttype}|${type}" 105 gdb_test "whatis ${name}.xy.z" "Invalid OpenCL vector component accessor z" 106 107 gdb_test "whatis ${name}.s0" "type = ${alttype}|${type}" 108 gdb_test "whatis ${name}.s9" "type = ${alttype}|${type}" 109 gdb_test "whatis ${name}.sa" "type = ${alttype}|${type}" 110 gdb_test "whatis ${name}.sf" "type = ${alttype}|${type}" 111 gdb_test "whatis ${name}.sF" "type = ${alttype}|${type}" 112 gdb_test "whatis ${name}.sg" "Invalid OpenCL vector component accessor sg" 113 gdb_test "whatis ${name}.sG" "Invalid OpenCL vector component accessor sG" 114 gdb_test "whatis ${name}.Sg" "Invalid OpenCL vector component accessor Sg" 115 gdb_test "whatis ${name}.SG" "Invalid OpenCL vector component accessor SG" 116 117 gdb_test "whatis ${name}.s01" "type = ${type}2" 118 gdb_test "whatis ${name}.s00" "type = ${type}2" 119 gdb_test "whatis ${name}.sF0" "type = ${type}2" 120 gdb_test "whatis ${name}.S42" "type = ${type}2" 121 122 gdb_test "whatis ${name}.s567" "type = ${type}3" 123 gdb_test "whatis ${name}.S333" "type = ${type}3" 124 gdb_test "whatis ${name}.Sf0A" "type = ${type}3" 125 gdb_test "whatis ${name}.SB1D" "type = ${type}3" 126 gdb_test "whatis ${name}.s01g" "Invalid OpenCL vector component accessor s01g" 127 128 gdb_test "whatis ${name}.s9876" "type = ${type}4" 129 gdb_test "whatis ${name}.sFFFF" "type = ${type}4" 130 gdb_test "whatis ${name}.sCafe" "type = ${type}4" 131 gdb_test "whatis ${name}.Sf001" "type = ${type}4" 132 gdb_test "whatis ${name}.s1fg2" "Invalid OpenCL vector component accessor s1fg2" 133 gdb_test "whatis ${name}.s012345" "Invalid OpenCL vector component accessor s012345" 134 135 gdb_test "whatis ${name}.s00000000" "type = ${type}8" 136 gdb_test "whatis ${name}.s00224466" "type = ${type}8" 137 gdb_test "whatis ${name}.sDEADBEEF" "type = ${type}8" 138 gdb_test "whatis ${name}.Sa628c193" "type = ${type}8" 139 140 gdb_test "whatis ${name}.s876543210" "Invalid OpenCL vector component accessor s876543210" 141 gdb_test "whatis ${name}.s0123456789abcde" "Invalid OpenCL vector component accessor s0123456789abcde" 142 143 gdb_test "whatis ${name}.s0123456789aBcDeF" "type = ${type}16" 144 gdb_test "whatis ${name}.s0022446688AACCFF" "type = ${type}16" 145 gdb_test "whatis ${name}.S0123456776543210" "type = ${type}16" 146 gdb_test "whatis ${name}.sFEDCBA9876543210" "type = ${type}16" 147 148 gdb_test "whatis ${name}.sfedcba98.S0246" "type = ${type}4" 149 gdb_test "whatis ${name}.sfedcba98.S0246.s13" "type = ${type}2" 150 gdb_test "whatis ${name}.sfedcba98.S0246.s13.s0" "type = ${alttype}|${type}" 151 gdb_test "whatis ${name}.s0123456789abcdef.s22" "type = ${type}2" 152 153 gdb_test "whatis ${name}.hi.s7654.wx" "type = ${type}2" 154 gdb_test "whatis ${name}.s0123456789abcdef.even.lo" "type = ${type}4" 155 gdb_test "whatis ${name}.odd.xyzw.s23" "type = ${type}2" 156 gdb_test "whatis ${name}.xyzw.hi.odd" "type = ${alttype}|${type}" 157 158 gdb_test "ptype ${name}.lo" "type = ${type}8" 159 gdb_test "ptype ${name}.hi" "type = ${type}8" 160 gdb_test "ptype ${name}.even" "type = ${type}8" 161 gdb_test "ptype ${name}.odd" "type = ${type}8" 162 163 gdb_test "ptype ${name}.hi.even" "type = ${type}4" 164 gdb_test "ptype ${name}.odd.odd.lo" "type = ${type}2" 165 gdb_test "ptype ${name}.even.hi.lo.odd" "type = ${alttype}|${type}" 166 167 gdb_test "ptype ${name}.x" "type = ${alttype}|${type}" 168 gdb_test "ptype ${name}.y" "type = ${alttype}|${type}" 169 gdb_test "ptype ${name}.z" "type = ${alttype}|${type}" 170 gdb_test "ptype ${name}.w" "type = ${alttype}|${type}" 171 172 gdb_test "ptype ${name}.xy" "type = ${type}2" 173 gdb_test "ptype ${name}.xx" "type = ${type}2" 174 gdb_test "ptype ${name}.wy" "type = ${type}2" 175 176 gdb_test "ptype ${name}.xyz" "type = ${type}3" 177 gdb_test "ptype ${name}.yxy" "type = ${type}3" 178 gdb_test "ptype ${name}.yzx" "type = ${type}3" 179 180 gdb_test "ptype ${name}.xywz" "type = ${type}4" 181 gdb_test "ptype ${name}.zzyy" "type = ${type}4" 182 gdb_test "ptype ${name}.wwww" "type = ${type}4" 183 184 gdb_test "ptype ${name}.xy.x" "type = ${alttype}|${type}" 185 gdb_test "ptype ${name}.wzyx.yy" "type = ${type}2" 186 gdb_test "ptype ${name}.wzyx.yx.x" "type = ${alttype}|${type}" 187 gdb_test "ptype ${name}.xyzw.w" "type = ${alttype}|${type}" 188 189 gdb_test "ptype ${name}.s0" "type = ${alttype}|${type}" 190 gdb_test "ptype ${name}.s9" "type = ${alttype}|${type}" 191 gdb_test "ptype ${name}.sa" "type = ${alttype}|${type}" 192 gdb_test "ptype ${name}.sf" "type = ${alttype}|${type}" 193 gdb_test "ptype ${name}.sF" "type = ${alttype}|${type}" 194 195 gdb_test "ptype ${name}.s01" "type = ${type}2" 196 gdb_test "ptype ${name}.s00" "type = ${type}2" 197 gdb_test "ptype ${name}.sF0" "type = ${type}2" 198 gdb_test "ptype ${name}.S42" "type = ${type}2" 199 200 gdb_test "ptype ${name}.s567" "type = ${type}3" 201 gdb_test "ptype ${name}.S333" "type = ${type}3" 202 gdb_test "ptype ${name}.Sf0A" "type = ${type}3" 203 gdb_test "ptype ${name}.SB1D" "type = ${type}3" 204 205 gdb_test "ptype ${name}.s9876" "type = ${type}4" 206 gdb_test "ptype ${name}.sFFFF" "type = ${type}4" 207 gdb_test "ptype ${name}.sCafe" "type = ${type}4" 208 gdb_test "ptype ${name}.Sf001" "type = ${type}4" 209 210 gdb_test "ptype ${name}.s00000000" "type = ${type}8" 211 gdb_test "ptype ${name}.s00224466" "type = ${type}8" 212 gdb_test "ptype ${name}.sDEADBEEF" "type = ${type}8" 213 gdb_test "ptype ${name}.Sa628c193" "type = ${type}8" 214 215 gdb_test "ptype ${name}.s0123456789aBcDeF" "type = ${type}16" 216 gdb_test "ptype ${name}.s0022446688AACCFF" "type = ${type}16" 217 gdb_test "ptype ${name}.S0123456776543210" "type = ${type}16" 218 gdb_test "ptype ${name}.sFEDCBA9876543210" "type = ${type}16" 219 220 gdb_test "ptype ${name}.sfedcba98.S0246" "type = ${type}4" 221 gdb_test "ptype ${name}.sfedcba98.S0246.s13" "type = ${type}2" 222 gdb_test "ptype ${name}.sfedcba98.S0246.s13.s0" "type = ${alttype}|${type}" 223 gdb_test "ptype ${name}.s0123456789abcdef.s22" "type = ${type}2" 224 225 gdb_test "ptype ${name}.hi.s7654.wx" "type = ${type}2" 226 gdb_test "ptype ${name}.s0123456789abcdef.even.lo" "type = ${type}4" 227 gdb_test "ptype ${name}.odd.xyzw.s23" "type = ${type}2" 228 gdb_test "ptype ${name}.xyzw.hi.odd" "type = ${alttype}|${type}" 229} 230 231proc check_sizeof { name size } { 232 gdb_test "print sizeof (${name}.lo)" " = [expr $size * 8]" 233 gdb_test "print sizeof (${name}.hi)" " = [expr $size * 8]" 234 gdb_test "print sizeof (${name}.even)" " = [expr $size * 8]" 235 gdb_test "print sizeof (${name}.odd)" " = [expr $size * 8]" 236 237 gdb_test "print sizeof (${name}.hi.even)" " = [expr $size * 4]" 238 gdb_test "print sizeof (${name}.odd.odd.lo)" " = [expr $size * 2]" 239 gdb_test "print sizeof (${name}.even.hi.lo.odd)" " = $size" 240 241 gdb_test "print sizeof (${name}.x)" " = $size" 242 gdb_test "print sizeof (${name}.xy)" " = [expr $size * 2]" 243 gdb_test "print sizeof (${name}.xyz)" " = [expr $size * 4]" 244 gdb_test "print sizeof (${name}.xyzw)" " = [expr $size * 4]" 245 246 gdb_test "print sizeof (${name}.xy.x)" " = $size" 247 gdb_test "print sizeof (${name}.wzyx.yy)" " = [expr $size * 2]" 248 gdb_test "print sizeof (${name}.wzyx.yx.x)" " = $size" 249 gdb_test "print sizeof (${name}.xyzw.w)" " = $size" 250 251 gdb_test "print sizeof (${name}.s0)" " = $size" 252 gdb_test "print sizeof (${name}.s01)" " = [expr $size * 2]" 253 gdb_test "print sizeof (${name}.s012)" " = [expr $size * 4]" 254 gdb_test "print sizeof (${name}.s0123)" " = [expr $size * 4]" 255 gdb_test "print sizeof (${name}.s01234567)" " = [expr $size * 8]" 256 gdb_test "print sizeof (${name}.s0123456789abcdef)" " = [expr $size * 16]" 257 258 gdb_test "print sizeof (${name}.sfedcba98.S0246)" " = [expr $size * 4]" 259 gdb_test "print sizeof (${name}.sfedcba98.S0246.s13)" " = [expr $size * 2]" 260 gdb_test "print sizeof (${name}.sfedcba98.S0246.s13.s0)" " = $size" 261 gdb_test "print sizeof (${name}.s0123456789abcdef.s22)" " = [expr $size * 2]" 262 263 gdb_test "print sizeof (${name}.hi.s7654.wx)" " = [expr $size * 2]" 264 gdb_test "print sizeof (${name}.s0123456789abcdef.even.lo)" " = [expr $size * 4]" 265 gdb_test "print sizeof (${name}.odd.xyzw.s23)" " = [expr $size * 2]" 266 gdb_test "print sizeof (${name}.xyzw.hi.odd)" " = $size" 267} 268 269# OpenCL vector component access 270proc check_access { name } { 271 gdb_test "print/d ${name}.lo" " = \\{0, 1, 2, 3, 4, 5, 6, 7\\}" 272 gdb_test "print/d ${name}.hi" " = \\{8, 9, 10, 11, 12, 13, 14, 15\\}" 273 gdb_test "print/d ${name}.even" " = \\{0, 2, 4, 6, 8, 10, 12, 14\\}" 274 gdb_test "print/d ${name}.odd" " = \\{1, 3, 5, 7, 9, 11, 13, 15\\}" 275 276 gdb_test "print/d ${name}.hi.even" " = \\{8, 10, 12, 14\\}" 277 gdb_test "print/d ${name}.odd.odd.lo" " = \\{3, 7\\}" 278 gdb_test "print/d ${name}.even.hi.lo.odd" " = 10" 279 280 gdb_test "print/d ${name}.x" " = 0" 281 gdb_test "print/d ${name}.y" " = 1" 282 gdb_test "print/d ${name}.z" " = 2" 283 gdb_test "print/d ${name}.w" " = 3" 284 285 gdb_test "print/d ${name}.xy" " = \\{0, 1\\}" 286 gdb_test "print/d ${name}.xx" " = \\{0, 0\\}" 287 gdb_test "print/d ${name}.wy" " = \\{3, 1\\}" 288 289 gdb_test "print/d ${name}.xyz" " = \\{0, 1, 2\\}" 290 gdb_test "print/d ${name}.yxy" " = \\{1, 0, 1\\}" 291 gdb_test "print/d ${name}.yzx" " = \\{1, 2, 0\\}" 292 293 gdb_test "print/d ${name}.xywz" " = \\{0, 1, 3, 2\\}" 294 gdb_test "print/d ${name}.zzyy" " = \\{2, 2, 1, 1\\}" 295 gdb_test "print/d ${name}.wwww" " = \\{3, 3, 3, 3\\}" 296 297 gdb_test "print/d ${name}.xy.x" " = 0" 298 gdb_test "print/d ${name}.wzyx.yy" " = \\{2, 2\\}" 299 gdb_test "print/d ${name}.wzyx.yx.x" " = 2" 300 gdb_test "print/d ${name}.xyzw.w" " = 3" 301 302 for {set i 0} {$i < 16} {incr i} { 303 gdb_test "print/d ${name}.s[format "%x" $i]" " = $i" 304 gdb_test "print/d ${name}.S[format "%x" $i]" " = $i" 305 if {$i > 9} { 306 gdb_test "print/d ${name}.s[format "%X" $i]" " = $i" 307 gdb_test "print/d ${name}.S[format "%X" $i]" " = $i" 308 } 309 } 310 311 gdb_test "print/d ${name}.s01" " = \\{0, 1\\}" 312 gdb_test "print/d ${name}.s00" " = \\{0, 0\\}" 313 gdb_test "print/d ${name}.sF0" " = \\{15, 0\\}" 314 gdb_test "print/d ${name}.S42" " = \\{4, 2\\}" 315 316 gdb_test "print/d ${name}.s567" " = \\{5, 6, 7\\}" 317 gdb_test "print/d ${name}.S333" " = \\{3, 3, 3\\}" 318 gdb_test "print/d ${name}.Sf0A" " = \\{15, 0, 10\\}" 319 gdb_test "print/d ${name}.SB1D" " = \\{11, 1, 13\\}" 320 321 gdb_test "print/d ${name}.s9876" " = \\{9, 8, 7, 6\\}" 322 gdb_test "print/d ${name}.sFFFF" " = \\{15, 15, 15, 15\\}" 323 gdb_test "print/d ${name}.sCafe" " = \\{12, 10, 15, 14\\}" 324 gdb_test "print/d ${name}.Sf001" " = \\{15, 0, 0, 1\\}" 325 326 gdb_test "print/d ${name}.s00000000" " = \\{0, 0, 0, 0, 0, 0, 0, 0\\}" 327 gdb_test "print/d ${name}.s00224466" " = \\{0, 0, 2, 2, 4, 4, 6, 6\\}" 328 gdb_test "print/d ${name}.sDEADBEEF" " = \\{13, 14, 10, 13, 11, 14, 14, 15\\}" 329 gdb_test "print/d ${name}.Sa628c193" " = \\{10, 6, 2, 8, 12, 1, 9, 3\\}" 330 331 gdb_test "print/d ${name}.s0123456789aBcDeF" " = \\{0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15\\}" 332 gdb_test "print/d ${name}.s0022446688AACCEE" " = \\{0, 0, 2, 2, 4, 4, 6, 6, 8, 8, 10, 10, 12, 12, 14, 14\\}" 333 gdb_test "print/d ${name}.S0123456776543210" " = \\{0, 1, 2, 3, 4, 5, 6, 7, 7, 6, 5, 4, 3, 2, 1, 0\\}" 334 gdb_test "print/d ${name}.sFEDCBA9876543210" " = \\{15, 14, 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, 1, 0\\}" 335 336 gdb_test "print/d ${name}.sfedcba98.S0246" " = \\{15, 13, 11, 9\\}" 337 gdb_test "print/d ${name}.sfedcba98.S0246.s13" " = \\{13, 9\\}" 338 gdb_test "print/d ${name}.sfedcba98.S0246.s13.s0" " = 13" 339 gdb_test "print/d ${name}.s0123456789abcdef.s22" " = \\{2, 2\\}" 340 341 gdb_test "print/d ${name}.hi.s7654.wx" " = \\{12, 15\\}" 342 gdb_test "print/d ${name}.s0123456789abcdef.even.lo" " = \\{0, 2, 4, 6\\}" 343 gdb_test "print/d ${name}.odd.xyzw.s23" " = \\{5, 7\\}" 344 gdb_test "print/d ${name}.xyzw.hi.odd" " = 3" 345 346 # lvalue tests 347 for {set i 0} {$i < 16} {incr i} { 348 gdb_test_no_output "set variable ${name}.s[format "%x" $i] = [expr 15 - $i]" 349 gdb_test "print/d ${name}.s[format "%x" $i]" " = [expr 15 - $i]" 350 } 351 gdb_test "print/d ${name}" " = \\{15, 14, 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, 1, 0\\}" 352 353 gdb_test_no_output "set variable ${name}.s02468ace = ${name}.s13579bdf" 354 gdb_test "print/d ${name}" " = \\{14, 14, 12, 12, 10, 10, 8, 8, 6, 6, 4, 4, 2, 2, 0, 0\\}" 355 356 gdb_test_no_output "set variable ${name}.wzyx = ${name}.even.odd" 357 gdb_test "print/d ${name}" " = \\{0, 4, 8, 12, 10, 10, 8, 8, 6, 6, 4, 4, 2, 2, 0, 0\\}" 358 359 gdb_test_no_output "set variable ${name}.odd.lo = ${name}.hi.even" 360 gdb_test "print/d ${name}" " = \\{0, 6, 8, 4, 10, 2, 8, 0, 6, 6, 4, 4, 2, 2, 0, 0\\}" 361 362 gdb_test_no_output "set variable ${name}.hi.hi.hi = ${name}.lo.s1623.lo" 363 gdb_test "print/d ${name}" " = \\{0, 6, 8, 4, 10, 2, 8, 0, 6, 6, 4, 4, 2, 2, 6, 8\\}" 364} 365 366proc do_check { name type alttype size } { 367 check_basic ${name} ${type} ${size} 368 check_type ${name} ${type} ${alttype} 369 check_sizeof ${name} ${size} 370 check_access ${name} 371} 372 373do_check "c16" "char" "char" 1 374do_check "uc16" "uchar" "unsigned char" 1 375do_check "s16" "short" "short" 2 376do_check "us16" "ushort" "unsigned short" 2 377do_check "i16" "int" "int" 4 378do_check "ui16" "uint" "unsigned int" 4 379do_check "l16" "long" "long" 8 380do_check "ul16" "ulong" "unsigned long" 8 381if { ${have_cl_khr_fp16} } { 382 do_check "h16" "half" "half" 2 383} 384do_check "f16" "float" "float" 4 385if { ${have_cl_khr_fp64} } { 386 do_check "d16" "double" "double" 8 387} 388 389# Delete the OpenCL program source 390remote_file target delete ${clprogram} 391