Microsoft MVP성태의 닷넷 이야기
C#에서 C++ DLL호출 ('PInvokeStackImbalance') [링크 복사], [링크+제목 복사],
조회: 10940
글쓴 사람
궁금하당 (abj7777 at naver.com)
홈페이지
첨부 파일

안녕하세요. 구글링해도 도저히 모르겠어서 올리게 됐습니다.

여기도 관련 글들이 많이 있더군요.
우선 현상은 다음과 같습니다.
호출함수중 유독 구조체 자료형을 사용한 한놈에서 문제가 생겼는데요.

uCAN_SendCANTxFrmae(tx);
라인에서 아래 에러가 뜹니다. (빌드는 성공)
관리 디버깅 도우미 'PInvokeStackImbalance' : 'PInvoke 함수 'WindowsFormsApp2!WindowsFormsApp2.Form1::uCAN_SendCANTxFrmae'에 대한 호출 결과 스택이 불안정하게 되었습니다. 관리되는 PInvoke 시그니처와 관리되지 않는 대상 시그니처가 일치하지 않기 때문인 것 같습니다. 호출 규칙 및 PInvoke 시그니처의 매개 변수와 관리되지 않는 대상 시그니처가 일치하는지 확인하십시오.'

찾아보니

1.
[DllImport("uCANDLL.dll")] 여기서
[DllImport("uCANDLL.dll", SetLastError = true, CharSet = CharSet.Ansi, CallingConvention = CallingConvention.StdCall)]
을 추가해봐라.
.StdCall을 Cdecl등으로 바꿔봐라.

-> 실패

2.
Intptr 및 Marshal.PtrToStructure를 사용해봐라

-> 실패

3. struct를 class로 바꿔봐라

-> 실패

---------------
방법을 알려주시면 정말 감사하겠습니다. 아래는 사용중인 Visual Studio 정보에요.

Microsoft Visual Studio Community 2019
버전 16.1.2
VisualStudio.16.Release/16.1.2+29001.49
Microsoft .NET Framework
버전 4.8.03752

설치된 버전: Community

Visual C++ 2019 00435-60000-00000-AA559
Microsoft Visual C++ 2019

Application Insights Tools for Visual Studio 패키지 9.1.00429.1
Application Insights Tools for Visual Studio

ASP.NET and Web Tools 2019 16.1.429.50124
ASP.NET and Web Tools 2019

Azure App Service 도구 v3.0.0 16.1.429.50124
Azure App Service 도구 v3.0.0

C# 도구 3.1.1-beta4-19281-06+58a4b1e79aea28115e66b06f850c83a3f1fcb6d3
IDE에서 사용되는 C# 구성 요소입니다. 프로젝트 형식 및 설정에 따라 다른 버전의 컴파일러를 사용할 수 있습니다.

F# 4.6용 Visual F# Tools 10.4 16.1.0-beta.19253.3+42526fe359672a05fd562dc16a91a43d0fe047a7
F# 4.6용 Microsoft Visual F# Tools 10.4

IntelliCode 확장 1.0
IntelliCode Visual Studio 확장 세부 정보

Microsoft JVM Debugger 1.0
Provides support for connecting the Visual Studio debugger to JDWP compatible Java Virtual Machines

Microsoft MI-Based Debugger 1.0
Provides support for connecting Visual Studio to MI compatible debuggers

Microsoft Visual C++ Wizards 1.0
Microsoft Visual C++ Wizards

Microsoft Visual Studio VC 패키지 1.0
Microsoft Visual Studio VC 패키지

NuGet 패키지 관리자 5.1.0
NuGet Package Manager in Visual Studio. For more information about NuGet, visit https://docs.nuget.org/

ProjectServicesPackage Extension 1.0
ProjectServicesPackage Visual Studio Extension Detailed Info

ResourcePackage 확장 1.0
ResourcePackage Visual Studio 확장 세부 정보

ResourcePackage 확장 1.0
ResourcePackage Visual Studio 확장 세부 정보

Test Adapter for Boost.Test 1.0
Enables Visual Studio's testing tools with unit tests written for Boost.Test. The use terms and Third Party Notices are available in the extension installation directory.

