/* * TOPPERS/JSP Kernel * Toyohashi Open Platform for Embedded Real-Time Systems/ * Just Standard Profile Kernel * * Copyright (C) 2000-2003 by Embedded and Real-Time Systems Laboratory * Toyohashi Univ. of Technology, JAPAN * * 上記著作権者は,以下の (1)〜(4) の条件か,Free Software Foundation * によって公表されている GNU General Public License の Version 2 に記 * 述されている条件を満たす場合に限り,本ソフトウェア(本ソフトウェア * を改変したものを含む.以下同じ)を使用・複製・改変・再配布(以下, * 利用と呼ぶ)することを無償で許諾する. * (1) 本ソフトウェアをソースコードの形で利用する場合には,上記の著作 * 権表示,この利用条件および下記の無保証規定が,そのままの形でソー * スコード中に含まれていること. * (2) 本ソフトウェアを,ライブラリ形式など,他のソフトウェア開発に使 * 用できる形で再配布する場合には,再配布に伴うドキュメント(利用 * 者マニュアルなど)に,上記の著作権表示,この利用条件および下記 * の無保証規定を掲載すること. * (3) 本ソフトウェアを,機器に組み込むなど,他のソフトウェア開発に使 * 用できない形で再配布する場合には,次のいずれかの条件を満たすこ * と. * (a) 再配布に伴うドキュメント(利用者マニュアルなど)に,上記の著 * 作権表示,この利用条件および下記の無保証規定を掲載すること. * (b) 再配布の形態を,別に定める方法によって,TOPPERSプロジェクトに * 報告すること. * (4) 本ソフトウェアの利用により直接的または間接的に生じるいかなる損 * 害からも,上記著作権者およびTOPPERSプロジェクトを免責すること. * * 本ソフトウェアは,無保証で提供されているものである.上記著作権者お * よびTOPPERSプロジェクトは,本ソフトウェアに関して,その適用可能性も * 含めて,いかなる保証も行わない.また,本ソフトウェアの利用により直 * 接的または間接的に生じたいかなる損害に関しても,その責任を負わない. * * @(#) $Id: devicecontrol.h,v 1.6 2004/01/18 08:59:29 takayuki Exp $ */ #ifndef __DEVICECONTROL_H_ #define __DEVICECONTROL_H_ #include "resource.h" // メイン シンボル #include #include "deviceCP.h" ///////////////////////////////////////////////////////////////////////////// // CDeviceControl MIDL_INTERFACE("DA93137D-FB52-4421-B95D-9077340AD03B") _IDeviceEvents : public IUnknown { public: virtual HRESULT STDMETHODCALLTYPE OnRead(long address,long sz,byte __RPC_FAR data[]) = 0; virtual HRESULT STDMETHODCALLTYPE OnWrite(long address,long sz,byte __RPC_FAR data[]) = 0; virtual HRESULT STDMETHODCALLTYPE OnKernelStart(void) = 0; virtual HRESULT STDMETHODCALLTYPE OnKernelExit(void) = 0; }; MIDL_INTERFACE("6575FAAB-8750-42D2-ADDD-4BE764AA2767") IDevice : public IUnknown { public: virtual HRESULT STDMETHODCALLTYPE IsValid(BOOL __RPC_FAR *valid) = 0; virtual HRESULT STDMETHODCALLTYPE SetDeviceName(BSTR devname) = 0; virtual HRESULT STDMETHODCALLTYPE Map(unsigned long address,unsigned long size) = 0; virtual HRESULT STDMETHODCALLTYPE Unmap(unsigned long address) = 0; virtual HRESULT STDMETHODCALLTYPE RaiseInterrupt(unsigned long inhno) = 0; }; class ATL_NO_VTABLE CDeviceControl : public CComObjectRootEx, public IDispatchImpl, public CComControl, public IPersistStreamInitImpl, public IOleControlImpl, public IOleObjectImpl, public IOleInPlaceActiveObjectImpl, public IViewObjectExImpl, public IOleInPlaceObjectWindowlessImpl, public IConnectionPointContainerImpl, public IPersistStorageImpl, public ISpecifyPropertyPagesImpl, public IQuickActivateImpl, public IDataObjectImpl, public IProvideClassInfo2Impl<&CLSID_DeviceControl, &DIID__IDeviceControlEvents, &LIBID_ATLDEVICELib>, public IPropertyNotifySinkCP, public CComCoClass, public _IDeviceEvents, public CProxy_IDeviceControlEvents< CDeviceControl > { public: CDeviceControl() : cookie(), manager(), KernelStarted(false), DataPointer(0), Limitation(0), Offset(0), AccessSize(1) { m_bWindowOnly = TRUE; } ~CDeviceControl() { if(cookie != 0 && manager != 0) { Close(); } } DECLARE_REGISTRY_RESOURCEID(IDR_DEVICECONTROL) DECLARE_PROTECT_FINAL_CONSTRUCT() BEGIN_COM_MAP(CDeviceControl) COM_INTERFACE_ENTRY(IDeviceControl) COM_INTERFACE_ENTRY(IDispatch) COM_INTERFACE_ENTRY(IViewObjectEx) COM_INTERFACE_ENTRY(IViewObject2) COM_INTERFACE_ENTRY(IViewObject) COM_INTERFACE_ENTRY(IOleInPlaceObjectWindowless) COM_INTERFACE_ENTRY(IOleInPlaceObject) COM_INTERFACE_ENTRY2(IOleWindow, IOleInPlaceObjectWindowless) COM_INTERFACE_ENTRY(IOleInPlaceActiveObject) COM_INTERFACE_ENTRY(IOleControl) COM_INTERFACE_ENTRY(IOleObject) COM_INTERFACE_ENTRY(IPersistStreamInit) COM_INTERFACE_ENTRY2(IPersist, IPersistStreamInit) COM_INTERFACE_ENTRY(IConnectionPointContainer) COM_INTERFACE_ENTRY(ISpecifyPropertyPages) COM_INTERFACE_ENTRY(IQuickActivate) COM_INTERFACE_ENTRY(IPersistStorage) COM_INTERFACE_ENTRY(IDataObject) COM_INTERFACE_ENTRY(IProvideClassInfo) COM_INTERFACE_ENTRY(IProvideClassInfo2) COM_INTERFACE_ENTRY(_IDeviceEvents) COM_INTERFACE_ENTRY_IMPL(IConnectionPointContainer) END_COM_MAP() BEGIN_PROP_MAP(CDeviceControl) PROP_DATA_ENTRY("_cx", m_sizeExtent.cx, VT_UI4) PROP_DATA_ENTRY("_cy", m_sizeExtent.cy, VT_UI4) PROP_ENTRY("AccessSize",9,CLSID_NULL) // Example entries // PROP_ENTRY("Property Description", dispid, clsid) // PROP_PAGE(CLSID_StockColorPage) END_PROP_MAP() BEGIN_CONNECTION_POINT_MAP(CDeviceControl) CONNECTION_POINT_ENTRY(IID_IPropertyNotifySink) CONNECTION_POINT_ENTRY(DIID__IDeviceControlEvents) END_CONNECTION_POINT_MAP() BEGIN_MSG_MAP(CDeviceControl) CHAIN_MSG_MAP(CComControl) DEFAULT_REFLECTION_HANDLER() END_MSG_MAP() // Handler prototypes: // LRESULT MessageHandler(UINT uMsg, WPARAM wParam, LPARAM lParam, BOOL& bHandled); // LRESULT CommandHandler(WORD wNotifyCode, WORD wID, HWND hWndCtl, BOOL& bHandled); // LRESULT NotifyHandler(int idCtrl, LPNMHDR pnmh, BOOL& bHandled); // IViewObjectEx DECLARE_VIEW_STATUS(VIEWSTATUS_SOLIDBKGND | VIEWSTATUS_OPAQUE) // IDeviceControl public: STDMETHOD(get_Value)(/*[out, retval]*/ long *pVal); STDMETHOD(put_Value)(/*[in]*/ long newVal); STDMETHOD(get_AccessSize)(/*[out, retval]*/ short *pVal); STDMETHOD(put_AccessSize)(/*[in]*/ short newVal); STDMETHOD(get_Offset)(/*[out, retval]*/ long *pVal); STDMETHOD(put_Offset)(/*[in]*/ long newVal); STDMETHOD(get_IsKernelStarted)(/*[out, retval]*/ BOOL *pVal); STDMETHOD(Unmap)(/*[in]*/long address); STDMETHOD(Map)(/*[in]*/long address,/*[in]*/long size); STDMETHOD(RaiseInterrupt)(/*[in]*/long inhno); STDMETHOD(get_Valid)(/*[out, retval]*/ BOOL *pVal); STDMETHOD(Close)(); STDMETHOD(Connect)(); STDMETHOD(get_DeviceName)(BSTR* pVal); STDMETHOD(put_DeviceName)(BSTR newVal); HRESULT OnDraw(ATL_DRAWINFO& di) { RECT& rc = *(RECT*)di.prcBounds; HDC memDC; HINSTANCE hInstance; HBITMAP memImage; HBITMAP oldImage; hInstance = (HINSTANCE)GetWindowLong(GWL_HINSTANCE); memImage = ::LoadBitmap(hInstance,MAKEINTRESOURCE(IDB_DEVICECONTROL_BIG)); memDC = ::CreateCompatibleDC(di.hdcDraw); oldImage = (HBITMAP) ::SelectObject(memDC,memImage); ::StretchBlt(di.hdcDraw,rc.left,rc.top,rc.right,rc.bottom,memDC,0,0,64,64,SRCCOPY); ::SelectObject(memDC, oldImage); ::DeleteObject(memImage); ::DeleteDC(memDC); return S_OK; } // _IDeviceEvents STDMETHOD(OnRead)(long address,long sz,byte __RPC_FAR data[]); STDMETHOD(OnWrite)(long address,long sz,byte __RPC_FAR data[]); STDMETHOD(OnKernelStart)(); STDMETHOD(OnKernelExit)(); DWORD cookie; CComBSTR devname; CComPtr manager; bool KernelStarted; unsigned char * DataPointer; long Limitation; long Offset; short AccessSize; }; #endif //__DEVICECONTROL_H_