pool/web/yaamp/modules/bench/devices.php
Tanguy Pruvot 580801f399 benchs: unique function to format devices labels
+ some new devices chips rules
2018-04-10 10:53:04 +02:00

138 lines
3.6 KiB
PHP

<?php
include('functions.php');
$client_ip = arraySafeVal($_SERVER,'REMOTE_ADDR');
$whitelisted = isAdminIP($client_ip);
if (!$whitelisted && is_file(YAAMP_LOGS.'/overloaded')) {
header('HTTP/1.0 503 Disabled, server overloaded');
return;
}
$this->pageTitle = "Devices";
$chips = array();
// todo: bench_devices table to cache that
$in_db = $this->memcache->get_database_list("benchmarks-devices",
"SELECT DISTINCT device, type, chip, idchip, vendorid FROM benchmarks WHERE idchip > 0 ORDER BY type DESC, device, vendorid",
array(), 120
);
foreach ($in_db as $key => $row) {
$vendorid = $row['vendorid'];
$chip = $row['chip'];
if (empty($chip)) $chip = getChipName($row);
if (!empty($vendorid)) $chips[$vendorid] = $chip;
}
$chip = 'all';
$options = '<option value="all">Show all</option>';
foreach($chips as $a => $count) {
if($a == $chip)
$options .= '<option value="'.$a.'" selected="selected">'.$a.'</option>';
else
$options .= '<option value="'.$a.'">'.$a.'</option>';
}
echo <<<end
<div align="right" style="margin-bottom: 2px; margin-right: 0px;">
<input class="search" type="search" data-column="all" style="width: 140px;" placeholder="Search..." />
</div>
<style type="text/css">
tr.ssrow.filtered { display: none; }
td.tick { font-weight: bolder; }
span.generic { color: gray; }
.page .footer { width: auto; };
</style>
<p style="margin-top: -20px; margin-bottom: 4px; line-height: 22px; font-weight: bolder;">
Devices in database
</p>
end;
$algos_columns = '';
$month = time() - (30 * 24 * 3600);
$algos = $this->memcache->get_database_column("benchmarks-algos",
"SELECT DISTINCT algo FROM benchmarks WHERE time > $month ORDER BY algo LIMIT 20",
array(), 120
);
foreach ($algos as $algo) {
$algos_columns .= '<th>'.$algo.'</th>';
}
JavascriptFile("/yaamp/ui/js/jquery.metadata.js");
JavascriptFile("/yaamp/ui/js/jquery.tablesorter.widgets.js");
showTableSorter('maintable', "{
tableClass: 'dataGrid',
widgets: ['zebra','filter'],
textExtraction: {
// 4: function(node, table, n) { return $(node).attr('data'); }
},
widgetOptions: {
filter_external: '.search',
filter_columnFilters: false,
filter_childRows : true,
filter_ignoreCase: true
}
}");
echo <<<END
<thead>
<tr>
<th data-sorter="text" width="70">Chip</th>
<th data-sorter="text" width="220">Device</th>
<th data-sorter="text" width="70">Vendor ID</th>
{$algos_columns}
</tr>
</thead><tbody>
END;
foreach ($in_db as $row) {
// ignore virtual devices
if ($row['chip'] == 'Virtual') continue;
echo '<tr class="ssrow">';
$vendorid = $row['vendorid'];
$chip = arraySafeVal($chips, $vendorid, '-');
if (!empty($row['idchip'])) {
$chip = CHtml::link($chip, '/bench?chip='.$row['idchip'].'&algo=all');
}
echo '<td>'.$chip.'</td>';
echo '<td>'.formatDevice($row).'</td>';
if (substr($vendorid,0,4) == '10de')
echo '<td><span class="generic" title="nVidia product id">'.$vendorid.'</span></td>';
else
echo '<td>'.CHtml::link($row['vendorid'],'/bench?vid='.$row['vendorid']).'</td>';
if (!empty($vendorid))
$records = dbocolumn("SELECT DISTINCT algo FROM benchmarks WHERE vendorid=:vid ", array(':vid'=>$vendorid));
else
$records = dbocolumn("SELECT DISTINCT algo FROM benchmarks WHERE device=:dev ", array(':dev'=>$row['device'])); // cpu
foreach ($algos as $algo) {
$tick = '&nbsp;';
if (in_array($algo, $records)) {
$url = '/bench?algo='.$algo;
if (!empty($row['idchip'])) {
$url .= '&chip='.$row['idchip'];
}
$tick = CHtml::link('✓', $url);
}
echo '<td class="tick">'.$tick.'</td>';
}
echo '</tr>';
}
echo '</tbody></table><br/>';
echo '<a href="/site/benchmarks">Learn how to submit your results</a>';
echo '<br/><br/>';