Test Adapter for Google Test 1.0
Google Test용으로 작성된 단위 테스트와 함께 Visual Studio의 테스트 도구를 사용합니다. 사용 약관 및 타사 고지 사항은 확장 설치 디렉터리에서 확인할 수 있습니다.

Visual Basic 도구 3.1.1-beta4-19281-06+58a4b1e79aea28115e66b06f850c83a3f1fcb6d3
IDE에서 사용되는 Visual Basic 구성 요소입니다. 프로젝트 형식 및 설정에 따라 다른 버전의 컴파일러를 사용할 수 있습니다.

Visual Studio Code 디버그 어댑터 호스트 패키지 1.0
Visual Studio에서 Visual Studio Code 디버그 어댑터를 호스트하기 위한 Interop 계층

Visual Studio Tools for CMake 1.0
Visual Studio Tools for CMake

Visual Studio Tools for CMake 1.0
Visual Studio Tools for CMake

일반적인 Azure Tools 1.10
Azure Mobile Services 및 Microsoft Azure 도구에서 사용할 일반적인 서비스를 제공합니다.











[최초 등록일: ]
[최종 수정일: 2/27/2020]


비밀번호

댓글 작성자
 



2020-02-28 09시00분
제가 사실 모든 질문에 대해 환경 구성까지 해가면서 답변할 정도로 그렇게 친절한 사람은 아닙니다. ^^ 일단, 최소 재현 프로젝트를 비주얼 스튜디오에서 F5 키로 테스트할 수 있는 유형이어야 합니다.

단지, 해당 프로젝트의 CAN_Frame 정의를 보면 byte [] 타입의 필드를 포함하고 있던데 배열은 참조형이기 때문에 당연히 C/C++의 구조체와는 다릅니다. 아마도 다음의 글들을 읽어 보시면 스스로 해결하실 수 있을 것입니다.

C# - blittable 타입이란?
; https://www.sysnet.pe.kr/2/0/11557

C# - string 배열을 담은 구조체를 직렬화하는 방법
; https://www.sysnet.pe.kr/2/0/11319

Win32 Interop - 크기가 정해지지 않은 배열을 C++에서 C#으로 전달하는 경우
; https://www.sysnet.pe.kr/2/0/737

C# 7.3 - 구조체의 고정 크기를 갖는 fixed 배열 필드에 대한 직접 접근 가능
; https://www.sysnet.pe.kr/2/0/11556
정성태
2020-02-28 09시10분
아... ^^ 구조체 정의를 넣어두셨군요. 아래와 같은 식이라면,

/*
 struct CANFrame{
    UINT8 Format; unsigned char
    UINT32 ID; unsigned int
    UINT8 DLC; unsigned char
    UINT8 Data[8]; unsigned char
    UINT64 TimeStamp; unsigned __int64
} typedef CAN_Frame;*/

다음과 같이 정의해 주면 될 것입니다.

public struct CAN_Frame
{
    public byte Format;
    public uint ID;
    public byte DLC;
    [MarshalAs(UnmanagedType.U1, SizeConst = 8)]
    public byte[] Data;
    public ulong TimeStamp;
}

구조체 정렬이 어떻게 설정되었는지는 모르겠으나, 경우에 따라 Pack으로 맞춰주어야 할 수도 있습니다.

[StructLayout(LayoutKind.Sequential, Pack = 1)]
public struct CAN_Frame
{
 ...
}
정성태
2020-02-28 11시26분
[궁금하당] 오 큰 도움이 되었고, 해결됐습니다. 친절하고 정확한 답변 정말 감사드립니다.

다만, 말씀해주신대로 했을 때,

System.TypeLoadException: ''CAN_Frame' 형식의 'Data' 필드를 마샬링할 수 없습니다. 관리되는/관리되지 않는 형식 조합이 잘못되었습니다. 배열 필드는 ByValArray 또는 SafeArray와 쌍이 되어야 합니다.'

라는 오류가 떠서 아래같이 바꿨더니 성공적으로 됐습니다~!

