OpenCores
URL https://opencores.org/ocsvn/or1k/or1k/trunk

Subversion Repositories or1k

[/] [or1k/] [trunk/] [mw/] [src/] [drivers/] [SubRepl.h] - Rev 1765

Compare with Previous | Blame | View Log

 
// these 4 inlines are here to get the code clearer (it was unreadable due do the parenthesis)
static inline T8p sd(T8p d1, int s1, T8p d2, int s2) 
// sd stands for shift data
{ return((d1<<s1)|(d2>>s2)); }
 
static inline T8p sdm(T8p d1, int s1, T8p d2, int s2, T8p m) 
// sdm stands for shift data mask
{ return(((d1<<s1)|(d2>>s2))&m); }
 
static inline T8p sdml(T8p d, int s, T8p m) 
// sdml stands for shift data left mask
{ return(m&(d<<s)); }
 
static inline T8p sdmr(T8p d, int s, T8p m) 
// sdmr stands for shift data right mask
{ return(m&(d>>s)); }
 
// for all the functions bellow
// the shift state is after in the function name.
// w? stands for the number of full words-1 to copy.
// as all these functions are based on the same principles,
// the comments are located in the most complex of them: Blt_Shift_Positif
 
// s and d are the source and destination pointers.
// ss and ds are the skip source and skip destination values (ie: the number to add to source and
// destination pointer at the end of each line to go to the next line).
// S, M1 and M2 are the shift, start and end masks.
// w is the number of full words to write per line
// h is the number of line to work on.
 
static inline void Blt_Shift_Positif_w0(P8p s, P8p d, int ss, int ds, int S, T8p M1, T8p M2, int w, int h)
{
  M1= M2&~M1;
  do
  { 
    *d= (*d&~M1) | sdml(*s, S, M1);
    d+= ds; s+= ss;
  } while (--h!=0);
  return;
}
 
static inline void Blt_Shift_Positif_w1(P8p s, P8p d, int ss, int ds, int S, T8p M1, T8p M2, int w, int h)
{
  int S2= 32-S;
  M1= ~M1;
  do
  {
    T8p d1= *s++;
    *d++= (*d&~M1)|sdml(d1, S, M1);
    *d= (*d&~M2)| sdm(*s, S, d1, S2, M2);
    d+= ds; s+= ss;
  } while (--h!=0);
  return;
}
 
static inline void Blt_Shift_Positif_w2(P8p s, P8p d, int ss, int ds, int S, T8p M1, T8p M2, int w, int h)
{
  int S2= 32- S;
  M1= ~M1;
  do
  {
    T8p d2, d1= *s++; *d++= (*d&~M1)|sdml(d1, S, M1);
    d2= *s++; *d++= sd(d2, S, d1, S2);
    *d= (*d&~M2)|sdm(*s, S, d2, S2, M2);
    d+= ds; s+= ss;
  } while (--h!=0);
  return;
}
 
static inline void Blt_Shift_Positif(P8p s, P8p d, int ss, int ds, int S, T8p M1, T8p M2, int w, int h)
{
  int S2= 32- S;
  M1= ~M1;
  // for each line to copy (there is at least one)
  do
  {
    int i;
    // get the first set of pixels from the source
    T8p d1= *s++;
    // combine the shifted source pixels with the destination pixels (use of mask1)
    *d++= (*d&~M1)|sdml(d1, S, M1);
    // for every other set of pixel
    i= w;
    // directly write the shifted set of pixels to the dest (see how 2 set of pixels are shifted and combined together like a sliding window)
    do { T8p d2= *s++; *d++= sd(d2, S, d1, S2); d1= d2; } while (--i!=0);
    // combine the final shifted source pixels with the destination pixels (use of mask2)
    *d= (*d&~M2)|sdm(*s, S, d1, S2, M2);
    // skip what is left of the curent lines in sources and dest.
    d+= ds; s+= ss;
  } while (--h!=0);
  return;
}
 
static inline void Blt_Shift_Null_w0(P8p s, P8p d, int ss, int ds, int S, T8p M1, T8p M2, int w, int h)
{
  M1|= ~M2;
  do
  { 
    *d= (*d&M1) | (*s&~M1);
    d+= ds; s+= ss;
  } while (--h!=0);
}
 
