Rev | Line | |
---|
[97] | 1 | #ifndef ATLAS_MVN_H |
---|
| 2 | #define ATLAS_MVN_H |
---|
| 3 | |
---|
| 4 | #include "atlas_misc.h" |
---|
| 5 | |
---|
| 6 | #define ATL_mvNMU 4 |
---|
| 7 | #define ATL_mvNNU 4 |
---|
| 8 | #ifndef ATL_L1mvelts |
---|
| 9 | #define ATL_L1mvelts ((3*ATL_L1elts)>>2) |
---|
| 10 | #endif |
---|
| 11 | #ifndef ATL_mvpagesize |
---|
| 12 | #define ATL_mvpagesize ATL_DivBySize(4096) |
---|
| 13 | #endif |
---|
| 14 | #ifndef ATL_mvntlb |
---|
| 15 | #define ATL_mvntlb 56 |
---|
| 16 | #endif |
---|
| 17 | |
---|
| 18 | #define ATL_GetPartMVN(A_, lda_, mb_, nb_) \ |
---|
| 19 | { \ |
---|
| 20 | *(nb_) = (ATL_L1mvelts - (ATL_mvNMU<<1)) / ((ATL_mvNMU<<1)+1); \ |
---|
| 21 | if (ATL_mvpagesize > (lda_)) \ |
---|
| 22 | { \ |
---|
| 23 | *(mb_) = (ATL_mvpagesize / (lda_)) * ATL_mvntlb; \ |
---|
| 24 | if ( *(mb_) < *(nb_) ) *(nb_) = *(mb_); \ |
---|
| 25 | } \ |
---|
| 26 | else if (ATL_mvntlb < *(nb_)) *(nb_) = ATL_mvntlb; \ |
---|
| 27 | if (*(nb_) > ATL_mvNNU) *(nb_) = (*(nb_) / ATL_mvNNU) * ATL_mvNNU; \ |
---|
| 28 | else *(nb_) = ATL_mvNNU; \ |
---|
| 29 | *(mb_) = (ATL_L1mvelts - *(nb_) * (ATL_mvNMU+1)) / (*(nb_)+2); \ |
---|
| 30 | if (*(mb_) > ATL_mvNMU) *(mb_) = (*(mb_) / ATL_mvNMU) * ATL_mvNMU; \ |
---|
| 31 | else *(mb_) = ATL_mvNMU; \ |
---|
| 32 | } |
---|
| 33 | |
---|
| 34 | #endif |
---|
Note: See
TracBrowser
for help on using the repository browser.