Spaces:
Runtime error
Runtime error
File size: 4,807 Bytes
83418c6 |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 |
ASIO-README.txt This document contains information to help you compile PortAudio with ASIO support. If you find any omissions or errors in this document please notify us on the PortAudio mailing list. NOTE: The Macintosh sections of this document are provided for historical reference. They refer to pre-OS X Macintosh. PortAudio no longer supports pre-OS X Macintosh. Steinberg does not support ASIO on Mac OS X. Building PortAudio with ASIO support ------------------------------------ To build PortAudio with ASIO support you need to compile and link with pa_asio.c, and files from the ASIO SDK (see below), along with the common PortAudio files from src/common/ and platform specific files from src/os/win/ (for Win32). If you are compiling with a non-Microsoft compiler on Windows, also compile and link with iasiothiscallresolver.cpp (see below for an explanation). For some platforms (MingW, Cygwin/MingW), you may simply be able to type: ./configure --with-host_os=mingw --with-winapi=asio [--with-asiodir=/usr/local/asiosdk2] make and life will be good. Make sure you update the above with the correct local path to the ASIO SDK. For Microsoft Visual C++ there is an build tutorial here: http://www.portaudio.com/trac/wiki/TutorialDir/Compile/WindowsASIOMSVC Obtaining the ASIO SDK ---------------------- In order to build PortAudio with ASIO support, you need to download the ASIO SDK (version 2.0 or later) from Steinberg. Steinberg makes the ASIO SDK available to anyone free of charge, however they do not permit its source code to be distributed. NOTE: In some cases the ASIO SDK may require patching, see below for further details. http://www.steinberg.net/en/company/developer.html If the above link is broken search Google for: "download steinberg ASIO SDK" Building the ASIO SDK on Windows -------------------------------- To build the ASIO SDK on Windows you need to compile and link with the following files from the ASIO SDK: asio_sdk\common\asio.cpp asio_sdk\host\asiodrivers.cpp asio_sdk\host\pc\asiolist.cpp You may also need to adjust your include paths to support inclusion of header files from the above directories. The ASIO SDK depends on the following COM API functions: CoInitialize, CoUninitialize, CoCreateInstance, CLSIDFromString For compilation with MinGW you will need to link with -lole32, for Borland compilers link with Import32.lib. Non-Microsoft (MSVC) Compilers on Windows including Borland and GCC ------------------------------------------------------------------- Steinberg did not specify a calling convention in the IASIO interface definition. This causes the Microsoft compiler to use the proprietary thiscall convention which is not compatible with other compilers, such as compilers from Borland (BCC and C++Builder) and GNU (gcc). Steinberg's ASIO SDK will compile but crash on initialization if compiled with a non-Microsoft compiler on Windows. PortAudio solves this problem using the iasiothiscallresolver library which is included in the distribution. When building ASIO support for non-Microsoft compilers, be sure to compile and link with iasiothiscallresolver.cpp. Note that iasiothiscallresolver includes conditional directives which cause it to have no effect if it is compiled with a Microsoft compiler, or on the Macintosh. If you use configure and make (see above), this should be handled automatically for you. For further information about the IASIO thiscall problem see this page: http://www.rossbencina.com/code/iasio-thiscall-resolver Building the ASIO SDK on (Pre-OS X) Macintosh --------------------------------------------- To build the ASIO SDK on Macintosh you need to compile and link with the following files from the ASIO SDK: host/asiodrivers.cpp host/mac/asioshlib.cpp host/mac/codefragements.cpp You may also need to adjust your include paths to support inclusion of header files from the above directories. (Pre-OS X) Macintosh ASIO SDK Bug Patch --------------------------------------- There is a bug in the ASIO SDK that causes the Macintosh version to often fail during initialization. Below is a patch that you can apply. In codefragments.cpp replace getFrontProcessDirectory function with the following one (GetFrontProcess replaced by GetCurrentProcess). bool CodeFragments::getFrontProcessDirectory(void *specs) { FSSpec *fss = (FSSpec *)specs; ProcessInfoRec pif; ProcessSerialNumber psn; memset(&psn,0,(long)sizeof(ProcessSerialNumber)); // if(GetFrontProcess(&psn) == noErr) // wrong !!! if(GetCurrentProcess(&psn) == noErr) // correct !!! { pif.processName = 0; pif.processAppSpec = fss; pif.processInfoLength = sizeof(ProcessInfoRec); if(GetProcessInformation(&psn, &pif) == noErr) return true; } return false; } ### |