This file is indexed.

/usr/share/psychtoolbox-3/PsychTests/AsyncFlipTest.m is in psychtoolbox-3-common 3.0.14.20170103+git6-g605ff5c.dfsg1-1build1.

This file is owned by root:root, with mode 0o644.

The actual contents of the file can be viewed below.

  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
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
function AsyncFlipTest(screenid, workload, pollingwait)
% AsyncFlipTest - Stress-Test & Benchmark async flips.
%
% This exercises the async flip implementation in some simulated
% workloads, to test its reliability on a given GPU + driver + operaring
% system combo, and to benchmark its timing behaviour.
%
% The reliability and performance of async flips depends strongly
% on the quality of the underlying graphics hardware (GPU), its
% device drivers and the operating system. When doing concurrent
% async flipping and drawing, the load is even higher, as is
% dependency on a specific system setup.
%
% This demo first runs a red flicker stimulus for basic testing,
% until you press any key. Then it runs more complex stimuli
% until you press any key or 10 seconds worth of stimulation have
% elapsed. Then various timing parameters are plotted.
%
% In the first part you should see homogeneous regular red
% flickering.
%
% In the second part you should see a monochrome (workload = 1),
% colorful (workload = 2) random dot image. For workload = 0
% you should see a black background, and in the center of the
% screen a rectangle with a flickering green background and a
% yellow text "Hallo ;-)". If you see something else, your
% operating system or graphics driver has a bug. If you see
% irregular flicker then your system is not up to the task at
% the current video refresh rate, ie., it skips many presentation
% deadlines due to some overload of the GPU or system.
%
% Usage:
%
% AsyncFlipTest2([screenid=max][, workload=0][, pollingwait=0]);
%
% screenid = Which screen to run on. Default = max screen.
%
% workload = Which drawing workload to simulate in test part II [0, 1 2].
%            See code for workloads. 0 Simulates drawing into offscreen
%            windows, then blitting those into onscreen window.
%            1 simulates large luminance texture workload.
%            2 simulate the kind of texture creation, upload and
%            drawing workload you would have when playing back 1920x1080p
%            HD video in color.
%
% pollingwait = Use 'AsyncFlipCheckEnd' instead of 'AsyncFlipEnd'
%               in 1st test?
%

% History:
% 6.01.2012  mk  Written.

AssertOpenGL;

if nargin < 1 || isempty(screenid)
    screenid = max(Screen('Screens'));
end

if nargin < 2 || isempty(workload)
    workload = 0;
end

if nargin < 3 || isempty(pollingwait)
    pollingwait = 0;
end

% Some random test images for texture testing:
img  = uint8(rand(1080, 1920) * 255);
img3 = uint8(rand(1080, 1920, 3) * 255);

% Open onscreen window with imaging pipeline enabled:
PsychImaging('PrepareConfiguration');
PsychImaging('AddTask', 'General', 'UseVirtualFramebuffer');
w = PsychImaging('OpenWindow', screenid, 0);

% Contrastmodulation for flickerstim is 80% of range:
cm=0.8;

KbReleaseWait;

ifi = Screen('GetFlipInterval', w);

% Sync us to retrace with a conventional flip:
Screen('Flip', w);

% Until keypress, test the simple way: Don't draw while flip
% is pending, but wait for flip completion before drawing:
while ~KbCheck
    % Wait for flip to complete, collect timestamps:
    if pollingwait
        tv1=0;
        while tv1 == 0
            tv1 = Screen('AsyncFlipCheckEnd', w);
            WaitSecs('YieldSecs', 0.001);
        end
    else
        tv1 = Screen('AsyncFlipEnd', w);
    end

    % Draw something:
    cm = 1 - cm;
    Screen('FillRect', w, [255*cm 0   0]);

    % Schedule new flip:
    Screen('AsyncFlipBegin', w, tv1 + ifi/2);
end

% Ready for part II:
KbReleaseWait;

% Some sync flips, and clearing the two buffers to black
% and green:
Screen('Flip', w);
Screen('FillRect', w, [0 255 0]);
Screen('Flip', w, 0, 2);
Screen('FillRect', w, [0 0 0]);
Screen('Flip', w, 0, 2);

n = Screen('NominalFramerate', w) * 10;
if n == 0
    n = 60 * 10;
end

t = zeros(6, n + 2);
fc = 1;

try
    % Test offscreen window interaction as well:
    woff = Screen('OpenOffscreenwindow', w, 128, [0 0 500 100]);

    % Do the parallel async flip and draw stuff until keypress:
    while ~KbCheck && (fc < n)
        % Drawing simulation:
        cm = 1 - cm;
        if ismember(0, workload)
            % Simulate drawing into offscreen windows:
            Screen('FillRect', woff, [0, 255*cm, 0]);
            DrawFormattedText(woff, 'Hallo :-)', 'center', 'center', [255 255 0]);

            % Draw final offscreen window to onscreen window:
            Screen('DrawTexture', w, woff);
        end

        if ismember(1, workload)
            % Simulate luminance texture blitting:
            tex = Screen('MakeTexture', w, img);
            Screen('DrawTexture', w, tex, [], [], [], [], [], [0 0 255*cm]);
            Screen('Close', tex);
        end

        if ismember(2, workload)
            % Simulate RGB texture blitting as in HD video playback:
            tex = Screen('MakeTexture', w, img3, [], [], [], 3);
            Screen('DrawTexture', w, tex, [], [], [], [], [], 255 * cm * [1 1 1]);
            Screen('Close', tex);
        end

        % Measure completion of draw-command submission to GPU driver:
        t(4,fc) = GetSecs;

        % Finish it off: We do a sync flip, so we can measure how long
        % the whole stimulus rendering takes:
        Screen('Drawingfinished', w, 2, 1);
        t(5,fc) = GetSecs;

        % Update framecounter:
        fc = fc + 1;
        t(6,fc) = GetSecs;

        % Wait for last AsyncFlip to complete, get its onset timestamp:
        t(1, fc) = Screen('AsyncFlipEnd', w);

        % How long did async flip post-completion code run? This includes
        % operating system scheduling delays and the completion timestamping.
        t(2, fc) = GetSecs;

        % Schedule next async flip:
        Screen('AsyncFlipBegin', w, t(1, fc) + ifi/2, 2);

        % How long did preparing the async flip take? This includes running the
        % PTB imaging pipeline to prepare the final framebuffer image:
        t(3, fc) = GetSecs;

        % Draw next image...
    end

    % Final flip to avoid shutdown warning:
    Screen('Flip', w);
    Screen('CloseAll');

    % Truncate to valid range, convert to msec's:
    t = 1000 * t(:, 2:fc-2);

    close all ;

    figure;
    plot(t(2,:) - t(1,:));
    title('Delay stimulus onset -> flip completion [msecs]:');

    figure;
    plot(t(3,:) - t(2,:));
    title('Delay flip completion -> Next flip scheduled [msecs]:');

    figure;
    plot(t(4,:) - t(3,:));
    title('Delay flip scheduled -> Drawing for next stimulus scheduled [msecs]:');

    figure;
    plot(t(5,:) - t(3,:));
    title('Delay flip scheduled -> Drawing of next stim finished [msecs]:');

    figure;
    plot(t(1,:) - t(6,:));
    title('Remaining headroom from drawing completion of next stim to onset of previous stim [msecs]:');
catch
    sca;
end