static inline void Blt_Shift_Null_w1(P8p s, P8p d, int ss, int ds, int S, T8p M1, T8p M2, int w, int h)
{
  do
  {
    *d++= (*d&M1)|(*s++&~M1);
    *d= (*d&~M2)|(*s&M2);
    d+= ds; s+= ss;
  } while (--h!=0);
  return;
}
 
static inline void Blt_Shift_Null_w2(P8p s, P8p d, int ss, int ds, int S, T8p M1, T8p M2, int w, int h)
{
  do
  {
    *d++= (*d&M1)|(*s++&~M1);
    *d++= *s++;
    *d= (*d&~M2)|(*s&M2);
    d+= ds; s+= ss;
  } while (--h!=0);
  return;
}
 
static inline void Blt_Shift_Null_w3(P8p s, P8p d, int ss, int ds, int S, T8p M1, T8p M2, int w, int h)
{
  do
  {
    *d++= (*d&M1)|(*s++&~M1);
    *d++= *s++;
    *d++= *s++;
    *d= (*d&~M2)|(*s&M2);
    d+= ds; s+= ss;
  } while (--h!=0);
  return;
}
 
static inline void Blt_Shift_Null(P8p s, P8p d, int ss, int ds, int S, T8p M1, T8p M2, int w, int h)
{
  do
  {
    int i;
    *d++= (*d&M1)|(*s++&~M1);
    switch (w&7)
    {
      case 7: *d++= *s++; case 6: *d++= *s++; case 5: *d++= *s++; case 4: *d++= *s++;
      case 3: *d++= *s++; case 2: *d++= *s++; case 1: *d++= *s++; case 0: default:; 
    }
    for (i= w>>3; i!=0; i--)               
    {
      *d++= *s++; *d++= *s++; *d++= *s++; *d++= *s++;
      *d++= *s++; *d++= *s++; *d++= *s++; *d++= *s++; 
    }
    *d= (*d&~M2)|(*s&M2);
    d+= ds; s+= ss;
  } while (--h!=0);
  return;
}
 
static inline void Blt_Shift_Negatif_w0(P8p s, P8p d, int ss, int ds, int S, T8p M1, T8p M2, int w, int h)
{
  int S2= 32+ S;
  S= -S;
  M1= M2&~M1;
  do
  { 
    *d= (*d&~M1) | sdm(*(s+1), S2, *s, S, M1);
    d+= ds; s+= ss;
  } while (--h!=0);
  return;
}
 
static inline void Blt_Shift_Negatif_w1(P8p s, P8p d, int ss, int ds, int S, T8p M1, T8p M2, int w, int h)
{ 
  int S2= 32+ S;
  M1= ~M1;
  S= -S;
  do
  {
    T8p d1= *s++; T8p d2= *s;
    *d++= (*d&~M1)|sdm(d2, S2, d1, S, M1);
    *d= (*d&~M2)|sdm(*(s+1), S2, *s, S, M2);
    d+= ds; s+= ss;
  } while (--h!=0);
  return;
}
 
static inline void Blt_Shift_Negatif_w2(P8p s, P8p d, int ss, int ds, int S, T8p M1, T8p M2, int w, int h)
{
  int S2= 32+S;
  M1= ~M1;
  ss--; 
  S= -S;
  do
  {
    T8p d1= *s++; T8p d2= *s++;
    *d++= (*d&~M1)|sdm(d2, S2, d1, S, M1);
    d1= *s++; *d++= sd(d1, S2, d2, S);
    *d= (*d&~M2)|sdm(*s, S2, d1, S, M2);
    d+= ds; s+= ss;
  } while (--h!=0);
  return;
}
 
static inline void Blt_Shift_Negatif(P8p s, P8p d, int ss, int ds, int S, T8p M1, T8p M2, int w, int h)
{
  int S2= 32+S;
  M1= ~M1;
  ss--; 
  S= -S;
  do
  {
    int i;
    T8p d1= *s++; T8p d2= *s++;
    *d++= (*d&~M1)|sdm(d2, S2, d1, S, M1);
    i= w;
    do { d1= d2; d2= *s++; *d++= sd(d2, S2, d1, S); } while (--i!=0);
    *d= (*d&~M2)|sdm(*s, S2, d2, S, M2);
    d+= ds; s+= ss;
  } while (--h!=0);
  return;
}
 

Compare with Previous | Blame | View Log

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.