[Rd] shared mem advice
Thomas Lumley
tlumley at u.washington.edu
Tue Apr 13 16:40:33 CEST 2004
On Tue, 13 Apr 2004, Alex Nu wrote:
>
> Hi,
>
> I want to write a package where I would use
> shared memory for some vectors
>
> Any suggestion is appreciated...
I'd recommend looking at external pointer objects. If the developer
webpage were working, that would be the place to look. I'm not sure where
else there is information.
>
> I wonder if the right approach would be to
> modify add a modified version of the
>
> allocVector(SEXPTYPE type, int length) function
>
> specifically
>
> shared_mem_id = shmget(shared_mem_key,
> SHM_SIZE,
> IPC_CREAT);
>
> shared = (SEXP) shmat(shared_mem_id, (void *)0, 0);
No, you want the shared memory to hold the data of the vector, not the
header record that the SEXP points to. If you do it this way you want to
look at how memory.c:allocVector uses malloc() for large vectors.
-thomas
>
> my_allocVector(SEXPTYPE type, int length, SEXP
> shared) {
>
> SEXP s=shared;
> ....
>
> And erase this if:
>
> #################################################
> if(size >=
> (LONG_MAX / sizeof(VECREC))-sizeof(SEXPREC_ALIGN)
> ||
> (s =
> malloc(sizeof(SEXPREC_ALIGN) + size *
> sizeof(VECREC))
> )
> == NULL) { {
> #################################################
>
> Alex
>
> ______________________________________________
> R-devel at stat.math.ethz.ch mailing list
> https://www.stat.math.ethz.ch/mailman/listinfo/r-devel
>
Thomas Lumley Assoc. Professor, Biostatistics
tlumley at u.washington.edu University of Washington, Seattle
More information about the R-devel
mailing list