| delorie.com/archives/browse.cgi | search |
| X-Recipient: | archive-cygwin AT delorie DOT com |
| DomainKey-Signature: | a=rsa-sha1; c=nofws; d=sourceware.org; h=list-id |
| :list-unsubscribe:list-subscribe:list-archive:list-post | |
| :list-help:sender:from:to:subject:date:message-id:references | |
| :in-reply-to:content-type:content-transfer-encoding | |
| :mime-version; q=dns; s=default; b=PuOE8ugHUcQkhkI4rU8k5VhRb/s/i | |
| F/3nOQ88Bl8M1CP+R3CpJHVwhwsVfMVusQ5QqPnxheaYknHU36/aHwIp+0xOqths | |
| vHpimGs60tn0EA9OFJWGj8ZwgP8amCNsPnM8lOQ6cfklqO4J30ZkXp6K8rcwLIre | |
| MHH4Un4oTQJ65Y= | |
| DKIM-Signature: | v=1; a=rsa-sha1; c=relaxed; d=sourceware.org; h=list-id |
| :list-unsubscribe:list-subscribe:list-archive:list-post | |
| :list-help:sender:from:to:subject:date:message-id:references | |
| :in-reply-to:content-type:content-transfer-encoding | |
| :mime-version; s=default; bh=A8n7kg0z9e3m7KG44hL3BjRTpPU=; b=mbI | |
| fLA8g1UBTVYtzW/rWEtee1sqa8tPt4eCeH6VDEFLy3WaLUkGJFdpYZm1JQTGaQSc | |
| PgfhbmRDf4uTKBQ3V87O3ZnjkNRTq5ig+ZegEFqKMD7K5yRzGb21XGQZbRmSuCaF | |
| KUVgoQdVF8X4ru15FQ+f4IC9/nXRTMOBlriRmTnU= | |
| Mailing-List: | contact cygwin-help AT cygwin DOT com; run by ezmlm |
| List-Id: | <cygwin.cygwin.com> |
| List-Subscribe: | <mailto:cygwin-subscribe AT cygwin DOT com> |
| List-Archive: | <http://sourceware.org/ml/cygwin/> |
| List-Post: | <mailto:cygwin AT cygwin DOT com> |
| List-Help: | <mailto:cygwin-help AT cygwin DOT com>, <http://sourceware.org/ml/#faqs> |
| Sender: | cygwin-owner AT cygwin DOT com |
| Mail-Followup-To: | cygwin AT cygwin DOT com |
| Delivered-To: | mailing list cygwin AT cygwin DOT com |
| Authentication-Results: | sourceware.org; auth=none |
| X-Virus-Found: | No |
| X-Spam-SWARE-Status: | No, score=-1.8 required=5.0 tests=AWL,BAYES_00,RP_MATCHES_RCVD,SPF_HELO_PASS,SPF_PASS autolearn=ham version=3.3.2 |
| X-HELO: | nihxway2out.hub.nih.gov |
| X-IronPortListener: | Outbound_SMTP |
| X-IronPort-Anti-Spam-Filtered: | true |
| X-IronPort-Anti-Spam-Result: | AicFAOSq6lKcKEeu/2dsb2JhbABZgwyBD70kgQwWdIIlAQEBAwESKEQLAgEIDRUUEB8TJQIEGxqHWwihOapyF45ROIMkgRQEjmOQNYsvgy2CKg |
| From: | "Lavrentiev, Anton (NIH/NLM/NCBI) [C]" <lavr AT ncbi DOT nlm DOT nih DOT gov> |
| To: | "cygwin AT cygwin DOT com" <cygwin AT cygwin DOT com> |
| Subject: | RE: second call to mmap() results in error |
| Date: | Thu, 30 Jan 2014 19:46:31 +0000 |
| Message-ID: | <5F8AAC04F9616747BC4CC0E803D5907D0C477869@MLBXv04.nih.gov> |
| References: | <20140129181250 DOT GW2821 AT calimero DOT vinschen DOT de> <52E95786 DOT 8050606 AT gmail DOT com> <20140130095822 DOT GY2821 AT calimero DOT vinschen DOT de> <001801cf1db6$66c47c40$344d74c0$@lbmsys.com> <20140130124558 DOT GA2821 AT calimero DOT vinschen DOT de> <003801cf1dbd$fc3ffc70$f4bff550$@lbmsys.com> <20140130170142 DOT GD2821 AT calimero DOT vinschen DOT de> <5F8AAC04F9616747BC4CC0E803D5907D0C4763CC AT MLBXv04 DOT nih DOT gov> <52EA9A53 DOT 2050203 AT cygwin DOT com> <5F8AAC04F9616747BC4CC0E803D5907D0C4764C5 AT MLBXv04 DOT nih DOT gov> <20140130183956 DOT GA3573 AT ednor DOT casa DOT cgf DOT cx> <5F8AAC04F9616747BC4CC0E803D5907D0C4764ED AT MLBXv04 DOT nih DOT gov> <52EA9EA2 DOT 5030202 AT cygwin DOT com> <5F8AAC04F9616747BC4CC0E803D5907D0C476528 AT MLBXv04 DOT nih DOT gov> <52EAA171 DOT 406 AT cygwin DOT com> <5F8AAC04F9616747BC4CC0E803D5907D0C4765D8 AT MLBXv04 DOT nih DOT gov> <52EAA848 DOT 7070808 AT cygwin DOT com> |
| In-Reply-To: | <52EAA848.7070808@cygwin.com> |
| MIME-Version: | 1.0 |
| X-IsSubscribed: | yes |
| X-MIME-Autoconverted: | from quoted-printable to 8bit by delorie.com id s0UJkunQ025655 |
> So if the question is why do you need to include ftruncate() in the code,
> take a look here:
No, that was not the question. W/o ftruncate(), _referencing_ the memory
becomes a problem (and the original code did not do that, but simply mmap'ed
two files).
> > Adding the <unistd.h> fixes the problem in all its iterations
OP privately wrote:
> The problem is also fixed by correct type-casting in the calls to mmap() ...
>
> mmap1 = mmap(NULL, (size_t) 524304, PROT_WRITE | PROT_READ, MAP_SHARED,
> shm_fd1, 0);
>
> The address returned from the call to mmap() -- with or without the
> ftruncate() -- was bad without the (size_t) specification.
(note "with or without ftruncate()")
And I ask again (last time, I promise), how on Earth adding <unistd.h> to
the code below would make the code suddenly working? (Like I said before,
that code worked for me, with -Wall showing nothing, from the very beginning.)
Anton Lavrentiev
Contractor NIH/NLM/NCBI
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <sys/types.h>
#include <sys/errno.h>
#include <fcntl.h>
#include <sys/mman.h>
int main()
{
int shm_fd1, shm_fd2;
char *mmap1, *mmap2;
/* get fd for each block of memory */
shm_fd1 = shm_open("/block1", O_CREAT | O_RDWR, 0666);
if (shm_fd1 == -1) {
fprintf(stderr, "Couldn't get fd for block1 (%s)\n",
strerror(errno));
exit(1);
}
shm_fd2 = shm_open("/block2", O_CREAT | O_RDWR, 0666);
if (shm_fd2 == -1) {
fprintf(stderr, "Couldn't get fd for /UNI_queue (%s)\n",
strerror(errno));
exit(1);
}
/* map each block */
mmap1 = mmap(NULL, 524304, PROT_WRITE | PROT_READ, MAP_SHARED, shm_fd1,
0);
if (mmap1 == (char *)-1) {
fprintf(stderr, "Couldn't map memory for /block1 (%s)\n",
strerror(errno));
exit(1);
}
mmap2 = mmap(NULL, 524304, PROT_WRITE | PROT_READ, MAP_SHARED, shm_fd2,
0);
if (mmap2 == (char *)-1) {
fprintf(stderr, "Couldn't map memory for /block2 (%s)\n",
strerror(errno));
exit(1);
}
fprintf(stdout, "Shared memory initialized\n");
exit(0);
}
--
Problem reports: http://cygwin.com/problems.html
FAQ: http://cygwin.com/faq/
Documentation: http://cygwin.com/docs.html
Unsubscribe info: http://cygwin.com/ml/#unsubscribe-simple
| webmaster | delorie software privacy |
| Copyright © 2019 by DJ Delorie | Updated Jul 2019 |