123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115 |
- MODULE WMPerfMonPluginUsb; (** AUTHOR "staubesv"; PURPOSE "Performance Monitor USB transfer rate plugin"; *)
- (**
- * History:
- *
- * 16.02.2006 First Release (staubesv)
- * 23.06.2006 Adapted to WMPerfMonPlugins (staubesv)
- * 27.02.2007 Remove plugins when unloading module (staubesv)
- * 13.03.2007 Added more statistics variables (staubesv)
- *)
- IMPORT
- WMPerfMonPlugins,
- KernelLog, UsbDebug, UsbHcdi, Plugins, Modules;
- CONST
- PluginName = "USB Transfer Rate";
- ModuleName = "WMPerfMonPluginUsb";
- TYPE
- UsbParameter = POINTER TO RECORD(WMPerfMonPlugins.Parameter)
- controller : UsbHcdi.Hcd;
- END;
- UsbTransferRate = OBJECT(WMPerfMonPlugins.Plugin)
- VAR
- controller : UsbHcdi.Hcd;
- PROCEDURE Init(p : WMPerfMonPlugins.Parameter);
- VAR ds : WMPerfMonPlugins.DatasetDescriptor;
- BEGIN
- p.name := PluginName; p.description := "Amount of transfered data";
- SELF.controller := p(UsbParameter).controller;
- WMPerfMonPlugins.GetNameDesc(controller, p.devicename);
- p.modulename := ModuleName;
- p.max := 60*1024; p.autoMax := TRUE; p.minDigits := 5;
- NEW(ds, 9);
- ds[0].name := "NbytesTransfered";
- ds[1].name := "NnofTransfers";
- ds[2].name := "NnofBulkTransfers";
- ds[3].name := "NnofControlTransfers";
- ds[4].name := "NnofInterruptTransfers";
- ds[5].name := "NnofIsochronousTransfers";
- ds[6].name := "NnofUnknownTransfers";
- ds[7].name := "NnofInterrupts";
- ds[8].name := "NnofInterruptsHandled";
- p.datasetDescriptor := ds;
- END Init;
- PROCEDURE UpdateDataset;
- BEGIN
- dataset[0] := controller.NbytesTransfered;
- dataset[1] := controller.NnofTransfers;
- dataset[2] := controller.NnofBulkTransfers;
- dataset[3] := controller.NnofControlTransfers;
- dataset[4] := controller.NnofInterruptTransfers;
- dataset[5] := controller.NnofIsochronousTransfers;
- dataset[6] := controller.NnofUnknownTransfers;
- dataset[7] := controller.NnofInterrupts;
- dataset[8] := controller.NnofInterruptsHandled;
- END UpdateDataset;
- END UsbTransferRate;
- PROCEDURE AddPlugin(hcd : UsbHcdi.Hcd);
- VAR par : UsbParameter; plugin : UsbTransferRate;
- BEGIN {EXCLUSIVE}
- NEW(par); par.controller := hcd; NEW(plugin, par);
- END AddPlugin;
- PROCEDURE RemovePlugin(hcd : UsbHcdi.Hcd);
- VAR devicename : WMPerfMonPlugins.DeviceName;
- BEGIN {EXCLUSIVE}
- WMPerfMonPlugins.GetNameDesc(hcd, devicename);
- WMPerfMonPlugins.updater.RemoveByName(PluginName, devicename);
- END RemovePlugin;
- PROCEDURE EventHandler(event : WORD; plugin : Plugins.Plugin);
- BEGIN
- IF event = Plugins.EventAdd THEN
- AddPlugin(plugin (UsbHcdi.Hcd));
- ELSIF event = Plugins.EventRemove THEN
- RemovePlugin(plugin (UsbHcdi.Hcd));
- END;
- END EventHandler;
- PROCEDURE InitPlugins;
- VAR table : Plugins.Table; i : LONGINT;
- BEGIN
- IF UsbDebug.PerformanceMonitoring THEN
- UsbHcdi.controllers.AddEventHandler(EventHandler, i);
- UsbHcdi.controllers.GetAll(table);
- IF table # NIL THEN FOR i := 0 TO LEN(table)-1 DO AddPlugin(table[i] (UsbHcdi.Hcd)); END; END;
- ELSE KernelLog.String("WMPerfMonUsbPlugin: Performance counters not enabled in UsbHcdi.Mod"); KernelLog.Ln;
- END;
- END InitPlugins;
- PROCEDURE Install*;
- END Install;
- PROCEDURE Cleanup;
- VAR ignore : LONGINT;
- BEGIN
- IF UsbDebug.PerformanceMonitoring THEN
- UsbHcdi.controllers.RemoveEventHandler(EventHandler, ignore);
- WMPerfMonPlugins.updater.RemoveByModuleName(ModuleName);
- END;
- END Cleanup;
- BEGIN
- Modules.InstallTermHandler(Cleanup);
- InitPlugins;
- END WMPerfMonPluginUsb.
- WMPerfMonPluginUsb.Install ~ System.Free WMPerfMonPluginUsb ~
|