summaryrefslogtreecommitdiff
path: root/packages/libogcfpc/src/ogc/dsp.inc
blob: b6b41bd956b43d599eeaa95dd980edae8f38f587 (plain)
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

{$IFDEF OGC_INTERFACE}
const
  DSPTASK_INIT = 0;  (*!< DSP task is initializing  *)
  DSPTASK_RUN = 1;  (*!< DSP task is running  *)
  DSPTASK_YIELD = 2;  (*!< DSP task has yield  *)
  DSPTASK_DONE = 3;  (*!< DSP task is done/ready  *)
  DSPTASK_CLEARALL = $00000000;  (*!< DSP task emtpy/ready  *)
  DSPTASK_ATTACH = $00000001;  (*!< DSP task attached  *)
  DSPTASK_CANCEL = $00000002;  (*!< DSP task canceled  *)

type
  DSPCallback = procedure; cdecl;
  DSPTaskCallback = procedure(task: pointer); cdecl;


type
  P_dsp_task = ^_dsp_task;
  _dsp_task = record
    state : cuint32;
    prio : cuint32;
    flags : cuint32;
    iram_maddr : pointer;
    iram_len : cuint32;
    iram_addr : cuint32;
    dram_maddr : pointer;
    dram_len : cuint32;
    dram_addr : cuint32;
    init_vec : cuint16;
    resume_vec : cuint16;
    init_cb : DSPTaskCallback;
    res_cb : DSPTaskCallback;
    done_cb : DSPTaskCallback;
    req_cb : DSPTaskCallback;
    next : P_dsp_task;
    prev : P_dsp_task;
  end;
  dsptask_t = _dsp_task;
  Pdsptask_t = ^dsptask_t;
  //DSPTaskCallback = procedure(task: Pdsptask_t); cdecl;


procedure DSP_Init; cdecl; external;


function DSP_CheckMailTo: cuint32; cdecl; external;


function DSP_CheckMailFrom: cuint32; cdecl; external;


function DSP_ReadMailFrom: cuint32; cdecl; external;


procedure DSP_AssertInt; cdecl; external;


procedure DSP_SendMailTo(mail: cuint32); cdecl; external;


function DSP_ReadCPUtoDSP: cuint32; cdecl; external;


function DSP_AddTask(task: Pdsptask_t): Pdsptask_t; cdecl; external;


function DSP_AssertTask(task: Pdsptask_t): Pdsptask_t; cdecl; external;


procedure DSP_CancelTask(task: Pdsptask_t); cdecl; external;


procedure DSP_Reset; cdecl; external;


procedure DSP_Halt; cdecl; external;


procedure DSP_Unhalt; cdecl; external;


function DSP_GetDMAStatus(): cuint32; cdecl; external;

function DSP_RegisterCallback(usr_cb: DSPCallback): DSPCallback; cdecl; external;
{$ENDIF}