Microsoft MVP성태의 닷넷 이야기
C++의 double pointer를 C#에서 구현하는 방법이 잘 안됩니다. [링크 복사], [링크+제목 복사],
조회: 14094
글쓴 사람
Heegyoo Lee
홈페이지
첨부 파일
 
(연관된 글이 1개 있습니다.)

안녕하세요.
좀 오래된 이미지 그래버 보드를 C#에서 사용하려고 합니다.
보드는 DLL 형태로 드라이버를 제공하는데
Init함수를 호출하면 보드에서 사용할 버퍼의 메모리 주소를 리턴하고
Scan을 시작하면 위 주소부터 이미지 데이터를 쓰게 됩니다.
C++에서는 다음과 같이 사용하면 동작합니다.

extern "C" __declspec(dllimport) bool OpenPCI(DWORD **RAM);
    pOpen = (DLL_Open)GetProcAddress(hdll, "OpenPCI");
    HMODULE hdll = LoadLibrary(L"aa.dll");
DWORD* RAMPCI;

    pOpen(&RAMPCI);
 ...
    DWORD data[i] = RAMPCI[i];
...

이를 C#으로 바꾸고자 해서 다음과 같이

        [DllImport("aa.dll", CallingConvention = CallingConvention.Cdecl)]
        public static extern bool OpenPCI(ref IntPtr pVRAM);

        IntPtr pVRAM = IntPtr.Zero;
        bool res = OpenPCI(ref pVRAM); //
...
        Marshal.Copy(pVRAM, linebuff, 0, Length); // 1 line read

코드를 작성했는데 컴파일 에러는 없이 동작은 하나 주소가 맞는지 알 수 없습니다.
실행해 보면 Marshal.Copy 수행 중에 보호된 메모리를 참조한다는 오류가 발생합니다.
디버거에서는 Open시 시그니처 오류로 스택이 불안정 해진다는 메세지가 나옵니다.

질문 : C++에서 RAMPCI 포인터의 주소를 인자로 보내면 버퍼 메모리 주소를 포인터의 값에 넣어 주는데
  C#에서 IntPtr의 주소를 갖는 포인터를 또 만들 수 있는지, 위의 코드처럼 ref pVRAM 으로 직접 받아 오면
  어떤 값이 리턴되어 오는지 궁금합니다.


[연관 글]






[최초 등록일: ]
[최종 수정일: 10/27/2023]


비밀번호

댓글 작성자
 



2023-10-27 07시34분
일단, 올려주신 조각 코드로는 문제가 없어 보입니다.

혹시 Marshal.Copy에서 크기에 맞지 않게 지정한 것이 아닐까요? 혹은, 확인을 위해 DWORD **pptr 인자를 받는 C++ DLL을 예제 코드로 작성해 interop 해보시면 좀 더 문제가 명확해 질 것입니다. 그렇게 했는데도 여전히 동일한 문제가 발생하면 만드신 예제 코드를 첨부해 주시면 코드를 확인해 보겠습니다.

다음의 글도 참고하세요.

Win32 Interop - C/C++ DLL로부터 이중 포인터 버퍼를 C#으로 받는 예제
; https://www.sysnet.pe.kr/2/0/13429
정성태
2023-11-03 07시38분
코드 자체는 동작하는 것처럼 보이는데요. (어떤 때는 시그니쳐가 맞지않아 스택이 불안정해진다.라는 메세지가 나옵니다.)
보드를 Open하면 버퍼를 0x100000 바이트 크기로 데이터를 써넣는데 중간에 '보호된 메모리를 액세스 하려고 한다.'는 에러가 납니다.
디버거에서 메모리를 보면 중간에 일부 구역이 ??로 표시되고 있습니다.
이것은 메모리에 대한 접근 권한이 없어서 나오는 에러 같은데 OS나 Visual Studio 버전을 낮춰봐도 같은 에러가 발생합니다.
원인을 찾아 보려면 어떻게 해야 할지 조언 구합니다.
Heegyoo Lee
2023-11-06 08시44분
일단, PInvokeStackImbalance 오류가 발생했다는 것은 아마도 호출 규약이 맞지 않았다는 것이고, 그렇다면 64비트 응용 프로그램이 아닌, 32비트 응용 프로그램인 것 같은데, 이런 경우 정확한 호출 규약을 맞춰줘야 합니다. 다음의 글을 보시고 이에 대해 Cdecl, Stdcall 등의 유형을 DllImport에 지정하시면 됩니다.

