La aceasta adresa puteti vizualiza 44 de tutoriale video Silverlight, de la folosirea gridurilor pana la animatii, storyboards, folosirea socketilor, etc...
Enjoy,
preview Hello World
Mult mai multe clipuri AICI !!!
De asemenea, nici aceasta adresa nu este de neglijat.
29 aprilie 2011
Mini-problema labirintului
In memoria principala este definita o matrice ce descrie calea de la intrarea într-un labirint pana la o comoara. Drumul spre comoara este encodat în matrice ca un set de salturi de la niste coordonate la altele (un nod din drum contine ca informatie urmatorul nod la care trebuie sa se sara). Stim ca am ajuns la comoara cand trebuie sa sarim la nodul (0, 0). In programul din PPU se scrie drumul în labirint si trimite SPU-ului adresa catre începutul matricii. SPU-ul va trebui sa gaseasca coordonatele comorii si sa le scrie în prima celula a labirintului (0, 0). In PPU la sfarsit se va verifica daca in celula (0, 0) se gasesc coordonatele comorii.
Rezolvare: http://dl.dropbox.com/u/24465060/labXcell.zip
----
Un program care utilizeaza sofware caching trebuie sa includa fisierul header “cache-api.h” si poate contine la inceputul sau definitii pentru:
Rezolvare: http://dl.dropbox.com/u/24465060/labXcell.zip
----
Instructiune | Descriere |
---|---|
cache_rd(name, eaddr) | Copiaza valoarea stocata la adresa eaddr in cache. Returneaza valoarea. |
cache_wr(name, eaddr, val) | Scrie in cache valoarea val. |
cache_touch(name, eaddr) | Aduce in cache valoarea stocata la adresa eaddr. Functia este non-blocanta. Functia intoarce adresa din spatiul de adrese al LS, unde va fi stocata valoarea la incheierea tranferului. |
cache_wait(name, lsa) | Asteapta terminarea unui transfer non-blocant, care intoarce date la adresa lsa din spatiul LS-ului. |
cache_rw(name, eaddr) | Copiaza in cache valoarea stocata la adresa eaddr, transmitand sistemului de cache faptul ca valoarea ar putea fi modificata. Functia este blocanta si va intoarce adresa din spatiul LS unde va fi stocata valoarea. Linia de cache este marcata dirty la scrierea datelor. |
cache_lock(name, lsa) | Blocheaza datele de la adresa lsa din cache. |
cache_unlock(name, lsa) | Deblocheaza date de la adresa lsa din cache. |
cache_flush(name) | |
cache_rd_x4(name, eaddr4) | Citeste un vector care contine 4 valori unsigned int. |
e_pr_stats(name) | Afiseaza statistici despre cache. |
'CACHE_NAME
' - un nume unic ce va identifica cache-ul.'CACHED_TYPE
' - tipul elementelor stocate in cadrul cache-ului. Poate fi orice tip de date valid in limbajul C.'CACHELINE_LOG2SIZE
' - log2 (dimensiunea unei linii de cache).'CACHE_LOG2NWAY
' - specifica asociativitatea cache-ului. Exista 2 valori posibile: 0 si 2 (2 fiind valoarea implicita).'CACHE_LOG2NSETS
' - log2 (numarul de seturi dintr-un cache). Valorile posibile sunt cuprinse intre 0 si 12. Valoarea implicita este 6 (26 = 64 seturi).'CACHE_TYPE
' - tipul de acces la cache: read-only (0) sau read-write (1 - implicit)'CACHE_SET_TAGID(set)
' - specifica tag-ID-ul unui anumit set. Valorile posibile sunt cuprinse intre 0 si 31. Implicit se defineste ca set mod 32.
14 aprilie 2011
Primul virus
Virusul a fost creat de niste pakistanezi in 1986 si s-a raspandit prin intermediul floppy disk -ului.
06 aprilie 2011
Exemplu de folosire memorie virtuala
Implementarea comenzii cp din Linux, folosind mmap :
int main (int argc, char *argv[])
{
int fdin, fdout, rc;
char *src, *dst;
struct stat statbuf;
DIE(argc != 3, "Usage: ./mycp ");
/* Open input and output files */
fdin = open (argv[1], O_RDONLY);
DIE(fdin == -1, "open fdin");
/* Open/create the output file */
fdout = open (argv[2], O_RDWR | O_CREAT | O_TRUNC, 0644);
DIE(fdout == -1, "open fdout");
/* truncate the output file to the input file size */
rc = fstat(fdin, &statbuf);
DIE(rc == -1, "fstat");
double size = (double)statbuf.st_size;
rc = ftruncate(fdout, size);
DIE(rc == -1, "ftruncate");
/* mmap the input and output file */
src = mmap (0, size, PROT_READ, MAP_SHARED, fdin, 0);
DIE( rc==-1, "mmap");
dst = mmap (0, size, PROT_WRITE, MAP_SHARED, fdout, 0); // la MAP_PRIVATE , rezultatul ramane doar in memorie
DIE( rc==-1, "mmap");
/* copy the input file to the output file */
memcpy(dst, src, size);
/* clean up */
rc = munmap(src, size);
DIE(rc == -1, "munmap");
rc = munmap(dst, size);
DIE(rc == -1, "munmap");
/* Close files */
rc = close(fdin);
DIE(rc == -1, "close source");
rc = close(fdout);
DIE(rc == -1, "close destination");
return 0;
}
int main (int argc, char *argv[])
{
int fdin, fdout, rc;
char *src, *dst;
struct stat statbuf;
DIE(argc != 3, "Usage: ./mycp
/* Open input and output files */
fdin = open (argv[1], O_RDONLY);
DIE(fdin == -1, "open fdin");
/* Open/create the output file */
fdout = open (argv[2], O_RDWR | O_CREAT | O_TRUNC, 0644);
DIE(fdout == -1, "open fdout");
/* truncate the output file to the input file size */
rc = fstat(fdin, &statbuf);
DIE(rc == -1, "fstat");
double size = (double)statbuf.st_size;
rc = ftruncate(fdout, size);
DIE(rc == -1, "ftruncate");
/* mmap the input and output file */
src = mmap (0, size, PROT_READ, MAP_SHARED, fdin, 0);
DIE( rc==-1, "mmap");
dst = mmap (0, size, PROT_WRITE, MAP_SHARED, fdout, 0); // la MAP_PRIVATE , rezultatul ramane doar in memorie
DIE( rc==-1, "mmap");
/* copy the input file to the output file */
memcpy(dst, src, size);
/* clean up */
rc = munmap(src, size);
DIE(rc == -1, "munmap");
rc = munmap(dst, size);
DIE(rc == -1, "munmap");
/* Close files */
rc = close(fdin);
DIE(rc == -1, "close source");
rc = close(fdout);
DIE(rc == -1, "close destination");
return 0;
}
Abonați-vă la:
Postări (Atom)