Commit 91752a9c authored by David S. Miller's avatar David S. Miller

Merge branch 'sparc64-vcc'

Jag Raman says:

====================
sparc64: Enable Virtual Console Concentrator (VCC)

Patchset to enable Virtual Console Concentrator (VCC). VCC provides
access to the serial console of a guest domain. It creates a RAW
VIO/LDC link between the guest domain & primary through which serial
console data is shared.

This set addresses feedback provided by Dave Miller. Cleanup of
driver state is also addressed in this set. Patches updated
are 4, 5, 6 & 7.
====================
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parents fa5dc772 8f03f948
...@@ -12294,6 +12294,7 @@ F: drivers/tty/serial/sunsab.h ...@@ -12294,6 +12294,7 @@ F: drivers/tty/serial/sunsab.h
F: drivers/tty/serial/sunsu.c F: drivers/tty/serial/sunsu.c
F: drivers/tty/serial/sunzilog.c F: drivers/tty/serial/sunzilog.c
F: drivers/tty/serial/sunzilog.h F: drivers/tty/serial/sunzilog.h
F: drivers/tty/vcc.c
SPARSE CHECKER SPARSE CHECKER
M: "Christopher Li" <sparse@chrisli.org> M: "Christopher Li" <sparse@chrisli.org>
......
...@@ -238,3 +238,4 @@ CONFIG_CRYPTO_TWOFISH=m ...@@ -238,3 +238,4 @@ CONFIG_CRYPTO_TWOFISH=m
# CONFIG_CRYPTO_ANSI_CPRNG is not set # CONFIG_CRYPTO_ANSI_CPRNG is not set
CONFIG_CRC16=m CONFIG_CRC16=m
CONFIG_LIBCRC32C=m CONFIG_LIBCRC32C=m
CONFIG_VCC=m
...@@ -52,6 +52,7 @@ struct vio_ver_info { ...@@ -52,6 +52,7 @@ struct vio_ver_info {
#define VDEV_NETWORK_SWITCH 0x02 #define VDEV_NETWORK_SWITCH 0x02
#define VDEV_DISK 0x03 #define VDEV_DISK 0x03
#define VDEV_DISK_SERVER 0x04 #define VDEV_DISK_SERVER 0x04
#define VDEV_CONSOLE_CON 0x05
u8 resv1[3]; u8 resv1[3];
u64 resv2[5]; u64 resv2[5];
...@@ -282,6 +283,14 @@ struct vio_dring_state { ...@@ -282,6 +283,14 @@ struct vio_dring_state {
struct ldc_trans_cookie cookies[VIO_MAX_RING_COOKIES]; struct ldc_trans_cookie cookies[VIO_MAX_RING_COOKIES];
}; };
#define VIO_TAG_SIZE ((int)sizeof(struct vio_msg_tag))
#define VIO_VCC_MTU_SIZE (LDC_PACKET_SIZE - VIO_TAG_SIZE)
struct vio_vcc {
struct vio_msg_tag tag;
char data[VIO_VCC_MTU_SIZE];
};
static inline void *vio_dring_cur(struct vio_dring_state *dr) static inline void *vio_dring_cur(struct vio_dring_state *dr)
{ {
return dr->base + (dr->entry_size * dr->prod); return dr->base + (dr->entry_size * dr->prod);
......
...@@ -1480,6 +1480,7 @@ int ldc_rx_reset(struct ldc_channel *lp) ...@@ -1480,6 +1480,7 @@ int ldc_rx_reset(struct ldc_channel *lp)
{ {
return __set_rx_head(lp, lp->rx_tail); return __set_rx_head(lp, lp->rx_tail);
} }
EXPORT_SYMBOL(ldc_rx_reset);
void __ldc_print(struct ldc_channel *lp, const char *caller) void __ldc_print(struct ldc_channel *lp, const char *caller)
{ {
...@@ -1493,6 +1494,7 @@ void __ldc_print(struct ldc_channel *lp, const char *caller) ...@@ -1493,6 +1494,7 @@ void __ldc_print(struct ldc_channel *lp, const char *caller)
lp->tx_head, lp->tx_tail, lp->tx_num_entries, lp->tx_head, lp->tx_tail, lp->tx_num_entries,
lp->rcv_nxt, lp->snd_nxt); lp->rcv_nxt, lp->snd_nxt);
} }
EXPORT_SYMBOL(__ldc_print);
static int write_raw(struct ldc_channel *lp, const void *buf, unsigned int size) static int write_raw(struct ldc_channel *lp, const void *buf, unsigned int size)
{ {
......
...@@ -246,6 +246,7 @@ u64 vio_vdev_node(struct mdesc_handle *hp, struct vio_dev *vdev) ...@@ -246,6 +246,7 @@ u64 vio_vdev_node(struct mdesc_handle *hp, struct vio_dev *vdev)
return node; return node;
} }
EXPORT_SYMBOL(vio_vdev_node);
static void vio_fill_channel_info(struct mdesc_handle *hp, u64 mp, static void vio_fill_channel_info(struct mdesc_handle *hp, u64 mp,
struct vio_dev *vdev) struct vio_dev *vdev)
......
...@@ -814,15 +814,21 @@ int vio_driver_init(struct vio_driver_state *vio, struct vio_dev *vdev, ...@@ -814,15 +814,21 @@ int vio_driver_init(struct vio_driver_state *vio, struct vio_dev *vdev,
case VDEV_NETWORK_SWITCH: case VDEV_NETWORK_SWITCH:
case VDEV_DISK: case VDEV_DISK:
case VDEV_DISK_SERVER: case VDEV_DISK_SERVER:
case VDEV_CONSOLE_CON:
break; break;
default: default:
return -EINVAL; return -EINVAL;
} }
if (!ops || !ops->send_attr || !ops->handle_attr || if (dev_class == VDEV_NETWORK ||
!ops->handshake_complete) dev_class == VDEV_NETWORK_SWITCH ||
return -EINVAL; dev_class == VDEV_DISK ||
dev_class == VDEV_DISK_SERVER) {
if (!ops || !ops->send_attr || !ops->handle_attr ||
!ops->handshake_complete)
return -EINVAL;
}
if (!ver_table || ver_table_size < 0) if (!ver_table || ver_table_size < 0)
return -EINVAL; return -EINVAL;
......
...@@ -455,4 +455,9 @@ config MIPS_EJTAG_FDC_KGDB_CHAN ...@@ -455,4 +455,9 @@ config MIPS_EJTAG_FDC_KGDB_CHAN
help help
FDC channel number to use for KGDB. FDC channel number to use for KGDB.
config VCC
tristate "Sun Virtual Console Concentrator"
depends on SUN_LDOMS
help
Support for Sun logical domain consoles.
endif # TTY endif # TTY
...@@ -33,5 +33,6 @@ obj-$(CONFIG_PPC_EPAPR_HV_BYTECHAN) += ehv_bytechan.o ...@@ -33,5 +33,6 @@ obj-$(CONFIG_PPC_EPAPR_HV_BYTECHAN) += ehv_bytechan.o
obj-$(CONFIG_GOLDFISH_TTY) += goldfish.o obj-$(CONFIG_GOLDFISH_TTY) += goldfish.o
obj-$(CONFIG_DA_TTY) += metag_da.o obj-$(CONFIG_DA_TTY) += metag_da.o
obj-$(CONFIG_MIPS_EJTAG_FDC_TTY) += mips_ejtag_fdc.o obj-$(CONFIG_MIPS_EJTAG_FDC_TTY) += mips_ejtag_fdc.o
obj-$(CONFIG_VCC) += vcc.o
obj-y += ipwireless/ obj-y += ipwireless/
This diff is collapsed.
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment