LabWindows/CVI

cancel
Showing results for 
Search instead for 
Did you mean: 

Non debuggable thread is trying to suspend execution

Solved!
Go to solution

Sorry.  Can't do much more help for you right now.  Seems it made it further than last time!?, although all the times are longer than your tick duration so thats no good

0 Kudos
Message 11 of 20
(3,422 Views)

Well I tried a very skinny version of my (rather large) program, with only the sampling of wave-in

 

Guess what? the error is gone!

 

Thing is, in my whole program if I leave just the sampling part out, the error is gone too!

 

Someone can make any chocolate out of this??!?!

0 Kudos
Message 12 of 20
(3,416 Views)

I slimmed the code down as small as possible, still having the error...

 

The (entire) c code is now:

 

 

#include <windows.h>
#include <MMSystem.h>
#include "laser.h"

#define SAMPLE_RATE 44100
#define NUMPTS      (int)(SAMPLE_RATE * 0.015)

short int waveIn[NUMPTS];   // 'short int' is a 16-bit type; I request 16-bit samples below

HWAVEIN      hWaveIn;
WAVEFORMATEX pFormat;
UINT 		 numDevs;
WAVEINCAPS   devCaps;
WAVEHDR      WaveInHdr; 
 
MMRESULT result;

int panel;


int WINAPI WinMain(HINSTANCE hInstance,      // handle to current instance
                   HINSTANCE hPrevInstance,  // handle to previous instance
                   LPSTR lpCmdLine,          // pointer to command line
                   int nCmdShow)             // show state of window
{
// Specify recording parameters
 
 pFormat.wFormatTag=WAVE_FORMAT_PCM;     // simple, uncompressed format
 pFormat.nChannels=1;                    //  1=mono, 2=stereo
 pFormat.nSamplesPerSec=SAMPLE_RATE;     // 44100
 pFormat.nAvgBytesPerSec=SAMPLE_RATE*2;  // = nSamplesPerSec * n.Channels * wBitsPerSample/8
 pFormat.nBlockAlign=2;                  // = n.Channels * wBitsPerSample/8
 pFormat.wBitsPerSample=16;              //  16 for high quality, 8 for telephone-grade
 pFormat.cbSize=0;

 waveInOpen(&hWaveIn, WAVE_MAPPER,&pFormat,
            0L, 0L, WAVE_FORMAT_DIRECT);

    if (InitCVIRTE (hInstance, 0, 0) == 0)
        return -1;
    if ((panel = LoadPanel (0, "laser.uir", PANEL)) < 0)
        return -1;
	
    DisplayPanel (panel);
    RunUserInterface ();
    DiscardPanel (panel);
	waveInClose(hWaveIn); 
	
    return 0;
}


int  CVICALLBACK timer(int panel, int control, int event, void *callbackData, int eventData1, int eventData2)
{
 if (event==EVENT_TIMER_TICK)
 {
 WAVEHDR      WaveInHdr;

// Set up and prepare header for input
 WaveInHdr.lpData = (LPSTR)waveIn;
 WaveInHdr.dwBufferLength = NUMPTS*2;
 WaveInHdr.dwBytesRecorded=0;
 WaveInHdr.dwUser = 0L;
 WaveInHdr.dwFlags = 0L;
 WaveInHdr.dwLoops = 0L;
 
 waveInPrepareHeader(hWaveIn, &WaveInHdr, sizeof(WaveInHdr));

 // Insert a wave input buffer
 waveInAddBuffer(hWaveIn, &WaveInHdr, sizeof(WaveInHdr));

 // Commence sampling input
 waveInStart(hWaveIn);

 // Wait until finished recording
 do {} while (waveInUnprepareHeader(hWaveIn, &WaveInHdr, sizeof(WaveInHdr))==WAVERR_STILLPLAYING);

 }
 return(0);
	
}

 

 

and the include file:

 

 

/**************************************************************************/
/* LabWindows/CVI User Interface Resource (UIR) Include File              */
/* Copyright (c) National Instruments 2010. All Rights Reserved.          */
/*                                                                        */
/* WARNING: Do not add to, delete from, or otherwise modify the contents  */
/*          of this include file.                                         */
/**************************************************************************/

#include <userint.h>

#ifdef __cplusplus
    extern "C" {
#endif

     /* Panels and Controls: */

#define  PANEL                            1
#define  PANEL_TIMER                      2       /* callback function: timer */


     /* Menu Bars, Menus, and Menu Items: */

          /* (no menu bars in the resource file) */


     /* Callback Prototypes: */

int  CVICALLBACK timer(int panel, int control, int event, void *callbackData, int eventData1, int eventData2);


#ifdef __cplusplus
    }
#endif

 

 

I also attached the files, including the *.uir.

Maybe someone could check whether he/she is having the same problem?

Download All
0 Kudos
Message 13 of 20
(3,413 Views)

i got the same error you did.

 

I tried debugging it and it seems the error occurs somewhere in the windows api code.  what is weird is that all the values always returned MMSUCCESS.  And looking at your test outputs, sometimes it error'ed in the middle of the printf, which leaves me to believe that it happened in a new thread created from the waveInStart;

 

The best info I found was at this link

 

Looking at the links - it seems the address of 7C90120E is in the ntdll.dll (ModLoad: 7c900000 7c9af000 ntdll.dll)

*** ERROR: Symbol file could not be found. Defaulted to export symbols for
ntdl
l.dll -
ntdll!DbgBreakPoint:
7c90120e cc int 3
0:000>

 

And maybe this link helps as it talks about full page heap?!

 

Seems you may need to debug the windows calls though.

 

Good Luck

0 Kudos
Message 14 of 20
(3,363 Views)

Well this certainly helps to point in the right direction!

 

So it is ntdll that is causing the errors, but to be honest that is the only thing I understand form your previous post 😕

 

A google search on ntdll errors suggest debugging it with windbg, but I really wouldn't know how......

0 Kudos
Message 15 of 20
(3,341 Views)

 

 I found a similiar topic:

http://us.generation-nt.com/answer/unhandled-exception-wavein-functions-help-26121542.html?page=2

 

where the 'solution' is to ignore the exception, which isn't very satisfying...

 

I noticed the errors are written to the debug output which gives:

 

HEAP[laser_dbg.exe]: Invalid address specified to RtlGetUserInfoHeap(00080000 , 009A700)

HEAP[laser_dbg.exe]: Invalid address specified to RtlGetUserInfoHeap(00080000 , 009A700)

HEAP[laser_dbg.exe]: Invalid address specified to RtlGetUserInfoHeap(00080000 , 009D400)

HEAP[laser_dbg.exe]: Invalid address specified to RtlGetUserInfoHeap(00080000 , 009D400)

HEAP[laser_dbg.exe]: Invalid address specified to RtlGetUserInfoHeap(00080000 , 009D600)

HEAP[laser_dbg.exe]: Invalid address specified to RtlGetUserInfoHeap(00080000 , 009D600)

 

Every time the break occurs one line is added.

 

So as you suggested, it indeed is 'heap-related', still don't quite know what that means though 😕

 

0 Kudos
Message 16 of 20
(3,331 Views)

Ya, as the problem gets lower and lower in the level of coding and OS, I know less Smiley Sad

 

It doesn't help when some of the suggested solutions are to ignore it or to increase the heap.  Unfortunately, I wouldn't know how to do either in CVI.  

 

You may need to update the header/subject message of the thread.

Message 17 of 20
(3,327 Views)
Solution
Accepted by topic author s060340

IT WORKS!!!

 

First, by enabling 'full page heap', the exceptions miracelously disappear! So this was yet another dead end in some way.

 

Appearently, heap errors appear when trying to write to an unallocated piece of memory, so it appears the buffer is unprepared too early.

 

The workaround is preparing the buffer only once (instead of every sample), and in the loop only call waveAddBuffer() and waveInStart()(and not waveIn(un)PrepareBuffer).

This way it either starts recording, or, when already recording, does nothing (i.e. return an error-value) and leaves the buffer alone.

By not unpreparing the buffer, it can't be not there and therefore the exceptions are gone!

 

ngay528, thank you very much for your help!

 

Regards Dirk

 

 

0 Kudos
Message 18 of 20
(3,320 Views)

Awesome!  Congrats and Good Luck with the program.

0 Kudos
Message 19 of 20
(3,316 Views)

I am also facing similar problem with RtlGetUserInfoHeap. In my program, waveInPrepareHeader and waveInUnprepareHeader are prepared once and waveInAddBuffer is kept in loop. Even though I am getting RtlGetUserInfoHeap problem. How to increase the heap size. Will it solve the problem without further deadend. Can you help.

 

y v subba rao

0 Kudos
Message 20 of 20
(2,952 Views)