blob: 3fa7c4dc2c889eec282a7fd5e607c1cd029f2167 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
|
# find_sim -- find a usable simulator
# This proc is local to this file and is used to locate a simulator to use.
# First we see if SIM=foo was specified on the command line.
# Otherwise we search the build tree, then $PATH.
proc find_sim { target_alias sim_dir sim_name } {
global tool_root_dir;
global SIM
if [info exists SIM] {
return $SIM
}
if [is_remote host] {
if ![board_info host exists no_transform_name] {
return ${target_alias}-${sim_name};
} else {
return ${sim_name};
}
}
# We have to search because tool_root_dir may actually point to that blasted
# "target" subdirectory.
set try [lookfor_file ${tool_root_dir} sim/${sim_dir}/${sim_name}];
if { $try != "" } {
return $try;
}
return ${target_alias}-${sim_name};
}
proc setup_sim { subdir_name } {
global target_alias;
global tool_root_dir;
global board;
if [info exists target_alias] {
set tmp $target_alias;
} else {
if [board_info $board exists target_install] {
set tmp [lindex [board_info $board target_install] 0];
}
}
if ![board_info $board exists sim] {
set_board_info sim [find_sim $tmp $subdir_name run];
}
verbose "Using simulator [board_info $board sim]\n"
}
set_board_info is_simulator 1;
|