1428d7b3dSmrg/* 2428d7b3dSmrg * Copyright © 2009 Intel Corporation 3428d7b3dSmrg * 4428d7b3dSmrg * Permission is hereby granted, free of charge, to any person obtaining a 5428d7b3dSmrg * copy of this software and associated documentation files (the "Software"), 6428d7b3dSmrg * to deal in the Software without restriction, including without limitation 7428d7b3dSmrg * the rights to use, copy, modify, merge, publish, distribute, sublicense, 8428d7b3dSmrg * and/or sell copies of the Software, and to permit persons to whom the 9428d7b3dSmrg * Software is furnished to do so, subject to the following conditions: 10428d7b3dSmrg * 11428d7b3dSmrg * The above copyright notice and this permission notice (including the next 12428d7b3dSmrg * paragraph) shall be included in all copies or substantial portions of the 13428d7b3dSmrg * Software. 14428d7b3dSmrg * 15428d7b3dSmrg * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 16428d7b3dSmrg * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 17428d7b3dSmrg * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL 18428d7b3dSmrg * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 19428d7b3dSmrg * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 20428d7b3dSmrg * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE 21428d7b3dSmrg * SOFTWARE. 22428d7b3dSmrg * 23428d7b3dSmrg * Author: 24428d7b3dSmrg * Zou Nan hai <nanhai.zou@intel.com> 25428d7b3dSmrg * Yan Li <li.l.yan@intel.com> 26428d7b3dSmrg * Liu Xi bin<xibin.liu@intel.com> 27428d7b3dSmrg */ 28428d7b3dSmrg/* GRF allocation: 29428d7b3dSmrg g1~g30: constant buffer 30428d7b3dSmrg g1~g2:intra IQ matrix in UB format 31428d7b3dSmrg g3~g4:non intra IQ matrix in UB format 32428d7b3dSmrg g5~g20:IDCT table 33428d7b3dSmrg g56~g79:DCT data after IQ before idct 34428d7b3dSmrg g83~g106: IDCT data after idct 35428d7b3dSmrg g82: thread payload backup 36428d7b3dSmrg g125: ip before idct 37428d7b3dSmrg*/ 38428d7b3dSmrgIDCT_START: 39428d7b3dSmrgmov (1) g126.0<1>UD ip {align1}; 40428d7b3dSmrgjmpi DO_IDCT; 41428d7b3dSmrgadd (16) g32<1>D g32<8,8,1>D ROW_ADD {compr}; 42428d7b3dSmrgadd (16) g34<1>D g34<8,8,1>D ROW_ADD {compr}; 43428d7b3dSmrgadd (16) g36<1>D g36<8,8,1>D ROW_ADD {compr}; 44428d7b3dSmrgadd (16) g38<1>D g38<8,8,1>D ROW_ADD {compr}; 45428d7b3dSmrg 46428d7b3dSmrgshr (16) g32<1>D g32<8,8,1>D ROW_SHIFT {compr}; 47428d7b3dSmrgshr (16) g34<1>D g34<8,8,1>D ROW_SHIFT {compr}; 48428d7b3dSmrgshr (16) g36<1>D g36<8,8,1>D ROW_SHIFT {compr}; 49428d7b3dSmrgshr (16) g38<1>D g38<8,8,1>D ROW_SHIFT {compr}; 50428d7b3dSmrg 51428d7b3dSmrgmov (16) g110.0<1>W g32<16,8,2>W {align1}; 52428d7b3dSmrgmov (16) g111.0<1>W g34<16,8,2>W {align1}; 53428d7b3dSmrgmov (16) g112.0<1>W g36<16,8,2>W {align1}; 54428d7b3dSmrgmov (16) g113.0<1>W g38<16,8,2>W {align1}; 55428d7b3dSmrg 56428d7b3dSmrgmov (1) g80.0<1>UD a0.0<1,1,1>UD {align1}; //save a0 57428d7b3dSmrgmov (1) a0.0<1>UD 0x0DB00DA0UD {align1}; //begin at g110.0, the output of idct_row.g4i 58428d7b3dSmrgmov (1) g126.0<1>UD ip {align1}; 59428d7b3dSmrgjmpi DO_IDCT; 60428d7b3dSmrg 61428d7b3dSmrgadd (16) g32<1>D g32<8,8,1>D COL_ADD {compr}; 62428d7b3dSmrgadd (16) g34<1>D g34<8,8,1>D COL_ADD {compr}; 63428d7b3dSmrgadd (16) g36<1>D g36<8,8,1>D COL_ADD {compr}; 64428d7b3dSmrgadd (16) g38<1>D g38<8,8,1>D COL_ADD {compr}; 65428d7b3dSmrg 66428d7b3dSmrgshr (16) g32<1>D g32<8,8,1>D COL_SHIFT {compr}; 67428d7b3dSmrgshr (16) g34<1>D g34<8,8,1>D COL_SHIFT {compr}; 68428d7b3dSmrgshr (16) g36<1>D g36<8,8,1>D COL_SHIFT {compr}; 69428d7b3dSmrgshr (16) g38<1>D g38<8,8,1>D COL_SHIFT {compr}; 70428d7b3dSmrg 71428d7b3dSmrgmov (1) a0.0<1>UD g80.0<1,1,1>UD {align1}; //restore a0 72428d7b3dSmrgadd (1) ip g125.0<1,1,1>UD 0x20UD {align1}; //jump back 73428d7b3dSmrg 74428d7b3dSmrgDO_IDCT: 75428d7b3dSmrgadd (1) a0.0<1>UD a0.0<1,1,1>UD 0x00200020UD {align1}; //increase the address 76428d7b3dSmrgdp4 (16) g40<1>D g[a0.0]<8,8,1>W g5<8,8,1>D {align1 compr}; 77428d7b3dSmrgdp4 (16) g42<1>D g[a0.0]<8,8,1>W g7<8,8,1>D {align1 compr}; 78428d7b3dSmrgdp4 (16) g44<1>D g[a0.0]<8,8,1>W g9<8,8,1>D {align1 compr}; 79428d7b3dSmrgdp4 (16) g46<1>D g[a0.0]<8,8,1>W g11<8,8,1>D {align1 compr}; 80428d7b3dSmrgdp4 (16) g48<1>D g[a0.0]<8,8,1>W g13<8,8,1>D {align1 compr}; 81428d7b3dSmrgdp4 (16) g50<1>D g[a0.0]<8,8,1>W g15<8,8,1>D {align1 compr}; 82428d7b3dSmrgdp4 (16) g52<1>D g[a0.0]<8,8,1>W g17<8,8,1>D {align1 compr}; 83428d7b3dSmrgdp4 (16) g54<1>D g[a0.0]<8,8,1>W g19<8,8,1>D {align1 compr}; 84428d7b3dSmrgadd (2) g32.0<1>D g40.0<8,1,8>D g40.16<8,1,8>D {align1}; 85428d7b3dSmrgadd (2) g33.0<1>D g42.0<8,1,8>D g42.16<8,1,8>D {align1}; 86428d7b3dSmrgadd (2) g34.0<1>D g44.0<8,1,8>D g44.16<8,1,8>D {align1}; 87428d7b3dSmrgadd (2) g35.0<1>D g46.0<8,1,8>D g46.16<8,1,8>D {align1}; 88428d7b3dSmrgadd (2) g36.0<1>D g48.0<8,1,8>D g48.16<8,1,8>D {align1}; 89428d7b3dSmrgadd (2) g37.0<1>D g50.0<8,1,8>D g50.16<8,1,8>D {align1}; 90428d7b3dSmrgadd (2) g38.0<1>D g52.0<8,1,8>D g52.16<8,1,8>D {align1}; 91428d7b3dSmrgadd (2) g39.0<1>D g54.0<8,1,8>D g54.16<8,1,8>D {align1}; 92428d7b3dSmrg 93428d7b3dSmrgadd (1) a0.0<1>UD a0.0<1,1,1>UD 0x00200020UD {align1}; 94428d7b3dSmrgdp4 (16) g40<1>D g[a0.0]<8,8,1>W g5<8,8,1>D {align1 compr}; 95428d7b3dSmrgdp4 (16) g42<1>D g[a0.0]<8,8,1>W g7<8,8,1>D {align1 compr}; 96428d7b3dSmrgdp4 (16) g44<1>D g[a0.0]<8,8,1>W g9<8,8,1>D {align1 compr}; 97428d7b3dSmrgdp4 (16) g46<1>D g[a0.0]<8,8,1>W g11<8,8,1>D {align1 compr}; 98428d7b3dSmrgdp4 (16) g48<1>D g[a0.0]<8,8,1>W g13<8,8,1>D {align1 compr}; 99428d7b3dSmrgdp4 (16) g50<1>D g[a0.0]<8,8,1>W g15<8,8,1>D {align1 compr}; 100428d7b3dSmrgdp4 (16) g52<1>D g[a0.0]<8,8,1>W g17<8,8,1>D {align1 compr}; 101428d7b3dSmrgdp4 (16) g54<1>D g[a0.0]<8,8,1>W g19<8,8,1>D {align1 compr}; 102428d7b3dSmrgadd (2) g32.8<1>D g40.0<8,1,8>D g40.16<8,1,8>D {align1}; 103428d7b3dSmrgadd (2) g33.8<1>D g42.0<8,1,8>D g42.16<8,1,8>D {align1}; 104428d7b3dSmrgadd (2) g34.8<1>D g44.0<8,1,8>D g44.16<8,1,8>D {align1}; 105428d7b3dSmrgadd (2) g35.8<1>D g46.0<8,1,8>D g46.16<8,1,8>D {align1}; 106428d7b3dSmrgadd (2) g36.8<1>D g48.0<8,1,8>D g48.16<8,1,8>D {align1}; 107428d7b3dSmrgadd (2) g37.8<1>D g50.0<8,1,8>D g50.16<8,1,8>D {align1}; 108428d7b3dSmrgadd (2) g38.8<1>D g52.0<8,1,8>D g52.16<8,1,8>D {align1}; 109428d7b3dSmrgadd (2) g39.8<1>D g54.0<8,1,8>D g54.16<8,1,8>D {align1}; 110428d7b3dSmrg 111428d7b3dSmrgadd (1) a0.0<1>UD a0.0<1,1,1>UD 0x00200020UD {align1}; 112428d7b3dSmrgdp4 (16) g40<1>D g[a0.0]<8,8,1>W g5<8,8,1>D {align1 compr}; 113428d7b3dSmrgdp4 (16) g42<1>D g[a0.0]<8,8,1>W g7<8,8,1>D {align1 compr}; 114428d7b3dSmrgdp4 (16) g44<1>D g[a0.0]<8,8,1>W g9<8,8,1>D {align1 compr}; 115428d7b3dSmrgdp4 (16) g46<1>D g[a0.0]<8,8,1>W g11<8,8,1>D {align1 compr}; 116428d7b3dSmrgdp4 (16) g48<1>D g[a0.0]<8,8,1>W g13<8,8,1>D {align1 compr}; 117428d7b3dSmrgdp4 (16) g50<1>D g[a0.0]<8,8,1>W g15<8,8,1>D {align1 compr}; 118428d7b3dSmrgdp4 (16) g52<1>D g[a0.0]<8,8,1>W g17<8,8,1>D {align1 compr}; 119428d7b3dSmrgdp4 (16) g54<1>D g[a0.0]<8,8,1>W g19<8,8,1>D {align1 compr}; 120428d7b3dSmrgadd (2) g32.16<1>D g40.0<8,1,8>D g40.16<8,1,8>D {align1}; 121428d7b3dSmrgadd (2) g33.16<1>D g42.0<8,1,8>D g42.16<8,1,8>D {align1}; 122428d7b3dSmrgadd (2) g34.16<1>D g44.0<8,1,8>D g44.16<8,1,8>D {align1}; 123428d7b3dSmrgadd (2) g35.16<1>D g46.0<8,1,8>D g46.16<8,1,8>D {align1}; 124428d7b3dSmrgadd (2) g36.16<1>D g48.0<8,1,8>D g48.16<8,1,8>D {align1}; 125428d7b3dSmrgadd (2) g37.16<1>D g50.0<8,1,8>D g50.16<8,1,8>D {align1}; 126428d7b3dSmrgadd (2) g38.16<1>D g52.0<8,1,8>D g52.16<8,1,8>D {align1}; 127428d7b3dSmrgadd (2) g39.16<1>D g54.0<8,1,8>D g54.16<8,1,8>D {align1}; 128428d7b3dSmrg 129428d7b3dSmrgadd (1) a0.0<1>UD a0.0<1,1,1>UD 0x00200020UD {align1}; 130428d7b3dSmrgdp4 (16) g40<1>D g[a0.0]<8,8,1>W g5<8,8,1>D {align1 compr}; 131428d7b3dSmrgdp4 (16) g42<1>D g[a0.0]<8,8,1>W g7<8,8,1>D {align1 compr}; 132428d7b3dSmrgdp4 (16) g44<1>D g[a0.0]<8,8,1>W g9<8,8,1>D {align1 compr}; 133428d7b3dSmrgdp4 (16) g46<1>D g[a0.0]<8,8,1>W g11<8,8,1>D {align1 compr}; 134428d7b3dSmrgdp4 (16) g48<1>D g[a0.0]<8,8,1>W g13<8,8,1>D {align1 compr}; 135428d7b3dSmrgdp4 (16) g50<1>D g[a0.0]<8,8,1>W g15<8,8,1>D {align1 compr}; 136428d7b3dSmrgdp4 (16) g52<1>D g[a0.0]<8,8,1>W g17<8,8,1>D {align1 compr}; 137428d7b3dSmrgdp4 (16) g54<1>D g[a0.0]<8,8,1>W g19<8,8,1>D {align1 compr}; 138428d7b3dSmrgadd (2) g32.24<1>D g40.0<8,1,8>D g40.16<8,1,8>D {align1}; 139428d7b3dSmrgadd (2) g33.24<1>D g42.0<8,1,8>D g42.16<8,1,8>D {align1}; 140428d7b3dSmrgadd (2) g34.24<1>D g44.0<8,1,8>D g44.16<8,1,8>D {align1}; 141428d7b3dSmrgadd (2) g35.24<1>D g46.0<8,1,8>D g46.16<8,1,8>D {align1}; 142428d7b3dSmrgadd (2) g36.24<1>D g48.0<8,1,8>D g48.16<8,1,8>D {align1}; 143428d7b3dSmrgadd (2) g37.24<1>D g50.0<8,1,8>D g50.16<8,1,8>D {align1}; 144428d7b3dSmrgadd (2) g38.24<1>D g52.0<8,1,8>D g52.16<8,1,8>D {align1}; 145428d7b3dSmrgadd (2) g39.24<1>D g54.0<8,1,8>D g54.16<8,1,8>D {align1}; 146428d7b3dSmrg 147428d7b3dSmrgadd (1) ip g126.0<1,1,1>UD 0x20UD {align1}; //jump back 148