Mercurial > mplayer.hg
view libdha/kernelhelper/test.c @ 17566:f580a7755ac5
Patch by Stefan Huehner / stefan % huehner ! org \
patch replaces '()' for the correct '(void)' in function
declarations/prototypes which have no parameters. The '()' syntax tell
thats there is a variable list of arguments, so that the compiler cannot
check this. The extra CFLAG '-Wstrict-declarations' shows those cases.
Comments about a similar patch applied to ffmpeg:
That in C++ these mean the same, but in ANSI C the semantics are
different; function() is an (obsolete) K&R C style forward declaration,
it basically means that the function can have any number and any types
of parameters, effectively completely preventing the compiler from doing
any sort of type checking. -- Erik Slagter
Defining functions with unspecified arguments is allowed but bad.
With arguments unspecified the compiler can't report an error/warning
if the function is called with incorrect arguments. -- M\ns Rullg\rd
author | rathann |
---|---|
date | Thu, 09 Feb 2006 14:08:03 +0000 |
parents | f04a9bc331a5 |
children |
line wrap: on
line source
#include <string.h> #include <stdio.h> #include <sys/ioctl.h> #include <unistd.h> #include <errno.h> #include <fcntl.h> #include <sys/mman.h> #include "dhahelper.h" int main(int argc, char *argv[]) { int fd; int ret; fd = open("/dev/dhahelper", O_RDWR); ioctl(fd, DHAHELPER_GET_VERSION, &ret); printf("api version: %d\n", ret); if (ret != API_VERSION) printf("incompatible api!\n"); { dhahelper_memory_t mem; mem.operation = MEMORY_OP_MAP; //mem.start = 0xe0000000; mem.start = 0xe4000008; mem.offset = 0; mem.size = 0x4000; mem.ret = 0; ret = ioctl(fd, DHAHELPER_MEMORY, &mem); printf("ret: %s\n", strerror(errno)); mem.ret = (int)mmap(NULL, (size_t)mem.size, PROT_READ, MAP_SHARED, fd, (off_t)0); printf("allocated to %x\n", mem.ret); if (argc > 1) if (mem.ret != 0) { int i; for (i = 0; i < 256; i++) printf("[%x] ", *(int *)(mem.ret+i)); printf("\n"); } munmap((void *)mem.ret, mem.size); mem.operation = MEMORY_OP_UNMAP; mem.start = mem.ret; ioctl(fd, DHAHELPER_MEMORY, &mem); } return(0); }