C# 개발자를 위한 Win32 DLL export 함수의 호출 규약 (1) - x86 환경에서의 __cdecl, __stdcall에 대한 Name mangling
; https://www.sysnet.pe.kr/2/0/11132

올려주신 조각 코드로 봐서는 아마도 "[DllImport("aa.dll", CallingConvention = CallingConvention.Cdecl)]"라고 쓴 것이 맞을 텐데... PInvokeStackImbalance 오류가 난다는 것이 좀 의아한 상황입니다.

'??'로 표시된 경우는, 접근 권한이 없다기보다는 잘못된 위치를 나타내고 있을 가능성이 더 큽니다. (따라서 OS나 비주얼 스튜디오의 버전과는 무관합니다.)

더 이상은 (원칙은 이미 모두 설명했기 때문에) 딱히 조언해 드릴 것이 없습니다. (재현 가능한 예제 코드가 필요합니다.)
정성태

... 31  32  33  [34]  35  36  37  38  39  40  41  42  43  44  45  ...
NoWriterDateCnt.TitleFile(s)
5055초보자8/29/201818893asp.net 에서 다른 서버의 iis를 stop하는 batch file을 실행시키는데 동작하지 않습니다. [5]
5054사도신8/29/201817748[wpf] textbox insert overite 모드시에 [4]파일 다운로드1
5053엿장수8/26/201816249directshow filter 에서의 IMediaSample 의 시간에대한질문입니다 [1]
5052오명현8/26/201816249Tcp소켓 실습 Exeption 도와주세요! [4]파일 다운로드1
5049오명현8/23/201816162책 477페이지 내용 중 이해가 안가는 부분이 있어 질문드립니다. [1]
5048오명현8/23/201815596포트 관련 질문 하나더 있습니다. [1]
5047오명현8/22/201816765포트가 없을 경우를 가정한 내용에 대해 질문이 있습니다. 책468p. [1]
5046엿장수8/22/201816430다이렉트쇼 필터 추가하는데 [2]
5045임도진8/22/201817374c# opencv dll파일 로드 질문 [3]파일 다운로드1
5044엿장수8/20/201817441graphedit 에 등록되어있는 필터를 가져와서 사용하는방법을 알고싶습니다 [2]
5043hori...8/20/201817299Expression에 대한 책의 예제 관련하여 질문드립니다. [1]
5042황윤하8/20/201819789모드버스 TCP 관련 질문 [3]
5041david8/18/201819078.NET WebAPI 에서 Response 지연되는 이유 [3]
5040농상8/14/201818328정규표현식에 대해서 [3]
5039유영태8/14/201820141비동기 소켓사용후 해당 스레드가 남아있을때 처리 방법 [4]파일 다운로드1
5038이정석8/9/201818252서버파일 로컬파일 비교 [2]
5037jjh8/8/201822929c# 으로 화면캡쳐해서 동영상으로 만드는앱을 만들고싶습니다 [6]
5036볼딱지8/8/201820405C# programming 개발 관련 질문이 있습니다. [1]
5035궁금합니...8/8/201821076C# 버전 고민 어떤 책을 사야하나요? [1]
5034신동열8/8/201818821덤프 파일 분석 관련해서 문의 드려요. [1]
5033최규성8/7/201821663C# WinForm, Oracle 9i 로 프로그래밍시 ODP.NET, 배포 설정 방법 질문입니다. [6]
5032이정석8/6/201823485C# 으로 만들 dll 등록 [7]
5031J.S.8/6/201817638System.Array class의 구조에 대한 질문 [1]
5030농상8/4/201817965람다 식을 이용한 메서드 정의 확대를 공부하고 있습니다. [2]
5029Soul...8/3/201818032C# ActiveX 컨트롤 질문드립니다. [4]
5028도토리8/1/201818193혹시 회사에서 TFS 구축시 SQL-Server 라이선스 정책 아시는분 계신지요? [2]
... 31  32  33  [34]  35  36  37  38  39  40  41  42  43  44  45  ...