Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 967
b: refs/heads/master
c: 60d300c
h: refs/heads/master
i:
  965: d20f6f1
  963: 4833e37
  959: e340247
v: v3
  • Loading branch information
Stuart Brady authored and Linus Torvalds committed May 5, 2005
1 parent 55efb5c commit 89470a6
Show file tree
Hide file tree
Showing 4 changed files with 76 additions and 11 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: 42d77c70177b2f7535766bce938d965fd863f0fd
refs/heads/master: 60d300c02fe2e0be9bb02904361e41e0307264b2
6 changes: 3 additions & 3 deletions trunk/include/linux/awe_voice.h
Original file line number Diff line number Diff line change
Expand Up @@ -29,9 +29,9 @@
#define SAMPLE_TYPE_AWE32 0x20
#endif

#ifndef _PATCHKEY
#define _PATCHKEY(id) ((id<<8)|0xfd)
#endif
#define _LINUX_PATCHKEY_H_INDIRECT
#include <linux/patchkey.h>
#undef _LINUX_PATCHKEY_H_INDIRECT

/*----------------------------------------------------------------
* patch information record
Expand Down
45 changes: 45 additions & 0 deletions trunk/include/linux/patchkey.h
Original file line number Diff line number Diff line change
@@ -0,0 +1,45 @@
/*
* <linux/patchkey.h> -- definition of _PATCHKEY macro
*
* Copyright (C) 2005 Stuart Brady
*
* This exists because awe_voice.h defined its own _PATCHKEY and it wasn't
* clear whether removing this would break anything in userspace.
*
* Do not include this file directly. Please use <sys/soundcard.h> instead.
* For kernel code, use <linux/soundcard.h>
*/

#ifndef _LINUX_PATCHKEY_H_INDIRECT
#error "patchkey.h included directly"
#endif

#ifndef _LINUX_PATCHKEY_H
#define _LINUX_PATCHKEY_H

/* Endian macros. */
#ifdef __KERNEL__
# include <asm/byteorder.h>
#else
# include <endian.h>
#endif

#if defined(__KERNEL__)
# if defined(__BIG_ENDIAN)
# define _PATCHKEY(id) (0xfd00|id)
# elif defined(__LITTLE_ENDIAN)
# define _PATCHKEY(id) ((id<<8)|0x00fd)
# else
# error "could not determine byte order"
# endif
#elif defined(__BYTE_ORDER)
# if __BYTE_ORDER == __BIG_ENDIAN
# define _PATCHKEY(id) (0xfd00|id)
# elif __BYTE_ORDER == __LITTLE_ENDIAN
# define _PATCHKEY(id) ((id<<8)|0x00fd)
# else
# error "could not determine byte order"
# endif
#endif

#endif /* _LINUX_PATCHKEY_H */
34 changes: 27 additions & 7 deletions trunk/include/linux/soundcard.h
Original file line number Diff line number Diff line change
Expand Up @@ -39,6 +39,13 @@
/* In Linux we need to be prepared for cross compiling */
#include <linux/ioctl.h>

/* Endian macros. */
#ifdef __KERNEL__
# include <asm/byteorder.h>
#else
# include <endian.h>
#endif

/*
* Supported card ID numbers (Should be somewhere else?)
*/
Expand Down Expand Up @@ -179,13 +186,26 @@ typedef struct seq_event_rec {
* Some big endian/little endian handling macros
*/

#if defined(_AIX) || defined(AIX) || defined(sparc) || defined(__sparc__) || defined(HPPA) || defined(PPC) || defined(__mc68000__)
/* Big endian machines */
# define _PATCHKEY(id) (0xfd00|id)
# define AFMT_S16_NE AFMT_S16_BE
#else
# define _PATCHKEY(id) ((id<<8)|0xfd)
# define AFMT_S16_NE AFMT_S16_LE
#define _LINUX_PATCHKEY_H_INDIRECT
#include <linux/patchkey.h>
#undef _LINUX_PATCHKEY_H_INDIRECT

#if defined(__KERNEL__)
# if defined(__BIG_ENDIAN)
# define AFMT_S16_NE AFMT_S16_BE
# elif defined(__LITTLE_ENDIAN)
# define AFMT_S16_NE AFMT_S16_LE
# else
# error "could not determine byte order"
# endif
#elif defined(__BYTE_ORDER)
# if __BYTE_ORDER == __BIG_ENDIAN
# define AFMT_S16_NE AFMT_S16_BE
# elif __BYTE_ORDER == __LITTLE_ENDIAN
# define AFMT_S16_NE AFMT_S16_LE
# else
# error "could not determine byte order"
# endif
#endif

/*
Expand Down

0 comments on commit 89470a6

Please sign in to comment.