Jump to content

Heap Peek: Difference between revisions

From LabVIEW Wiki
less bold
Line 36: Line 36:
== Heap View ==
== Heap View ==


Heap, for LV, is really a Front Panel or Block Diagram. Despite the name, they don't really have a heap-like structure. Both FP and BD are stored in form of a tree, strongly inspired by XML format. The main difference is - the LV Heap format is binary, not text-based.
Heap, for LV, is really a [[Front Panel]] or [[Block Diagram]]. Despite the name, they don't really have a heap-like structure. Both FP and BD are stored in form of a tree, strongly inspired by [https://en.wikipedia.org/wiki/XML XML format]. The main difference is - the LV Heap format is binary, not text-based.


In Heap View, Heaps are displayed in a flattened form, not in its full tree-like glory. Part of the entries show properties of the whole pane, and the rest is controls, indicators and other elements added to the pane.
In ''Heap View'', Heaps are displayed in a flattened form, not in its full tree-like glory. Part of the entries show properties of the whole pane, and the rest is [[Control|controls]], [[Indicator|indicators]] and other elements added to the pane.


The view for ''FPHP'' reveals that controls and indicators are composed of several [[Control Parts|parts]] - ie. Numeric controls consist of: Label, Frame, Up/Down buttons, Edit field, Radix and Annex. Each [[Control_Parts#List_of_parts|part has partID]], which is used by LV to identify type of that part.
The view for ''FPHP'' reveals that controls and indicators are composed of several [[Control Parts|parts]] - ie. Numeric controls consist of: Label, Frame, Up/Down buttons, Edit field, Radix and Annex. Each [[Control_Parts#List_of_parts|part has partID]], which is used by LV to identify type of that part.

Revision as of 15:38, 5 June 2020

Heap Peek is a debug feature available at least since LabVIEW 3.0. It allows to view internal data structures created for all loaded VI files, including Front Panel Heap and Block Diagram Heap. The feature is intended for use by LV R&D, though users may in some cases be instructed by LV Support to check something there.

Enabling Heap Peek

The Heap Peek keyboard shortcut is by default disabled in fresh installations of LabVIEW. To enable it:

Then, to trigger the Heap Peek window:

  • Open your VI
  • Press CTRL+SHIFT+D+H. On Mac, use the command key instead of CTRL. This will open the Heap Peek window.

Using Heap Peek

The window is divided into 5 sections:

  • Loaded Container Files are in top-left,
  • Heap View is top-right,
  • Structure selection for info pane in middle-left,
  • Toolbar at the middle,
  • Information pane is at base.

The first section, as for usage flow, is top-left one. Start there, by left clicking to select the specific file and specific heap you want to look at. When the heap is selected, you can display many details on it by clicking rows of either top-right or middle section. These details will show at base, in Information pane.

Note: Heap Peek does not have any ability to change the objects. It is display information only.

Loaded Container Files list

The list is divided into Contexts. In each of these, you can see memory location of the item (within LabVIEW process memory), and entries marked BDHP or FPHP.

  • BDHP is Block Diagram Heap
  • FPHP is Front Panel Heap

Note: There are VIs in LV that are not real VIs (for example, a pseudo VI that is created to represent a Call By Reference to another application instance on another machine), and attempting to do Find to jump to their components can cause problems because those VIs never expect to actually draw themselves.

Heap View

Heap, for LV, is really a Front Panel or Block Diagram. Despite the name, they don't really have a heap-like structure. Both FP and BD are stored in form of a tree, strongly inspired by XML format. The main difference is - the LV Heap format is binary, not text-based.

In Heap View, Heaps are displayed in a flattened form, not in its full tree-like glory. Part of the entries show properties of the whole pane, and the rest is controls, indicators and other elements added to the pane.

The view for FPHP reveals that controls and indicators are composed of several parts - ie. Numeric controls consist of: Label, Frame, Up/Down buttons, Edit field, Radix and Annex. Each part has partID, which is used by LV to identify type of that part.

Note: To learn more about LV Heaps, consider exporting a few to XML, and looking at them there. The flat list visible in Heap View will be very helpful when you understand them, but it's not the best way to acquire that understanding.

Structure selection

Here you can select one of the structures within VI files other than FPHP/BDHP. These are per-file, not per-heap - so you won't find any difference in them if you select different part of the same file in Loaded Container Files list.

The selectable options are:

  • VI Fields - lists values of many common settings and flags of the VI file
  • DS Fields - lists Data Space properties, including Table of QEs and Table of TMEs
  • OH Fields
  • Stats - statistics for objects used within Heaps
  • Link Info - content of all LinkObj lists
  • Names In Memory
  • IL Code Stream - Prints Intermediate Language Code used during code compilation process
  • Code Disassembly - Prints assembly generated by the compiler for given VI file
  • Transform Metrics
  • UDClass Info
  • Full OMUDClassPtr List
  • Available Implementers

DS Fields

Data Space in an important concept in LV internals. In short, Data Space contains filling for all type mapped data types. And in more detail:

  • Like in all languages, you can define data types in LabVIEW. You don't need any action to define integer, it's trivial. But compound types, like Clusters and Arrays - these you need to define.
  • LV stores all data types used within a VI in form of Type Descriptors (TDs). There is a table of these in every VI file.
  • When an instance of data type is required - real variable needs to be created - the TD is added to Type Map. Type Map is just another table, which maps TDs into Data Space. That Type Map Entry is a confirmation that there is an area reserved in Data Space for the variable, and it also points to the specific place where data starts.
  • Data Space is a continuous block of memory, which consists only of data. Reading Data Space requires information of what is stored where - so Type Map Entries are required to give meaning to the binary values stored in Data Space.

The DS Fields section contains some general information on Data Space of the file, and then displays whole mapping of the Data Space (DSTM). As of LV2014 is doesn't show values stored in data space, but it shows offsets within said Data Space, and Type Map Entries (TMEs) with information about which data type is stored there, with all its properties. The DSTM data in this section is cut to only show part of Data Space which is used for different purposes than Heap - the complete Data Space is always larger.

Some of the types stored in Data Space are not linked directly to user created code, and are LV internal data instead. For example, the data space always contains a block of 51 integer values - these are settings internal to LabVIEW, called DSInit. It also contains a list of DCOs - objects which contain selected properties of controls and indicators from Front Panel, and are retained even when FP is removed form VI file.

Toolbar

The toolbar consists of several fields.

  • Next/prev buttons
  • Currently selected item name text
  • U button
  • F button - Click on it to find the object selected in Heap View. LabVIEW will switch to the block diagram or front panel and select related object.
  • UO button

Note: A previous author said that few developers really know the capacities of heap peek. This is true... it's a debugging tool, and it gets hacked up to debug whatever anyone needs to debug.