[StructLayout(LayoutKind.Sequential, Pack = 1)] --> 변경
[StructLayout(LayoutKind.Sequential, CharSet = CharSet.Ansi)]

[MarshalAs(UnmanagedType.U1, SizeConst = 8)] --> 변경
[MarshalAs(UnmanagedType.ByValArray, SizeConst = 8)]

환경 정보는.. 구성을 부탁드리려 했다기 보단.. 혹시 디버깅에 참고가 될까해서 넣은 정보입니다..
[guest]
2020-02-28 11시29분
[궁금하당] 최종 오류안난 코드 -->

[StructLayout(LayoutKind.Sequential, CharSet = CharSet.Ansi)]
public struct CAN_Frame
{
    public byte Format;
    public uint ID;
    public byte DLC;
    [MarshalAs(UnmanagedType.ByValArray, SizeConst = 8)]
    public byte[] Data;
    public ulong TimeStamp;
}
[guest]

... 31  32  33  34  35  36  37  [38]  39  40  41  42  43  44  45  ...
NoWriterDateCnt.TitleFile(s)
4909필승11/5/201710632TextBox에 관해 질문 드립니다. [5]
4908필승11/1/201713984특정 시각에 프로그램 종료 또는 재시작시 오류 발생 [8]
4907심너울10/29/20179563선생님이 쓰신 "시작하세요! C# 7.1~"으로 공부하고 있는데요~ [2]
4906guest10/25/20179137.net core, .net standard 관련해서 궁금합니다 [2]
490510/25/20178403watermark 관련문의 [1]
4903Ho10/25/20178798간단한 서버를 구현해 보고 싶습니다. [2]
4902황재승10/22/20179848C# 7.1 프로그래밍 왕초보자도 이해할 수 있는 수준인가요? [1]
4901김레오10/17/201714564c# 프로그램 난독화 도구인 confuserex라는 도구를 사용하다 여쭙습니다. [2]
4900황준범10/12/201710319ClickOnce 배포관련 질문드립니다. [1]
4899Ques...9/28/201712769C# 프로그램이 "응답 없음" 시에도 계속 독립적으로 돌아가는 타이머 생성법 [3]
4898ssdrm9/27/20179550Clickonce 실행시 보안에 막힙니다 ㅠ [1]
4897김태진9/23/20179719윈도우7 작업관리자의 상세(details)탭 생성에 대해 여쭙습니다. [1]
4896장진국9/19/201711080안녕하세요 WPF 에서 Window객체가 가비지 콜렉션에 의해 수집되지 않는거 같아서 문의드립니다. [1]
4895Ques...9/18/201710743Generic 에 관하여 질문드립니다. [5]
4894얼마전6...9/14/201712641C# 7.1에서 보강된 부분만 PDF로 제공하는 건 아니되나요? [2]
4893BigII9/14/201711672타 언어(JAVA, PHP 등)에서 받은 RSA 개인키 문자열을 이용하여 내용 복호화 가능 여부 [4]
4892Ques...9/13/201710717서브 폼에서는 무거운 작업을해도 속도가 빠를까요 ?? [1]
4891윤현수9/11/201711327Taskbar에 관한 질문입니다. [5]
4890제발9/11/20179843 시작하세요! C# 6.0 프로그래밍 책이 절판됐나요? [5]파일 다운로드1
4889낙낙이9/7/20179279안녕하세요! xsl관련 이야기입니다. [1]
4888heyh...9/6/20179110클릭원스를 수동으로 배포 시 업데이트 할 때 [1]
4887이경현9/4/20179656Windows server 2012 파일 없어짐 현상... [1]
4886질문자9/1/201711528disconnecteditem에 대하여 아시나요? [4]파일 다운로드1
4883솔솔8/30/201710036dataview에서 select한 index 가져오기 [1]
4882user8/30/201712673UI 변경 작업 여러개를 동시에 사용하려면 어떻게 해야되나요 ?? [7]
4884user8/31/20179334    답변글 [답변]: UI 변경 작업 여러개를 동시에 사용하려면 어떻게 해야되나요 ??파일 다운로드1
... 31  32  33  34  35  36  37  [38]  39  40  41  42  43  44  45  ...