How/where to report MS bugs?
-
I am sorry if this is the wrong place to post this question. I couldn't figure out what the best forum for it would be. I think that I've ran into a bug in .NET Framework and I would like to report it to MS together with some sample code and files. I cannot seem to figure out where to send this information. After clicking for a while thru all the microsoft.com "contact us" pages I am totally lost. Any help will be greatly appreciated. TIA. Kostya.
Actually, there are a couple of Microsoft guys who are right here on CP. Nick Hodapp runs the Semicolon column, and it's about Microsoft support this month, you may want to check that out. Also, Eric Gunnerson is the C# Quality Assurance manager. If it's a problem that you have with C# rather than .NET, you could talk to him...of course, I'm sure he would be glad to relay a message to another department if you told him of a bug in .NET... Norm Almond: I seen some GUI's in my life but WTF is this mess ;-) Leppie: I made an app for my sister and she wouldnt use it till it was colorful enough:) Norm:good point leppie, from that statement I can only deduce that this GUI must be aimed at children:laugh: Leppie:My sister is 25:eek: -Norm on the MailMagic GUI
-
Actually, there are a couple of Microsoft guys who are right here on CP. Nick Hodapp runs the Semicolon column, and it's about Microsoft support this month, you may want to check that out. Also, Eric Gunnerson is the C# Quality Assurance manager. If it's a problem that you have with C# rather than .NET, you could talk to him...of course, I'm sure he would be glad to relay a message to another department if you told him of a bug in .NET... Norm Almond: I seen some GUI's in my life but WTF is this mess ;-) Leppie: I made an app for my sister and she wouldnt use it till it was colorful enough:) Norm:good point leppie, from that statement I can only deduce that this GUI must be aimed at children:laugh: Leppie:My sister is 25:eek: -Norm on the MailMagic GUI
David, It looks like the bug is in one of the .NET Class Library classes, so it is not language specific. In fact, I have just tried it in C# (Windows app), VB.NET (Windows app) and ASP.NET (C#). In all 3 cases I get the same exception in exactly the same place, so it seems to be the Framework problem. I hate to bother Nick Nodapp or Eric Gunnerson if there is a place where bug reports like this should be sent. But if I won't find place like that, I guess, I will have to ask them for help. Thank you for your suggestions.
-
David, It looks like the bug is in one of the .NET Class Library classes, so it is not language specific. In fact, I have just tried it in C# (Windows app), VB.NET (Windows app) and ASP.NET (C#). In all 3 cases I get the same exception in exactly the same place, so it seems to be the Framework problem. I hate to bother Nick Nodapp or Eric Gunnerson if there is a place where bug reports like this should be sent. But if I won't find place like that, I guess, I will have to ask them for help. Thank you for your suggestions.
Read Nick's Semicolon article. He talks about how to report bugs. Tim Smith "Programmers are always surrounded by complexity; we can not avoid it... If our basic tool, the language in which we design and code our programs, is also complicated, the language itself becomes part of the problem rather that part of the solution." Hoare - 1980 ACM Turing Award Lecture
-
David, It looks like the bug is in one of the .NET Class Library classes, so it is not language specific. In fact, I have just tried it in C# (Windows app), VB.NET (Windows app) and ASP.NET (C#). In all 3 cases I get the same exception in exactly the same place, so it seems to be the Framework problem. I hate to bother Nick Nodapp or Eric Gunnerson if there is a place where bug reports like this should be sent. But if I won't find place like that, I guess, I will have to ask them for help. Thank you for your suggestions.
Tell us the class name, member and the context of use. There are IL desassemblers out there to exactly figure out what's going on.
She's so dirty, she threw a boomerang and it wouldn't even come back.
-
Read Nick's Semicolon article. He talks about how to report bugs. Tim Smith "Programmers are always surrounded by complexity; we can not avoid it... If our basic tool, the language in which we design and code our programs, is also complicated, the language itself becomes part of the problem rather that part of the solution." Hoare - 1980 ACM Turing Award Lecture
Thank you.
-
Tell us the class name, member and the context of use. There are IL desassemblers out there to exactly figure out what's going on.
She's so dirty, she threw a boomerang and it wouldn't even come back.
I don't see how IL disassembler will help me. Perhaps, I will be able to pin point the problem down to a specific location, but I will not be able to fix or redistribute a fix to the rest of the world. MS needs to know about it, so if it is indeed a bug they can fix it in the next SP or patch. Am I wrong?
-
I don't see how IL disassembler will help me. Perhaps, I will be able to pin point the problem down to a specific location, but I will not be able to fix or redistribute a fix to the rest of the world. MS needs to know about it, so if it is indeed a bug they can fix it in the next SP or patch. Am I wrong?
They have S.I.G.s and hords of consultants for this purpose already. Fixing this thing ? Of course not, think workaround instead. That's what an IL disassembler is for. (chop Anakrino).
She's so dirty, she threw a boomerang and it wouldn't even come back.
-
I don't see how IL disassembler will help me. Perhaps, I will be able to pin point the problem down to a specific location, but I will not be able to fix or redistribute a fix to the rest of the world. MS needs to know about it, so if it is indeed a bug they can fix it in the next SP or patch. Am I wrong?
What Stephane wants to try is disassembling the actuall .NET Framework class. When you do that, you can see what the .NET class is actually doing and can see if it really does what you want it to do... Which class is it by the way? Norm Almond: I seen some GUI's in my life but WTF is this mess ;-) Leppie: I made an app for my sister and she wouldnt use it till it was colorful enough:) Norm:good point leppie, from that statement I can only deduce that this GUI must be aimed at children:laugh: Leppie:My sister is 25:eek: -Norm on the MailMagic GUI
-
They have S.I.G.s and hords of consultants for this purpose already. Fixing this thing ? Of course not, think workaround instead. That's what an IL disassembler is for. (chop Anakrino).
She's so dirty, she threw a boomerang and it wouldn't even come back.
__Stephane Rodriguez__ wrote: That's what an IL disassembler is for. (chop Anakrino). I don't like Anakrino very much either... X| Just give me the good-old-fashioned IL...:-D Norm Almond: I seen some GUI's in my life but WTF is this mess ;-) Leppie: I made an app for my sister and she wouldnt use it till it was colorful enough:) Norm:good point leppie, from that statement I can only deduce that this GUI must be aimed at children:laugh: Leppie:My sister is 25:eek: -Norm on the MailMagic GUI
-
They have S.I.G.s and hords of consultants for this purpose already. Fixing this thing ? Of course not, think workaround instead. That's what an IL disassembler is for. (chop Anakrino).
She's so dirty, she threw a boomerang and it wouldn't even come back.
Ok. Here it goes: I need to read EXIF info out of JPEG images. There is support for it in .NET
System.Drawing.Image
class. The property in question isPropertyItems
. This property returns an array ofSystem.Drawing.Imaging.PropertyItem
objects. A very simple code sample would be:Image img = Image.FromFile("mypicture.jpg");
PropertyItem[] pitems = img.PropertyItems;It used to work fine. However, there is a new digital camera that was just released just a few days ago that produces images with EXIF 2.2 (updated standard) information. The camera is Sony DSC-F717. Whenever I am trying to use image out of this camera I get an exception "Value cannot be null" in the second line of the above code. Naturally, my first thought was that .NET is just not written to support newer EXIF standard. But there are 2 problems with this: a) It should not give an exception - it does not seem like a correct behavior in this case. It should report "Invalid format" or something... b) I've found images out of another brand of camera that are in EXIF 2.2 format and they work... Then I thought that Sony camera's produces invalid images (not following standard or bug in encoding), but it still should not crash the framework IMO. That is the description of my problem. I can supply a sample image that causes the error if someone cares to see it for themselves.
-
What Stephane wants to try is disassembling the actuall .NET Framework class. When you do that, you can see what the .NET class is actually doing and can see if it really does what you want it to do... Which class is it by the way? Norm Almond: I seen some GUI's in my life but WTF is this mess ;-) Leppie: I made an app for my sister and she wouldnt use it till it was colorful enough:) Norm:good point leppie, from that statement I can only deduce that this GUI must be aimed at children:laugh: Leppie:My sister is 25:eek: -Norm on the MailMagic GUI
According to my Call Stack the error occures somewhere in System.Drawing.Imaging.PropertyItemInternal class. I have posted the details in response to Stephane. Thanks.
-
Ok. Here it goes: I need to read EXIF info out of JPEG images. There is support for it in .NET
System.Drawing.Image
class. The property in question isPropertyItems
. This property returns an array ofSystem.Drawing.Imaging.PropertyItem
objects. A very simple code sample would be:Image img = Image.FromFile("mypicture.jpg");
PropertyItem[] pitems = img.PropertyItems;It used to work fine. However, there is a new digital camera that was just released just a few days ago that produces images with EXIF 2.2 (updated standard) information. The camera is Sony DSC-F717. Whenever I am trying to use image out of this camera I get an exception "Value cannot be null" in the second line of the above code. Naturally, my first thought was that .NET is just not written to support newer EXIF standard. But there are 2 problems with this: a) It should not give an exception - it does not seem like a correct behavior in this case. It should report "Invalid format" or something... b) I've found images out of another brand of camera that are in EXIF 2.2 format and they work... Then I thought that Sony camera's produces invalid images (not following standard or bug in encoding), but it still should not crash the framework IMO. That is the description of my problem. I can supply a sample image that causes the error if someone cares to see it for themselves.
As expected, System.Drawing.Image.FromFile("...") does a simple GDI+ call : GdipLoadImageFromFile("..."). Which is a gdi+ exported function (see dumpbin /exports <winsysdir>gdiplus.dll). So the issue is more probably in GDI+ itself. There is no direct reference to the GdipLoadImageFromFile() function in the MSDN documentation. Instead you have a reference to the actual method in the Image class wrapper. Just here[^].
She's so dirty, she threw a boomerang and it wouldn't even come back.
-
Ok. Here it goes: I need to read EXIF info out of JPEG images. There is support for it in .NET
System.Drawing.Image
class. The property in question isPropertyItems
. This property returns an array ofSystem.Drawing.Imaging.PropertyItem
objects. A very simple code sample would be:Image img = Image.FromFile("mypicture.jpg");
PropertyItem[] pitems = img.PropertyItems;It used to work fine. However, there is a new digital camera that was just released just a few days ago that produces images with EXIF 2.2 (updated standard) information. The camera is Sony DSC-F717. Whenever I am trying to use image out of this camera I get an exception "Value cannot be null" in the second line of the above code. Naturally, my first thought was that .NET is just not written to support newer EXIF standard. But there are 2 problems with this: a) It should not give an exception - it does not seem like a correct behavior in this case. It should report "Invalid format" or something... b) I've found images out of another brand of camera that are in EXIF 2.2 format and they work... Then I thought that Sony camera's produces invalid images (not following standard or bug in encoding), but it still should not crash the framework IMO. That is the description of my problem. I can supply a sample image that causes the error if someone cares to see it for themselves.
This sounds like it could be a bug in GDI+, there was another one found earlier this year by someone on CP (I forget the exact symptoms now). My suggestion is to make a post similar to this one in the appropriate CP forum (.NET Framework) and/or post on the appropriate public MS newsgroup for .NET.
James Sig code stolen from David Wulff
-
Ok. Here it goes: I need to read EXIF info out of JPEG images. There is support for it in .NET
System.Drawing.Image
class. The property in question isPropertyItems
. This property returns an array ofSystem.Drawing.Imaging.PropertyItem
objects. A very simple code sample would be:Image img = Image.FromFile("mypicture.jpg");
PropertyItem[] pitems = img.PropertyItems;It used to work fine. However, there is a new digital camera that was just released just a few days ago that produces images with EXIF 2.2 (updated standard) information. The camera is Sony DSC-F717. Whenever I am trying to use image out of this camera I get an exception "Value cannot be null" in the second line of the above code. Naturally, my first thought was that .NET is just not written to support newer EXIF standard. But there are 2 problems with this: a) It should not give an exception - it does not seem like a correct behavior in this case. It should report "Invalid format" or something... b) I've found images out of another brand of camera that are in EXIF 2.2 format and they work... Then I thought that Sony camera's produces invalid images (not following standard or bug in encoding), but it still should not crash the framework IMO. That is the description of my problem. I can supply a sample image that causes the error if someone cares to see it for themselves.
For Image.PropertyItems, it's the same GDI+ stuff (Image::GetPropertyItem gdi+ wrapper in gdiplus.dll). I would be you, I would try to reproduce the issue using C++ alone. That said, I don't know all ins and outs about JPEG codecs, but you'll find in PlatformSDK\include\prelease\GdiplusImaging.h the GUID for the JPEG codec, and more interestingly this :
//---------------------------------------------------------------------------
// Property sets
//---------------------------------------------------------------------------DEFINE_GUID(FormatIDImageInformation, 0xe5836cbe,0x5eef,0x4f1d,0xac,0xde,0xae,0x4c,0x43,0xb6,0x08,0xce);
DEFINE_GUID(FormatIDJpegAppHeaders, 0x1c4afdcd,0x6177,0x43cf,0xab,0xc7,0x5f,0x51,0xaf,0x39,0xee,0x85);which lets me believe you can handle custom JPEG internals with the current gdiplus. Lotsa work tonight for those interested ! (sorry, I'm already falling asleep....:zzz:)
She's so dirty, she threw a boomerang and it wouldn't even come back.
-
According to my Call Stack the error occures somewhere in System.Drawing.Imaging.PropertyItemInternal class. I have posted the details in response to Stephane. Thanks.
Here is the PropertyItem internal :
public System.Drawing.Imaging.PropertyItem[] get_PropertyItems() {
int local0;
int local1;
int local2;
IntPtr local3;
System.Drawing.Imaging.PropertyItem[] local4;local2 = SafeNativeMethods.GdipGetPropertyCount(this.nativeImage, local1); if (local2 != 0) throw SafeNativeMethods.StatusException(local2); local2 = SafeNativeMethods.GdipGetPropertySize(this.nativeImage, local0, local1); if (local2 != 0) throw SafeNativeMethods.StatusException(local2); if (local0 == 0 || local1 == 0) return new PropertyItem\[0\]; local3 = Marshal.AllocHGlobal(local0); local2 = SafeNativeMethods.GdipGetAllPropertyItems(this.nativeImage, local0, local1, local3); if (local2 != 0) { Marshal.FreeHGlobal(local3); throw SafeNativeMethods.StatusException(local2); } local4 = PropertyItemInternal.ConvertFromMemory(local3, local1); Marshal.FreeHGlobal(local3); GC.KeepAlive(this); return local4;
}
You can see the gdiplus calls. PropertyItemInternal.ConvertFromMemory :
nternal static System.Drawing.Imaging.PropertyItem[] ConvertFromMemory(IntPtr propdata, int count) {
System.Drawing.Imaging.PropertyItem[] local0;
int local1;
PropertyItemInternal local2;local0 = new PropertyItem\[checked((uint) count)\]; local1 = 0; while (local1 < count) { local2 = (PropertyItemInternal) UnsafeNativeMethods.PtrToStructure(propdata, typeof(PropertyItemInternal)); local0\[local1\] = new PropertyItem(); local0\[local1\].Id = local2.id; local0\[local1\].Len = local2.len; local0\[local1\].Type = local2.type; local0\[local1\].Value = local2.Value; propdata = 20315E582031596Cop\_Explicit20315970
20315E582031596Cop_Explicit20315970
propdata20315968 + (long) Marshal.SizeOf(typeof(PropertyItemInternal))20315968;
local1++;
}
return local0;
}
She's so dirty, she threw a boomerang and it wouldn't even come back.
-
Here is the PropertyItem internal :
public System.Drawing.Imaging.PropertyItem[] get_PropertyItems() {
int local0;
int local1;
int local2;
IntPtr local3;
System.Drawing.Imaging.PropertyItem[] local4;local2 = SafeNativeMethods.GdipGetPropertyCount(this.nativeImage, local1); if (local2 != 0) throw SafeNativeMethods.StatusException(local2); local2 = SafeNativeMethods.GdipGetPropertySize(this.nativeImage, local0, local1); if (local2 != 0) throw SafeNativeMethods.StatusException(local2); if (local0 == 0 || local1 == 0) return new PropertyItem\[0\]; local3 = Marshal.AllocHGlobal(local0); local2 = SafeNativeMethods.GdipGetAllPropertyItems(this.nativeImage, local0, local1, local3); if (local2 != 0) { Marshal.FreeHGlobal(local3); throw SafeNativeMethods.StatusException(local2); } local4 = PropertyItemInternal.ConvertFromMemory(local3, local1); Marshal.FreeHGlobal(local3); GC.KeepAlive(this); return local4;
}
You can see the gdiplus calls. PropertyItemInternal.ConvertFromMemory :
nternal static System.Drawing.Imaging.PropertyItem[] ConvertFromMemory(IntPtr propdata, int count) {
System.Drawing.Imaging.PropertyItem[] local0;
int local1;
PropertyItemInternal local2;local0 = new PropertyItem\[checked((uint) count)\]; local1 = 0; while (local1 < count) { local2 = (PropertyItemInternal) UnsafeNativeMethods.PtrToStructure(propdata, typeof(PropertyItemInternal)); local0\[local1\] = new PropertyItem(); local0\[local1\].Id = local2.id; local0\[local1\].Len = local2.len; local0\[local1\].Type = local2.type; local0\[local1\].Value = local2.Value; propdata = 20315E582031596Cop\_Explicit20315970
20315E582031596Cop_Explicit20315970
propdata20315968 + (long) Marshal.SizeOf(typeof(PropertyItemInternal))20315968;
local1++;
}
return local0;
}
She's so dirty, she threw a boomerang and it wouldn't even come back.
Yes and here is my call stack:
mscorlib.dll!System.Runtime.InteropServices.Marshal::Copy(__int32 source = 0, unsigned char[] destination = {Length=0},
__int32 startIndex = 0, __int32 length = 0) + 0x26 bytessystem.drawing.dll!System.Drawing.Imaging.PropertyItemInternal::get_Value() + 0x3d bytes
system.drawing.dll!System.Drawing.Imaging.PropertyItemInternal::ConvertFromMemory(__int32 propdata = 1541584,
__int32 count = 49) + 0x100 bytessystem.drawing.dll!System.Drawing.Image::get_PropertyItems() + 0xe6 bytes
Clearly 0 is being passed as an argument to Marshal::Copy(). There is some check is missing for IntPtr == null... Chris M. is going to ban us forever for posting all this programming stuff in the lounge... :-O
-
I am sorry if this is the wrong place to post this question. I couldn't figure out what the best forum for it would be. I think that I've ran into a bug in .NET Framework and I would like to report it to MS together with some sample code and files. I cannot seem to figure out where to send this information. After clicking for a while thru all the microsoft.com "contact us" pages I am totally lost. Any help will be greatly appreciated. TIA. Kostya.
-
Read Nick's Semicolon article. He talks about how to report bugs. Tim Smith "Programmers are always surrounded by complexity; we can not avoid it... If our basic tool, the language in which we design and code our programs, is also complicated, the language itself becomes part of the problem rather that part of the solution." Hoare - 1980 ACM Turing Award Lecture
And it's pretty obvious that his article was needed, if support was so hard to find at the Microsoft site ( I don't know, I've never looked ) Christian Hey, at least Logo had, at it's inception, a mechanical turtle. VB has always lacked even that... - Shog9 04-09-2002 During last 10 years, with invention of VB and similar programming environments, every ill-educated moron became able to develop software. - Alex E. - 12-Sept-2002
-
Thank you. Now, where are those homework questions I had... :)
-
Chris Maunder wrote: Just send Nick all your bugs (VS.NET related, .NET framework related, your homework questions...). The more the merrier. Ooh, Nick's gonna get you for that one. Don't forget his blackmail threat in this month's column! Chistopher Duncan Author - The Career Programmer: Guerilla Tactics for an Imperfect World (Apress)