xref: /qemu/scripts/analyse-9p-simpletrace.py (revision 7999f7e1273b63ec3a60d8cf2cb79cb88575744a)
149a88ce3SHarsh Prateek Bora#!/usr/bin/env python
249a88ce3SHarsh Prateek Bora# Pretty print 9p simpletrace log
349a88ce3SHarsh Prateek Bora# Usage: ./analyse-9p-simpletrace <trace-events> <trace-pid>
449a88ce3SHarsh Prateek Bora#
549a88ce3SHarsh Prateek Bora# Author: Harsh Prateek Bora
649a88ce3SHarsh Prateek Bora
749a88ce3SHarsh Prateek Boraimport simpletrace
849a88ce3SHarsh Prateek Bora
949a88ce3SHarsh Prateek Boraclass VirtFSRequestTracker(simpletrace.Analyzer):
1049a88ce3SHarsh Prateek Bora        def begin(self):
1149a88ce3SHarsh Prateek Bora                print "Pretty printing 9p simpletrace log ..."
1249a88ce3SHarsh Prateek Bora
13*7999f7e1SAneesh Kumar K.V        def v9fs_rerror(self, tag, id, err):
14*7999f7e1SAneesh Kumar K.V                print "RERROR (tag =", tag, ", id =", id, ",err =", err, ")"
1549a88ce3SHarsh Prateek Bora
1649a88ce3SHarsh Prateek Bora        def v9fs_version(self, tag, id, msize, version):
1749a88ce3SHarsh Prateek Bora                print "TVERSION (tag =", tag, ", msize =", msize, ", version =", version, ")"
1849a88ce3SHarsh Prateek Bora
1949a88ce3SHarsh Prateek Bora        def v9fs_version_return(self, tag, id, msize, version):
2049a88ce3SHarsh Prateek Bora                print "RVERSION (tag =", tag, ", msize =", msize, ", version =", version, ")"
2149a88ce3SHarsh Prateek Bora
2249a88ce3SHarsh Prateek Bora        def v9fs_attach(self, tag, id, fid, afid, uname, aname):
2349a88ce3SHarsh Prateek Bora                print "TATTACH (tag =", tag, ", fid =", fid, ", afid =", afid, ", uname =", uname, ", aname =", aname, ")"
2449a88ce3SHarsh Prateek Bora
25*7999f7e1SAneesh Kumar K.V        def v9fs_attach_return(self, tag, id, type, version, path):
2649a88ce3SHarsh Prateek Bora                print "RATTACH (tag =", tag, ", qid={type =", type, ", version =", version, ", path =", path, "})"
2749a88ce3SHarsh Prateek Bora
2849a88ce3SHarsh Prateek Bora        def v9fs_stat(self, tag, id, fid):
2949a88ce3SHarsh Prateek Bora                print "TSTAT (tag =", tag, ", fid =", fid, ")"
3049a88ce3SHarsh Prateek Bora
3149a88ce3SHarsh Prateek Bora        def v9fs_stat_return(self, tag, id, mode, atime, mtime, length):
3249a88ce3SHarsh Prateek Bora                print "RSTAT (tag =", tag, ", mode =", mode, ", atime =", atime, ", mtime =", mtime, ", length =", length, ")"
3349a88ce3SHarsh Prateek Bora
3449a88ce3SHarsh Prateek Bora        def v9fs_getattr(self, tag, id, fid, request_mask):
3549a88ce3SHarsh Prateek Bora                print "TGETATTR (tag =", tag, ", fid =", fid, ", request_mask =", hex(request_mask), ")"
3649a88ce3SHarsh Prateek Bora
3749a88ce3SHarsh Prateek Bora        def v9fs_getattr_return(self, tag, id, result_mask, mode, uid, gid):
3849a88ce3SHarsh Prateek Bora                print "RGETATTR (tag =", tag, ", result_mask =", hex(result_mask), ", mode =", oct(mode), ", uid =", uid, ", gid =", gid, ")"
3949a88ce3SHarsh Prateek Bora
4049a88ce3SHarsh Prateek Bora        def v9fs_walk(self, tag, id, fid, newfid, nwnames):
4149a88ce3SHarsh Prateek Bora                print "TWALK (tag =", tag, ", fid =", fid, ", newfid =", newfid, ", nwnames =", nwnames, ")"
4249a88ce3SHarsh Prateek Bora
4349a88ce3SHarsh Prateek Bora        def v9fs_walk_return(self, tag, id, nwnames, qids):
4449a88ce3SHarsh Prateek Bora                print "RWALK (tag =", tag, ", nwnames =", nwnames, ", qids =", hex(qids), ")"
4549a88ce3SHarsh Prateek Bora
4649a88ce3SHarsh Prateek Bora        def v9fs_open(self, tag, id, fid, mode):
4749a88ce3SHarsh Prateek Bora                print "TOPEN (tag =", tag, ", fid =", fid, ", mode =", oct(mode), ")"
4849a88ce3SHarsh Prateek Bora
4949a88ce3SHarsh Prateek Bora        def v9fs_open_return(self, tag, id, type, version, path, iounit):
5049a88ce3SHarsh Prateek Bora                print "ROPEN (tag =", tag,  ", qid={type =", type, ", version =", version, ", path =", path, "}, iounit =", iounit, ")"
5149a88ce3SHarsh Prateek Bora
5249a88ce3SHarsh Prateek Bora        def v9fs_lcreate(self, tag, id, dfid, flags, mode, gid):
5349a88ce3SHarsh Prateek Bora                print "TLCREATE (tag =", tag, ", dfid =", dfid, ", flags =", oct(flags), ", mode =", oct(mode), ", gid =", gid, ")"
5449a88ce3SHarsh Prateek Bora
55*7999f7e1SAneesh Kumar K.V        def v9fs_lcreate_return(self, tag, id, type, version, path, iounit):
5649a88ce3SHarsh Prateek Bora                print "RLCREATE (tag =", tag,  ", qid={type =", type, ", version =", version, ", path =", path, "}, iounit =", iounit, ")"
5749a88ce3SHarsh Prateek Bora
5849a88ce3SHarsh Prateek Bora        def v9fs_fsync(self, tag, id, fid, datasync):
5949a88ce3SHarsh Prateek Bora                print "TFSYNC (tag =", tag, ", fid =", fid, ", datasync =", datasync, ")"
6049a88ce3SHarsh Prateek Bora
6149a88ce3SHarsh Prateek Bora        def v9fs_clunk(self, tag, id, fid):
6249a88ce3SHarsh Prateek Bora                print "TCLUNK (tag =", tag, ", fid =", fid, ")"
6349a88ce3SHarsh Prateek Bora
6449a88ce3SHarsh Prateek Bora        def v9fs_read(self, tag, id, fid, off, max_count):
6549a88ce3SHarsh Prateek Bora                print "TREAD (tag =", tag, ", fid =", fid, ", off =", off, ", max_count =", max_count, ")"
6649a88ce3SHarsh Prateek Bora
6749a88ce3SHarsh Prateek Bora        def v9fs_read_return(self, tag, id, count, err):
6849a88ce3SHarsh Prateek Bora                print "RREAD (tag =", tag, ", count =", count, ", err =", err, ")"
6949a88ce3SHarsh Prateek Bora
7049a88ce3SHarsh Prateek Bora        def v9fs_readdir(self, tag, id, fid, offset, max_count):
7149a88ce3SHarsh Prateek Bora                print "TREADDIR (tag =", tag, ", fid =", fid, ", offset =", offset, ", max_count =", max_count, ")"
7249a88ce3SHarsh Prateek Bora
7349a88ce3SHarsh Prateek Bora        def v9fs_readdir_return(self, tag, id, count, retval):
7449a88ce3SHarsh Prateek Bora                print "RREADDIR (tag =", tag, ", count =", count, ", retval =", retval, ")"
7549a88ce3SHarsh Prateek Bora
7649a88ce3SHarsh Prateek Bora        def v9fs_write(self, tag, id, fid, off, count, cnt):
7749a88ce3SHarsh Prateek Bora                print "TWRITE (tag =", tag, ", fid =", fid, ", off =", off, ", count =", count, ", cnt =", cnt, ")"
7849a88ce3SHarsh Prateek Bora
7949a88ce3SHarsh Prateek Bora        def v9fs_write_return(self, tag, id, total, err):
8049a88ce3SHarsh Prateek Bora                print "RWRITE (tag =", tag, ", total =", total, ", err =", err, ")"
8149a88ce3SHarsh Prateek Bora
82*7999f7e1SAneesh Kumar K.V        def v9fs_create(self, tag, id, fid, name, perm, mode):
8349a88ce3SHarsh Prateek Bora                print "TCREATE (tag =", tag, ", fid =", fid, ", perm =", oct(perm), ", name =", name, ", mode =", oct(mode), ")"
8449a88ce3SHarsh Prateek Bora
85*7999f7e1SAneesh Kumar K.V        def v9fs_create_return(self, tag, id, type, version, path, iounit):
8649a88ce3SHarsh Prateek Bora                print "RCREATE (tag =", tag,  ", qid={type =", type, ", version =", version, ", path =", path, "}, iounit =", iounit, ")"
8749a88ce3SHarsh Prateek Bora
8849a88ce3SHarsh Prateek Bora        def v9fs_symlink(self, tag, id, fid, name, symname, gid):
8949a88ce3SHarsh Prateek Bora                print "TSYMLINK (tag =", tag, ", fid =", fid, ", name =", name, ", symname =", symname, ", gid =", gid, ")"
9049a88ce3SHarsh Prateek Bora
9149a88ce3SHarsh Prateek Bora        def v9fs_symlink_return(self, tag, id, type, version, path):
9249a88ce3SHarsh Prateek Bora                print "RSYMLINK (tag =", tag,  ", qid={type =", type, ", version =", version, ", path =", path, "})"
9349a88ce3SHarsh Prateek Bora
9449a88ce3SHarsh Prateek Bora        def v9fs_flush(self, tag, id, flush_tag):
9549a88ce3SHarsh Prateek Bora                print "TFLUSH (tag =", tag, ", flush_tag =", flush_tag, ")"
9649a88ce3SHarsh Prateek Bora
9749a88ce3SHarsh Prateek Bora        def v9fs_link(self, tag, id, dfid, oldfid, name):
9849a88ce3SHarsh Prateek Bora                print "TLINK (tag =", tag, ", dfid =", dfid, ", oldfid =", oldfid, ", name =", name, ")"
9949a88ce3SHarsh Prateek Bora
10049a88ce3SHarsh Prateek Bora        def v9fs_remove(self, tag, id, fid):
10149a88ce3SHarsh Prateek Bora                print "TREMOVE (tag =", tag, ", fid =", fid, ")"
10249a88ce3SHarsh Prateek Bora
10349a88ce3SHarsh Prateek Bora        def v9fs_wstat(self, tag, id, fid, mode, atime, mtime):
10449a88ce3SHarsh Prateek Bora                print "TWSTAT (tag =", tag, ", fid =", fid, ", mode =", oct(mode), ", atime =", atime, "mtime =", mtime, ")"
10549a88ce3SHarsh Prateek Bora
10649a88ce3SHarsh Prateek Bora        def v9fs_mknod(self, tag, id, fid, mode, major, minor):
10749a88ce3SHarsh Prateek Bora                print "TMKNOD (tag =", tag, ", fid =", fid, ", mode =", oct(mode), ", major =", major, ", minor =", minor, ")"
10849a88ce3SHarsh Prateek Bora
10949a88ce3SHarsh Prateek Bora        def v9fs_lock(self, tag, id, fid, type, start, length):
11049a88ce3SHarsh Prateek Bora                print "TLOCK (tag =", tag, ", fid =", fid, "type =", type, ", start =", start, ", length =", length, ")"
11149a88ce3SHarsh Prateek Bora
11249a88ce3SHarsh Prateek Bora        def v9fs_lock_return(self, tag, id, status):
11349a88ce3SHarsh Prateek Bora                print "RLOCK (tag =", tag, ", status =", status, ")"
11449a88ce3SHarsh Prateek Bora
11549a88ce3SHarsh Prateek Bora        def v9fs_getlock(self, tag, id, fid, type, start, length):
11649a88ce3SHarsh Prateek Bora                print "TGETLOCK (tag =", tag, ", fid =", fid, "type =", type, ", start =", start, ", length =", length, ")"
11749a88ce3SHarsh Prateek Bora
11849a88ce3SHarsh Prateek Bora        def v9fs_getlock_return(self, tag, id, type, start, length, proc_id):
11949a88ce3SHarsh Prateek Bora                print "RGETLOCK (tag =", tag, "type =", type, ", start =", start, ", length =", length, ", proc_id =", proc_id,  ")"
12049a88ce3SHarsh Prateek Bora
12149a88ce3SHarsh Prateek Bora        def v9fs_mkdir(self, tag, id, fid, name, mode, gid):
12249a88ce3SHarsh Prateek Bora                print "TMKDIR (tag =", tag, ", fid =", fid, ", name =", name, ", mode =", mode, ", gid =", gid, ")"
12349a88ce3SHarsh Prateek Bora
12449a88ce3SHarsh Prateek Bora        def v9fs_mkdir_return(self, tag, id, type, version, path, err):
12549a88ce3SHarsh Prateek Bora                print "RMKDIR (tag =", tag,  ", qid={type =", type, ", version =", version, ", path =", path, "}, err =", err, ")"
12649a88ce3SHarsh Prateek Bora
12749a88ce3SHarsh Prateek Bora        def v9fs_xattrwalk(self, tag, id, fid, newfid, name):
12849a88ce3SHarsh Prateek Bora                print "TXATTRWALK (tag =", tag, ", fid =", fid, ", newfid =", newfid, ", xattr name =", name, ")"
12949a88ce3SHarsh Prateek Bora
13049a88ce3SHarsh Prateek Bora        def v9fs_xattrwalk_return(self, tag, id, size):
13149a88ce3SHarsh Prateek Bora                print "RXATTRWALK (tag =", tag, ", xattrsize  =", size, ")"
13249a88ce3SHarsh Prateek Bora
13349a88ce3SHarsh Prateek Bora        def v9fs_xattrcreate(self, tag, id, fid, name, size, flags):
13449a88ce3SHarsh Prateek Bora                print "TXATTRCREATE (tag =", tag, ", fid =", fid, ", name =", name, ", xattrsize =", size, ", flags =", flags, ")"
13549a88ce3SHarsh Prateek Bora
13649a88ce3SHarsh Prateek Bora        def v9fs_readlink(self, tag, id, fid):
13749a88ce3SHarsh Prateek Bora                print "TREADLINK (tag =", tag, ", fid =", fid, ")"
13849a88ce3SHarsh Prateek Bora
13949a88ce3SHarsh Prateek Bora        def v9fs_readlink_return(self, tag, id, target):
14049a88ce3SHarsh Prateek Bora                print "RREADLINK (tag =", tag, ", target =", target, ")"
14149a88ce3SHarsh Prateek Bora
14249a88ce3SHarsh Prateek Borasimpletrace.run(VirtFSRequestTracker())
143