16448336.patch revision 1508
1788N/A--- a/src/ast_vgatool.h Wed Nov 12 12:43:18 2014
1788N/A+++ b/src/ast_vgatool.h Wed Nov 12 12:48:31 2014
1788N/A@@ -86,33 +86,30 @@
1788N/A #define GetIndexReg(off, index, val) do { \
1788N/A struct vis_io_reg io_reg = { \
1788N/A .offset = off, \
1788N/A- .value = index \
1788N/A+ .value = index, \
1788N/A+ .offset1 = off+1 \
1788N/A }; \
1788N/A- ioctl(pAST->fd, VIS_SETIOREG, &io_reg); \
1788N/A- io_reg.offset = off+1; \
1788N/A- ioctl(pAST->fd, VIS_GETIOREG, &io_reg); \
1788N/A+ ioctl(pAST->fd, AST_GET_INDEX, &io_reg); \
1788N/A val = io_reg.value; \
1788N/A } while (0)
1788N/A
1788N/A #define SetIndexReg(off, index, val) do { \
1788N/A struct vis_io_reg io_reg = { \
1788N/A- .offset = off, \
1788N/A- .value = index \
1788N/A+ .offset = off, \
1788N/A+ .value = index, \
1788N/A+ .offset1 = off+1, \
1788N/A+ .value1 = val \
1788N/A }; \
1788N/A- ioctl(pAST->fd, VIS_SETIOREG, &io_reg); \
1788N/A- io_reg.offset = off+1; \
1788N/A- io_reg.value = val; \
1788N/A- ioctl(pAST->fd, VIS_SETIOREG, &io_reg); \
1788N/A+ ioctl(pAST->fd, AST_SET_INDEX, &io_reg); \
1788N/A } while (0)
1788N/A
1788N/A #define GetIndexRegMask(off, index, and, val) do { \
1788N/A struct vis_io_reg io_reg = { \
1788N/A .offset = off, \
1788N/A- .value = index \
1788N/A+ .value = index, \
1788N/A+ .offset1 = off+1 \
1788N/A }; \
1788N/A- ioctl(pAST->fd, VIS_SETIOREG, &io_reg); \
1788N/A- io_reg.offset = off+1; \
1788N/A- ioctl(pAST->fd, VIS_GETIOREG, &io_reg); \
1788N/A+ ioctl(pAST->fd, AST_GET_INDEX, &io_reg); \
1788N/A val = io_reg.value & and; \
1788N/A } while (0)
1788N/A
1788N/A@@ -120,18 +117,16 @@
1788N/A UCHAR __Temp; \
1788N/A struct vis_io_reg io_reg = { \
1788N/A .offset = off, \
1788N/A- .value = index \
1788N/A+ .value = index, \
1788N/A+ .offset1 = off+1 \
1788N/A }; \
1788N/A- ioctl(pAST->fd, VIS_SETIOREG, &io_reg); \
1788N/A- io_reg.offset = off + 1; \
1788N/A- ioctl(pAST->fd, VIS_GETIOREG, &io_reg); \
1788N/A+ ioctl(pAST->fd, AST_GET_INDEX, &io_reg); \
1788N/A __Temp = (io_reg.value & and) | val; \
1788N/A io_reg.offset = off; \
1788N/A io_reg.value = index; \
1788N/A- ioctl(pAST->fd, VIS_SETIOREG, &io_reg); \
- io_reg.offset = off+1; \
- io_reg.value = __Temp; \
- ioctl(pAST->fd, VIS_SETIOREG, &io_reg); \
+ io_reg.offset1 = off+1; \
+ io_reg.value1 = __Temp; \
+ ioctl(pAST->fd, AST_SET_INDEX, &io_reg); \
} while (0)
#else /* !__sparc__ */
--- a/src/ast.h Wed Nov 12 12:42:27 2014
+++ b/src/ast.h Wed Nov 12 12:43:02 2014
@@ -376,9 +376,19 @@
#define VIS_SETIOREG (VIOC | 17)
#define VIS_GETIOREG (VIOC | 18)
+#ifdef __sparc
+#define ASTIOC ('Y' << 8)
+#define AST_GET_INDEX (ASTIOC | 14)
+#define AST_SET_INDEX (ASTIOC | 15)
+#endif
+
typedef struct vis_io_reg {
uchar_t offset;
uchar_t value;
+#ifdef __sparc
+ uchar_t offset1;
+ uchar_t value1;
+#endif
} vis_io_reg_t;
#endif