xref: /openbmc/qemu/hmp-commands-info.hx (revision 1ab08790bb75e40cf35002edc26672d6b0e8004e)
1HXCOMM See docs/devel/docs.rst for the format of this file.
2HXCOMM
3HXCOMM This file defines the contents of an array of HMPCommand structs
4HXCOMM which specify the name, behaviour and help text for HMP commands.
5HXCOMM Text between SRST and ERST is rST format documentation.
6HXCOMM HXCOMM can be used for comments, discarded from both rST and C.
7HXCOMM
8HXCOMM In this file, generally SRST fragments should have two extra
9HXCOMM spaces of indent, so that the documentation list item for "info foo"
10HXCOMM appears inside the documentation list item for the top level
11HXCOMM "info" documentation entry. The exception is the first SRST
12HXCOMM fragment that defines that top level entry.
13
14SRST
15``info`` *subcommand*
16  Show various information about the system state.
17
18ERST
19
20    {
21        .name       = "version",
22        .args_type  = "",
23        .params     = "",
24        .help       = "show the version of QEMU",
25        .cmd        = hmp_info_version,
26        .flags      = "p",
27    },
28
29SRST
30  ``info version``
31    Show the version of QEMU.
32ERST
33
34    {
35        .name       = "network",
36        .args_type  = "",
37        .params     = "",
38        .help       = "show the network state",
39        .cmd        = hmp_info_network,
40    },
41
42SRST
43  ``info network``
44    Show the network state.
45ERST
46
47    {
48        .name       = "chardev",
49        .args_type  = "",
50        .params     = "",
51        .help       = "show the character devices",
52        .cmd        = hmp_info_chardev,
53        .flags      = "p",
54    },
55
56SRST
57  ``info chardev``
58    Show the character devices.
59ERST
60
61    {
62        .name       = "block",
63        .args_type  = "nodes:-n,verbose:-v,device:B?",
64        .params     = "[-n] [-v] [device]",
65        .help       = "show info of one block device or all block devices "
66                      "(-n: show named nodes; -v: show details)",
67        .cmd        = hmp_info_block,
68    },
69
70SRST
71  ``info block``
72    Show info of one block device or all block devices.
73ERST
74
75    {
76        .name       = "blockstats",
77        .args_type  = "",
78        .params     = "",
79        .help       = "show block device statistics",
80        .cmd        = hmp_info_blockstats,
81    },
82
83SRST
84  ``info blockstats``
85    Show block device statistics.
86ERST
87
88    {
89        .name       = "block-jobs",
90        .args_type  = "",
91        .params     = "",
92        .help       = "show progress of ongoing block device operations",
93        .cmd        = hmp_info_block_jobs,
94    },
95
96SRST
97  ``info block-jobs``
98    Show progress of ongoing block device operations.
99ERST
100
101    {
102        .name       = "registers",
103        .args_type  = "cpustate_all:-a,vcpu:i?",
104        .params     = "[-a|vcpu]",
105        .help       = "show the cpu registers (-a: show register info for all cpus;"
106                      " vcpu: specific vCPU to query; show the current CPU's registers if"
107                      " no argument is specified)",
108        .cmd        = hmp_info_registers,
109    },
110
111SRST
112  ``info registers``
113    Show the cpu registers.
114ERST
115
116#if defined(TARGET_I386)
117    {
118        .name       = "lapic",
119        .args_type  = "apic-id:i?",
120        .params     = "[apic-id]",
121        .help       = "show local apic state (apic-id: local apic to read, default is which of current CPU)",
122
123        .cmd        = hmp_info_local_apic,
124    },
125#endif
126
127SRST
128  ``info lapic``
129    Show local APIC state
130ERST
131
132    {
133        .name       = "cpus",
134        .args_type  = "",
135        .params     = "",
136        .help       = "show infos for each CPU",
137        .cmd        = hmp_info_cpus,
138    },
139
140SRST
141  ``info cpus``
142    Show infos for each CPU.
143ERST
144
145    {
146        .name       = "history",
147        .args_type  = "",
148        .params     = "",
149        .help       = "show the command line history",
150        .cmd        = hmp_info_history,
151        .flags      = "p",
152    },
153
154SRST
155  ``info history``
156    Show the command line history.
157ERST
158
159    {
160        .name       = "irq",
161        .args_type  = "",
162        .params     = "",
163        .help       = "show the interrupts statistics (if available)",
164        .cmd_info_hrt = qmp_x_query_irq,
165    },
166
167SRST
168  ``info irq``
169    Show the interrupts statistics (if available).
170ERST
171
172    {
173        .name       = "pic",
174        .args_type  = "",
175        .params     = "",
176        .help       = "show PIC state",
177        .cmd_info_hrt = qmp_x_query_interrupt_controllers,
178    },
179
180SRST
181  ``info pic``
182    Show PIC state.
183ERST
184
185    {
186        .name       = "pci",
187        .args_type  = "",
188        .params     = "",
189        .help       = "show PCI info",
190        .cmd        = hmp_info_pci,
191    },
192
193SRST
194  ``info pci``
195    Show PCI information.
196ERST
197
198#if defined(TARGET_I386) || defined(TARGET_SH4) || defined(TARGET_SPARC) || \
199    defined(TARGET_PPC) || defined(TARGET_XTENSA) || defined(TARGET_M68K)
200    {
201        .name       = "tlb",
202        .args_type  = "",
203        .params     = "",
204        .help       = "show virtual to physical memory mappings",
205        .cmd        = hmp_info_tlb,
206    },
207#endif
208
209SRST
210  ``info tlb``
211    Show virtual to physical memory mappings.
212ERST
213
214#if defined(TARGET_I386) || defined(TARGET_RISCV)
215    {
216        .name       = "mem",
217        .args_type  = "",
218        .params     = "",
219        .help       = "show the active virtual memory mappings",
220        .cmd        = hmp_info_mem,
221    },
222#endif
223
224SRST
225  ``info mem``
226    Show the active virtual memory mappings.
227ERST
228
229    {
230        .name       = "mtree",
231        .args_type  = "flatview:-f,dispatch_tree:-d,owner:-o,disabled:-D",
232        .params     = "[-f][-d][-o][-D]",
233        .help       = "show memory tree (-f: dump flat view for address spaces;"
234                      "-d: dump dispatch tree, valid with -f only);"
235                      "-o: dump region owners/parents;"
236                      "-D: dump disabled regions",
237        .cmd        = hmp_info_mtree,
238    },
239
240SRST
241  ``info mtree``
242    Show memory tree.
243ERST
244
245#if defined(CONFIG_TCG)
246    {
247        .name       = "jit",
248        .args_type  = "",
249        .params     = "",
250        .help       = "show dynamic compiler info",
251    },
252#endif
253
254SRST
255  ``info jit``
256    Show dynamic compiler info.
257ERST
258
259#if defined(CONFIG_TCG)
260    {
261        .name       = "opcount",
262        .args_type  = "",
263        .params     = "",
264        .help       = "show dynamic compiler opcode counters",
265    },
266#endif
267
268SRST
269  ``info opcount``
270    Show dynamic compiler opcode counters
271ERST
272
273    {
274        .name       = "sync-profile",
275        .args_type  = "mean:-m,no_coalesce:-n,max:i?",
276        .params     = "[-m] [-n] [max]",
277        .help       = "show synchronization profiling info, up to max entries "
278                      "(default: 10), sorted by total wait time. (-m: sort by "
279                      "mean wait time; -n: do not coalesce objects with the "
280                      "same call site)",
281        .cmd        = hmp_info_sync_profile,
282    },
283
284SRST
285  ``info sync-profile [-m|-n]`` [*max*]
286    Show synchronization profiling info, up to *max* entries (default: 10),
287    sorted by total wait time.
288
289    ``-m``
290      sort by mean wait time
291    ``-n``
292      do not coalesce objects with the same call site
293
294    When different objects that share the same call site are coalesced,
295    the "Object" field shows---enclosed in brackets---the number of objects
296    being coalesced.
297ERST
298
299    {
300        .name       = "kvm",
301        .args_type  = "",
302        .params     = "",
303        .help       = "show KVM information",
304        .cmd        = hmp_info_kvm,
305    },
306
307SRST
308  ``info kvm``
309    Show KVM information.
310ERST
311
312    {
313        .name       = "numa",
314        .args_type  = "",
315        .params     = "",
316        .help       = "show NUMA information",
317        .cmd_info_hrt = qmp_x_query_numa,
318    },
319
320SRST
321  ``info numa``
322    Show NUMA information.
323ERST
324
325    {
326        .name       = "usb",
327        .args_type  = "",
328        .params     = "",
329        .help       = "show guest USB devices",
330        .cmd_info_hrt = qmp_x_query_usb,
331    },
332
333SRST
334  ``info usb``
335    Show guest USB devices.
336ERST
337
338    {
339        .name       = "usbhost",
340        .args_type  = "",
341        .params     = "",
342        .help       = "show host USB devices",
343    },
344
345SRST
346  ``info usbhost``
347    Show host USB devices.
348ERST
349
350    {
351        .name       = "capture",
352        .args_type  = "",
353        .params     = "",
354        .help       = "show capture information",
355        .cmd        = hmp_info_capture,
356    },
357
358SRST
359  ``info capture``
360    Show capture information.
361ERST
362
363    {
364        .name       = "snapshots",
365        .args_type  = "",
366        .params     = "",
367        .help       = "show the currently saved VM snapshots",
368        .cmd        = hmp_info_snapshots,
369    },
370
371SRST
372  ``info snapshots``
373    Show the currently saved VM snapshots.
374ERST
375
376    {
377        .name       = "status",
378        .args_type  = "",
379        .params     = "",
380        .help       = "show the current VM status (running|paused)",
381        .cmd        = hmp_info_status,
382        .flags      = "p",
383    },
384
385SRST
386  ``info status``
387    Show the current VM status (running|paused).
388ERST
389
390    {
391        .name       = "mice",
392        .args_type  = "",
393        .params     = "",
394        .help       = "show which guest mouse is receiving events",
395        .cmd        = hmp_info_mice,
396    },
397
398SRST
399  ``info mice``
400    Show which guest mouse is receiving events.
401ERST
402
403#if defined(CONFIG_VNC)
404    {
405        .name       = "vnc",
406        .args_type  = "",
407        .params     = "",
408        .help       = "show the vnc server status",
409        .cmd        = hmp_info_vnc,
410    },
411#endif
412
413SRST
414  ``info vnc``
415    Show the vnc server status.
416ERST
417
418#if defined(CONFIG_SPICE)
419    {
420        .name       = "spice",
421        .args_type  = "",
422        .params     = "",
423        .help       = "show the spice server status",
424        .cmd        = hmp_info_spice,
425    },
426#endif
427
428SRST
429  ``info spice``
430    Show the spice server status.
431ERST
432
433    {
434        .name       = "name",
435        .args_type  = "",
436        .params     = "",
437        .help       = "show the current VM name",
438        .cmd        = hmp_info_name,
439        .flags      = "p",
440    },
441
442SRST
443  ``info name``
444    Show the current VM name.
445ERST
446
447    {
448        .name       = "uuid",
449        .args_type  = "",
450        .params     = "",
451        .help       = "show the current VM UUID",
452        .cmd        = hmp_info_uuid,
453        .flags      = "p",
454    },
455
456SRST
457  ``info uuid``
458    Show the current VM UUID.
459ERST
460
461#if defined(CONFIG_SLIRP)
462    {
463        .name       = "usernet",
464        .args_type  = "",
465        .params     = "",
466        .help       = "show user network stack connection states",
467        .cmd        = hmp_info_usernet,
468    },
469#endif
470
471SRST
472  ``info usernet``
473    Show user network stack connection states.
474ERST
475
476    {
477        .name       = "migrate",
478        .args_type  = "",
479        .params     = "",
480        .help       = "show migration status",
481        .cmd        = hmp_info_migrate,
482    },
483
484SRST
485  ``info migrate``
486    Show migration status.
487ERST
488
489    {
490        .name       = "migrate_capabilities",
491        .args_type  = "",
492        .params     = "",
493        .help       = "show current migration capabilities",
494        .cmd        = hmp_info_migrate_capabilities,
495    },
496
497SRST
498  ``info migrate_capabilities``
499    Show current migration capabilities.
500ERST
501
502    {
503        .name       = "migrate_parameters",
504        .args_type  = "",
505        .params     = "",
506        .help       = "show current migration parameters",
507        .cmd        = hmp_info_migrate_parameters,
508    },
509
510SRST
511  ``info migrate_parameters``
512    Show current migration parameters.
513ERST
514
515    {
516        .name       = "balloon",
517        .args_type  = "",
518        .params     = "",
519        .help       = "show balloon information",
520        .cmd        = hmp_info_balloon,
521    },
522
523SRST
524  ``info balloon``
525    Show balloon information.
526ERST
527
528    {
529        .name       = "qtree",
530        .args_type  = "brief:-b",
531        .params     = "[-b]",
532        .help       = "show device tree (-b: brief, omit properties)",
533        .cmd        = hmp_info_qtree,
534    },
535
536SRST
537  ``info qtree``
538    Show device tree.
539ERST
540
541    {
542        .name       = "qdm",
543        .args_type  = "",
544        .params     = "",
545        .help       = "show qdev device model list",
546        .cmd        = hmp_info_qdm,
547    },
548
549SRST
550  ``info qdm``
551    Show qdev device model list.
552ERST
553
554    {
555        .name       = "qom-tree",
556        .args_type  = "path:s?",
557        .params     = "[path]",
558        .help       = "show QOM composition tree",
559        .cmd        = hmp_info_qom_tree,
560        .flags      = "p",
561    },
562
563SRST
564  ``info qom-tree``
565    Show QOM composition tree.
566ERST
567
568    {
569        .name       = "roms",
570        .args_type  = "",
571        .params     = "",
572        .help       = "show roms",
573        .cmd_info_hrt = qmp_x_query_roms,
574    },
575
576SRST
577  ``info roms``
578    Show roms.
579ERST
580
581    {
582        .name       = "trace-events",
583        .args_type  = "name:s?,vcpu:i?",
584        .params     = "[name] [vcpu]",
585        .help       = "show available trace-events & their state "
586                      "(name: event name pattern; vcpu: vCPU to query, default is any)",
587        .cmd = hmp_info_trace_events,
588        .command_completion = info_trace_events_completion,
589    },
590
591SRST
592  ``info trace-events``
593    Show available trace-events & their state.
594ERST
595
596    {
597        .name       = "tpm",
598        .args_type  = "",
599        .params     = "",
600        .help       = "show the TPM device",
601        .cmd        = hmp_info_tpm,
602    },
603
604SRST
605  ``info tpm``
606    Show the TPM device.
607ERST
608
609    {
610        .name       = "memdev",
611        .args_type  = "",
612        .params     = "",
613        .help       = "show memory backends",
614        .cmd        = hmp_info_memdev,
615        .flags      = "p",
616    },
617
618SRST
619  ``info memdev``
620    Show memory backends
621ERST
622
623    {
624        .name       = "memory-devices",
625        .args_type  = "",
626        .params     = "",
627        .help       = "show memory devices",
628        .cmd        = hmp_info_memory_devices,
629    },
630
631SRST
632  ``info memory-devices``
633    Show memory devices.
634ERST
635
636    {
637        .name       = "iothreads",
638        .args_type  = "",
639        .params     = "",
640        .help       = "show iothreads",
641        .cmd        = hmp_info_iothreads,
642        .flags      = "p",
643    },
644
645SRST
646  ``info iothreads``
647    Show iothread's identifiers.
648ERST
649
650    {
651        .name       = "rocker",
652        .args_type  = "name:s",
653        .params     = "name",
654        .help       = "Show rocker switch",
655        .cmd        = hmp_rocker,
656    },
657
658SRST
659  ``info rocker`` *name*
660    Show rocker switch.
661ERST
662
663    {
664        .name       = "rocker-ports",
665        .args_type  = "name:s",
666        .params     = "name",
667        .help       = "Show rocker ports",
668        .cmd        = hmp_rocker_ports,
669    },
670
671SRST
672  ``info rocker-ports`` *name*-ports
673    Show rocker ports.
674ERST
675
676    {
677        .name       = "rocker-of-dpa-flows",
678        .args_type  = "name:s,tbl_id:i?",
679        .params     = "name [tbl_id]",
680        .help       = "Show rocker OF-DPA flow tables",
681        .cmd        = hmp_rocker_of_dpa_flows,
682    },
683
684SRST
685  ``info rocker-of-dpa-flows`` *name* [*tbl_id*]
686    Show rocker OF-DPA flow tables.
687ERST
688
689    {
690        .name       = "rocker-of-dpa-groups",
691        .args_type  = "name:s,type:i?",
692        .params     = "name [type]",
693        .help       = "Show rocker OF-DPA groups",
694        .cmd        = hmp_rocker_of_dpa_groups,
695    },
696
697SRST
698  ``info rocker-of-dpa-groups`` *name* [*type*]
699    Show rocker OF-DPA groups.
700ERST
701
702#if defined(TARGET_S390X)
703    {
704        .name       = "skeys",
705        .args_type  = "addr:l",
706        .params     = "address",
707        .help       = "Display the value of a storage key",
708        .cmd        = hmp_info_skeys,
709    },
710#endif
711
712SRST
713  ``info skeys`` *address*
714    Display the value of a storage key (s390 only)
715ERST
716
717#if defined(TARGET_S390X)
718    {
719        .name       = "cmma",
720        .args_type  = "addr:l,count:l?",
721        .params     = "address [count]",
722        .help       = "Display the values of the CMMA storage attributes for a range of pages",
723        .cmd        = hmp_info_cmma,
724    },
725#endif
726
727SRST
728  ``info cmma`` *address*
729    Display the values of the CMMA storage attributes for a range of
730    pages (s390 only)
731ERST
732
733    {
734        .name       = "dump",
735        .args_type  = "",
736        .params     = "",
737        .help       = "Display the latest dump status",
738        .cmd        = hmp_info_dump,
739    },
740
741SRST
742  ``info dump``
743    Display the latest dump status.
744ERST
745
746    {
747        .name       = "ramblock",
748        .args_type  = "",
749        .params     = "",
750        .help       = "Display system ramblock information",
751        .cmd_info_hrt = qmp_x_query_ramblock,
752    },
753
754SRST
755  ``info ramblock``
756    Dump all the ramblocks of the system.
757ERST
758
759    {
760        .name       = "hotpluggable-cpus",
761        .args_type  = "",
762        .params     = "",
763        .help       = "Show information about hotpluggable CPUs",
764        .cmd        = hmp_hotpluggable_cpus,
765        .flags      = "p",
766    },
767
768SRST
769  ``info hotpluggable-cpus``
770    Show information about hotpluggable CPUs
771ERST
772
773    {
774        .name       = "vm-generation-id",
775        .args_type  = "",
776        .params     = "",
777        .help       = "Show Virtual Machine Generation ID",
778        .cmd = hmp_info_vm_generation_id,
779    },
780
781SRST
782  ``info vm-generation-id``
783    Show Virtual Machine Generation ID
784ERST
785
786    {
787        .name       = "memory_size_summary",
788        .args_type  = "",
789        .params     = "",
790        .help       = "show the amount of initially allocated and "
791                      "present hotpluggable (if enabled) memory in bytes.",
792        .cmd        = hmp_info_memory_size_summary,
793    },
794
795SRST
796  ``info memory_size_summary``
797    Display the amount of initially allocated and present hotpluggable (if
798    enabled) memory in bytes.
799ERST
800
801#if defined(TARGET_I386)
802    {
803        .name       = "sev",
804        .args_type  = "",
805        .params     = "",
806        .help       = "show SEV information",
807        .cmd        = hmp_info_sev,
808    },
809#endif
810
811SRST
812  ``info sev``
813    Show SEV information.
814ERST
815
816    {
817        .name       = "replay",
818        .args_type  = "",
819        .params     = "",
820        .help       = "show record/replay information",
821        .cmd        = hmp_info_replay,
822    },
823
824SRST
825  ``info replay``
826    Display the record/replay information: mode and the current icount.
827ERST
828
829    {
830        .name       = "dirty_rate",
831        .args_type  = "",
832        .params     = "",
833        .help       = "show dirty rate information",
834        .cmd        = hmp_info_dirty_rate,
835    },
836
837SRST
838  ``info dirty_rate``
839    Display the vcpu dirty rate information.
840ERST
841
842    {
843        .name       = "vcpu_dirty_limit",
844        .args_type  = "",
845        .params     = "",
846        .help       = "show dirty page limit information of all vCPU",
847        .cmd        = hmp_info_vcpu_dirty_limit,
848    },
849
850SRST
851  ``info vcpu_dirty_limit``
852    Display the vcpu dirty page limit information.
853ERST
854
855#if defined(TARGET_I386)
856    {
857        .name       = "sgx",
858        .args_type  = "",
859        .params     = "",
860        .help       = "show intel SGX information",
861        .cmd        = hmp_info_sgx,
862    },
863#endif
864
865SRST
866  ``info sgx``
867    Show intel SGX information.
868ERST
869
870#if defined(CONFIG_MOS6522)
871    {
872        .name         = "via",
873        .args_type    = "",
874        .params       = "",
875        .help         = "show guest mos6522 VIA devices",
876        .cmd          = hmp_info_via,
877    },
878#endif
879
880SRST
881  ``info via``
882    Show guest mos6522 VIA devices.
883ERST
884
885    {
886        .name       = "stats",
887        .args_type  = "target:s,names:s?,provider:s?",
888        .params     = "target [names] [provider]",
889        .help       = "show statistics for the given target (vm or vcpu); optionally filter by"
890                      "name (comma-separated list, or * for all) and provider",
891        .cmd        = hmp_info_stats,
892    },
893
894SRST
895  ``info stats``
896    Show runtime-collected statistics
897ERST
898
899    {
900        .name      = "virtio",
901        .args_type = "",
902        .params    = "",
903        .help      = "List all available virtio devices",
904        .cmd       = hmp_virtio_query,
905        .flags     = "p",
906    },
907
908SRST
909  ``info virtio``
910    List all available virtio devices
911ERST
912
913    {
914        .name      = "virtio-status",
915        .args_type = "path:s",
916        .params    = "path",
917        .help      = "Display status of a given virtio device",
918        .cmd       = hmp_virtio_status,
919        .flags     = "p",
920    },
921
922SRST
923  ``info virtio-status`` *path*
924    Display status of a given virtio device
925ERST
926
927    {
928        .name      = "virtio-queue-status",
929        .args_type = "path:s,queue:i",
930        .params    = "path queue",
931        .help      = "Display status of a given virtio queue",
932        .cmd       = hmp_virtio_queue_status,
933        .flags     = "p",
934    },
935
936SRST
937  ``info virtio-queue-status`` *path* *queue*
938    Display status of a given virtio queue
939ERST
940
941    {
942        .name      = "virtio-vhost-queue-status",
943        .args_type = "path:s,queue:i",
944        .params    = "path queue",
945        .help      = "Display status of a given vhost queue",
946        .cmd       = hmp_vhost_queue_status,
947        .flags     = "p",
948    },
949
950SRST
951  ``info virtio-vhost-queue-status`` *path* *queue*
952    Display status of a given vhost queue
953ERST
954
955    {
956        .name       = "virtio-queue-element",
957        .args_type  = "path:s,queue:i,index:i?",
958        .params     = "path queue [index]",
959        .help       = "Display element of a given virtio queue",
960        .cmd        = hmp_virtio_queue_element,
961        .flags      = "p",
962    },
963
964SRST
965  ``info virtio-queue-element`` *path* *queue* [*index*]
966    Display element of a given virtio queue
967ERST
968
969    {
970        .name       = "cryptodev",
971        .args_type  = "",
972        .params     = "",
973        .help       = "show the crypto devices",
974        .cmd        = hmp_info_cryptodev,
975        .flags      = "p",
976    },
977
978SRST
979  ``info cryptodev``
980    Show the crypto devices.
981ERST
982