/* * Copyright (c) 1999 University of Utah and the Flux Group. * All rights reserved. * * This file is part of the Flux OSKit. The OSKit is free software, also known * as "open source;" you can redistribute it and/or modify it under the terms * of the GNU General Public License (GPL), version 2, as published by the Free * Software Foundation (FSF). To explore alternate licensing terms, contact * the University of Utah at csl-dist@cs.utah.edu or +1-801-585-3271. * * The OSKit is distributed in the hope that it will be useful, but WITHOUT ANY * WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS * FOR A PARTICULAR PURPOSE. See the GPL for more details. You should have * received a copy of the GPL along with the OSKit; see the file COPYING. If * not, write to the FSF, 59 Temple Place #330, Boston, MA 02111-1307, USA. */ /* * IStream wrapper for com console */ #include #include #include struct strm { oskit_stream_t strmi; int refs; int port; }; static OSKIT_COMDECL query(oskit_stream_t *si, const struct oskit_guid *iid, void **out_ihandle) { struct strm *s = (struct strm*)si; if (memcmp(iid, &oskit_iunknown_iid, sizeof(*iid)) == 0 || memcmp(iid, &oskit_stream_iid, sizeof(*iid)) == 0) { s->refs++; *out_ihandle = &s->strmi; return 0; } *out_ihandle = 0; return OSKIT_E_NOINTERFACE; } static OSKIT_COMDECL_U add_ref(oskit_stream_t *si) { struct strm *s = (struct strm*)si; return ++s->refs; } static OSKIT_COMDECL_U release(oskit_stream_t *si) { struct strm *s = (struct strm*)si; int newcount = --s->refs; #if 0 if (newcount < 0) panic("com_console: mangled reference count"); #endif if (newcount == 0) { com_cons_flush(s->port); #if 0 /* Statically allocated so don't free it */ osenv_mem_free(s, 0, sizeof(*s)); #endif } return newcount; } static OSKIT_COMDECL read(oskit_stream_t *si, void *buf, oskit_u32_t len, oskit_u32_t *out_actual) { struct strm *s = (struct strm*)si; int i; for(i=0; i < len; ++i) { ((char*)buf)[i] = com_cons_getchar(s->port); } *out_actual = i; return 0; } static OSKIT_COMDECL write(oskit_stream_t *si, const void *buf, oskit_u32_t len, oskit_u32_t *out_actual) { struct strm *s = (struct strm*)si; int i=0; for(i=0; i < len; ++i) { com_cons_putchar(s->port, ((char*)buf)[i]); } return 0; } static OSKIT_COMDECL seek(oskit_stream_t *si, oskit_s64_t ofs, oskit_seek_t whence, oskit_u64_t *out_newpos) { return OSKIT_ESPIPE; } static OSKIT_COMDECL setsize(oskit_stream_t *si, oskit_u64_t new_size) { return OSKIT_EINVAL; } static OSKIT_COMDECL copyto(oskit_stream_t *si, oskit_stream_t *dst, oskit_u64_t size, oskit_u64_t *out_read, oskit_u64_t *out_written) { return OSKIT_E_NOTIMPL; /*XXX*/ } static OSKIT_COMDECL commit(oskit_stream_t *si, oskit_u32_t commit_flags) { return OSKIT_E_NOTIMPL; } static OSKIT_COMDECL revert(oskit_stream_t *si) { return OSKIT_E_NOTIMPL; } static OSKIT_COMDECL lock_region(oskit_stream_t *si, oskit_u64_t offset, oskit_u64_t size, oskit_u32_t lock_type) { return OSKIT_E_NOTIMPL; } static OSKIT_COMDECL unlock_region(oskit_stream_t *si, oskit_u64_t offset, oskit_u64_t size, oskit_u32_t lock_type) { return OSKIT_E_NOTIMPL; } static OSKIT_COMDECL stat(oskit_stream_t *si, oskit_stream_stat_t *out_stat, oskit_u32_t stat_flags) { return OSKIT_E_NOTIMPL; /*XXX*/ } static OSKIT_COMDECL clone(oskit_stream_t *si, oskit_stream_t **out_stream) { return OSKIT_E_NOTIMPL; /*XXX*/ } static struct oskit_stream_ops ops = { query, add_ref, release, read, write, seek, setsize, copyto, commit, revert, lock_region, unlock_region, stat, clone }; static struct strm com_console_impl; oskit_error_t com_console_init(int com_port, struct termios *com_params, oskit_stream_t **out_stream) { com_console_impl.strmi.ops = &ops; com_console_impl.refs = 1; com_console_impl.port = com_port; com_cons_init(com_port, com_params); *out_stream = &com_console_impl.strmi; return 0; }