Bienvenue à Blogs CodeS-SourceS Identification | Inscription | Aide

CoqBlog

.NET is good :-)
{ Blog de coq }

Actualités

VMMap en mode instrumentation sur système 64bit : attention à la plateforme cible du build .NET

Si vous tentez d'utiliser VMMap en mode instrumentation* vous avez peut-être rencontré une erreur relativement peu explicite au lancement du profiling :

VMMap : message d'erreur "Unable to launch application", "The handle is invalid"

Unable to launch application:
"E:\Temp\ApplicationToProfile\ApplicationToProfile\bin\Release\ApplicationToProfile.exe"

Error:
The handle is invalid.

 

Cause

Cela se produit car sur un système 64bit, quand on lui fournit un exécutable compilé en plateforme cible Any CPU (Any CPU à l'ancienne, pas le nouveau Any CPU + "Prefer 32-bit" de VS2012), VMMap utilise son lanceur 32bit par défaut alors que notre processus va démarrer avec le CLR 64bit.

Ce comportement se constate facilement en utilisant Process Monitor (procmon) pour examiner le lancement du profiling, en ajoutant des filtres "Process Name" pour "vmmap.exe", "vmmap64.exe" et "ApplicationToProfile.exe" (dans mon cas) :

Process Monitor - Filtres

Process Monitor - Trace lancement profiling VMMap

On voit bien que vmmap64.exe (auto-extrait et lancé par VMMap si utilisé sur OS 64bit) relance sa version 32bit (vmmap.exe) pour qu'elle prenne en charge notre exécutable alors qu'il aurait dû lancer notre exécutable directement.
Pour les curieux la valeur du paramètre "-p" est juste le chemin de l'exécutable, en représentation texte des bytes UTF16 Big Endian de la chaine de caractères.

 

Solution

Pour pouvoir utiliser le mode instrumentation de VMMap sur une application .NET lancée sur un système 64bit alors qu'elle était compilée en plateforme cible Any CPU, il faut que celle-ci soit recompilée explicitement pour la plateforme qu'elle va utiliser, c'est-à-dire x64 :

Configuration Manager de Visual Studio

VMMap - Profiling d'application .NET en cours

 

 

* : Pour rappel le mode instrumentation est, par opposition au mode snapshot simple où on s'attache à un processus déjà démarré, le mode où VMMap lance lui même l'exécutable et instrumente certaines méthodes pour pouvoir tracer les allocations de mémoire.

On y accède par le second onglet, "Launch and trace a new process", de la boite de dialogue "Select or Launch Process" :

VMMap : boite de dialogue "Select or Launch Process", onglet "Launch and trace a new process"

Ce post vous a plu ? Ajoutez le dans vos favoris pour ne pas perdre de temps à le retrouver le jour où vous en aurez besoin :
Posted: samedi 25 mai 2013 22:25 par coq
Classé sous : ,

Commentaires

Pas de commentaires

Les commentaires anonymes sont désactivés

Les 10 derniers blogs postés

- Azure Days le 24 avril ! par Blog de Jérémy Jeanson le 04-08-2018, 17:51

- Office 365: Ajouter ou retirer des comptes utilisateurs des administrateurs de collections de site via PowerShell par Blog Technique de Romelard Fabrice le 02-19-2018, 18:18

- Office 365: Extraire dans un fichier CSV une liste de tous les Teamsites présents dans votre tenant Office 365 par Blog Technique de Romelard Fabrice le 02-19-2018, 15:39

- SharePoint 2007: Forcer le Check-In des fichiers avant la migration vers SharePoint Online par Blog Technique de Romelard Fabrice le 02-19-2018, 15:13

- Office 365: Comment configurer l’ouverture des fichiers stockés dans une Document Library par Blog Technique de Romelard Fabrice le 02-19-2018, 14:25

- Microsoft Flow - Boite Mail partagée - Bibliothèque SharePoint par Le Blog (Vert) d'Arnaud JUND le 01-12-2018, 09:05

- Office 365: Nettoyage des versions de List Item avant migration depuis SharePoint On Premise vers SharePoint Online par Blog Technique de Romelard Fabrice le 08-08-2017, 15:36

- Office 365: Comment supprimer des éléments de liste SharePoint Online via PowerShell par Blog Technique de Romelard Fabrice le 07-26-2017, 17:09

- Nouveau blog http://bugshunter.net par Blog de Jérémy Jeanson le 07-01-2017, 16:56

- Office 365: Script PowerShell pour assigner des droits Full Control à un groupe défini par Blog Technique de Romelard Fabrice le 04-30-2017, 09:22