Skip to content

Releases: microsoft/perfview

PerfView 2.0.44

01 Jul 21:41
6ccbcb4
Compare
Choose a tag to compare

Roll-up until 7/1/2019.

TraceEvent 2.0.43

19 Jun 03:29
0706708
Compare
Choose a tag to compare

Roll-up until 6/18/2019.

Includes support for the new EventPipe nettrace format.

PerfView 2.0.43 Public Release

19 Jun 03:29
0706708
Compare
Choose a tag to compare

Roll-up until 6/18/2019.

TraceEvent 2.0.42 Release

06 May 23:18
919f5fa
Compare
Choose a tag to compare

Rollup until 5/6/2019.

PerfView 2.0.42 Public Release

06 May 23:20
919f5fa
Compare
Choose a tag to compare

Rollup until 5/6/2019.

TraceEvent 2.0.41 Release

25 Apr 03:04
63e841e
Compare
Choose a tag to compare

Rollup until 4/24/2019.

Includes preview support for streaming from EventPipe.

TraceEvent 2.0.40 Release

01 Apr 21:34
ebe4f8a
Compare
Choose a tag to compare

Rollup until 4/1/2019

TraceEvent 2.0.39 Release

21 Mar 20:29
496a208
Compare
Choose a tag to compare

Rollup until 3/20/19

PerfView 2.0.39 Public Release

21 Mar 20:41
496a208
Compare
Choose a tag to compare

This is mostly a bug fix release from the 2.0.26. However there are a few small new features:

  1. Update to display the type of the alloction for C++ code (in the Net OS Heap Alloc View).
    It is now the case that if you have PDBS for the call site of a C++ 'new' expression and that compiler
    supports it (I believe anything after VS2017 CPP compiler will work), then PerfView will create a 'Type XXX'
    pseduo-node for allocation sites. Having this type information can definately be useful.
  2. Added the /focusProcess=ProcessIDOrName qualifier (e.g. focusProcess=PerfView.exe) This allows you
    to only turn on non-Kernel events
    for a particular process, and thus cut the overhead / size of the collection when there are many
    active processes on the system.. Note that it does not have an effect on kernel events (which are
    often the most common, but not always), so it may not help as much as you would like, but DEFINITELY
    helps during rundown (if you have many managed processes, they all do rundown which can be impactful).
    So it always helps when there are many managed processes (because of rundown) but can help quite a lot
    if many of those processes allocate a lot, or use the threadpool (which both can create many events).
  3. Added support for the /SessionName=XXXX parameter which renames both the user and kernel
    session names that PerfView uses (which allow you to have two PerfView's running or run
    with other tools that use the kernel provider)
  4. Added the /DotNetCallsSampled command line option that does call instrumentation
    but samples every 997 calls (to keep overhead low)
  5. Added the /DisableInlining command line option that tells the runtime not to
    inline (used with the /DotNetCalls or /DotNetCallsSampled options)
  6. Added the user command 'NetperfToSpeedScope netPerfFileName' which will convert a .NET *.netperf file
    (created by the .NET Core runtime), into a *.speedscope file which is the format that the
    https://www.speedscope.app/ tool can use (this is a flamegraph viewer).

To get the tool simply download the PerfView.exe executable and use it. I include the PDB files in case you need to debug something, but that is a rare case and you don't need to do that normally.

The PerfView64.exe is optional. It is a small wrapper that launches PerfView as a 64 bit application. If you are dealing with very large traces that cause 'out of memory' errors, this can be used to avoid the problem. Note that you need PerfView.exe to be present next to PerfView64.exe for it to work.

Like all versions of PerfView you can see the specific release notes from the past year by accessing the 'Help -> Release Notes' menu entry.

You can also see detailed informational about what changes went into this release by viewing the Github history.

TraceEvent 2.0.38 Release

27 Feb 19:36
906b9cb
Compare
Choose a tag to compare

Rollup until 2/20/19.