var Module = {}; var verbose_mode = false; var text_buffer = ""; Module["printErr"] = Module["print"] = function(text) { if (verbose_mode) console.log(text); text_buffer += text + "\n"; } importScripts('yosys.js'); onmessage = function(e) { var request = e.data[0]; var response = { "idx": request.idx, "args": [] }; if (request.mode == "run") { response["errmsg"] = ""; try { text_buffer = ""; Module.ccall('run', '', ['string'], [request.cmd]); } catch (e) { response.errmsg = Module.ccall('errmsg', 'string', [], []); } response.args.push(text_buffer); response.args.push(response.errmsg); text_buffer = ""; } if (request.mode == "read_file") { try { response.args.push(FS.readFile(request.filename, {encoding: 'utf8'})); } catch (e) { } } if (request.mode == "write_file") { try { FS.writeFile(request.filename, request.text, {encoding: 'utf8'}); } catch (e) { } } if (request.mode == "read_dir") { try { response.args.push(FS.readdir(request.dirname)); } catch (e) { } } if (request.mode == "remove_file") { try { FS.unlink(request.filename); } catch (e) { } } if (request.mode == "verbose") { if (request.value) console.log(text_buffer); verbose_mode = request.value; } postMessage([response]); } postMessage([{ "idx": 0, "args": [] }]); 4.3 xenJames
aboutsummaryrefslogtreecommitdiffstats
path: root/tools/xentrace/setsize.c
blob: fcb1fcb6b0ebfbefc60a452fcf8fc603704d2e25 (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
#include <stdlib.h>
#include <stdio.h>
#include <errno.h>
#include <xenctrl.h>

int main(int argc, char * argv[])
{
    unsigned long size;
    int xc_handle = xc_interface_open();
  
    if ( xc_tbuf_get_size(xc_handle, &size) != 0 )
    {
        perror("Failure to get tbuf info from Xen. Guess size is 0");
        printf("This may mean that tracing is not enabled in xen.\n");
    }
    else
    {
        printf("Current tbuf size: 0x%lx\n", size);
    }

    if (argc < 2)
        exit(0);

    size = atol(argv[1]);

    if ( xc_tbuf_set_size(xc_handle, size) != 0 )
    {
        perror("set_size Hypercall failure");
        exit(1);
    }
    printf("set_size succeeded.\n");
  
    if (xc_tbuf_get_size(xc_handle, &size) != 0)
        perror("Failure to get tbuf info from Xen."
               " Tracing must be enabled first");
    else
        printf("New tbuf size: 0x%lx\n", size);
  
    xc_interface_close(xc_handle);
    return 0;
}